V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
northisland
V2EX  ›  问与答

请问, float32 和 int 普通运算计算速度差不多么?

  •  
  •   northisland · 2015-10-16 12:30:33 +08:00 · 2525 次点击
    这是一个创建于 3359 天前的主题,其中的信息可能已经有所发展或是发生改变。
    楼主很懒没有研究过,也没测试。

    以前在学校觉得浮点数计算方法略麻烦,在某些精简指令集(把浮点数指令简化了=_=我在瞎猜)的 CPU 上,可能会慢。
    把我的瞎猜实例化,就像int1+int2可能花1个处理器周期,但float1+float2可能就花>1个处理器周期。

    但事实上是不是这样呢?当然楼主说的肯定是PC处理器,撑死讨论一下ARM。


    请和我探讨一下,验证一下,多谢
    1 条回复    2015-10-16 13:23:19 +08:00
    msg7086
        1
    msg7086  
       2015-10-16 13:23:19 +08:00   ❤️ 1
    https://software.intel.com/sites/landingpage/IntrinsicsGuide/#techs=AVX,AVX2&cats=Arithmetic&expand=73,112

    就拿现在主流的 AVX 系指令集来说。

    32 位整数相加 __m256i _mm256_add_epi32 (__m256i a, __m256i b)
    Architecture Latency Throughput
    Haswell 1 0.5

    32 位浮点相加 __m256 _mm256_add_ps (__m256 a, __m256 b)
    Architecture Latency Throughput
    Haswell 3 1

    延迟是 3 倍,吞吐量占用是 2 倍。(吞吐量占用是越小越快)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1346 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 17:35 · PVG 01:35 · LAX 09:35 · JFK 12:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.