-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathVector.java
177 lines (136 loc) · 2.97 KB
/
Vector.java
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
package frc.robot.subsystems.drive;
public class Vector
{
private double _x;
private double _y;
private double _r;
private double _theta;
public Vector()
{
this(0, 0);
}
public Vector(double x, double y)
{
this(x, y, true);
}
public Vector(double first, double second, boolean isCartesian)
{
if (isCartesian)
{
_x = first;
_y = second;
updatePolar();
}
else
{
_r = first;
_theta = second;
updateCartesian();
}
}
public Vector clone()
{
return new Vector(_x, _y);
}
public double getX()
{
return _x;
}
public void setX(double x)
{
_x = x;
updatePolar();
}
public double getY()
{
return _y;
}
public void setY(double y)
{
_y = y;
updatePolar();
}
public double getR()
{
return _r;
}
public void setR(double r)
{
_r = r;
updateCartesian();
}
public double getTheta()
{
return _theta;
}
public void setTheta(double theta)
{
_theta = normalizeAngle(theta);
updateCartesian();
}
public void setCartesianPosition(double x, double y)
{
_x = x;
_y = y;
updatePolar();
}
public void translateCartesianPosition(double dx, double dy)
{
setCartesianPosition(_x + dx, _y + dy);
}
public void setPolarPosition(double r, double theta)
{
_r = r;
_theta = normalizeAngle(theta);
updateCartesian();
}
public void translatePolarPosition(double dr, double dtheta)
{
setPolarPosition(_r + dr, _theta + dtheta);
}
public Vector multiply(double scalar)
{
Vector v = clone();
v._r *= scalar;
v.updateCartesian();
return v;
}
public Vector divide(double scalar)
{
Vector v = clone();
v._r /= scalar;
v.updateCartesian();
return v;
}
public Vector add(Vector other)
{
return new Vector(getX() + other.getX(), getY() + other.getY());
}
public Vector subtract(Vector other)
{
return new Vector(getX() - other.getX(), getY() - other.getY());
}
private void updateCartesian()
{
_y = _r * Math.cos(Math.toRadians(_theta));
_x = _r * Math.sin(Math.toRadians(_theta));
}
private void updatePolar()
{
_r = Math.sqrt((_x * _x) + (_y * _y));
_theta = normalizeAngle(Math.toDegrees(Math.atan2(_x, _y)));
}
public static double normalizeAngle(double angle)
{
if (angle < 0)
{
angle += 360 * (((int)angle / -360) + 1);
}
return angle % 360;
}
@Override
public String toString()
{
return String.format("(%6.2f, %6.2f)", getX(), getY());
}
}