设为首页收藏本站

爱吱声

 找回密码
 注册
搜索
12
返回列表 发新帖
楼主: 雷达
打印 上一主题 下一主题

[信息技术] C++ 比 Octave 慢好多,怎么破?

[复制链接]

该用户从未签到

21#
发表于 2022-10-3 01:16:57 | 只看该作者
雷达 发表于 2022-10-2 03:04+ W' W3 ]$ E" F6 R9 B
多谢关注。
! {4 F) M+ K) I/ k6 `, H规模还比较大,一个至少3万*3万的二维浮点复数矩阵,用一个4000点复数矢量对矩阵的每一个3万 ...
/ P; ~7 |. J/ H, P5 K
你在 Octave 跑出来的速度是多少?没有具体数据的话能不能说一下数量级上大致在哪里?
* g' k/ _$ @: b5 f, Z% C2 C% f& j* [3 f5 x4 ~' c2 F
另外,你在 Octave 上的测试是按实际数据量跑的吗?我大概估计了一下,如果我没有算错,你那个二维浮点复数矩阵的数据量大约240TB(1 billion elements, each element has 30000x8 bytes)。这么大的数据量不可能全都放进内存中准备好,(事实上,它们已经不是一块硬盘可以装得下的了,放在磁盘阵列上吗?)有可能计算机的I/O吞吐性能也成为影响真正计算速度的一个重要因素。
回复 支持 反对

使用道具 举报

  • TA的每日心情

    2025-9-22 22:19
  • 签到天数: 1183 天

    [LV.10]大乘

    22#
     楼主| 发表于 2022-10-3 09:13:33 | 只看该作者
    本帖最后由 雷达 于 2022-10-3 09:16 编辑
    + ^/ p/ E9 O1 i* z
    沉宝 发表于 2022-10-3 01:16
    & ]6 m" @" ]! E  S" G" O2 N2 i你在 Octave 跑出来的速度是多少?没有具体数据的话能不能说一下数量级上大致在哪里?9 v, d7 |3 z# x; J" [; C

    ) M1 h* ?2 z9 _1 Z6 u& F: ~另外,你在 Octav ...
    8 B0 _. `9 K2 e, T, P
    & J. c1 k* Z! K" ~/ U3 n
    应该没有那么大。2 K9 ?* d. k( \" M/ @: _
    我算的:
    2 Z% @8 r7 U: J) V7 p) G  e$ d4 j- u3万*3万的二维浮点复数矩阵, 30k*30k = 900M个点, 复数 *2, 浮点数 *4,总共 7.2G。1 v  A: \3 i# f& w6 O' @, Z
    做算法的时候,一行一行从文件读取,有个16G内存应该足够了
    回复 支持 反对

    使用道具 举报

    手机版|小黑屋|Archiver|网站错误报告|爱吱声   

    GMT+8, 2026-5-17 23:15 , Processed in 0.051710 second(s), 16 queries , Gzip On.

    Powered by Discuz! X3.2

    © 2001-2013 Comsenz Inc.

    快速回复 返回顶部 返回列表