forked from csc-training/hpc-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
heat_main.py
55 lines (43 loc) · 1.88 KB
/
heat_main.py
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
from __future__ import print_function
import time
import argparse
from heat import init_fields, write_field, iterate
def main(input_file='bottle.dat', a=0.5, dx=0.1, dy=0.1,
timesteps=200, image_interval=4000):
# Initialise the temperature field
field, field0 = init_fields(input_file)
print("Heat equation solver")
print("Diffusion constant: {}".format(a))
print("Input file: {}".format(input_file))
print("Parameters")
print("----------")
print(" nx={} ny={} dx={} dy={}".format(field.shape[0], field.shape[1],
dx, dy))
print(" time steps={} image interval={}".format(timesteps,
image_interval))
# Plot/save initial field
write_field(field, 0)
# Iterate
t0 = time.time()
iterate(field, field0, a, dx, dy, timesteps, image_interval)
t1 = time.time()
# Plot/save final field
write_field(field, timesteps)
print("Simulation finished in {0} s".format(t1-t0))
if __name__ == '__main__':
# Process command line arguments
parser = argparse.ArgumentParser(description='Heat equation')
parser.add_argument('-dx', type=float, default=0.01,
help='grid spacing in x-direction')
parser.add_argument('-dy', type=float, default=0.01,
help='grid spacing in y-direction')
parser.add_argument('-a', type=float, default=0.5,
help='diffusion constant')
parser.add_argument('-n', type=int, default=200,
help='number of time steps')
parser.add_argument('-i', type=int, default=4000,
help='image interval')
parser.add_argument('-f', type=str, default='bottle.dat',
help='input file')
args = parser.parse_args()
main(args.f, args.a, args.dx, args.dy, args.n, args.i)