Math.Net Hello,World

本文介绍如何使用Math.NET Numerics库解决线性方程组问题,并提供了具体的C#代码示例,展示了如何建立系数矩阵及右侧向量,并通过Math.NET库求解方程组。

Math.Net DotNet阵营中的开源Math库,官网为www.mathdotnet.com。

高数、线代等知识已经忘得差不多了,MathNet的相关中文资料好像也不多,真有点费力气。

VS中使用Math.Net 可以直接用Nuget添加MathNet.Numerics。

下面测试一个最简单的线性方程组:

1.建立左侧的系数矩阵
1  1
1 -1

var ma = DenseMatrix.OfArray(new double[,] {{1, 1}, {1, -1}});

2.建立右侧的矩阵或向量

var va = Vector<double>.Build.DenseOfArray(new double[] {3,1});//向量
var mb = DenseMatrix.OfArray(new double[,] {{3}, {1}});//矩阵

3.求解

//var mx = ma.Solve(va);
var mx = ma.Solve(mb);

源代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using MathNet.Numerics.LinearAlgebra;
using MathNet.Numerics.LinearAlgebra.Double;

namespace ConsoleDemo
{
    class Program
    {
        static void Main(string[] args)
        {
            /*
            var ma = DenseMatrix.OfArray(new double[,] {{1, 1}, {1, -1}});
            var va = Vector<double>.Build.DenseOfArray(new double[] {3,1});
            var mx = ma.Solve(va);
            Console.WriteLine(mx.ToString());
            Console.ReadLine();
            */
            var ma = DenseMatrix.OfArray(new double[,] { { 1, 1 }, { 1, -1 } });
            var mb = DenseMatrix.OfArray(new double[,] {{3}, {1}});
            var mx = ma.Solve(mb);
            Console.WriteLine(mx.ToString());
            Console.ReadLine();
        }
    }
}

转载于:https://my.oschina.net/fdstudio/blog/872734

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值