The following GO program gives the error:
./fft.go:13: constant -6.28319 truncated to integer
./fft.go:13: cannot use -7 * k / N (type int) as type float64 in assignment
Program:
package main
import (
"math"
"fmt"
)
func main() {
fmt.Println("Hello world ",math.E)
var k, N int = 1, 10
var ans float64 = 0
var c float64 = (-2.0 * math.Pi * k) / N
x := make([]float64,N)
for i := 0; i < len(x); i++ {
x[i] = 1
}
ans = 0
for i := 0; i < N; i++ {
ans += x[i] * math.E
}
fmt.Println(ans)
}
Why cant I use an int
in a type of float64
?
Replace
var c float64 = (-2.0 * math.Pi * k) / N
by
var c float64 = (-2.0 * math.Pi * float64(k)) / float64(N)
To quote the spec:
Conversions are required when different numeric types are mixed in an expression or assignment. For instance, int32 and int are not the same type even though they may have the same size on a particular architecture.
Go uses static typing and doesn't automatically convert between numeric types. The reason is probably to avoid some errors. For instance, what value and what type should float64(2.5) * int(2)
yield? Should the result be int(5)
? int(4)
? float64(5.0)
? In Go, this isn't an issue. The Go FAQ has more to say on this.
@jnml points out that, in this case, the following is enough:
var c float64 = -2 * math.Pi / float64(N)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With