[13661] | 1 | import numpy
|
---|
| 2 | from model import *
|
---|
| 3 | from triangle import *
|
---|
| 4 | from setmask import *
|
---|
| 5 | from parameterize import *
|
---|
| 6 | from setflowequation import *
|
---|
| 7 | from EnumDefinitions import *
|
---|
| 8 | from solve import *
|
---|
| 9 | from MatlabFuncs import *
|
---|
| 10 |
|
---|
| 11 | md=triangle(model(),'../Exp/Square.exp',200000.)
|
---|
| 12 | md=setmask(md,'','')
|
---|
| 13 | md=parameterize(md,'../Par/SquareSheetConstrained.py')
|
---|
| 14 | md.extrude(3,1)
|
---|
| 15 | md=setflowequation(md,'macayeal','all')
|
---|
| 16 |
|
---|
| 17 | #control parameters
|
---|
| 18 | md.inversion.iscontrol=1
|
---|
| 19 | md.inversion.control_parameters=['FrictionCoefficient']
|
---|
| 20 | md.inversion.min_parameters=1.*numpy.ones((md.mesh.numberofvertices,1))
|
---|
| 21 | md.inversion.max_parameters=200.*numpy.ones((md.mesh.numberofvertices,1))
|
---|
| 22 | md.inversion.nsteps=2
|
---|
| 23 | md.inversion.cost_functions=numpy.hstack((103*numpy.ones((md.inversion.nsteps,1)),501*numpy.ones((md.inversion.nsteps,1))))
|
---|
| 24 | md.inversion.cost_functions_coefficients=numpy.ones((md.mesh.numberofvertices,2))
|
---|
| 25 | md.inversion.cost_functions_coefficients[:,1]=2.*10**-7
|
---|
| 26 | md.inversion.gradient_scaling=3.*numpy.ones((md.inversion.nsteps,1))
|
---|
| 27 | md.inversion.maxiter_per_step=2*numpy.ones(md.inversion.nsteps)
|
---|
| 28 | md.inversion.step_threshold=0.3*numpy.ones(md.inversion.nsteps)
|
---|
| 29 | md.inversion.vx_obs=md.initialization.vx
|
---|
| 30 | md.inversion.vy_obs=md.initialization.vy
|
---|
| 31 |
|
---|
| 32 | md.cluster=generic('name',oshostname(),'np',3)
|
---|
| 33 | md=solve(md,DiagnosticSolutionEnum())
|
---|
| 34 |
|
---|
| 35 | #Fields and tolerances to track changes
|
---|
| 36 | field_names =['Gradient','Misfits','FrictionCoefficient','Pressure','Vel','Vx','Vy']
|
---|
| 37 | field_tolerances=[1e-12,1e-12,1e-12,1e-12,1e-12,1e-12,1e-12,1e-12,1e-12,1e-12]
|
---|
| 38 | field_values=[\
|
---|
| 39 | md.results['DiagnosticSolution'][1]['Gradient1'],\
|
---|
| 40 | md.results['DiagnosticSolution'][1]['J'],\
|
---|
| 41 | md.results['DiagnosticSolution'][1]['FrictionCoefficient'],\
|
---|
| 42 | md.results['DiagnosticSolution'][1]['Pressure'],\
|
---|
| 43 | md.results['DiagnosticSolution'][1]['Vel'],\
|
---|
| 44 | md.results['DiagnosticSolution'][1]['Vx'],\
|
---|
| 45 | md.results['DiagnosticSolution'][1]['Vy'],\
|
---|
| 46 | ]
|
---|