Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Gaussian Process Buckling Constraints in Blade Stiffened Shell Constitutive Subclass #311

Merged
merged 124 commits into from
Oct 22, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
124 commits
Select commit Hold shift + click to select a range
cb844b5
demonstrate exploded views
sean-engelstad Dec 1, 2023
1d6b95c
Merge branch 'master' of github.com:sean-engelstad/tacs
sean-engelstad Mar 14, 2024
79d0b25
Merge branch 'master' of github.com:sean-engelstad/tacs
sean-engelstad Mar 20, 2024
b08f4bb
prototype of the TACSGPBladestiffenedshellconstitutive class
sean-engelstad Apr 24, 2024
d562b8e
prototype closed-form buckling constraints
sean-engelstad Apr 24, 2024
c64fa39
Merge branch 'smdogroup:master' into GPbladeconstitutive
sean-engelstad Apr 25, 2024
fd9b400
outline of TACS assembler subroutine to compute panel dimensions
sean-engelstad Apr 25, 2024
4b491c2
merge
sean-engelstad Apr 25, 2024
7caf055
prototype panel dimensions computation
sean-engelstad Apr 25, 2024
2ce3da9
Merge branch 'master' of github.com:sean-engelstad/tacs
sean-engelstad Apr 27, 2024
89bff20
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad Apr 27, 2024
1e4f69b
prototype computePanelDimensions routine
sean-engelstad Apr 28, 2024
84fe3e3
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad Apr 28, 2024
759d89c
update failure criterion with new buckling constraints
sean-engelstad Apr 29, 2024
8daadd7
update GP blade stiffened
sean-engelstad Apr 29, 2024
4aa1605
cleanup mass moment and MOI calls
sean-engelstad Apr 29, 2024
29db0a9
clang-format and add setPanelLength and width subroutines
sean-engelstad Apr 29, 2024
990e217
clang format
sean-engelstad Apr 29, 2024
431f0f8
remove computePanelDimensions
sean-engelstad Apr 29, 2024
1056078
add panel width constraint
sean-engelstad Apr 29, 2024
8c472d4
prototype of panel width constraint
sean-engelstad May 1, 2024
e57a425
remove needsPanelDimensions
sean-engelstad May 1, 2024
4fba62f
update the failure sensitivities for GP constitutive
sean-engelstad May 1, 2024
df1df93
update gaussian process folder
sean-engelstad May 10, 2024
92acbd3
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad May 10, 2024
ceb3056
update GP Model.h file
sean-engelstad May 10, 2024
db4982a
demo gaussian process models
sean-engelstad May 12, 2024
b42be20
prototype for GP buckling constraints and full GP failure criterion
sean-engelstad May 13, 2024
f0b6fc5
add tests of each nondimensional parameter and critical load
sean-engelstad May 13, 2024
1535d94
begin making the unittest for TACS GP blade stiffened shell constitut…
sean-engelstad May 13, 2024
7e09d9a
clang reformat
sean-engelstad May 13, 2024
bc18519
update makefile to compile TACSGPBlade stiffened
sean-engelstad May 13, 2024
2e3cd56
successfully compiling versions of the GP Model and GP constitutive c…
sean-engelstad May 13, 2024
3bd471b
add cython code for GP blade stiffened constitutive and the GP models
sean-engelstad May 13, 2024
363a354
first compiling cython objects for GP models and constitutive
sean-engelstad May 13, 2024
b1f5d4e
prototype for python level constitutive test on GP constitutive class
sean-engelstad May 13, 2024
619d581
change subclass structure for gp constitutive at the cython level
sean-engelstad May 13, 2024
334560e
fix GP model pointers in Cython constructor of GP const
sean-engelstad May 13, 2024
8a3235a
first fully running prototype of the test_gp_blade_shell_constitutive
sean-engelstad May 13, 2024
cd76427
fix all nondimensional parameter tests
sean-engelstad May 13, 2024
ee64c8b
working closed-form internal tests
sean-engelstad May 14, 2024
cb21872
clang-format
sean-engelstad May 14, 2024
447d6a4
save current progress on fixing ML kernel derivatives
sean-engelstad May 14, 2024
04ec185
fix the ML internal tests
sean-engelstad May 14, 2024
31ba675
save progress on fixing axial global critical ML load
sean-engelstad May 14, 2024
0c7f294
working internal tests with ML buckling constraints in the loop!
sean-engelstad May 15, 2024
1d3bd19
add TACS prefix to all C++ GaussianProcessModel classes
sean-engelstad May 15, 2024
33432d0
add from_csv methods to build the GP models
sean-engelstad May 15, 2024
84ed5a1
add stiffenerCripplingStiffness routine for stiffener crippling load
sean-engelstad May 15, 2024
5286c0b
working fail strain sens derivs in TACSGPBladeStiffenedShellConstitut…
sean-engelstad May 15, 2024
8a711f2
fixed all but stiffener crippling failDV sens now
sean-engelstad May 15, 2024
663eb62
all gp constitutive tests pass now!
sean-engelstad May 16, 2024
fde8e71
remove default print statements from gp blade tests
sean-engelstad May 16, 2024
306ead0
fix a Newton iteration bug in the shear closed-form solution
sean-engelstad May 16, 2024
60ceee7
add closed-form demo example
sean-engelstad May 16, 2024
fe2f8fa
undo free GP pointers bug
sean-engelstad May 16, 2024
3b80e00
setkS
sean-engelstad May 16, 2024
6f3d4e5
change transverse shear parameter formula
sean-engelstad May 17, 2024
f926e77
clang-format
sean-engelstad May 17, 2024
f5446d8
change zeta transformed parameter again
sean-engelstad May 17, 2024
a1f16fa
fix jacobian of new zeta parameter
sean-engelstad May 18, 2024
9eb9286
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad May 18, 2024
26abe22
fix bug in reading in the csv archived model data
sean-engelstad May 19, 2024
82d9b13
updated the closed form and axialGP examples
sean-engelstad May 19, 2024
f865740
change xi value in demo scripts
sean-engelstad May 20, 2024
2293ef7
update GP blade constitutive parameters
sean-engelstad May 22, 2024
a010f6f
fix the derivatives for the corrected shear closed-form solution
sean-engelstad May 22, 2024
64d1833
update panel length and width constraints for F2F compatibility
sean-engelstad May 22, 2024
b2245a7
black reformat
sean-engelstad May 22, 2024
1213edb
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad May 24, 2024
eac77dc
add TACSPanelGPs class to improve the runtime
sean-engelstad May 24, 2024
a79d56f
fix reset saved data check
sean-engelstad May 24, 2024
a4cc41f
running ML optimization although one derivative doesn't work
sean-engelstad May 24, 2024
a94848e
update nondim shear solution
sean-engelstad May 26, 2024
61623fa
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad May 28, 2024
7338bb7
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad May 29, 2024
29a4b80
update the tacs constituve pxd file
sean-engelstad May 29, 2024
1f051ac
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad May 29, 2024
c388ea2
fix gamma for shear case and crippling load
sean-engelstad Jun 3, 2024
babe9eb
fix memory leaks!
sean-engelstad Jun 4, 2024
a2d13ee
fix all bug failDV ML test so far
sean-engelstad Jun 4, 2024
dc1b852
fix derivatives after removing memory leaks
sean-engelstad Jun 5, 2024
4efda5c
fix unittests and add some debug DV printouts
sean-engelstad Jun 8, 2024
d2b9304
fix kernels to match kernel option 9 in ml_buckling
sean-engelstad Jun 13, 2024
bebaba2
improved analytic shear surrogate model for intermediate aspect ratios
sean-engelstad Jun 17, 2024
f27d1f6
update panel length
sean-engelstad Jun 24, 2024
22fd6af
update unittests
sean-engelstad Jun 30, 2024
4eddfe5
change name from test to check in examples folder
sean-engelstad Jun 30, 2024
af56106
remove print statements
sean-engelstad Jun 30, 2024
1bfd52f
turn off setKS weight into ML model
sean-engelstad Aug 18, 2024
3282a39
improvements to ML buckling model
sean-engelstad Aug 28, 2024
07ddcfb
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad Aug 28, 2024
c51dba7
update pyproject.toml also
sean-engelstad Aug 29, 2024
78581cb
add component input to average stresses in TACS assembler
sean-engelstad Sep 1, 2024
fba8bb6
update shear closed-form with lowAR pred
sean-engelstad Sep 5, 2024
490e34a
add TACS blade stiffened shell optimization example for gp-const
sean-engelstad Sep 6, 2024
9d342dc
fix closed-form shear loads soft_max to soft_min
sean-engelstad Sep 6, 2024
b8cdffb
update the way panel D matrix is computed with centroid
sean-engelstad Sep 16, 2024
3822b4b
Merge branch 'GPbladeconstitutive' of github.com:sean-engelstad/tacs …
sean-engelstad Sep 16, 2024
64d7c0b
working derivatives tests and buckling benchmark!
sean-engelstad Sep 17, 2024
30bb7e4
add ability to see failure values
sean-engelstad Sep 18, 2024
97e7150
remove printout
sean-engelstad Sep 18, 2024
7cb4e30
update the GP local buckling constraints
sean-engelstad Sep 22, 2024
92a05f9
fix new memory leak
sean-engelstad Sep 24, 2024
32a7aa1
update gp stiffened plate examples
sean-engelstad Sep 24, 2024
e61ade6
merge with Ali's PR
sean-engelstad Oct 8, 2024
a2ec8a9
working derivative tests after merge with Ali's blade stiffened updates
sean-engelstad Oct 8, 2024
e020e43
add way to change stiffener crippling prediction mode
sean-engelstad Oct 8, 2024
d71c8ee
working functors
sean-engelstad Oct 8, 2024
e3be2cd
fix bug in constructing GPbladeconstitutive
sean-engelstad Oct 8, 2024
a97be46
fix introduced shear loads bug
sean-engelstad Oct 8, 2024
3a8809a
fix complex step test and black reformat
sean-engelstad Oct 8, 2024
6bb23a5
clang google format
sean-engelstad Oct 8, 2024
e80be6d
clang format
sean-engelstad Oct 9, 2024
5ca229b
clang format headers
sean-engelstad Oct 9, 2024
bc7d5fc
remove extra print statement
sean-engelstad Oct 9, 2024
1530a40
switch from functors to virtual and overridden methods
sean-engelstad Oct 9, 2024
4d3aa62
documentation for the TACS GP constitutive class in constitutive.pyx
sean-engelstad Oct 12, 2024
0f71226
fix the documentation for local mode buckling predictions
sean-engelstad Oct 12, 2024
cbe7a3d
address new and delete[] issues, docstrings, cleanup examples, etc.
sean-engelstad Oct 18, 2024
7524984
remove redundant methods in constitutive.pyx
sean-engelstad Oct 21, 2024
eab0fb1
add cptrs in constitutive.pyx to make integration tests pass
sean-engelstad Oct 21, 2024
384fbdc
update docs and docstrings
sean-engelstad Oct 22, 2024
d2e7922
fix panel width docs
sean-engelstad Oct 22, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
working functors
  • Loading branch information
sean-engelstad committed Oct 8, 2024
commit d71c8ee8f8c28f973da33dbbb9172d683e22957a
61 changes: 30 additions & 31 deletions examples/gp_stiffened_plate/mlb_plate_compare_highAR.py
Original file line number Diff line number Diff line change
Expand Up @@ -92,16 +92,16 @@ class uses T stiffeners.


# Overall plate dimensions
width = 0.422
length = 1.0
width = 1.0
length = 6.25773

# Material properties (UD tape properties from textbook case)
rho = 1609.0
E1 = 138e9
E2 = 9.177e9
nu12 = 0.326
G12 = 4.957e9
G13 = 4.957e9
E2 = 138e9
nu12 = 0.3
G12 = E1 / 2.0 / (1+nu12)
G13 = E1 / 2.0 / (1+nu12)
Xt = 2068e6
Xc = 1723e6
Yt = 96.5e6
Expand All @@ -112,29 +112,29 @@ class uses T stiffeners.
panelLength = length
panelWidth = width

stiffenerPitch = 0.111
stiffenerPitch = 0.5
stiffenerPitchMin = 0.1
stiffenerPitchMax = 0.7

panelThickness = 1e-2
panelThicknessMin = 0.6e-3
panelThicknessMax = 0.1

stiffenerHeight = 27.4e-3
stiffenerHeightMin = 25e-3
stiffenerHeight = 76.633e-3
stiffenerHeightMin = 10e-3
stiffenerHeightMax = 0.15

stiffenerThickness = 5.49e-3
stiffenerThickness = 3.8316e-3
stiffenerThicknessMin = 0.6e-3
stiffenerThicknessMax = 0.1

# Ply angles/initial ply fractions
ply_angles = np.deg2rad([0.0, 45.0])
skin_ply_fractions = np.array([0.7, 0.3])
stiffener_ply_fractions = np.array([0.7, 0.3])
ply_angles = np.deg2rad([0.0])
skin_ply_fractions = np.array([1.0])
stiffener_ply_fractions = np.array([1.0])

# Shear and compressive traction loads
Ny = 30209 # N/m
Ny = 121167 # N/m
Nxy = 0.0 # N/m


Expand Down Expand Up @@ -177,11 +177,10 @@ def element_callback(
skin_ply_fraction_dv_nums = np.array(
[
currentDVNum,
currentDVNum + 1,
],
dtype=np.intc,
)
currentDVNum += 2
currentDVNum += 1

stiffenerHeightNum = currentDVNum
currentDVNum = currentDVNum + 1
Expand All @@ -194,11 +193,10 @@ def element_callback(
stiffener_ply_fraction_dv_nums = np.array(
[
currentDVNum,
currentDVNum + 1,
],
dtype=np.intc,
)
currentDVNum += 2
currentDVNum += 1
else:
skin_ply_fraction_dv_nums = -np.ones(len(ply_angles), dtype=np.intc)
stiffener_ply_fraction_dv_nums = -np.ones(
Expand Down Expand Up @@ -231,17 +229,17 @@ def element_callback(
panelWidthNum=panelWidthNum,
flangeFraction=0.0,
)
# con.setStiffenerPitchBounds(stiffenerPitchMin, stiffenerPitchMax)
# con.setPanelThicknessBounds(panelThicknessMin, panelThicknessMax)
# con.setStiffenerThicknessBounds(
# stiffenerThicknessMin, stiffenerThicknessMax
# )
# con.setPanelPlyFractionBounds(
# np.array([1.0]), np.array([1.0])
# )
# con.setStiffenerPlyFractionBounds(
# np.array([1.0]), np.array([1.0])
# )
con.setStiffenerPitchBounds(stiffenerPitchMin, stiffenerPitchMax)
con.setPanelThicknessBounds(panelThicknessMin, panelThicknessMax)
con.setStiffenerThicknessBounds(
stiffenerThicknessMin, stiffenerThicknessMax
)
con.setPanelPlyFractionBounds(
np.array([0.0]), np.array([1.0])
)
con.setStiffenerPlyFractionBounds(
np.array([0.0]), np.array([1.0])
)

# We need to enforce that stiffenerHeight <= stiffenerPitch, if we are not
# using a stiffener pitch DV we can simply enforce this as an upper bound
Expand Down Expand Up @@ -278,10 +276,10 @@ def element_callback(
DVScales.append(stiffPitchScale)
DVScales.append(panelThicknessScale)
if args.usePlyFracDV:
DVScales += [1.0] * 4
DVScales += [1.0] * 1
DVScales += [stiffenerHeightScale, stiffenerThicknessScale]
if args.usePlyFracDV:
DVScales += [1.0] * 4
DVScales += [1.0] * 1

return elem, DVScales

Expand Down Expand Up @@ -583,6 +581,7 @@ def configure(self):
prob.setup(mode="rev")

prob.run_model()
print("done", flush=True)
exit()

# Output N2 representation of OpenMDAO model
Expand Down
51 changes: 42 additions & 9 deletions src/constitutive/TACSBladeStiffenedShellConstitutive.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -215,6 +215,39 @@ TACSBladeStiffenedShellConstitutive::TACSBladeStiffenedShellConstitutive(
// Arrays for storing ply failure sensitivities
this->panelPlyFailSens = new TacsScalar[2 * this->numPanelPlies];
this->stiffenerPlyFailSens = new TacsScalar[2 * this->numStiffenerPlies];

// initialize the functions using the base class
// these function pointers are overwritten in the derived class for GP/ML buckling
evalLocalPanelBuckling = [this](const TacsScalar e[]) {
return this->_evalLocalPanelBuckling(e);
};
evalGlobalPanelBuckling = [this](const TacsScalar e[]) {
return this->_evalGlobalPanelBuckling(e);
};
evalStiffenerCrippling = [this](const TacsScalar stiffenerStrain[]) {
return this->_evalStiffenerCrippling(stiffenerStrain);
};
evalLocalPanelBucklingStrainSens = [this](const TacsScalar e[], TacsScalar localBucklingSens[]) {
return this->_evalLocalPanelBucklingStrainSens(e, localBucklingSens);
};
evalGlobalPanelBucklingStrainSens = [this](const TacsScalar e[], TacsScalar globalBucklingSens[]) {
return this->_evalGlobalPanelBucklingStrainSens(e, globalBucklingSens);
};
evalStiffenerCripplingStrainSens = [this](const TacsScalar stiffenerStrain[], TacsScalar stiffenerStrainSens[]) {
return this->_evalStiffenerCripplingStrainSens(stiffenerStrain, stiffenerStrainSens);
};
addLocalPanelBucklingDVSens = [this](int elemIndex, TacsScalar scale, const double pt[], const TacsScalar X[],
const TacsScalar strain[], int dvLen, TacsScalar dfdx[]) {
return this->_addLocalPanelBucklingDVSens(elemIndex, scale, pt, X, strain, dvLen, dfdx);
};
addGlobalPanelBucklingDVSens = [this](int elemIndex, TacsScalar scale, const double pt[], const TacsScalar X[],
const TacsScalar strain[], int dvLen, TacsScalar dfdx[]) {
return this->_addGlobalPanelBucklingDVSens(elemIndex, scale, pt, X, strain, dvLen, dfdx);
};
addStiffenerCripplingDVSens = [this](const TacsScalar scale, const TacsScalar stiffenerStrain[], TacsScalar dfdx[]) {
return this->_addStiffenerCripplingDVSens(scale, stiffenerStrain, dfdx);
};

}

// ==============================================================================
Expand Down Expand Up @@ -2031,7 +2064,7 @@ void TACSBladeStiffenedShellConstitutive::computeStiffenerMOISens(
// Buckling functions
// ==============================================================================

TacsScalar TACSBladeStiffenedShellConstitutive::evalGlobalPanelBuckling(
TacsScalar TACSBladeStiffenedShellConstitutive::_evalGlobalPanelBuckling(
const TacsScalar e[]) {
TacsScalar stress[TACSShellConstitutive::NUM_STRESSES];
TacsScalar D1, D2, D3;
Expand Down Expand Up @@ -2102,7 +2135,7 @@ void TACSBladeStiffenedShellConstitutive::
}

TacsScalar
TACSBladeStiffenedShellConstitutive::evalGlobalPanelBucklingStrainSens(
TACSBladeStiffenedShellConstitutive::_evalGlobalPanelBucklingStrainSens(
const TacsScalar e[], TacsScalar sens[]) {
TacsScalar stiffness[NUM_TANGENT_STIFFNESS_ENTRIES], stress[NUM_STRESSES];
this->computeStiffness(stiffness);
Expand Down Expand Up @@ -2131,7 +2164,7 @@ TACSBladeStiffenedShellConstitutive::evalGlobalPanelBucklingStrainSens(
return strengthRatio;
}

void TACSBladeStiffenedShellConstitutive::addGlobalPanelBucklingDVSens(
void TACSBladeStiffenedShellConstitutive::_addGlobalPanelBucklingDVSens(
int elemIndex, TacsScalar scale, const double pt[], const TacsScalar X[],
const TacsScalar strain[], int dvLen, TacsScalar dfdx[]) {
TacsScalar stress[NUM_STRESSES];
Expand Down Expand Up @@ -2675,7 +2708,7 @@ void TACSBladeStiffenedShellConstitutive::testGlobalBucklingStiffnessSens() {
delete[] DVPert;
}

TacsScalar TACSBladeStiffenedShellConstitutive::evalLocalPanelBuckling(
TacsScalar TACSBladeStiffenedShellConstitutive::_evalLocalPanelBuckling(
const TacsScalar e[]) {
// Compute panel stiffness matrix and loads
TacsScalar panelStiffness[NUM_TANGENT_STIFFNESS_ENTRIES],
Expand Down Expand Up @@ -2722,7 +2755,7 @@ TacsScalar TACSBladeStiffenedShellConstitutive::computeCriticalShearLoad(
}

TacsScalar
TACSBladeStiffenedShellConstitutive::evalLocalPanelBucklingStrainSens(
TACSBladeStiffenedShellConstitutive::_evalLocalPanelBucklingStrainSens(
const TacsScalar e[], TacsScalar sens[]) {
// Compute panel stiffness matrix and loads
TacsScalar panelStiffness[NUM_TANGENT_STIFFNESS_ENTRIES],
Expand Down Expand Up @@ -2757,7 +2790,7 @@ TACSBladeStiffenedShellConstitutive::evalLocalPanelBucklingStrainSens(
return strengthRatio;
}

void TACSBladeStiffenedShellConstitutive::addLocalPanelBucklingDVSens(
void TACSBladeStiffenedShellConstitutive::_addLocalPanelBucklingDVSens(
int elemIndex, TacsScalar scale, const double pt[], const TacsScalar X[],
const TacsScalar strain[], int dvLen, TacsScalar dfdx[]) {
// Compute panel stiffness matrix and loads
Expand Down Expand Up @@ -3316,7 +3349,7 @@ void TACSBladeStiffenedShellConstitutive::computeStiffenerCripplingValues(
}
}

TacsScalar TACSBladeStiffenedShellConstitutive::evalStiffenerCrippling(
TacsScalar TACSBladeStiffenedShellConstitutive::_evalStiffenerCrippling(
const TacsScalar stiffenerStrain[]) {
const int numPlies = this->numStiffenerPlies;
this->computeStiffenerCripplingValues(stiffenerStrain,
Expand All @@ -3328,7 +3361,7 @@ TacsScalar TACSBladeStiffenedShellConstitutive::evalStiffenerCrippling(
}

TacsScalar
TACSBladeStiffenedShellConstitutive::evalStiffenerCripplingStrainSens(
TACSBladeStiffenedShellConstitutive::_evalStiffenerCripplingStrainSens(
const TacsScalar stiffenerStrain[], TacsScalar sens[]) {
const int numPlies = this->numStiffenerPlies;
const int numStrain = TACSBeamConstitutive::NUM_STRESSES;
Expand Down Expand Up @@ -3452,7 +3485,7 @@ TACSBladeStiffenedShellConstitutive::evalStiffenerCripplingStrainSens(
return fail;
}

void TACSBladeStiffenedShellConstitutive::addStiffenerCripplingDVSens(
void TACSBladeStiffenedShellConstitutive::_addStiffenerCripplingDVSens(
const TacsScalar scale, const TacsScalar stiffenerStrain[],
TacsScalar dfdx[]) {
TACSOrthotropicPly* ply = this->stiffenerPly;
Expand Down
30 changes: 21 additions & 9 deletions src/constitutive/TACSBladeStiffenedShellConstitutive.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ bladeFSDT model from previous versions of TACS developed by Graeme Kennedy.
#include "TACSMaterialProperties.h"
#include "TACSShellConstitutive.h"
#include "TacsUtilities.h"
#include <functional>

void printStiffnessMatrix(const TacsScalar* const C);

Expand Down Expand Up @@ -885,7 +886,7 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
* @param e Shell strains
* @return TacsScalar Strength ratio
*/
TacsScalar evalGlobalPanelBuckling(const TacsScalar e[]);
TacsScalar _evalGlobalPanelBuckling(const TacsScalar e[]);

/**
* @brief Compute the panel + stiffener stiffness values used to compute the
Expand All @@ -907,7 +908,7 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
* @param sens Sensitivity of the output w.r.t the shell strains
* @return TacsScalar Strength Ratio
*/
TacsScalar evalGlobalPanelBucklingStrainSens(const TacsScalar e[],
TacsScalar _evalGlobalPanelBucklingStrainSens(const TacsScalar e[],
TacsScalar sens[]);

/**
Expand All @@ -922,7 +923,7 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
@param dvLen The length of the design vector (not used)
@param dfdx The DV sensitivity array to add to
*/
void addGlobalPanelBucklingDVSens(int elemIndex, TacsScalar scale,
void _addGlobalPanelBucklingDVSens(int elemIndex, TacsScalar scale,
const double pt[], const TacsScalar X[],
const TacsScalar strain[], int dvLen,
TacsScalar dfdx[]);
Expand Down Expand Up @@ -973,7 +974,7 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
* @param e Shell strains
* @return TacsScalar Strength ratio
*/
TacsScalar evalLocalPanelBuckling(const TacsScalar e[]);
TacsScalar _evalLocalPanelBuckling(const TacsScalar e[]);

/**
* @brief Compute the critical axial load for local buckling of the panel
Expand All @@ -1000,7 +1001,7 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
* @param sens Sensitivity of the output w.r.t the shell strains
* @return TacsScalar Strength Ratio
*/
TacsScalar evalLocalPanelBucklingStrainSens(const TacsScalar e[],
TacsScalar _evalLocalPanelBucklingStrainSens(const TacsScalar e[],
TacsScalar sens[]);

/**
Expand All @@ -1015,7 +1016,7 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
@param dvLen The length of the design vector (not used)
@param dfdx The DV sensitivity array to add to
*/
void addLocalPanelBucklingDVSens(int elemIndex, TacsScalar scale,
void _addLocalPanelBucklingDVSens(int elemIndex, TacsScalar scale,
const double pt[], const TacsScalar X[],
const TacsScalar strain[], int dvLen,
TacsScalar dfdx[]);
Expand Down Expand Up @@ -1281,14 +1282,14 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
* @param stiffenerStrain Stiffener centroid beam strains
* @return TacsScalar Strength ratio
*/
TacsScalar evalStiffenerCrippling(const TacsScalar stiffenerStrain[]);
TacsScalar _evalStiffenerCrippling(const TacsScalar stiffenerStrain[]);
void computeStiffenerCripplingValues(const TacsScalar stiffenerStrain[],
TacsScalar plyFailValues[]);

TacsScalar evalStiffenerCripplingStrainSens(
TacsScalar _evalStiffenerCripplingStrainSens(
const TacsScalar stiffenerStrain[], TacsScalar sens[]);

void addStiffenerCripplingDVSens(const TacsScalar scale,
void _addStiffenerCripplingDVSens(const TacsScalar scale,
const TacsScalar stiffenerStrain[],
TacsScalar dfdx[]);

Expand Down Expand Up @@ -1389,6 +1390,17 @@ class TACSBladeStiffenedShellConstitutive : public TACSShellConstitutive {
TacsScalar* panelPlyFailSens;
TacsScalar* stiffenerPlyFailSens;

// function pointers for overridden buckling loads for ML/GP buckling subclass
std::function<TacsScalar(const TacsScalar[])> evalLocalPanelBuckling;
std::function<TacsScalar(const TacsScalar[])> evalGlobalPanelBuckling;
std::function<TacsScalar(const TacsScalar[])> evalStiffenerCrippling;
std::function<TacsScalar(const TacsScalar[],TacsScalar[])> evalLocalPanelBucklingStrainSens;
std::function<TacsScalar(const TacsScalar[],TacsScalar[])> evalGlobalPanelBucklingStrainSens;
std::function<TacsScalar(const TacsScalar[],TacsScalar[])> evalStiffenerCripplingStrainSens;
std::function<void(int,TacsScalar,const double[],const TacsScalar[],const TacsScalar[],int dvLen,TacsScalar[])> addLocalPanelBucklingDVSens;
std::function<void(int,TacsScalar,const double[],const TacsScalar[],const TacsScalar[],int dvLen,TacsScalar[])> addGlobalPanelBucklingDVSens;
std::function<void(const TacsScalar, const TacsScalar[], TacsScalar[])> addStiffenerCripplingDVSens;

static const char* const constName; ///< Constitutive model name
static const int NUM_Q_ENTRIES = 6; ///< Number of entries in the Q matrix
static const int NUM_ABAR_ENTRIES =
Expand Down
Loading