Ejemplo n.º 1
0
 public static void mulToOutUnsafe(Rot q, Vec2 v, Vec2 out_Renamed)
 {
     out_Renamed.x = q.c * v.x - q.s * v.y;
     out_Renamed.y = q.s * v.x + q.c * v.y;
 }
Ejemplo n.º 2
0
 /// <summary>Initialize as a copy of another transform. </summary>
 public Transform(Transform xf)
 {
     p = xf.p.Clone();
     q = xf.q.Clone();
 }
Ejemplo n.º 3
0
 /// <summary>Initialize using a position vector and a rotation matrix. </summary>
 public Transform(Vec2 _position, Rot _R)
 {
     p = _position.Clone();
     q = _R.Clone();
 }
Ejemplo n.º 4
0
 public static void mul(Rot q, Rot r, Rot out_Renamed)
 {
     float tempc = q.c * r.c - q.s * r.s;
     out_Renamed.s = q.s * r.c + q.c * r.s;
     out_Renamed.c = tempc;
 }
Ejemplo n.º 5
0
 public static void MulTransUnsafe(Rot q, Rot r, Rot result)
 {
     // [ qc qs] * [rc -rs] = [qc*rc+qs*rs -qc*rs+qs*rc]
     // [-qs qc] [rs rc] [-qs*rc+qc*rs qs*rs+qc*rc]
     // s = qc * rs - qs * rc
     // c = qc * rc + qs * rs
     result.Sin = q.Cos * r.Sin - q.Sin * r.Cos;
     result.Cos = q.Cos * r.Cos + q.Sin * r.Sin;
 }
Ejemplo n.º 6
0
 public static void mulTransUnsafe(Rot q, Vec2 v, Vec2 out_Renamed)
 {
     out_Renamed.x = q.c * v.x + q.s * v.y;
     out_Renamed.y = (-q.s) * v.x + q.c * v.y;
 }
Ejemplo n.º 7
0
 public virtual Rot Clone()
 {
     Rot copy = new Rot();
     copy.s = s;
     copy.c = c;
     return copy;
 }
Ejemplo n.º 8
0
 public static void MulToOutUnsafe(Rot q, Vec2 v, Vec2 result)
 {
     result.X = q.Cos * v.X - q.Sin * v.Y;
     result.Y = q.Sin * v.X + q.Cos * v.Y;
 }
Ejemplo n.º 9
0
 public static void MulTrans(Rot q, Rot r, Rot result)
 {
     float tempc = q.Cos * r.Cos + q.Sin * r.Sin;
     result.Sin = q.Cos * r.Sin - q.Sin * r.Cos;
     result.Cos = tempc;
 }
Ejemplo n.º 10
0
 public Rot Set(Rot other)
 {
     Sin = other.Sin;
     Cos = other.Cos;
     return this;
 }
Ejemplo n.º 11
0
 public static void MulToOut(Rot q, Vec2 v, Vec2 result)
 {
     float tempy = q.Sin * v.X + q.Cos * v.Y;
     result.X = q.Cos * v.X - q.Sin * v.Y;
     result.Y = tempy;
 }
Ejemplo n.º 12
0
 public Rot Clone()
 {
     Rot copy = new Rot();
     copy.Sin = Sin;
     copy.Cos = Cos;
     return copy;
 }
Ejemplo n.º 13
0
 public static void MulUnsafe(Rot q, Rot r, Rot result)
 {
     Debug.Assert(r != result);
     Debug.Assert(q != result);
     // [qc -qs] * [rc -rs] = [qc*rc-qs*rs -qc*rs-qs*rc]
     // [qs qc] [rs rc] [qs*rc+qc*rs -qs*rs+qc*rc]
     // s = qs * rc + qc * rs
     // c = qc * rc - qs * rs
     result.Sin = q.Sin * r.Cos + q.Cos * r.Sin;
     result.Cos = q.Cos * r.Cos - q.Sin * r.Sin;
 }
Ejemplo n.º 14
0
 public static void MulTransUnsafe(Rot q, Vec2 v, Vec2 result)
 {
     result.X = q.Cos * v.X + q.Sin * v.Y;
     result.Y = (-q.Sin) * v.X + q.Cos * v.Y;
 }
Ejemplo n.º 15
0
 public static void mulTrans(Rot q, Vec2 v, Vec2 out_Renamed)
 {
     float tempy = (-q.s) * v.x + q.c * v.y;
     out_Renamed.x = q.c * v.x + q.s * v.y;
     out_Renamed.y = tempy;
 }
Ejemplo n.º 16
0
 /// <summary>
 /// The default constructor.
 /// </summary>
 public Transform()
 {
     P = new Vec2();
     Q = new Rot();
 }
Ejemplo n.º 17
0
 public static void mulTransUnsafe(Rot q, Rot r, Rot out_Renamed)
 {
     // [ qc qs] * [rc -rs] = [qc*rc+qs*rs -qc*rs+qs*rc]
     // [-qs qc] [rs rc] [-qs*rc+qc*rs qs*rs+qc*rc]
     // s = qc * rs - qs * rc
     // c = qc * rc + qs * rs
     out_Renamed.s = q.c * r.s - q.s * r.c;
     out_Renamed.c = q.c * r.c + q.s * r.s;
 }
Ejemplo n.º 18
0
 /// <summary>
 /// Initialize as a copy of another transform.
 /// </summary>
 public Transform(Transform xf)
 {
     P = xf.P.Clone();
     Q = xf.Q.Clone();
 }
Ejemplo n.º 19
0
 public static void mulUnsafe(Rot q, Rot r, Rot out_Renamed)
 {
     Debug.Assert(r != out_Renamed);
     Debug.Assert(q != out_Renamed);
     // [qc -qs] * [rc -rs] = [qc*rc-qs*rs -qc*rs-qs*rc]
     // [qs qc] [rs rc] [qs*rc+qc*rs -qs*rs+qc*rc]
     // s = qs * rc + qc * rs
     // c = qc * rc - qs * rs
     out_Renamed.s = q.s * r.c + q.c * r.s;
     out_Renamed.c = q.c * r.c - q.s * r.s;
 }
Ejemplo n.º 20
0
 /// <summary>
 /// Initialize using a position vector and a rotation matrix.
 /// </summary>
 public Transform(Vec2 position, Rot r)
 {
     P = position.Clone();
     Q = r.Clone();
 }
Ejemplo n.º 21
0
 public virtual Rot set_Renamed(Rot other)
 {
     s = other.s;
     c = other.c;
     return this;
 }
Ejemplo n.º 22
0
 /// <summary>The default constructor. </summary>
 public Transform()
 {
     p = new Vec2();
     q = new Rot();
 }
Ejemplo n.º 23
0
 public static void mulToOut(Rot q, Vec2 v, Vec2 out_Renamed)
 {
     float tempy = q.s * v.x + q.c * v.y;
     out_Renamed.x = q.c * v.x - q.s * v.y;
     out_Renamed.y = tempy;
 }
Ejemplo n.º 24
0
 public static void MulTrans(Rot q, Vec2 v, Vec2 result)
 {
     float tempy = (-q.Sin) * v.X + q.Cos * v.Y;
     result.X = q.Cos * v.X + q.Sin * v.Y;
     result.Y = tempy;
 }