草庐IT

floating-point-conversion

全部标签

go - big.Float 中的 Div 和 Mod

big.Int支持除法和模运算。为什么big.Float不支持除法和取模运算?Quo()与除法不同吗?是否有math.Mod(x,yfloat64)等价于big.Float 最佳答案 整数和大整数的除法或商运算产生整数值,而对float产生float。这就是运算具有不同精度和数学意义的原因。varx,yint=5,3z:=x/y//giveyou1但是varx,yfloat32=5,3z:=x/y//giveyou1.6666666模数或提醒操作没有在float上定义,因为很难详细说明它们的含义。与math/big相同

go - 在golang中 float 返回零

为什么这段代码总是返回零:packagemainimport"fmt"funcmain(){varindex_of_arrayintfmt.Scan(&index_of_array)vararr=make([]int,index_of_array)fori:=0;i0{positive++}elseifarr_v我的意思是输出一个小数,表示数组中正数的分数。一个小数,表示数组中负数的分数。表示数组中零的分数的小数。示例输入6-43-9041示例输出0.5000000.3333330.166667但在我的代码中,输出是这样的,输入相同0.0000000.0000000.000000

floating-point - 常量截断为整数

以下GO程序报错:./fft.go:13:constant-6.28319truncatedtointeger./fft.go:13:cannotuse-7*k/N(typeint)astypefloat64inassignment程序:packagemainimport("math""fmt")funcmain(){fmt.Println("Helloworld",math.E)vark,Nint=1,10varansfloat64=0varcfloat64=(-2.0*math.Pi*k)/Nx:=make([]float64,N)fori:=0;i为什么我不能在float64类型

Golang gin-gonic 反向代理导致 panic "interface conversion: *http.timeoutWriter is not http.CloseNotifier: missing method CloseNotify"

我正在使用GinGonic创建反向代理端点的框架,目标端点使用grpcGateway提供服务使用下面给出的代码。这类似于为Gin建议的反向代理方法here和hereep1:=v1.Group("/ep1"){ep1.GET("/ep2",reverseProxy("http://localhost:50000"))}funcreverseProxy(targetstring)gin.HandlerFunc{url,err:=url.Parse(target)iferr!=nil{log.Println("ReverseProxytargeturlcouldnotbeparsed:",e

转到哈希表 : casting without conversion?

我正在实现一个专门的哈希表。出于空间使用和性能原因,我正在尝试将大量数据存储在单个64位intkey中。每个键都应该有这样的结构://Keystructure,fromLSB//evalresult(16bits)//move(16bits)//age(16bits):themoveofthegameonwhichthispositionwouldhaveoccurred//depth(8bits)//nodetype(8bits):fromthethreeconstantsabove这是一个简单的实现:varkeys[1000]uint64varvalues[1000]uint64f

go - 为什么 int64(1.1*float64(time.Minute)) 是错误而 int64(0.5*float64(time.Minute)) 不在 golang 1.9.2 中?

我在golang1.9.2中遇到了一个非常奇怪的错误:当我尝试编写int64(1.1*float64(time.Minute))时显示错误。编译器说常量被截断为整数。但是当我将1.1更改为其他float(如1.20.51.7)时,它会编译!而且当我这样写的时候它也可以编译:value:=1.1*float64(time.Minute)fmt.Println(int64(value))这是go本身的一些错误吗?我在ubuntu14.04x64上运行go 最佳答案 常量1.1*float64(time.Minute)有小数部分(值大约为

sorting - go type conversion - 使用共享接口(interface)对 2 片不同的接口(interface)进行排序

下面的示例包含2个接口(interface)Foo和Bar,它们都实现了相同的接口(interface)Timestamper。它还包含实现sort.Interface的类型ByTimestamp.如函数main所示,我想使用类型ByTimestamp对Foo的slice和slice进行排序条形图。但是,代码将无法编译,因为它无法将foos(类型[]Foo)转换为ByTimestamp类型,并且无法将bars(类型[]Bar)转换为ByTimestamp类型。是否可以使用实现sort.Interface的单一类型对实现相同接口(interface)的2个不同接口(interface)s

floating-point - 为什么 float 不正确?

为什么有些数字存储为浮点数时会失去准确性?例如,十进制数9.2可以精确地表示为两个十进制整数(92/10)的比率,两个整数都可以精确地以二进制(0b1011100/0b1010)表示。但是,存储为浮点数的相同比率永远不会完全等于9.2:32-bit"singleprecision"float:9.1999998092651367187564-bit"doubleprecision"float:9.199999999999999289457264239899814128875732421875这样一个看似简单的数字如何在存储的64位中过大? 最佳答案

google-app-engine - 戈朗 : Audio to FLAC conversion without running a executable

我正在尝试制作一个从存储中获取文件并将任意音频文件转换为FLAC的GoogleAppEngine。但是,AppEngine不允许运行可执行文件。我当前的代码看起来像这样:cmd:=exec.CommandContext(ctx,`./ffmpeg`,`-i`,`pipe:0`,`pipe:1`,`-ac`,`1`,`-c:a`,`flac`,`-f`,`flac`)cmd.Stdin=rccmd.Stdout=wcvarerrOutputbytes.Buffercmd.Stderr=&errOutputerr=cmd.Run()fmt.Printf("Runningffmpeg:%v.

长数字的 JSON 解码给出 float

例如,我使用golang编码和解码JSON,当我想用​​数字字段进行编码时,golang将其转换为float而不是使用长数字。我有以下JSON:{"id":12423434,"Name":"Fernando"}在marshal到map并再次unmarshal到json字符串后,我得到:{"id":1.2423434e+07,"Name":"Fernando"}如您所见,“id”字段采用浮点表示法。我使用的代码如下:packagemainimport("encoding/json""fmt""os")funcmain(){//CreatetheJsonstringvarb=[]byte(