DoubleMatrixDivide(Double, DoubleMatrix) Method

Determines the division of a scalar by a matrix.

Definition

Namespace: Novacta.Analytics
Assembly: Novacta.Analytics (in Novacta.Analytics.dll) Version: 2.1.0+428f3840cfab98dda567bb0ed350b302533e273a
C#
public static DoubleMatrix Divide(
	double left,
	DoubleMatrix right
)

Parameters

left  Double
The left operand.
right  DoubleMatrix
The right operand.

Return Value

DoubleMatrix
The result of dividing left by right.

Remarks

Let LaTeX equation and LaTeX equation be the right number of rows and columns, respectively, and let its generic entry given by

LaTeX equation

The method returns a matrix having the same dimensions of right, whose generic entry is:

LaTeX equation

Example

In the following example, a scalar is divided by a matrix.

C#
using System;

namespace Novacta.Analytics.CodeExamples
{
    public class DivisionExample2  
    {
        public void Main()
        {
            // Create the left operand.
            double left = 10.0;
            Console.WriteLine("left =");
            Console.WriteLine(left);
            Console.WriteLine();

            // Create the right operand.
            var data = new double[6] {
                0,  20,  40,
               10,  30,  50,
            };
            var right = DoubleMatrix.Dense(2, 3, data, StorageOrder.RowMajor);
            Console.WriteLine("right =");
            Console.WriteLine(right);

            // Divide left by right.
            var result = left / right;

            Console.WriteLine();
            Console.WriteLine("left / right =");
            Console.WriteLine(result);

            // In .NET languages that do not support overloaded operators,
            // you can use the alternative methods named Divide.
            result = DoubleMatrix.Divide(left, right);

            Console.WriteLine();
            Console.WriteLine("DoubleMatrix.Divide(left, right) returns");
            Console.WriteLine();
            Console.WriteLine(result);

            // Both operators and alternative methods are overloaded to 
            // support read-only matrix arguments.
            // Compute the division using a read-only wrapper of right.
            ReadOnlyDoubleMatrix readOnlyRight = right.AsReadOnly();
            result = left / readOnlyRight;

            Console.WriteLine();
            Console.WriteLine("left / readOnlyRight =");
            Console.WriteLine(result);
        }
    }
}

// Executing method Main() produces the following output:
// 
// left =
// 10
// 
// right =
// 0                20               40               
// 10               30               50               
// 
// 
// 
// left / right =
// Infinity         0.5              0.25             
// 1                0.333333333      0.2              
// 
// 
// 
// DoubleMatrix.Divide(left, right) returns
// 
// Infinity         0.5              0.25             
// 1                0.333333333      0.2              
// 
// 
// 
// left / readOnlyRight =
// Infinity         0.5              0.25             
// 1                0.333333333      0.2              
// 
//

Exceptions

ArgumentNullExceptionright is null.

See Also