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