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("\n"); //进行矩阵的加法运算
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("\n"); //进行矩阵的加法运算
Console.WriteLine("第一个矩阵和第二个矩阵的减法运算结果是:");
MatrixCalc.MatrixCalc Sub = new MatrixCalc.MatrixCalc(); //实例化
var SubResult = Sub.SubMatrixs(matrix1, matrix2);//调用加法方法(上面一样注意矩阵维度要一致)
Console.WriteLine(SubResult);
Console.WriteLine("\n"); //进行矩阵的乘法运算
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("\n"); //进行矩阵的乘法运算(点乘运算)
Console.WriteLine("第一个矩阵和第二个矩阵的点乘法运算结果是:");
MatrixCalc.MatrixCalc DotMul = new MatrixCalc.MatrixCalc(); //实例化
var DotMulResult = DotMul.DotMulMatrixs(matrix1, matrix2);//调用加法方法(注意矩阵维度)
Console.WriteLine(DotMulResult);
Console.WriteLine("\n"); //进行矩阵的除法运算(正向除法)
Console.WriteLine("第一个矩阵和第二个矩阵的除法运算结果是:");
MatrixCalc.MatrixCalc Div = new MatrixCalc.MatrixCalc(); //实例化
var DivResult = Div.DivMatrixs(matrix1, matrix2);//调用加法方法(注意矩阵维度)
Console.WriteLine(DivResult);
Console.WriteLine("\n"); //进行矩阵的点除法运算(正向点除法)
Console.WriteLine("第一个矩阵和第二个矩阵的点除法运算结果是:");
MatrixCalc.MatrixCalc DotDiv = new MatrixCalc.MatrixCalc(); //实例化
var DotDivResult = DotDiv.DotDivMatrixs(matrix1, matrix2);//调用加法方法(注意矩阵维度)
Console.WriteLine(DotDivResult);
Console.WriteLine("\n"); //进行矩阵的平方法运算(第二个值是平方值,不是两个矩阵的平方运算)
Console.WriteLine("第一个矩阵的平方法运算结果是:");
MatrixCalc.MatrixCalc Square = new MatrixCalc.MatrixCalc(); //实例化
var SquareResult = Square.SquareMatrixs(matrix1, 2);//调用加法方法
Console.WriteLine(SquareResult);
Console.WriteLine("\n"); //进行矩阵的逆矩阵运算
Console.WriteLine("第一个矩阵逆矩阵运算结果是:");
MatrixCalc.MatrixCalc Inv = new MatrixCalc.MatrixCalc(); //实例化
var InvResult = Inv.InvMatrix(matrix1);//调用加法方法(注意矩阵维度)
Console.WriteLine(InvResult);
Console.WriteLine("\n"); //进行矩阵的转置运算
Console.WriteLine("第一个矩阵转置矩阵运算结果是:");
MatrixCalc.MatrixCalc Trans = new MatrixCalc.MatrixCalc(); //实例化
var TransResult = Trans.TransMatrix(matrix1);//调用加法方法(注意矩阵维度)
Console.WriteLine(TransResult);
Console.WriteLine("\n"); //进行矩阵的行列式运算
Console.WriteLine("第一个矩阵行列式运算结果是:");
MatrixCalc.MatrixCalc Det= new MatrixCalc.MatrixCalc(); //实例化
var DetResult = Det.DetMatrix(matrix1);//调用加法方法
Console.WriteLine(DetResult);
Console.WriteLine("\n"); //进行矩阵的秩运算
Console.WriteLine("第一个矩阵秩运算结果是:");
MatrixCalc.MatrixCalc Rank = new MatrixCalc.MatrixCalc(); //实例化
var RankResult = Rank.RankMatrix(matrix1);//调用加法方法
Console.WriteLine(RankResult);
Console.WriteLine("\n"); //进行矩阵的特征值运算
Console.WriteLine("第一个矩阵特征值运算结果是:");
MatrixCalc.MatrixCalc Eig = new MatrixCalc.MatrixCalc(); //实例化
var EigResult = Eig.EigMatrix(matrix1);//调用加法方法
Console.WriteLine(EigResult);
Console.WriteLine("\n"); } }
}

3. 和MATLAB运行结果一致  

Matlab高级教程_第二篇:MATLAB和C#一些常用的矩阵运算方法的转换的更多相关文章

  1. Matlab高级教程_第二篇:MATLAB和C#对应数据类型的讲解(多讲一点儿C#的矩阵运算)

    1. MATLAB对应C#的数据类型主要在引入的父类库MWArray当中.有如下对应规则 .NET TYPE MWArrayTYPE MATLAB Type System.Double MWNumer ...

  2. Matlab高级教程_第二篇:一个简单的混编例子

    1. 常用的混编是MATLAB和VS两个编辑器之间的混编方式. 2. 因为MATLAB的核是C型语言,因此常见的混编方式是MATLAB和C型语言的混编. 3. 这里介绍一个简单的MATLAB语言混编成 ...

  3. Matlab高级教程_第二篇:Matlab相见恨晚的模块_02_并行运算-2

    1 MATLAB并行计算-从个人桌面到远程集群和云(陈伟/魏奋)视频摘录笔记 https://cn.mathworks.com/videos/parallel-computing-with-matla ...

  4. Matlab高级教程_第二篇:Matlab相见恨晚的模块_02_并行运算-1

    1 更高级的算法牵扯到更多重的循环和复杂的计算,尤其是现在人工智能的算法尤其如此.有些历史知识的人能够了解到,人工智能的很多基本算法其实近百年之前就有了,但是当时的计算机技术达不到去实现这些算法的要求 ...

  5. Matlab高级教程_第二篇:关于MATLAB转C#过程中遇到输出两组参数的问题

    1. 在matlab的m函数很可能遇到原函数[a,b] = func(a); 这样的两个输出参数. 2. 在观察C#生成后定义中我们发现: public MWArray HP(); public MW ...

  6. Matlab高级教程_第二篇:Matlab相见恨晚的模块_01_定时器

    MATLAB的定时器功能(timer函数): 1 从MATLAB6.5版本开始,MATLAB开始支持定时器.相对于传统的pause函数来说,定时器要强大的多,不仅可以等效实现pause的功能,还可以显 ...

  7. Matlab高级教程_第二篇:Matlab相见恨晚的模块_02_并行运算-关于parfor的问题

    1 我们知道MATLAB支持并行运行一般有四种模式: 第一种模式:本机调用多核CPU性能并行运算 第二种模式:本机调用GPU性能并行运算 第三种模式:多计算机组成集群,调用集群CPU性能并行运算 第四 ...

  8. Matlab高级教程_第二篇:关于MATLAB转C#过程中MWArray到C#数组,C#数组到MWArray相互转换

    Matlab传递数据时使用的方法,那么Matlab计算完成后在C#中应该怎么获取它的计算数据呢? 需要遵循两个基本步骤: 弄清楚Matlab函数传回的数据到底是什么格式?struct?cell?cha ...

  9. Matlab高级教程_第二篇:Matlab2016a和VS2013混合

    1. 首先把VS2017的XML两个配置文件放到 2. 然后一步一步的进行选择: 3. 2016版本的deploytool工具已经改版了,具体详细使用如下 4. 编写一个测试函数 我们编译成C#语言的 ...

随机推荐

  1. CMD命令实现数字雨

    首先,我们在桌面上先创建一个“.bat”格式的文件,文件名为“数字雨.bat”,创建好了之后右键点击编辑. 在其中输入: @echo off title 数字雨 color 0a setlocal E ...

  2. 寒假day25

    今天解决了部分数据爬取不下来的问题,同时进行了面试的准备

  3. Python调用c++可执行程序

    1.c++编译程序 #include <iostream> using namespace std; int test() { , b = ; return a+b; } int main ...

  4. Linux 下 OpenCV3 安装

    编译安装OpenCV3 从官网下载:http://opencv.org/releases.html 选择一个较新版本的opencv3.X,下载source源代码 下载之后解压,并cd到该文件夹进行编译 ...

  5. HDU 5428:The Factor

    The Factor  Accepts: 101  Submissions: 811  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: 65 ...

  6. Adobe PhotoShop CS6中文破解版下载

    在网上找了好多个PhotoShop破解版,但安装过程中都出现一些问题,用不了.现在找到一个比较小的PhotoShop CS6安装包,大小200M左右,下载解压,点击安装就可以使用了,安装过程十分简单. ...

  7. Bugku 逆向

    1.入门逆向 下载解压,在文件夹中打开命令行窗口执行一下:baby.exe 发现输出了一串字符,在将其放到IDA中然后是这样: 发现上面有一串输出和我们命令行窗口中的一样,但是下面为什么又多了一大溜东 ...

  8. 吴裕雄--天生自然MySQL学习笔记:MySQL 元数据

    你可能想知道MySQL以下三种信息: 查询结果信息: SELECT, UPDATE 或 DELETE语句影响的记录数. 数据库和数据表的信息: 包含了数据库及数据表的结构信息. MySQL服务器信息: ...

  9. java 单利模式设计原理,饿汉式懒汉式,开发中推荐饿汉式

    单例模式的设计:  1 //Single类进内存,对象还没有存在,只有调用了getInstance方法时,才建立对象. //对象是方法被调用时,才初始化,也叫做对象的延时加载.成为:懒汉式. //Si ...

  10. iOS中copy和=的区别

    copy是浅拷贝即指针拷贝,让对象的引用计数加一 在MRC环境下,=只是简单的指针指向,引用对象的引用计数并不会增加,在用局部变量赋值时很容易出现野指针 在ARC环境下,=的效果等同于copy和ret ...