-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy patheight.cpp
More file actions
60 lines (49 loc) · 1.37 KB
/
eight.cpp
File metadata and controls
60 lines (49 loc) · 1.37 KB
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
#include <cstdio>
#include <cstdlib>
#include <cassert>
#include <algorithm>
#define SKIP_SELF
#include "Nbody.h"
#ifndef INTGRT
#define INTGRT KDKDK_4th
#endif
int main(int argc, char **argv){
Nbody sys;
sys.resize(3);
assert(argc > 1);
const int invtick = atoi(argv[1]);
const double tick = 1.0 / invtick;
sys.set_eps(0.0);
sys.ptcl[0].pos = { 0.97000436, -0.24308753, 0.0};
sys.ptcl[1].pos = {-0.97000436, +0.24308753, 0.0};
sys.ptcl[2].pos = {0.0, 0.0, 0.0};
sys.ptcl[0].vel = {-0.93240737/(-2.0),-0.86473146/(-2.0),0.0};
sys.ptcl[1].vel = {-0.93240737/(-2.0),-0.86473146/(-2.0),0.0};
sys.ptcl[2].vel = {-0.93240737, -0.86473146, 0.0};
sys.ptcl[0].mass = 1.0;
sys.ptcl[1].mass = 1.0;
sys.ptcl[2].mass = 1.0;
sys.ptcl[0].id = 0;
sys.ptcl[1].id = 1;
sys.ptcl[2].id = 2;
sys.calc_acc();
double en0 = sys.energy(stderr);
double err_max = 0.0;
FILE *fp = fopen("orbit.dat", "w");
while(sys.tsys < 100.0){
sys.INTGRT(tick);
double en1 = sys.energy();
double de = (en1 - en0) / en0;
printf("%e %e\n", sys.tsys, de);
#if 1
fprintf(fp, "%e %e %f %f %f %f %f %f\n",
sys.tsys, de,
sys.ptcl[0].pos.x, sys.ptcl[0].pos.y,
sys.ptcl[1].pos.x, sys.ptcl[1].pos.y,
sys.ptcl[2].pos.x, sys.ptcl[2].pos.y);
#endif
err_max = std::max(err_max, fabs(de));
}
printf("%e %e (dt,error_max)\n", 12.*tick, err_max);
fclose(fp);
}