/// <summary> /// Constructs this matrix from a dmat2x4. Non-overwritten fields are from an Identity matrix. /// </summary> public dmat2(dmat2x4 m) { this.m00 = m.m00; this.m01 = m.m01; this.m10 = m.m10; this.m11 = m.m11; }
/// <summary> /// Constructs this matrix from a dmat2x4. Non-overwritten fields are from an Identity matrix. /// </summary> public dmat2x3(dmat2x4 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; }
/// <summary> /// Constructs this matrix from a dmat2x4. Non-overwritten fields are from an Identity matrix. /// </summary> public dmat3x2(dmat2x4 m) { this.m00 = m.m00; this.m01 = m.m01; this.m10 = m.m10; this.m11 = m.m11; this.m20 = 0.0; this.m21 = 0.0; }
/// <summary> /// Constructs this matrix from a dmat2x4. Non-overwritten fields are from an Identity matrix. /// </summary> public dmat2x4(dmat2x4 m) { this.m00 = m.m00; this.m01 = m.m01; this.m02 = m.m02; this.m03 = m.m03; this.m10 = m.m10; this.m11 = m.m11; this.m12 = m.m12; this.m13 = m.m13; }
/// <summary> /// Constructs this matrix from a dmat2x4. Non-overwritten fields are from an Identity matrix. /// </summary> public dmat3(dmat2x4 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 = 0.0; this.m21 = 0.0; this.m22 = 1.0; }
/// <summary> /// Constructs this matrix from a dmat2x4. Non-overwritten fields are from an Identity matrix. /// </summary> public dmat3x4(dmat2x4 m) { this.m00 = m.m00; this.m01 = m.m01; this.m02 = m.m02; this.m03 = m.m03; this.m10 = m.m10; this.m11 = m.m11; this.m12 = m.m12; this.m13 = m.m13; this.m20 = 0.0; this.m21 = 0.0; this.m22 = 1.0; this.m23 = 0.0; }
/// <summary> /// Executes a component-wise - (subtract). /// </summary> public static dmat2x4 CompSub(dmat2x4 A, dmat2x4 B) => new dmat2x4(A.m00 - B.m00, A.m01 - B.m01, A.m02 - B.m02, A.m03 - B.m03, A.m10 - B.m10, A.m11 - B.m11, A.m12 - B.m12, A.m13 - B.m13);
/// <summary> /// Executes a component-wise + (add). /// </summary> public static dmat2x4 CompAdd(dmat2x4 A, dmat2x4 B) => new dmat2x4(A.m00 + B.m00, A.m01 + B.m01, A.m02 + B.m02, A.m03 + B.m03, A.m10 + B.m10, A.m11 + B.m11, A.m12 + B.m12, A.m13 + B.m13);
/// <summary> /// Executes a component-wise / (divide). /// </summary> public static dmat2x4 CompDiv(dmat2x4 A, dmat2x4 B) => new dmat2x4(A.m00 / B.m00, A.m01 / B.m01, A.m02 / B.m02, A.m03 / B.m03, A.m10 / B.m10, A.m11 / B.m11, A.m12 / B.m12, A.m13 / B.m13);
/// <summary> /// Executes a component-wise * (multiply). /// </summary> public static dmat2x4 CompMul(dmat2x4 A, dmat2x4 B) => new dmat2x4(A.m00 * B.m00, A.m01 * B.m01, A.m02 * B.m02, A.m03 * B.m03, A.m10 * B.m10, A.m11 * B.m11, A.m12 * B.m12, A.m13 * B.m13);
/// <summary> /// Returns true iff this equals rhs component-wise. /// </summary> public bool Equals(dmat2x4 rhs) => (((m00.Equals(rhs.m00) && m01.Equals(rhs.m01)) && (m02.Equals(rhs.m02) && m03.Equals(rhs.m03))) && ((m10.Equals(rhs.m10) && m11.Equals(rhs.m11)) && (m12.Equals(rhs.m12) && m13.Equals(rhs.m13))));
/// <summary> /// Returns an enumerator that iterates through all fields. /// </summary> public static IEnumerator <double> GetEnumerator(dmat2x4 m) => m.GetEnumerator();
/// <summary> /// Creates a 1D array with all values (internal order) /// </summary> public static double[] Values1D(dmat2x4 m) => m.Values1D;
/// <summary> /// Creates a 2D array with all values (address: Values[x, y]) /// </summary> public static double[,] Values(dmat2x4 m) => m.Values;