在使用Golang代码时,数学计算速度慢
来源:stackoverflow
时间:2024-02-06 22:26:40 259浏览 收藏
在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是Golang学习者,那么本文《在使用Golang代码时,数学计算速度慢》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!
问题内容问题:使用 math 包中的代码比使用 math 包慢得多。
下面的代码是从数学模块复制的,但是 math.Sqrt 的执行速度比 sqrt 快得多。我的问题是:为什么,可以做什么?
示例:(注意,感兴趣的函数不是 math.Sqrt。我想编写函数组合的自定义版本。)
package main
import (
"fmt"
"math"
"unsafe"
)
const (
uvnan = 0x7FF8000000000001
uvinf = 0x7FF0000000000000
uvneginf = 0xFFF0000000000000
uvone = 0x3FF0000000000000
mask = 0x7FF
shift = 64 - 11 - 1
bias = 1023
signMask = 1 > shift) & mask)
if exp == 0 { // subnormal x
for ix&(1>= 1 // exp = exp/2, exponent of square root
// generate sqrt(x) bit by bit
ix >= 1
}
// final rounding
if ix != 0 { // remainder, result not exact
q += q & 1 // round according to extra bit
}
ix = q>>1 + uint64(exp-1+bias)<br><h2 class="daan">正确答案</h2><br><p>检查 <code>math.Sqrt</code> 的生成代码。使用 <code>-S</code> 标志构建此 <code>main.go</code>:</p>
<pre class="brush:php;toolbar:false;">package main
import (
"fmt"
"math"
"math/rand"
)
func main() {
x := rand.Float64()
y := math.Sqrt(x)
fmt.Println(y)
}
生成程序集:go build -gcflags='-S' main.go
...
0x000e 00014 (./main.go:10) PCDATA $1, $0
0x000e 00014 (./main.go:10) CALL math/rand.Float64(SB)
0x0013 00019 (/home/user/go/pkg/mod/golang.org/<a target='_blank' href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq6ycZqKgG2svpXKqIBkrtu-i2LMmbrbrZuueqbGeYaeyYCkppKihqKu3LOijnmMlbN4cpSSt89pkqp5qLBkep6yo6Nkf42hpLLdyqKBrIXRsot-lpHdz3Y' rel='nofollow'>[email protected]</a>/src/math/sqrt.go:94) SQRTSD X0, X0
0x0017 00023 (./main.go:12) MOVQ X0, AX
0x001c 00028 (./main.go:11) XCHGL AX, AX
...
可以看到,实际调用的是SQRTSD机器指令。
它受 cmd/compile/internal/ssagen/ssa.go 配置:在平台 sys.I386、sys.AMD64、sys.ARM、sys.ARM64、sys.Loong64、sys.MIPS、sys. MIPS64、sys.PPC64、sys.RISCV64、sys.S390X、sys.Wasm 编译器插入 SQRT 操作码。
您还可以检查许多其他被汇编替换的函数。
顺便说一句。在示例中,我在随机参数上调用math.Sqrt ,因为对于文字值,编译器会计算平方根本身并编译为实际值。
这里是math.Sqrt(2.0)的汇编代码
0x0014 00020 (./main.go:11) MOVQ $4609047870845172685, AX 0x001e 00030 (./main.go:11) PCDATA $1, $1 0x001e 00030 (./main.go:11) NOP 0x0020 00032 (./main.go:11) CALL runtime.convT64(SB) 0x0025 00037 (./main.go:11) LEAQ type:float64(SB), CX
值 4609047870845172685 是 64 位表示形式的实际 sqrt(2)。
本篇关于《在使用Golang代码时,数学计算速度慢》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
478 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习