/[escript]/trunk/modellib/test/python/convection.py
ViewVC logotype

Contents of /trunk/modellib/test/python/convection.py

Parent Directory Parent Directory | Revision Log Revision Log


Revision 155 - (show annotations)
Wed Nov 9 02:02:19 2005 UTC (17 years, 4 months ago) by jgs
File MIME type: text/x-python
File size: 2768 byte(s)
move all directories from trunk/esys2 into trunk and remove esys2

1 # $Id$
2
3 #
4 #
5 # a very simple convection model in model frame:
6 #
7
8 from esys.escript.modelframe import Link,Simulation
9 from esys.modellib.geometry import RectangularDomain,ScalarConstrainer,VectorConstrainer
10 from esys.modellib.input import Sequencer,InterpolateOverBox,GaussianProfile,LinearCombination
11 from esys.modellib.flow import SteadyIncompressibleFlow
12 from esys.modellib.temperature import TemperatureAdvection
13 from esys.modellib.materials import SimpleEarthModel,GravityForce
14 from esys.modellib.visualization import WriteVTK
15
16 dom=RectangularDomain()
17 dom.order=2
18
19 temp_constraints=ScalarConstrainer()
20 temp_constraints.domain=Link(dom)
21 temp_constraints.top=1
22 temp_constraints.bottom=1
23
24 vel_constraints=VectorConstrainer()
25 vel_constraints.domain=Link(dom)
26 vel_constraints.left=[1,0,0]
27 vel_constraints.right=[1,0,0]
28 vel_constraints.top=[0,1,0]
29 vel_constraints.bottom=[0,1,0]
30 vel_constraints.front=[0,0,1]
31 vel_constraints.back=[0,0,1]
32
33
34 temp_val=InterpolateOverBox()
35 temp_val.domain=Link(dom,"domain")
36 temp_val.right_top_back=Link(dom,"l")
37 temp_val.value_left_bottom_front=1.
38 temp_val.value_right_bottom_front=1.
39 temp_val.value_left_top_front=0.
40 temp_val.value_right_top_front=0.
41 temp_val.value_left_bottom_back=1.
42 temp_val.value_right_bottom_back=1.
43 temp_val.value_left_top_back=0.
44 temp_val.value_right_top_back=0.
45
46 mat=SimpleEarthModel()
47 mat.density0=1.
48 mat.viscocity0=1.
49 mat.rayleigh_number=10000.
50 mat.alpha=0.001
51
52 temp=TemperatureAdvection(debug=True)
53 temp.domain=Link(dom)
54 temp.density=Link(mat,"density0")
55 temp.heat_capacity=Link(mat,"heat_capacity")
56 temp.location_fixed_temperature=Link(temp_constraints,"location_of_constraint")
57 temp.fixed_temperature=Link(temp_val,"out")
58 temp.safety_factor=0.01
59 mat.temperature=Link(temp,"temperature")
60
61
62 grav=GravityForce()
63 grav.domain=Link(dom,"domain")
64 grav.direction=[0.,-1.,0.]
65 grav.density=Link(mat,"density")
66 grav.gravity=Link(mat,"gravity")
67
68
69 vel=SteadyIncompressibleFlow(debug=True)
70 vel.domain=Link(dom)
71 vel.internal_force=Link(grav,"gravity_force")
72 vel.viscosity=Link(mat,"viscosity")
73 vel.location_prescribed_velocity=Link(vel_constraints,"location_of_constraint")
74 vel.rel_tol=1.e-6
75 temp.velocity=Link(vel,"velocity")
76
77 sq=Sequencer()
78 sq.t_end=0.005
79
80 vis=WriteVTK()
81 vis.t=Link(sq)
82 vis.scalar=Link(temp,"temperature")
83 vis.vector=Link(vel,"velocity")
84 vis.stride=5
85
86 per=GaussianProfile()
87 per.domain=Link(dom)
88 per.x_c=[0.5,0.5,0.5]
89 per.A=0.0001
90 per.width=0.01
91 per.r=0
92
93 lc=LinearCombination()
94 lc.f0=1.
95 lc.v0=Link(per,"out")
96 lc.f1=1.
97 lc.v1=Link(temp_val,"out")
98 temp.temperature=Link(lc,"out")
99
100 # s=Simulation([dom,sq,temp_constraints,vel_constraints,temp_val,per,lc,mat,grav,Simulation([vel],debug=True),temp,vis],debug=True)
101 s=Simulation([dom,sq,Simulation([vel],debug=True),temp,vis],debug=True)
102 s.writeXML()
103 s.run()

Properties

Name Value
svn:eol-style native
svn:keywords Author Date Id Revision

  ViewVC Help
Powered by ViewVC 1.1.26