用Golang绘制图表

首先

因为在使用Golang绘制图表时遇到了困难,所以我将其作为备忘录留下来。
看起来gonum plot很方便。
然而,旧的文章似乎参考了Google Code上的go get位置。
现在,它已经迁移到了GitHub,所以请执行以下操作。

go get gonum.org/v1/plot/...

绘制两组数据的图表

根据点(8.0, 2.0)和(3.0, 6.0)分别生成100个符合高斯分布的学习数据,并将其作为class1和class2进行绘图。
以下是相关代码,请参考注释部分。

(8.0, 2.0)和(3.0, 6.0)作为軸,分别生成100個符合高斯分布的數據,並作為class1和class2進行繪圖。
以下是相關代碼,請參考註釋部分。

package main

import (
    "image/color"![plot.png](https://qiita-image-store.s3.amazonaws.com/0/123283/3a191005-7612-21c4-88ef-aa6b3f3c5e29.png)

    "math/rand"
    "time"

    "gonum.org/v1/plot"
    "gonum.org/v1/plot/plotter"
    "gonum.org/v1/plot/vg"
)

func main() {

    // 図の生成
    p, err := plot.New()
    if err != nil {
        panic(err)
    }
    //label
    p.Title.Text = "Points Example"
    p.X.Label.Text = "X"
    p.Y.Label.Text = "Y"

    // 補助線
    p.Add(plotter.NewGrid())

    //クラス1
    x1, y1 := 8.0, 2.0

    //クラス2
    x2, y2 := 3.0, 6.0

    //各クラスのサンプル
    n := 200

    // 散布図の作成
    plot1, err := plotter.NewScatter(randomPoints(n, x1, y1))
    if err != nil {
        panic(err)
    }

    plot2, err := plotter.NewScatter(randomPoints(n, x2, y2))
    if err != nil {
        panic(err)
    }

    //色を指定する.
    plot1.GlyphStyle.Color = color.RGBA{R: 255, B: 128, A: 55}
    plot2.GlyphStyle.Color = color.RGBA{R: 155, B: 128, A: 255}

    //plot1,plot2をplot
    p.Add(plot1)
    p.Add(plot2)

    //label
    p.Legend.Add("class1", plot1)
    p.Legend.Add("class2", plot2)

    // 座標範囲
    p.X.Min = 0
    p.X.Max = 10
    p.Y.Min = 0
    p.Y.Max = 10

    // plot.pngに保存
    if err := p.Save(6*vg.Inch, 6*vg.Inch, "plot.png"); err != nil {
        panic(err)
    }

}

//ガウス分布
func random(axis float64) float64 {
    //分散
    dispersion := 1.0
    rand.Seed(time.Now().UnixNano())
    return rand.NormFloat64()*dispersion + axis
}

//学習データの生成
func randomPoints(n int, x, y float64) plotter.XYs {
    pts := make(plotter.XYs, n)
    for i := range pts {
        pts[i].X = random(x)
        pts[i].Y = random(y)
    }
    return pts
}

结局 (jié jú)

plot.png

我真实地能够绘制出来。

文献引用

我尝试使用gonum包在Go语言中绘制图表。

广告
将在 10 秒后关闭
bannerAds