Coverage for pySDC/projects/AllenCahn_Bayreuth/visualize_temp.py: 0%
62 statements
« prev ^ index » next coverage.py v7.6.9, created at 2024-12-20 14:51 +0000
« prev ^ index » next coverage.py v7.6.9, created at 2024-12-20 14:51 +0000
1import json
2import glob
3import numpy as np
4import matplotlib
6matplotlib.use('TkAgg')
7import matplotlib.pyplot as plt
8from mpl_toolkits.axes_grid1 import AxesGrid
9from argparse import ArgumentParser
11import imageio
14def plot_data(path='./data', name='', output='.'):
15 """
16 Visualization using numpy arrays (written via MPI I/O) and json description
18 Produces one png file per time-step, combine as movie via e.g.
19 > ffmpeg -i data/name_%08d.png name.mp4
21 Args:
22 path (str): path to data files
23 name (str): name of the simulation (expects data to be in data path)
24 output (str): path to output
25 """
27 json_files = sorted(glob.glob(f'{path}/{name}_*.json'))
28 data_files = sorted(glob.glob(f'{path}/{name}_*.dat'))
30 for json_file, data_file in zip(json_files, data_files):
31 with open(json_file, 'r') as fp:
32 obj = json.load(fp)
34 index = json_file.split('_')[-1].split('.')[0]
35 print(f'Working on step {index}...')
37 array = np.fromfile(data_file, dtype=obj['datatype'])
38 array = array.reshape(obj['shape'], order='C')
40 fig = plt.figure()
42 grid = AxesGrid(
43 fig, 111, nrows_ncols=(1, 2), axes_pad=0.15, cbar_mode='single', cbar_location='right', cbar_pad=0.15
44 )
46 im = grid[0].imshow(array[..., 0], vmin=0, vmax=1)
47 im = grid[1].imshow(array[..., 1], vmin=0, vmax=1)
49 grid[0].set_title(f"Field - Time: {obj['time']:6.4f}")
50 grid[1].set_title(f"Temperature - Time: {obj['time']:6.4f}")
52 grid[1].yaxis.set_visible(False)
54 grid.cbar_axes[0].colorbar(im)
56 plt.savefig(f'{output}/{name}_{index}.png', bbox_inches='tight')
57 plt.close()
60def make_movie(path='./data', name='', output='.'):
61 """
62 Visualization using numpy arrays (written via MPI I/O) and json description
64 Produces one png file per time-step, combine as movie via e.g.
65 > ffmpeg -i data/name_%08d.png name.mp4
67 Args:
68 path (str): path to data files
69 name (str): name of the simulation (expects data to be in data path)
70 output (str): path to output
71 """
73 json_files = sorted(glob.glob(f'{path}/{name}_*.json'))
74 data_files = sorted(glob.glob(f'{path}/{name}_*.dat'))
76 img_list = []
77 for json_file, data_file in zip(json_files, data_files):
78 with open(json_file, 'r') as fp:
79 obj = json.load(fp)
81 index = json_file.split('_')[1].split('.')[0]
82 print(f'Working on step {index}...')
84 array = np.fromfile(data_file, dtype=obj['datatype'])
85 array = array.reshape(obj['shape'], order='C')
87 fig, ax = plt.subplots(1, 2)
89 ax[0].imshow(array[..., 0], vmin=0, vmax=1)
90 ax[1].imshow(array[..., 1], vmin=0, vmax=1)
92 # ax.set_colorbar()
93 ax[0].set_title(f"Field - Time: {obj['time']:6.4f}")
94 ax[1].set_title(f"Temperature - Time: {obj['time']:6.4f}")
96 fig.tight_layout()
98 # draw the canvas, cache the renderer
99 fig.canvas.draw()
100 image = np.frombuffer(fig.canvas.tostring_rgb(), dtype='uint8')
101 img_list.append(image.reshape(fig.canvas.get_width_height()[::-1] + (3,)))
102 plt.close()
104 # c += 1
105 # if c == 3:
106 # break
108 fname = f'{output}/{name}.mp4'
109 imageio.mimsave(fname, img_list, fps=8)
112def make_movie_from_files(path='./data', name='', output='.'):
113 """
114 Visualization using numpy arrays (written via MPI I/O) and json description
116 Produces one png file per time-step, combine as movie via e.g.
117 > ffmpeg -i data/name_%08d.png name.mp4
119 Args:
120 path (str): path to data files
121 name (str): name of the simulation (expects data to be in data path)
122 output (str): path to output
123 """
125 img_files = sorted(glob.glob(f'{path}/{name}_*.png'))
126 print(f'{path}{name}')
128 images = []
129 for fimg in img_files:
130 img = imageio.imread(fimg)
131 print(fimg, img.shape)
132 images.append(imageio.imread(fimg))
133 fname = f'{output}/{name}.mp4'
134 imageio.mimsave(fname, images, fps=8)
137if __name__ == "__main__":
138 parser = ArgumentParser()
139 parser.add_argument("-p", "--path", help='Path to data files', type=str, default='./data')
140 parser.add_argument("-n", "--name", help='Name of the simulation', type=str)
141 parser.add_argument("-o", "--output", help='Path for output file', type=str, default='.')
142 args = parser.parse_args()
144 # name = 'AC-test-tempforce'
145 name = 'AC-bench-tempforce'
147 plot_data(path=args.path, name=args.name, output=args.output)
148 # make_movie(path=args.path, name=args.name, output=args.output)
149 make_movie_from_files(path=args.path, name=args.name, output=args.output)