public static ComplexMatrix ElementWiseMultiply(
ComplexMatrix left,
ComplexMatrix right
)
Public Shared Function ElementWiseMultiply (
left As ComplexMatrix,
right As ComplexMatrix
) As ComplexMatrix
public:
static ComplexMatrix^ ElementWiseMultiply(
ComplexMatrix^ left,
ComplexMatrix^ right
)
static member ElementWiseMultiply :
left : ComplexMatrix *
right : ComplexMatrix -> ComplexMatrix
Let and
be the left
number of rows and columns, respectively, and consider its generic entry
Analogously, Let and
be the right
number of rows and columns, respectively, and let its generic entry given by
The method returns a matrix
whose generic entry is
provided that the dimensions of left agree
with those of right; otherwise, an exception
is thrown.
In the following example, some matrices are element wise multiplied.
using System;
using System.Numerics;
namespace Novacta.Analytics.CodeExamples
{
public class ComplexElementWiseMultiplyExample0
{
public void Main()
{
// Create the left operand.
var data = new Complex[6] {
new(1, -1), new(5, -5),
new(2, -2), new(6, -6),
new(3, -3), new(7, -7)
};
var left = ComplexMatrix.Dense(3, 2, data, StorageOrder.RowMajor);
Console.WriteLine("left =");
Console.WriteLine(left);
// Create the right operand.
data = [
new(-1, 1), new(-5, 5),
new(-2, 2), new(-6, 6),
new(-3, 3), new(-7, 7)
];
var right = ComplexMatrix.Dense(3, 2, data, StorageOrder.RowMajor);
Console.WriteLine("right =");
Console.WriteLine(right);
// Element wise multiply left by right.
var result = ComplexMatrix.ElementWiseMultiply(left, right);
Console.WriteLine();
Console.WriteLine("Element wise multiplication: left * right =");
Console.WriteLine(result);
// Class ReadOnlyComplexMatrix supports element wise multiplications
// where some arguments are read-only matrices.
// Compute the product using a read-only wrapper of left.
ReadOnlyComplexMatrix readOnlyLeft = left.AsReadOnly();
result = ReadOnlyComplexMatrix.ElementWiseMultiply(readOnlyLeft, right);
Console.WriteLine();
Console.WriteLine("Element wise multiplication: readOnlyLeft * right =");
Console.WriteLine(result);
}
}
}
// Executing method Main() produces the following output:
//
// left =
// ( 1, -1) ( 5, -5)
// ( 2, -2) ( 6, -6)
// ( 3, -3) ( 7, -7)
//
//
// right =
// ( -1, 1) ( -5, 5)
// ( -2, 2) ( -6, 6)
// ( -3, 3) ( -7, 7)
//
//
//
// Element wise multiplication: left * right =
// ( 0, 2) ( 0, 50)
// ( 0, 8) ( 0, 72)
// ( 0, 18) ( 0, 98)
//
//
//
// Element wise multiplication: readOnlyLeft * right =
// ( 0, 2) ( 0, 50)
// ( 0, 8) ( 0, 72)
// ( 0, 18) ( 0, 98)
//
//
ArgumentNullException | left is null. -or- right is null. |
ArgumentException | left and right have not the same number of rows and columns. |