Matlab高级教程_第二篇:MATLAB和C#一些常用的矩阵运算方法的转换
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#一些常用的矩阵运算方法的转换的更多相关文章
- Matlab高级教程_第二篇:MATLAB和C#对应数据类型的讲解(多讲一点儿C#的矩阵运算)
1. MATLAB对应C#的数据类型主要在引入的父类库MWArray当中.有如下对应规则 .NET TYPE MWArrayTYPE MATLAB Type System.Double MWNumer ...
- Matlab高级教程_第二篇:一个简单的混编例子
1. 常用的混编是MATLAB和VS两个编辑器之间的混编方式. 2. 因为MATLAB的核是C型语言,因此常见的混编方式是MATLAB和C型语言的混编. 3. 这里介绍一个简单的MATLAB语言混编成 ...
- Matlab高级教程_第二篇:Matlab相见恨晚的模块_02_并行运算-2
1 MATLAB并行计算-从个人桌面到远程集群和云(陈伟/魏奋)视频摘录笔记 https://cn.mathworks.com/videos/parallel-computing-with-matla ...
- Matlab高级教程_第二篇:Matlab相见恨晚的模块_02_并行运算-1
1 更高级的算法牵扯到更多重的循环和复杂的计算,尤其是现在人工智能的算法尤其如此.有些历史知识的人能够了解到,人工智能的很多基本算法其实近百年之前就有了,但是当时的计算机技术达不到去实现这些算法的要求 ...
- Matlab高级教程_第二篇:关于MATLAB转C#过程中遇到输出两组参数的问题
1. 在matlab的m函数很可能遇到原函数[a,b] = func(a); 这样的两个输出参数. 2. 在观察C#生成后定义中我们发现: public MWArray HP(); public MW ...
- Matlab高级教程_第二篇:Matlab相见恨晚的模块_01_定时器
MATLAB的定时器功能(timer函数): 1 从MATLAB6.5版本开始,MATLAB开始支持定时器.相对于传统的pause函数来说,定时器要强大的多,不仅可以等效实现pause的功能,还可以显 ...
- Matlab高级教程_第二篇:Matlab相见恨晚的模块_02_并行运算-关于parfor的问题
1 我们知道MATLAB支持并行运行一般有四种模式: 第一种模式:本机调用多核CPU性能并行运算 第二种模式:本机调用GPU性能并行运算 第三种模式:多计算机组成集群,调用集群CPU性能并行运算 第四 ...
- Matlab高级教程_第二篇:关于MATLAB转C#过程中MWArray到C#数组,C#数组到MWArray相互转换
Matlab传递数据时使用的方法,那么Matlab计算完成后在C#中应该怎么获取它的计算数据呢? 需要遵循两个基本步骤: 弄清楚Matlab函数传回的数据到底是什么格式?struct?cell?cha ...
- Matlab高级教程_第二篇:Matlab2016a和VS2013混合
1. 首先把VS2017的XML两个配置文件放到 2. 然后一步一步的进行选择: 3. 2016版本的deploytool工具已经改版了,具体详细使用如下 4. 编写一个测试函数 我们编译成C#语言的 ...
随机推荐
- UVALive 5913 字典树
先输入n个字符串的字典,每个字符串的前缀+后缀可以组成新的合法字符串,但肯定是有重复的,问从给定的字符串,生成的所有可能的字符串为多少个 把前缀和后缀压入字典树,达到前缀和后缀的去重,首先的总和即为前 ...
- Android自定义View——刮刮卡效果
想要红包的实现效果的可以关注我的博客,仿饿了么红包 下层图片:我们的红包的图片 上层图片:有两部分 一部分是灰色背景 一部分是拥有透明度为0,并且模式为交集的画笔 使用滑动监听,滑动时,用透明度为0的 ...
- 学生信息的添加 Java web简单项目初试(失败)
题目要求: 1登录账号:要求由6到12位字母.数字.下划线组成,只有字母可以开头:(1分) 2登录密码:要求显示“• ”或“*”表示输入位数,密码要求八位以上字母.数字组成.(1分) 3性别:要求用单 ...
- 2014_csu选拔1_B
Description Here is no naked girl nor naked runners, but a naked problem: you are to find the K-th s ...
- 设计模式讲解4:Bridge模式源码
声明:迁移自本人CSDN博客https://blog.csdn.net/u013365635 桥接模式可以和排列组合关联起来理解,一个对象有多种不通种类的属性,如attributeA1,attribu ...
- 201703-1 分蛋糕 Java
思路: 注意最后如果剩余蛋糕的重量小于k,也算一个人分到 import java.util.Scanner; public class Main { public static void main(S ...
- Python中使用print打印进度条
import time for i in range(0,101,2): time.sleep(0.1) char_num = i//2 #打印多少个'*' per_str = '\r%s%% : % ...
- Vue专题-路由系统
一切分离都是为了更好的结合,本文详细介绍了前后端分离架构之后,前端如果实现路由控制,即Vue路由系统. Vue路由系统 VueRouter实现原理 VueRouter的实现原理是根据监控锚点值的改变, ...
- 【PS学习成果】手持雷电
结合网上的教程和素材,试试水. 备注申明:图片和教程 均来自网络PS家园网(www.psjia.com),如有侵权,请联系本人,马上删除.
- 如何修改Jquery Mobile 设置默认选项
以下的默认配置可以通过$.mobile对象重新配置自定义命名空间s (字符, 默认: ""): 在jQuery Mobile中,甚至可以自定义象HTML5中的data-attrib ...