1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
#!/usr/bin/env python
import openturns as ot
import openturns.testing
import persalys
myStudy = persalys.Study("myStudy")
# Model
dist_R = ot.LogNormalMuSigma(300.0, 30.0).getDistribution()
dist_F = ot.Normal(75000.0, 5000.0)
R = persalys.Input("R", 300.0, dist_R, "Yield stress (Pa)")
F = persalys.Input("F", 75000.0, dist_F, "Traction force (N)")
G = persalys.Output("G", "Stress difference (Pa)")
code = "from math import pi\n\ndef _exec(R, F):\n G = R-F/(pi*100.0)\n return G\n"
model = persalys.PythonPhysicalModel("myPhysicalModel", [R, F], [G], code)
model.setProcessNumber(1)
myStudy.add(model)
f = model.getFunction()
print(f([300.0, 75000.0]))
# Design of Experiment - Parametric analysis ##
bounds = persalys.GridDesignOfExperiment.GetDefaultBounds(model)
values = [[bounds.getLowerBound()[i], bounds.getUpperBound()[i]] for i in range(2)]
aDesign = persalys.GridDesignOfExperiment("design", model, values)
myStudy.add(aDesign)
aDesign.run()
# Taylor Expansion ##
taylorExpansionsMoments = persalys.TaylorExpansionMomentsAnalysis(
"myTaylorExpansionMoments", model
)
myStudy.add(taylorExpansionsMoments)
taylorExpansionsMoments.run()
taylorExpansionsMomentsResult = taylorExpansionsMoments.getResult()
# Monte Carlo ##
montecarlo = persalys.MonteCarloAnalysis("myMonteCarlo", model)
montecarlo.setMaximumCalls(1000)
myStudy.add(montecarlo)
montecarlo.run()
montecarloResult = montecarlo.getResult()
meanCI = montecarloResult.getMeanConfidenceInterval()
stdCi = montecarloResult.getStdConfidenceInterval()
# Sobol ##
sobol = persalys.SobolAnalysis("mySobol", model)
sobol.setMaximumConfidenceIntervalLength(-1)
sobol.setMaximumCalls(1000)
sobol.setReplicationSize(250)
myStudy.add(sobol)
sobol.run()
sobolResult = sobol.getResult()
# SRC ##
src = persalys.SRCAnalysis("mySRC", model, 1000)
myStudy.add(src)
src.run()
srcResult = src.getResult()
# script
script = myStudy.getPythonScript()
print(script)
exec(script)
|