1.相关方法已经生产引用,直接调用的结果如下:
2. 相关调用代码如下:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using MathWorks.MATLAB.NET.Arrays; using MathWorks.MATLAB.NET.Utility; using MatrixCalc; namespace 矩阵运算转换测试 { class Program { static void Main(string[] args) { //生成一个double类型的矩阵,用内置的MATLAB父类MWArray方法 //第一个矩阵 Console.WriteLine("第一个矩阵");//2行2列 MWArray matrix1 = (MWNumericArray)new double[2, 2] { { 10.5, 25.6 }, { 55.4, 66.8 } }; Console.WriteLine(matrix1); //第二个矩阵 Console.WriteLine("第二个矩阵");//2行2列 MWArray matrix2 = (MWNumericArray)new double[2, 2] { { 70.5, 28.6 }, { 35.3, 63.9 } }; Console.WriteLine(matrix2); //第三个矩阵 Console.WriteLine("第三个矩阵");//3行3列 MWArray matrix3 = (MWNumericArray)new double[3, 3] { { 70.5, 28.6,77.88 }, { 35.3, 63.9,55.66 },{22.58,66.98,44.77 } }; Console.WriteLine(matrix3); //第四个向量 Console.WriteLine("第三个向量");//3行3列 MWArray array = (MWNumericArray)new double[1, 3] { { 70.5, 28.6, 77.88 }}; Console.WriteLine(array); Console.WriteLine(" "); //进行矩阵的加法运算 Console.WriteLine("第一个矩阵和第二个矩阵的加法运算结果是:"); MatrixCalc.MatrixCalc Add = new MatrixCalc.MatrixCalc(); //实例化 var AddResult = Add.AddMatrixs(matrix1,matrix2);//调用加法方法 //var AddResult = Add.AddMatrixs(matrix1, matrix3);//调用加法方法//此处报错,因为两个矩阵的维度不一样 Console.WriteLine(AddResult); Console.WriteLine(" "); //进行矩阵的加法运算 Console.WriteLine("第一个矩阵和第二个矩阵的减法运算结果是:"); MatrixCalc.MatrixCalc Sub = new MatrixCalc.MatrixCalc(); //实例化 var SubResult = Sub.SubMatrixs(matrix1, matrix2);//调用加法方法(上面一样注意矩阵维度要一致) Console.WriteLine(SubResult); Console.WriteLine(" "); //进行矩阵的乘法运算 MatrixCalc.MatrixCalc Mul = new MatrixCalc.MatrixCalc(); //实例化 var MulResult1 = Mul.MulMatrixs(matrix1, matrix2);//调用加法方法 //var MulResult2 = Mul.MulMatrixs(matrix1, matrix3);//调用加法方法 Console.WriteLine("第一个矩阵和第二个矩阵的乘法运算结果是:"); Console.WriteLine(MulResult1); //Console.WriteLine("第一个矩阵和第三个矩阵的乘法运算结果是:");//错误维度不一样 //Console.WriteLine(MulResult2); Console.WriteLine("第四个向量和第三个矩阵的乘法运算结果是:"); var MulResult3 = Mul.MulMatrixs(array, matrix3);//调用加法方法 Console.WriteLine(MulResult3); Console.WriteLine(" "); //进行矩阵的乘法运算(点乘运算) Console.WriteLine("第一个矩阵和第二个矩阵的点乘法运算结果是:"); MatrixCalc.MatrixCalc DotMul = new MatrixCalc.MatrixCalc(); //实例化 var DotMulResult = DotMul.DotMulMatrixs(matrix1, matrix2);//调用加法方法(注意矩阵维度) Console.WriteLine(DotMulResult); Console.WriteLine(" "); //进行矩阵的除法运算(正向除法) Console.WriteLine("第一个矩阵和第二个矩阵的除法运算结果是:"); MatrixCalc.MatrixCalc Div = new MatrixCalc.MatrixCalc(); //实例化 var DivResult = Div.DivMatrixs(matrix1, matrix2);//调用加法方法(注意矩阵维度) Console.WriteLine(DivResult); Console.WriteLine(" "); //进行矩阵的点除法运算(正向点除法) Console.WriteLine("第一个矩阵和第二个矩阵的点除法运算结果是:"); MatrixCalc.MatrixCalc DotDiv = new MatrixCalc.MatrixCalc(); //实例化 var DotDivResult = DotDiv.DotDivMatrixs(matrix1, matrix2);//调用加法方法(注意矩阵维度) Console.WriteLine(DotDivResult); Console.WriteLine(" "); //进行矩阵的平方法运算(第二个值是平方值,不是两个矩阵的平方运算) Console.WriteLine("第一个矩阵的平方法运算结果是:"); MatrixCalc.MatrixCalc Square = new MatrixCalc.MatrixCalc(); //实例化 var SquareResult = Square.SquareMatrixs(matrix1, 2);//调用加法方法 Console.WriteLine(SquareResult); Console.WriteLine(" "); //进行矩阵的逆矩阵运算 Console.WriteLine("第一个矩阵逆矩阵运算结果是:"); MatrixCalc.MatrixCalc Inv = new MatrixCalc.MatrixCalc(); //实例化 var InvResult = Inv.InvMatrix(matrix1);//调用加法方法(注意矩阵维度) Console.WriteLine(InvResult); Console.WriteLine(" "); //进行矩阵的转置运算 Console.WriteLine("第一个矩阵转置矩阵运算结果是:"); MatrixCalc.MatrixCalc Trans = new MatrixCalc.MatrixCalc(); //实例化 var TransResult = Trans.TransMatrix(matrix1);//调用加法方法(注意矩阵维度) Console.WriteLine(TransResult); Console.WriteLine(" "); //进行矩阵的行列式运算 Console.WriteLine("第一个矩阵行列式运算结果是:"); MatrixCalc.MatrixCalc Det= new MatrixCalc.MatrixCalc(); //实例化 var DetResult = Det.DetMatrix(matrix1);//调用加法方法 Console.WriteLine(DetResult); Console.WriteLine(" "); //进行矩阵的秩运算 Console.WriteLine("第一个矩阵秩运算结果是:"); MatrixCalc.MatrixCalc Rank = new MatrixCalc.MatrixCalc(); //实例化 var RankResult = Rank.RankMatrix(matrix1);//调用加法方法 Console.WriteLine(RankResult); Console.WriteLine(" "); //进行矩阵的特征值运算 Console.WriteLine("第一个矩阵特征值运算结果是:"); MatrixCalc.MatrixCalc Eig = new MatrixCalc.MatrixCalc(); //实例化 var EigResult = Eig.EigMatrix(matrix1);//调用加法方法 Console.WriteLine(EigResult); Console.WriteLine(" "); } } }
3. 和MATLAB运行结果一致