1 | """
|
---|
2 | == == == == == == == == == == == == == == == == == == ==
|
---|
3 | Auto generated python script for ISSM: test213.m
|
---|
4 | Created on 2012-09-27 via translateToPy.py Ver 1.0 by mikep
|
---|
5 | == == == == == == == == == == == == == == == == == == ==
|
---|
6 |
|
---|
7 | Matlab script conversion into python
|
---|
8 | translateToPy.py Author: Michael Pellegrin
|
---|
9 | translateToPy.py Date: 09/24/12
|
---|
10 | == == == == == == == == == == == == == == == == == == ==
|
---|
11 | """
|
---|
12 |
|
---|
13 | from MatlabFuncs import *
|
---|
14 | from model import *
|
---|
15 | from EnumDefinitions import *
|
---|
16 | from numpy import *
|
---|
17 | from triangle import *
|
---|
18 | from setmask import *
|
---|
19 | from parameterize import *
|
---|
20 | from setflowequation import *
|
---|
21 | from solve import *
|
---|
22 |
|
---|
23 | md=triangle(model(),'../Exp/Square.exp',200000)
|
---|
24 | md=setmask(md,'all','')
|
---|
25 | md=parameterize(md,'../Par/SquareShelf.py')
|
---|
26 | md.extrude(3,1)
|
---|
27 | md=setflowequation(md,'macayeal','all')
|
---|
28 |
|
---|
29 |
|
---|
30 | # control parameters
|
---|
31 |
|
---|
32 | md.inversion.iscontrol=1
|
---|
33 | md.inversion.control_parameters=['MaterialsRheologyBbar']
|
---|
34 | md.inversion.min_parameters=10**6*ones((md.mesh.numberofvertices,1))
|
---|
35 | md.inversion.max_parameters=2.*10**9*ones((md.mesh.numberofvertices,1))
|
---|
36 | md.inversion.nsteps=2
|
---|
37 | md.inversion.cost_functions=101.*ones((md.inversion.nsteps,1))
|
---|
38 | md.inversion.cost_functions_coefficients=ones((md.mesh.numberofvertices,1))
|
---|
39 | md.inversion.gradient_scaling=10**7*ones((md.inversion.nsteps,1))
|
---|
40 | md.inversion.maxiter_per_step=2.*ones((md.inversion.nsteps,1))
|
---|
41 | md.inversion.step_threshold=0.3*ones((md.inversion.nsteps,1))
|
---|
42 | md.inversion.vx_obs=md.initialization.vx
|
---|
43 | md.inversion.vy_obs=md.initialization.vy
|
---|
44 |
|
---|
45 |
|
---|
46 | md.cluster=generic('name',oshostname(),'np',3)
|
---|
47 | md=solve(md,DiagnosticSolutionEnum())
|
---|
48 |
|
---|
49 |
|
---|
50 | # Fields and tolerances to track changes
|
---|
51 |
|
---|
52 | field_names =['Gradient','Misfits','MaterialsRheologyBbar','Pressure','Vel','Vx','Vy']
|
---|
53 | field_tolerances=[1e-13,1e-13,1e-13,1e-13,1e-13,1e-13,1e-13]
|
---|
54 | #field_tolerances=[1e-13,1e-13,1e-13,1e-13,1e-13,1e-13,1e-13,1e-13,1e-13,1e-13]
|
---|
55 | field_values=[\
|
---|
56 | md.results['DiagnosticSolution'][1]['Gradient1'],\
|
---|
57 | md.results['DiagnosticSolution'][1]['J'],\
|
---|
58 | md.results['DiagnosticSolution'][1]['MaterialsRheologyB'],\
|
---|
59 | md.results['DiagnosticSolution'][1]['Pressure'],\
|
---|
60 | md.results['DiagnosticSolution'][1]['Vel'],\
|
---|
61 | md.results['DiagnosticSolution'][1]['Vx'],\
|
---|
62 | md.results['DiagnosticSolution'][1]['Vy'],\
|
---|
63 | ]
|
---|