首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将matrix<double>转换为Matrix<float>?

如何将matrix<double>转换为Matrix<float>?
EN

Stack Overflow用户
提问于 2015-05-12 15:24:48
回答 2查看 1.4K关注 0票数 4

我想计算一下:Matrix<float> * Matrix<double>

Matrix<float>大约有6M*3元素,如何将Matrix<double>转换为Matrix<float>,以便获得Matrix<float>结果。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-05-12 16:28:01

可以使用Map函数将双矩阵参数转换为浮动矩阵:

代码语言:javascript
复制
Matrix<double> m1 = Matrix<double>.Build.Random(6000000,3);
Matrix<float> m2 = m1.Map(x => (float)x);

或者另一种

代码语言:javascript
复制
Matrix<float> m2 = m1.Map(Convert.ToSingle);
票数 3
EN

Stack Overflow用户

发布于 2015-05-12 15:29:26

下面是如何将双数组转换为浮点数数组,然后只需将矩阵转换为数组,反之亦然

代码语言:javascript
复制
public static float[][] Convert(double[][] mtx)
{
    var floatMtx = new float[mtx.Length][];
    for (int i = 0; i < mtx.Length; i++)
    {
        floatMtx[i] = new float[mtx[i].Length];
        for (int j = 0; j < mtx[i].Length; j++)
            floatMtx[i][j] = (float)mtx[i][j];
    }
    return floatMtx;
}
Or:

public static float[][] Convert(double[][] mtx)
{
    return mtx.Select(i => i.Select(j => (float)j).ToArray()).ToArray();
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30195260

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档