forked from neuraloperator/physics_informed
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpinns.py
35 lines (27 loc) · 1.23 KB
/
pinns.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
from argparse import ArgumentParser
import yaml
from baselines.pinns_ns_05s import train
from baselines.pinns_ns_50s import train_longtime
from baselines.sapinns import train_sapinn
import csv
if __name__ == '__main__':
parser = ArgumentParser(description='Basic paser')
parser.add_argument('--config_path', type=str, help='Path to the configuration file')
parser.add_argument('--log', action='store_true', help='log the results')
parser.add_argument('--start', type=int, default=0, help='start index')
parser.add_argument('--stop', type=int, default=1, help='stopping index')
args = parser.parse_args()
config_file = args.config_path
with open(config_file, 'r') as stream:
config = yaml.load(stream, yaml.FullLoader)
with open(config['log']['logfile'], 'a') as f:
writer = csv.writer(f)
writer.writerow(['Index', 'Error in u', 'Error in v', 'Error in w', 'Step', 'Time cost'])
for i in range(args.start, args.stop):
print(f'Start to solve instance {i}')
if 'time_scale' in config['data']:
train_longtime(i, config, args)
elif config['log']['group'] == 'SA-PINNs':
train_sapinn(i, config, args)
else:
train(i, config, args)