예제 #1
0
 /// <summary>
 /// Constructs this matrix from a lmat4x2. Non-overwritten fields are from an Identity matrix.
 /// </summary>
 public lmat2(lmat4x2 m)
 {
     this.m00 = m.m00;
     this.m01 = m.m01;
     this.m10 = m.m10;
     this.m11 = m.m11;
 }
예제 #2
0
 /// <summary>
 /// Constructs this matrix from a lmat4x2. Non-overwritten fields are from an Identity matrix.
 /// </summary>
 public lmat2x3(lmat4x2 m)
 {
     this.m00 = m.m00;
     this.m01 = m.m01;
     this.m02 = 0;
     this.m10 = m.m10;
     this.m11 = m.m11;
     this.m12 = 0;
 }
예제 #3
0
 /// <summary>
 /// Constructs this matrix from a lmat4x2. Non-overwritten fields are from an Identity matrix.
 /// </summary>
 public lmat3x2(lmat4x2 m)
 {
     this.m00 = m.m00;
     this.m01 = m.m01;
     this.m10 = m.m10;
     this.m11 = m.m11;
     this.m20 = m.m20;
     this.m21 = m.m21;
 }
예제 #4
0
 /// <summary>
 /// Constructs this matrix from a lmat4x2. Non-overwritten fields are from an Identity matrix.
 /// </summary>
 public lmat3(lmat4x2 m)
 {
     this.m00 = m.m00;
     this.m01 = m.m01;
     this.m02 = 0;
     this.m10 = m.m10;
     this.m11 = m.m11;
     this.m12 = 0;
     this.m20 = m.m20;
     this.m21 = m.m21;
     this.m22 = 1;
 }
예제 #5
0
 /// <summary>
 /// Executes a component-wise - (subtract).
 /// </summary>
 public static lmat4x2 CompSub(lmat4x2 A, lmat4x2 B) => new lmat4x2(A.m00 - B.m00, A.m01 - B.m01, A.m10 - B.m10, A.m11 - B.m11, A.m20 - B.m20, A.m21 - B.m21, A.m30 - B.m30, A.m31 - B.m31);
예제 #6
0
 /// <summary>
 /// Executes a component-wise + (add).
 /// </summary>
 public static lmat4x2 CompAdd(lmat4x2 A, lmat4x2 B) => new lmat4x2(A.m00 + B.m00, A.m01 + B.m01, A.m10 + B.m10, A.m11 + B.m11, A.m20 + B.m20, A.m21 + B.m21, A.m30 + B.m30, A.m31 + B.m31);
예제 #7
0
 /// <summary>
 /// Executes a component-wise / (divide).
 /// </summary>
 public static lmat4x2 CompDiv(lmat4x2 A, lmat4x2 B) => new lmat4x2(A.m00 / B.m00, A.m01 / B.m01, A.m10 / B.m10, A.m11 / B.m11, A.m20 / B.m20, A.m21 / B.m21, A.m30 / B.m30, A.m31 / B.m31);
예제 #8
0
 /// <summary>
 /// Executes a component-wise * (multiply).
 /// </summary>
 public static lmat4x2 CompMul(lmat4x2 A, lmat4x2 B) => new lmat4x2(A.m00 * B.m00, A.m01 * B.m01, A.m10 * B.m10, A.m11 * B.m11, A.m20 * B.m20, A.m21 * B.m21, A.m30 * B.m30, A.m31 * B.m31);
예제 #9
0
 /// <summary>
 /// Returns true iff this equals rhs component-wise.
 /// </summary>
 public bool Equals(lmat4x2 rhs) => (((m00.Equals(rhs.m00) && m01.Equals(rhs.m01)) && (m10.Equals(rhs.m10) && m11.Equals(rhs.m11))) && ((m20.Equals(rhs.m20) && m21.Equals(rhs.m21)) && (m30.Equals(rhs.m30) && m31.Equals(rhs.m31))));
예제 #10
0
 /// <summary>
 /// Returns an enumerator that iterates through all fields.
 /// </summary>
 public static IEnumerator <long> GetEnumerator(lmat4x2 m) => m.GetEnumerator();
예제 #11
0
 /// <summary>
 /// Creates a 1D array with all values (internal order)
 /// </summary>
 public static long[] Values1D(lmat4x2 m) => m.Values1D;
예제 #12
0
 /// <summary>
 /// Creates a 2D array with all values (address: Values[x, y])
 /// </summary>
 public static long[,] Values(lmat4x2 m) => m.Values;