mirror of
https://github.com/bcicen/ctop.git
synced 2025-11-12 22:25:40 +01:00
refactor data hist structs, add Val field
This commit is contained in:
@@ -16,8 +16,8 @@ func NewExpandedCpu() *ExpandedCpu {
|
|||||||
cpu.Width = 50
|
cpu.Width = 50
|
||||||
cpu.X = 0
|
cpu.X = 0
|
||||||
cpu.Y = 4
|
cpu.Y = 4
|
||||||
cpu.Data = cpu.hist.data
|
cpu.Data = cpu.hist.Data
|
||||||
cpu.DataLabels = cpu.hist.labels
|
cpu.DataLabels = cpu.hist.Labels
|
||||||
cpu.AxesColor = ui.ColorDefault
|
cpu.AxesColor = ui.ColorDefault
|
||||||
cpu.LineColor = ui.ColorGreen
|
cpu.LineColor = ui.ColorGreen
|
||||||
return cpu
|
return cpu
|
||||||
|
|||||||
@@ -1,74 +1,60 @@
|
|||||||
package expanded
|
package expanded
|
||||||
|
|
||||||
type IntHist struct {
|
type IntHist struct {
|
||||||
data []int
|
Val int // most current data point
|
||||||
labels []string
|
Data []int // historical data points
|
||||||
|
Labels []string
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewIntHist(max int) IntHist {
|
func NewIntHist(max int) *IntHist {
|
||||||
return IntHist{
|
return &IntHist{
|
||||||
data: make([]int, max),
|
Data: make([]int, max),
|
||||||
labels: make([]string, max),
|
Labels: make([]string, max),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h IntHist) Append(val int) {
|
func (h *IntHist) Append(val int) {
|
||||||
if len(h.data) == cap(h.data) {
|
if len(h.Data) == cap(h.Data) {
|
||||||
h.data = append(h.data[:0], h.data[1:]...)
|
h.Data = append(h.Data[:0], h.Data[1:]...)
|
||||||
}
|
}
|
||||||
|
h.Val = val
|
||||||
|
h.Data = append(h.Data, val)
|
||||||
|
}
|
||||||
|
|
||||||
h.data = append(h.data, val)
|
type DiffHist struct {
|
||||||
|
*IntHist
|
||||||
|
lastVal int
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewDiffHist(max int) *DiffHist {
|
||||||
|
return &DiffHist{NewIntHist(max), -1}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *DiffHist) Append(val int) {
|
||||||
|
if h.lastVal >= 0 { // skip append if this is the initial update
|
||||||
|
diff := val - h.lastVal
|
||||||
|
h.IntHist.Append(diff)
|
||||||
|
}
|
||||||
|
h.lastVal = val
|
||||||
}
|
}
|
||||||
|
|
||||||
type FloatHist struct {
|
type FloatHist struct {
|
||||||
data []float64
|
Val float64 // most current data point
|
||||||
labels []string
|
Data []float64 // historical data points
|
||||||
|
Labels []string
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewFloatHist(max int) FloatHist {
|
func NewFloatHist(max int) FloatHist {
|
||||||
return FloatHist{
|
return FloatHist{
|
||||||
data: make([]float64, max),
|
Data: make([]float64, max),
|
||||||
labels: make([]string, max),
|
Labels: make([]string, max),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h FloatHist) Append(val float64) {
|
func (h FloatHist) Append(val float64) {
|
||||||
if len(h.data) == cap(h.data) {
|
if len(h.Data) == cap(h.Data) {
|
||||||
h.data = append(h.data[:0], h.data[1:]...)
|
h.Data = append(h.Data[:0], h.Data[1:]...)
|
||||||
}
|
}
|
||||||
h.data = append(h.data, val)
|
h.Val = val
|
||||||
}
|
h.Data = append(h.Data, val)
|
||||||
|
|
||||||
type DiffHist struct {
|
|
||||||
data []int // data point derivatives
|
|
||||||
srcData []int // principal input data
|
|
||||||
labels []string
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewDiffHist(max int) DiffHist {
|
|
||||||
return DiffHist{
|
|
||||||
data: make([]int, max),
|
|
||||||
srcData: make([]int, max),
|
|
||||||
labels: make([]string, max),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// return most recent value
|
|
||||||
func (h DiffHist) Last() int {
|
|
||||||
return h.data[len(h.data)-1]
|
|
||||||
}
|
|
||||||
|
|
||||||
func (h DiffHist) Append(val int) {
|
|
||||||
if len(h.data) == cap(h.data) {
|
|
||||||
h.data = append(h.data[:0], h.data[1:]...)
|
|
||||||
}
|
|
||||||
if len(h.srcData) == cap(h.srcData) {
|
|
||||||
h.srcData = append(h.srcData[:0], h.srcData[1:]...)
|
|
||||||
}
|
|
||||||
|
|
||||||
diff := val - h.srcData[len(h.srcData)-1]
|
|
||||||
if diff != val { // skip adding to data if this is the initial update
|
|
||||||
h.data = append(h.data, diff)
|
|
||||||
}
|
|
||||||
h.srcData = append(h.srcData, val)
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import (
|
|||||||
|
|
||||||
type ExpandedMem struct {
|
type ExpandedMem struct {
|
||||||
*ui.BarChart
|
*ui.BarChart
|
||||||
hist IntHist
|
hist *IntHist
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewExpandedMem() *ExpandedMem {
|
func NewExpandedMem() *ExpandedMem {
|
||||||
@@ -23,9 +23,9 @@ func NewExpandedMem() *ExpandedMem {
|
|||||||
mem.X = 0
|
mem.X = 0
|
||||||
mem.Y = 14
|
mem.Y = 14
|
||||||
mem.TextColor = ui.ColorDefault
|
mem.TextColor = ui.ColorDefault
|
||||||
mem.Data = mem.hist.data
|
mem.Data = mem.hist.Data
|
||||||
mem.BarColor = ui.ColorGreen
|
mem.BarColor = ui.ColorGreen
|
||||||
mem.DataLabels = mem.hist.labels
|
mem.DataLabels = mem.hist.Labels
|
||||||
mem.NumFmt = cwidgets.ByteFormatInt
|
mem.NumFmt = cwidgets.ByteFormatInt
|
||||||
return mem
|
return mem
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,8 +10,8 @@ import (
|
|||||||
|
|
||||||
type ExpandedNet struct {
|
type ExpandedNet struct {
|
||||||
*ui.Sparklines
|
*ui.Sparklines
|
||||||
rxHist DiffHist
|
rxHist *DiffHist
|
||||||
txHist DiffHist
|
txHist *DiffHist
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewExpandedNet() *ExpandedNet {
|
func NewExpandedNet() *ExpandedNet {
|
||||||
@@ -25,14 +25,14 @@ func NewExpandedNet() *ExpandedNet {
|
|||||||
rx := ui.NewSparkline()
|
rx := ui.NewSparkline()
|
||||||
rx.Title = "RX"
|
rx.Title = "RX"
|
||||||
rx.Height = 1
|
rx.Height = 1
|
||||||
rx.Data = net.rxHist.data
|
rx.Data = net.rxHist.Data
|
||||||
rx.TitleColor = ui.ColorDefault
|
rx.TitleColor = ui.ColorDefault
|
||||||
rx.LineColor = ui.ColorGreen
|
rx.LineColor = ui.ColorGreen
|
||||||
|
|
||||||
tx := ui.NewSparkline()
|
tx := ui.NewSparkline()
|
||||||
tx.Title = "TX"
|
tx.Title = "TX"
|
||||||
tx.Height = 1
|
tx.Height = 1
|
||||||
tx.Data = net.txHist.data
|
tx.Data = net.txHist.Data
|
||||||
tx.TitleColor = ui.ColorDefault
|
tx.TitleColor = ui.ColorDefault
|
||||||
tx.LineColor = ui.ColorYellow
|
tx.LineColor = ui.ColorYellow
|
||||||
|
|
||||||
@@ -44,10 +44,10 @@ func (w *ExpandedNet) Update(rx int64, tx int64) {
|
|||||||
var rate string
|
var rate string
|
||||||
|
|
||||||
w.rxHist.Append(int(rx))
|
w.rxHist.Append(int(rx))
|
||||||
rate = strings.ToLower(cwidgets.ByteFormatInt(w.rxHist.Last()))
|
rate = strings.ToLower(cwidgets.ByteFormatInt(w.rxHist.Val))
|
||||||
w.Lines[0].Title = fmt.Sprintf("RX [%s/s]", rate)
|
w.Lines[0].Title = fmt.Sprintf("RX [%s/s]", rate)
|
||||||
|
|
||||||
w.txHist.Append(int(tx))
|
w.txHist.Append(int(tx))
|
||||||
rate = strings.ToLower(cwidgets.ByteFormatInt(w.txHist.Last()))
|
rate = strings.ToLower(cwidgets.ByteFormatInt(w.txHist.Val))
|
||||||
w.Lines[1].Title = fmt.Sprintf("TX [%s/s]", rate)
|
w.Lines[1].Title = fmt.Sprintf("TX [%s/s]", rate)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user