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