forked from kektobiologist/motion-simulation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconstants.h
87 lines (51 loc) · 3.04 KB
/
constants.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
79
80
81
82
83
84
85
86
87
#ifndef CONSTANTS_H
#define CONSTANTS_H
namespace Constants {
const double FINAL_VEL = 0;
const int GOAL_DEPTH = 300;
const int CENTER_X = 0;
const int CENTER_Y = 0;
const int HALF_FIELD_MAXX = 3025; //actual 225 (rugged surface at end)
const int HALF_FIELD_MAXY = 2050;
const int OUR_GOAL_MAXY = 600;
const int OUR_GOAL_MINY = -600;
const int OPP_GOAL_MAXY = 600;
const int OPP_GOAL_MINY = -600;
const int OUR_GOAL_WIDTH = OUR_GOAL_MAXY - OUR_GOAL_MINY;
const int OPP_GOAL_WIDTH = OPP_GOAL_MAXY - OPP_GOAL_MINY;
const int CENTER_CIRCLE_DIAMETER = 1000;
const int DBOX_WIDTH = 1200; //Along X direction
const int DBOX_HEIGHT = 855; //Along Y direction(half height in each y direction)
const int DBOX_DEPTH = 10;
const int BALL_AT_CORNER_THRESH = 20;
/* Bot Parameteres configuration */
// mm
const float BOT_RADIUS = 150; // mm
const float BALL_RADIUS = 40; // mm
const float SAFE_RADIUS = (BOT_RADIUS * 2);
const float COLLISION_DIST = (BOT_RADIUS * 7);
const int DRIBBLER_BALL_THRESH = 500; // mm
const int BOT_BALL_THRESH = 150; // mm
const int BOT_BALL_THRESH_FOR_PR = 200; // mm
//const int BOT_POINT_THRESH = 147; // mm
// Parameters useful for camera's data transformation.
const int OUR_GOAL_Y = 500;
const int OPP_GOAL_Y = 0;
static const double d = 6.8; // 6.5 for old bot distance between wheels in cm for new bot
static const double ticksToCmS = 1.107; //1.139still only approximate... v = v_ticks * ticksToCmS
static const double fieldXConvert = 23.79; // now im always using xconvert as standard conversion from strategy -> cm and vice versa.
static const double fieldYConvert = fieldXConvert; //22.02;
// NOTE(arpit): Uncertainties should be non-zero when simulating. Currently 0 since bot data is fetched from vision.
static const double xUncertainty = 0;//0.5; // Uncertainty is in %age of max value. eg. 1% where fabs(x) <= 1000 means fabs(error) <= 10
static const double yUncertainty = 0;//0.5;
static const double thetaUncertainty = 0;//3;
// NOTE(arpit): numPacketDelay and update() specified here is only used in simulation.
static const int numPacketDelay = 0; // num of packets to delay in update
static const double vwmax = 200; // 200cm/s^2
static const double vwSlope = -5.92; //making vw as function of r
static const double vwIntercept= 750;
static const double vsat = ticksToCmS*120.; // 100 cm/s
static const double atmax = 100*ticksToCmS; // cm/s^2, need to measure this, need to take inertia into account
static const double awmax = 1000; // 1/s^2, no idea how to measure this, need to take inertia into account
}
#endif // CONSTANTS_H