c# 画正态分布图

  /// <summary>
    /// 提供正态分布的数据和图片
    /// </summary>
    public class StandardDistribution
    {

       
        /// <summary>
        /// 样本数据
        /// </summary>
        public List<double> Xs { get; private set; }

        public StandardDistribution(List<double> Xs)
        {
            this.Xs = Xs;

            Average = Xs.Average();
            Variance = GetVariance(Xs);

            if (Variance == 0) throw new Exception("方差为0");//此时不需要统计 因为每个样本数据都相同,可以在界面做相应提示

            StandardVariance = Math.Sqrt(Variance);
        }

        /// <summary>
        /// 方差/标准方差的平方
        /// </summary>
        public double Variance { get; private set; }

        /// <summary>
        /// 标准方差
        /// </summary>
        public double StandardVariance { get; private set; }

        /// <summary>
        /// 算数平均值/数学期望
        /// </summary>
        public double Average { get; private set; }

        /// <summary>
        /// 1/ (2π的平方根)的值
        /// </summary>
        public static double InverseSqrt2PI = 1 / Math.Sqrt(2 * Math.PI);

        /// <summary>
        /// 获取指定X值的Y值  计算正太分布的公式
        /// </summary>
        /// <param name="x"></param>
        /// <returns></returns>
        public double GetGaussianDistributionY(double x)
        {
            double PowOfE = -(Math.Pow(Math.Abs(x - Average), 2) / (2 * Variance));

            double result = (StandardDistribution.InverseSqrt2PI / StandardVariance) * Math.Pow(Math.E, PowOfE);

            return result;
        }

        /// <summary>
        /// 获取正太分布的坐标<x,y>
        /// </summary>
        /// <returns></returns>
        public List<Tuple<double, double>> GetGaussianDistributionYs()
        {
            List
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# 中,要绘制正态分布(也称为 CPK ),你可以使用一些第三方库来帮助你完成任务,例如 MathNet.Numerics 和 ZedGraph。 首先,你需要确保你的项目中已经安装了 MathNet.Numerics 和 ZedGraph 库。你可以使用 NuGet 程序包管理器来安装这些库。 下面是一个简单的示例代码,用于绘制一个 CPK 正态分布: ```csharp using System; using System.Collections.Generic; using MathNet.Numerics.Distributions; using ZedGraph; namespace CPKDistribution { class Program { static void Main(string[] args) { // 创建一个 ZedGraph 控件 GraphPane graphPane = new GraphPane(); graphPane.Title.Text = "CPK Distribution"; graphPane.XAxis.Title.Text = "X"; graphPane.YAxis.Title.Text = "Probability Density"; // 创建一个正态分布对象 Normal normalDistribution = new Normal(0, 1); // 计算并绘制数据点 PointPairList dataPoints = new PointPairList(); for (double x = -3; x <= 3; x += 0.1) { double y = normalDistribution.Density(x); dataPoints.Add(x, y); } // 添加数据点到表 LineItem lineItem = graphPane.AddCurve("CPK Distribution", dataPoints, System.Drawing.Color.Blue, SymbolType.None); // 创建一个窗口并显示表 using (var form = new ZedGraphForm(graphPane)) { form.ShowDialog(); } } } } ``` 这段代码通过 MathNet.Numerics 库创建了一个正态分布对象,然后计算并绘制了一系列数据点。然后使用 ZedGraph 库创建一个表,并将数据点添加到表中,最后显示表。 请注意,这只是一个简单的示例,你可以根据你的需求进行修改和扩展。希望能对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值