page contents

关于C#:使用Math.Net计算一些统计分布信息

本文讲述了关于C#:使用Math.Net计算一些统计分布信息!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

attachments-2022-11-f4k6pNOj637c299dcd48f.jpg本文讲述了关于C#:使用Math.Net计算一些统计分布信息!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

我将一些结果存储在多维数组中:

1
double[,] results;

每列都是特定变量(例如"房屋","汽车","电力")的价格的时间序列。我想为每个变量计算一些统计信息,以便以更紧凑的形式总结结果。
例如,我正在研究Math.Net中的百分位函数。

我想计算每列价格的第90个百分位数(因此,对于每个变量)。

我正在尝试以下操作,因为该函数不适用于多维数组(因此我无法将result [,]作为百分位数函数的参数传递):

1
2
3
4
for (int i = 0, i <= results.GetLength(2), i++)
{
    myList.Add(MathNet.Numerics.Statistics.Statistics.Percentile(results[,i]90));
}

因此,我想遍历result [,]的列并计算第90个百分位数,然后将结果添加到列表中。
但是,由于result [,i]语法错误,因此无法使用。不幸的是,没有其他(更清晰的)错误消息。

您能否帮助我了解问题出在哪里,以及是否有更好的方法来按列计算百分位数?

百分位数是具有以下调用序列的扩展方法:

1
public static double Percentile(this IEnumerable<double> data, int p)

因此,您可以使用Linq将2d数组转换为适当的序列以传递给Percentile。

但是,results.GetLength(2)将引发异常,因为GetLength()的维度参数是从零开始的。 您可能是说results.GetLength(1)。 假设这就是您的意思,则可以执行以下操作:

1
2
3
4
        var query = Enumerable.Range(0, results.GetLength(1))
            .Select(iCol => Enumerable.Range(0, results.GetLength(0))
                .Select(iRow => results[iRow, iCol])
                .Percentile(90));

您可以让Linq为您列出清单,

1
        var myList= query.ToList();

或将其添加到预先存在的列表中:

1
        myList.AddRange(query);

更新

要过滤NaN值,请使用double.IsNaN:

1
2
3
4
5
        var query = Enumerable.Range(0, results.GetLength(1))
            .Select(iCol => Enumerable.Range(0, results.GetLength(0))
                .Select(iRow => results[iRow, iCol])
                .Where(=> !double.IsNaN(d))
                .Percentile(90));

更新

如果提取几个数组扩展名:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public static class ArrayExtensions
{
    public static IEnumerable<IEnumerable< T >> Columns< T >(this T[,] array)
    {
        if (array == null)
            throw new ArgumentNullException();
        return Enumerable.Range(0, array.GetLength(1))
            .Select(iCol => Enumerable.Range(0, array.GetLength(0))
                .Select(iRow => array[iRow, iCol]));
    }

    public static IEnumerable<IEnumerable< T >> Rows< T >(this T[,] array)
    {
        if (array == null)
            throw new ArgumentNullException();
        return Enumerable.Range(0, array.GetLength(0))
            .Select(iRow => Enumerable.Range(0, array.GetLength(1))
                .Select(iCol => array[iRow, iCol]));
    }
}

查询变为:

1
        var query = results.Columns().Select(col => col.Where(=> !double.IsNaN(d)).Percentile(90));

这似乎更加清楚。

更多相关技术内容咨询欢迎前往并持续关注六星社区了解详情。

想高效系统的学习Python编程语言,推荐大家关注一个微信公众号:Python编程学习圈。每天分享行业资讯、技术干货供大家阅读,关注即可免费领取整套Python入门到进阶的学习资料以及教程,感兴趣的小伙伴赶紧行动起来吧。

attachments-2022-05-rLS4AIF8628ee5f3b7e12.jpg

  • 发表于 2022-11-22 09:45
  • 阅读 ( 541 )
  • 分类:C/C++开发

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
王昭君
王昭君

209 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. 小柒 1470 文章
  3. Pack 1135 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章