source code
/* The Computer Language Benchmarks Game
https://salsa.debian.org/benchmarksgame-team/benchmarksgame/
Naive transliteration from Sebastien Loisel's C program
contributed by Isaac Gouy
*/
package main
import (
"flag"
"fmt"
"math"
"strconv"
)
func eval_A(i, j int) float64 { return 1.0/ float64(((i+j)*(i+j+1)/2+i+1)) }
type Vec []float64
func eval_A_times_u(N int, u Vec, Au Vec) {
for i := 0; i < N; i++ {
Au[i]=0
for j := 0; j < N; j++ {
Au[i] += float64(eval_A(i,j)) * u[j]
}
}
}
func eval_At_times_u(N int, u Vec, Au Vec) {
for i := 0; i < N; i++ {
Au[i]=0
for j := 0; j < N; j++ {
Au[i] += float64(eval_A(j,i)) * u[j]
}
}
}
func eval_AtA_times_u(N int, u, AtAu Vec) {
v := make(Vec, N); eval_A_times_u(N,u,v); eval_At_times_u(N,v,AtAu)
}
func main() {
flag.Parse()
var reps int
if flag.NArg() > 0 { reps = 12 } else { reps = 1 }
for r := 0; r < reps; r++ {
N := 100
if flag.NArg() > 0 { N, _ = strconv.Atoi(flag.Arg(0)) }
u := make(Vec, N)
for i := 0; i < N; i++ { u[i] = 1 }
v := make(Vec, N)
var vBv, vv float64
for i := 0; i < 10; i++ {
eval_AtA_times_u(N,u,v)
eval_AtA_times_u(N,v,u)
}
vBv = 0; vv = 0
for i := 0; i < N; i++ { vBv += u[i]*v[i]; vv += v[i]*v[i] }
fmt.Printf("%0.9f\n", math.Sqrt(vBv/vv))
}
}
notes, command-line, and program output
NOTES:
64-bit Ubuntu quad core
go version go1.23.1 linux/amd64
GOAMD64=v2
Sun, 22 Dec 2024 18:14:13 GMT
MAKE:
/opt/src/go1.23.1/go/bin/go build -o spectralnorma.go-8.go_run spectralnorma.go-8.go
5.68s to complete and log all make actions
COMMAND LINE:
./spectralnorma.go-8.go_run 5500
PROGRAM OUTPUT:
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153
1.274224153