From 3590b35e6a825ecd9016718c9645dad79b10c427 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carlos=20Mart=C3=ADn?= Date: Mon, 1 Apr 2019 12:20:05 +0100 Subject: [PATCH 1/2] Add LowerBound and UpperBound options --- asciigraph.go | 6 ++++++ asciigraph_test.go | 38 ++++++++++++++++++++++++++++++++++++++ options.go | 29 +++++++++++++++++++++-------- 3 files changed, 65 insertions(+), 8 deletions(-) diff --git a/asciigraph.go b/asciigraph.go index 394b66d..1cf6a16 100644 --- a/asciigraph.go +++ b/asciigraph.go @@ -48,6 +48,12 @@ func PlotMany(data [][]float64, options ...Option) string { maximum = max } } + if config.LowerBound != nil && *config.LowerBound < minimum { + minimum = *config.LowerBound + } + if config.UpperBound != nil && *config.UpperBound > maximum { + maximum = *config.UpperBound + } interval := math.Abs(maximum - minimum) if config.Height <= 0 { diff --git a/asciigraph_test.go b/asciigraph_test.go index 464bf2b..f8d69dc 100644 --- a/asciigraph_test.go +++ b/asciigraph_test.go @@ -201,6 +201,44 @@ func TestPlot(t *testing.T) { 38.46 ┤ ││ │││ 37.46 ┤ ╰╯ │││ 36.45 ┤ ╰╯╰`}, + { + []float64{2, 1, 1, 2, -2, 5, 7, 11, 3, 7, 4, 5, 6, 9, 4, 0, 6, 1, 5, 3, 6, 2}, + []Option{LowerBound(-3), UpperBound(13)}, + ` 13.00 ┤ + 12.00 ┤ + 11.00 ┤ ╭╮ + 10.00 ┤ ││ + 9.00 ┤ ││ ╭╮ + 8.00 ┤ ││ ││ + 7.00 ┤ ╭╯│╭╮ ││ + 6.00 ┤ │ │││ ╭╯│ ╭╮ ╭╮ + 5.00 ┤ ╭╯ │││╭╯ │ ││╭╮││ + 4.00 ┤ │ ││╰╯ ╰╮││││││ + 3.00 ┤ │ ╰╯ ││││╰╯│ + 2.00 ┼╮ ╭╮│ ││││ ╰ + 1.00 ┤╰─╯││ ││╰╯ + 0.00 ┤ ││ ╰╯ + -1.00 ┤ ││ + -2.00 ┤ ╰╯ + -3.00 ┤`}, + { + []float64{2, 1, 1, 2, -2, 5, 7, 11, 3, 7, 4, 5, 6, 9, 4, 0, 6, 1, 5, 3, 6, 2}, + []Option{LowerBound(0), UpperBound(3)}, + ` 11.00 ┤ ╭╮ + 10.00 ┤ ││ + 9.00 ┤ ││ ╭╮ + 8.00 ┤ ││ ││ + 7.00 ┤ ╭╯│╭╮ ││ + 6.00 ┤ │ │││ ╭╯│ ╭╮ ╭╮ + 5.00 ┤ ╭╯ │││╭╯ │ ││╭╮││ + 4.00 ┤ │ ││╰╯ ╰╮││││││ + 3.00 ┤ │ ╰╯ ││││╰╯│ + 2.00 ┼╮ ╭╮│ ││││ ╰ + 1.00 ┤╰─╯││ ││╰╯ + 0.00 ┤ ││ ╰╯ + -1.00 ┤ ││ + -2.00 ┤ ╰╯`}, + { []float64{1, 1, math.NaN(), 1, 1}, nil, diff --git a/options.go b/options.go index 0a2b160..c11156f 100644 --- a/options.go +++ b/options.go @@ -11,14 +11,15 @@ type Option interface { // config holds various graph options type config struct { - Width, Height int - Offset int - Caption string - Precision uint - CaptionColor AnsiColor - AxisColor AnsiColor - LabelColor AnsiColor - SeriesColors []AnsiColor + Width, Height int + LowerBound, UpperBound *float64 + Offset int + Caption string + Precision uint + CaptionColor AnsiColor + AxisColor AnsiColor + LabelColor AnsiColor + SeriesColors []AnsiColor } // An optionFunc applies an option. @@ -59,6 +60,18 @@ func Height(h int) Option { }) } +// LowerBound sets the graph's minimum value for the vertical axis. It will be ignored +// if the series contains a lower value. +func LowerBound(min float64) Option { + return optionFunc(func(c *config) { c.LowerBound = &min }) +} + +// UpperBound sets the graph's maximum value for the vertical axis. It will be ignored +// if the series contains a bigger value. +func UpperBound(max float64) Option { + return optionFunc(func(c *config) { c.UpperBound = &max }) +} + // Offset sets the graphs offset. func Offset(o int) Option { return optionFunc(func(c *config) { c.Offset = o }) From 3a1efcd3b3b754d26fda19be4d1f9a3319e3d086 Mon Sep 17 00:00:00 2001 From: Rohit Gupta Date: Fri, 23 Jun 2023 01:30:09 +0530 Subject: [PATCH 2/2] cli: add flags for lower and upper bound options --- README.md | 4 ++++ cmd/asciigraph/main.go | 9 +++++++++ 2 files changed, 13 insertions(+) diff --git a/README.md b/README.md index dbcd456..069bd77 100644 --- a/README.md +++ b/README.md @@ -130,6 +130,8 @@ Options: set fps to control how frequently graph to be rendered when realtime graph enabled (default 24) -h height height in text rows, 0 for auto-scaling + -lb lower bound + lower bound set the minimum value for the vertical axis (ignored if series contains lower values) (default +Inf) -lc label color y-axis label color of the plot -o offset @@ -140,6 +142,8 @@ Options: enables realtime graph for data stream -sc series color series color of the plot + -ub upper bound + upper bound set the maximum value for the vertical axis (ignored if series contains larger values) (default -Inf) -w width width in columns, 0 for auto-scaling asciigraph expects data points from stdin. Invalid values are logged to stderr. diff --git a/cmd/asciigraph/main.go b/cmd/asciigraph/main.go index 200b676..c40c462 100644 --- a/cmd/asciigraph/main.go +++ b/cmd/asciigraph/main.go @@ -6,6 +6,7 @@ import ( "flag" "fmt" "log" + "math" "os" "strconv" "time" @@ -26,6 +27,8 @@ var ( captionColor asciigraph.AnsiColor axisColor asciigraph.AnsiColor labelColor asciigraph.AnsiColor + lowerBound = math.Inf(1) + upperBound = math.Inf(-1) ) func main() { @@ -79,6 +82,8 @@ func main() { return nil } }) + flag.Float64Var(&lowerBound, "lb", lowerBound, "`lower bound` set the minimum value for the vertical axis (ignored if series contains lower values)") + flag.Float64Var(&upperBound, "ub", upperBound, "`upper bound` set the maximum value for the vertical axis (ignored if series contains larger values)") flag.Parse() @@ -119,6 +124,8 @@ func main() { asciigraph.CaptionColor(captionColor), asciigraph.AxisColor(axisColor), asciigraph.LabelColor(labelColor), + asciigraph.LowerBound(lowerBound), + asciigraph.UpperBound(upperBound), ) asciigraph.Clear() fmt.Println(plot) @@ -145,6 +152,8 @@ func main() { asciigraph.CaptionColor(captionColor), asciigraph.AxisColor(axisColor), asciigraph.LabelColor(labelColor), + asciigraph.LowerBound(lowerBound), + asciigraph.UpperBound(upperBound), ) fmt.Println(plot)