-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBody.hh
53 lines (44 loc) · 870 Bytes
/
Body.hh
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
#ifndef _BODY_HH_
#define _BODY_HH_
class Body{
public:
Body() : m_(0.0) {};
Body(double x, double y, double vx, double vy, double m):
x_(x), y_(y), vx_(vx), vy_(vy), m_(m), fx_(0.0), fy_(0.0){};
double x() const{
return x_;
}
double y() const{
return y_;
}
double vx() const{
return vx_;
}
double vy() const{
return vy_;
}
double m() const{
return m_;
}
double fx() const{
return fx_;
}
double fy() const{
return fy_;
}
//Adds gravitational force due to the body puller.
void accGravityFrom(Body const &puller);
//Leapfrog integration
void integrate(double h);
private:
static const double G;
static const double min_dist;
double x_; //x-coordinate
double y_; //y-coordinate
double vx_; //x velocity
double vy_; //y velocity
double m_; //mass
double fx_;
double fy_;
};
#endif