-
Notifications
You must be signed in to change notification settings - Fork 50
/
Copy pathmeshio.h
78 lines (67 loc) · 2.12 KB
/
meshio.h
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#ifndef MESHIO_H
#define MESHIO_H
//ldoc on
/**
* ## I/O
*
* After finishing a run (or every several steps), we might want to
* write out a data file for post processing. One simple approach is
* to draw a gray scale or color picture showing some scalar quantity
* at each point. The Portable Gray Map (PGM) format is one of the
* few graphics formats that can be dumped out in a handful of lines
* of code without any library calls. The files can be converted to
* something more modern and snazzy (like a PNG or GIF) later on.
* Note that we don't actually dump out the state vector for each cell
* -- we need to produce something that is an integer in the range
* [0,255]. That's what the function `f` is for!
*/
template <class Sim, typename F>
void write_pgm(const char* fname, const Sim& u, F f)
{
using namespace std;
FILE* fp = fopen(fname, "wb");
fprintf(fp, "P5\n");
fprintf(fp, "%d %d 255\n", u.xsize(), u.ysize());
for (int iy = u.ysize()-1; iy >= 0; --iy)
for (int ix = 0; ix < u.xsize(); ++ix)
fputc(min(255, max(0, f(u(ix,iy)))), fp);
fclose(fp);
}
/**
*
* An alternative to writing an image file is to write a data file for
* further processing by some other program -- in this case, a Python
* visualizer. The visualizer takes the number of pixels in x and y
* in the first two entries, then raw single-precision raster pictures.
*
*/
template <class Sim>
class SimViz {
public:
SimViz(const char* fname, const Sim& sim) : sim(sim) {
fp = fopen(fname, "w");
if (fp) {
float xy[2];
xy[0] = sim.xsize();
xy[1] = sim.ysize();
fwrite(xy, sizeof(float), 2, fp);
}
}
void write_frame() {
if (fp)
for (int j = 0; j < sim.ysize(); ++j)
for (int i = 0; i < sim.xsize(); ++i) {
float uij = sim(i,j)[0];
fwrite(&uij, sizeof(float), 1, fp);
}
}
~SimViz() {
if (fp)
fclose(fp);
}
private:
const Sim& sim;
FILE* fp;
};
//ldoc off
#endif /* MESHIO_H */