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
|
package main
import (
"fmt"
"github.com/bsipos/thist"
"math/rand"
"time"
)
// randStream return a channel filled with endless normal random values
func randStream() chan float64 {
c := make(chan float64)
go func() {
for {
c <- rand.NormFloat64()
}
}()
return c
}
func main() {
// create new histogram
h := thist.NewHist(nil, "Example histogram", "auto", -1, true)
c := randStream()
i := 0
for {
// add data point to hsitogram
h.Update(<-c)
if i%50 == 0 {
// draw histogram
fmt.Println(h.Draw())
time.Sleep(time.Second)
}
i++
}
}
|