/
saxpy_parallel_fixed.go
61 lines (53 loc) · 1.34 KB
/
saxpy_parallel_fixed.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
==================================================================
SAXPY: Ejecución paralela mediante distribucion modular
==================================================================
*/
package main
import (
"runtime"
"flag"
"fmt"
"runtime/pprof"
"os"
"SAXPY_Init"
"time"
)
var _numCPUs = runtime.NumCPU()
func _init_numCPUs() {
runtime.GOMAXPROCS(_numCPUs)
}
var cpuprofile = flag.String("cpuprofile", "", "write cpu profile to file")
func main() {
init := time.Now()
flag.Parse()
if *cpuprofile != "" {
f, err := os.Create(*cpuprofile)
if err != nil {
fmt.Println("Error: ", err)
}
pprof.StartCPUProfile(f)
defer pprof.StopCPUProfile()
}
_init_numCPUs()
var n int = 300000000 // Tamaño de los vectores
var a float32 = 2 // Factor de multiplicacion
x, y := SAXPY_Init.Saxpy_init(n)
init_p := time.Now()
var _barrier_1_bool = make(chan bool)
for _i := 0; _i < _numCPUs; _i++ {
go func(_routine_num int) {
var ()
for i := _routine_num + 0; i < (n+0)/1; i += _numCPUs { // Modo de paralelización.
y[i] = a*x[i] + y[i]
}
_barrier_1_bool <- true
}(_i)
}
for _i := 0; _i < _numCPUs; _i++ {
<-_barrier_1_bool
}
fin_p := time.Since(init_p).Seconds()
fin := time.Since(init).Seconds()
fmt.Println(_numCPUs, ",", fin_p, ",", fin)
}