Documentation ¶
Index ¶
- Constants
- func SortRowsIndex0(a, b []string) int
- type Histogram
- func NewHistogram(name string) *Histogram
- func ParseFileCSV(file string, name string, binNameColIdx, binFrequencyColIdx uint) (*Histogram, error)
- func ParseTable(tbl table.Table, binNameColIdx, binFrequencyColIdx uint) (*Histogram, error)
- func ReadFileHistogramBins(filename string) (*Histogram, error)
- func (hist *Histogram) Add(binName string, binCount int)
- func (hist *Histogram) AddBulk(m map[string]int)
- func (hist *Histogram) AddMap(binMap map[string]string, binCount int)
- func (hist *Histogram) BinNameExists(binName string) bool
- func (hist *Histogram) BinNames() []string
- func (hist *Histogram) BinNamesMore(inclOrdered, inclUnordered, inclEmpty bool) []string
- func (hist *Histogram) BinValue(binName string) (int, error)
- func (hist *Histogram) BinValueOrDefault(binName string, def int) int
- func (hist *Histogram) GetOrDefault(binName string, def int) int
- func (hist *Histogram) Inflate()
- func (hist *Histogram) ItemCount() uint
- func (hist *Histogram) ItemCounts(sortBy string) maputil.Records
- func (hist *Histogram) ItemNames() []string
- func (hist *Histogram) ItemValuesOrdered() maputil.Records
- func (hist *Histogram) Map() map[string]int
- func (hist *Histogram) MapAdd(m map[string]int)
- func (hist *Histogram) MapKeySplit(mapKey string, mapValIncl []string) (*HistogramSet, error)
- func (hist *Histogram) MapKeyValues(key string, dedupe bool) ([]string, error)
- func (hist *Histogram) MapKeys() ([]string, error)
- func (hist *Histogram) MapKeysFlattenSingle(mapKeyFilter string) (*Histogram, error)
- func (hist *Histogram) MapKeysReduce(mapKeysFilter []string) (*Histogram, error)
- func (hist *Histogram) MapToHistogramSet(histName, binName string) (*HistogramSet, error)
- func (hist *Histogram) OrderOrDefault(inclUnordered bool) []string
- func (hist *Histogram) Stats() point.PointSet
- func (hist *Histogram) Sum() int
- func (hist *Histogram) Table(colNameBinName, colNameBinCount string) *table.Table
- func (hist *Histogram) TableMap(mapCols []string, colNameBinCount string, fnSort func(a, b []string) int) (*table.Table, error)
- func (hist *Histogram) TableSetMap(cfgs []HistogramMapTableConfig) (*table.TableSet, error)
- func (hist *Histogram) TransformBinNames(xfFunc func(input string) string) *Histogram
- func (hist *Histogram) TransformBinNamesMap(xfMap map[string]string, matchType string) *Histogram
- func (hist *Histogram) WriteTableASCII(w io.Writer, header []string, sortBy string, inclTotal bool)
- func (hist *Histogram) WriteXLSX(filename, sheetname, colNameBinName, colNameBinCount string) error
- type HistogramAny
- type HistogramMapTableConfig
- type HistogramMapTableSetConfig
- type HistogramSet
- func (hset *HistogramSet) Add(histName, binName string, binCount int)
- func (hset *HistogramSet) AddDateUIDCount(dt time.Time, uid string, count int)
- func (hset *HistogramSet) BinNameExists(binName string) bool
- func (hset *HistogramSet) BinNames() []string
- func (hset *HistogramSet) BinParentCounts() map[uint]map[string]uint
- func (hset *HistogramSet) BinValue(histName, binName string) int
- func (hset *HistogramSet) DatetimeKeyCount() (timeseries.TimeSeries, error)
- func (hset *HistogramSet) DatetimeKeyCountTable(interval timeutil.Interval, countColName string) (table.Table, error)
- func (hset *HistogramSet) DatetimeKeyToQuarter(name string) (*HistogramSet, error)
- func (hset *HistogramSet) FilterHistogramNames(inFunc, exFunc func(histname string) bool) *HistogramSet
- func (hset *HistogramSet) HistogramBinNames(setName string) []string
- func (hset *HistogramSet) HistogramNameExists(histName string) bool
- func (hset *HistogramSet) HistogramSetTimeKeyCountWriteXLSX(filename string, interval timeutil.Interval, countColName string) error
- func (hset *HistogramSet) ItemCount() uint
- func (hset *HistogramSet) ItemCounts() *Histogram
- func (hset *HistogramSet) ItemNames() []string
- func (hset *HistogramSet) LeafStats(name string) *Histogram
- func (hset *HistogramSet) Map() map[string]map[string]int
- func (hset *HistogramSet) MapAdd(m map[string]map[string]int)
- func (hset *HistogramSet) String(histNotSet, binNotSet string) string
- func (hset *HistogramSet) Sum() int
- func (hset *HistogramSet) Table(colNameHist, colNameBin, colNameCount string) table.Table
- func (hset *HistogramSet) TablePivot(tableName, histColName string, ...) (*table.Table, error)
- func (hset *HistogramSet) ToTimeSeriesDistinct() (timeseries.TimeSeries, error)
- func (hset *HistogramSet) TransformBinNamesMap(xfMap map[string]string) *HistogramSet
- func (hset *HistogramSet) TransformHistogramNamesMap(xfMap map[string]string, matchType string) *HistogramSet
- func (hset *HistogramSet) TransformNames(xfFuncHist, xfFuncBin func(input string) string) *HistogramSet
- func (hset *HistogramSet) WriteXLSX(filename, sheetName, colName1, colName2, colNameCount string) error
- func (hset *HistogramSet) WriteXLSXPivot(filename, sheetName, histColName string, ...) error
- type HistogramSetMetadata
- type HistogramSets
- func (hsets *HistogramSets) Add(hsetName, histName, binName string, binCount int, trimSpace bool)
- func (hsets *HistogramSets) BinNames() []string
- func (hsets *HistogramSets) BinSumsByHset() *Histogram
- func (hsets *HistogramSets) BinValue(hsetName, histName, binName string) int
- func (hsets *HistogramSets) Counts() *HistogramSetsCounts
- func (hsets *HistogramSets) FilterHsetNames(inFunc, exFunc func(name string) bool) *HistogramSets
- func (hsets *HistogramSets) Flatten(name string) *HistogramSet
- func (hsets *HistogramSets) ItemCount() uint
- func (hsets *HistogramSets) ItemNames() []string
- func (hsets *HistogramSets) Map() map[string]map[string]map[string]int
- func (hsets *HistogramSets) MapAdd(m map[string]map[string]map[string]int, trimSpace bool)
- func (hsets *HistogramSets) Sum() int
- func (hsets *HistogramSets) Table(tableName, colNameHSet, colNameHist, colNameBinName, colNameBinCount string) table.Table
- func (hsets *HistogramSets) TablePivot(opts TablePivotOpts) table.Table
- func (hsets *HistogramSets) TransformBinNamesMap(xfBinNames map[string]string) *HistogramSets
- func (hsets *HistogramSets) TransformNames(xfHsetName, xfFuncHistName, xfFuncBinName func(name string) string) *HistogramSets
- func (hsets *HistogramSets) Visit(visit func(hsetName, histName, binName string, binCount int))
- func (hsets *HistogramSets) WriteXLSX(...) error
- func (hsets *HistogramSets) WriteXLSXPivot(filename string, opts TablePivotOpts) error
- type HistogramSetsCounts
- type TablePivotOpts
- func (opts TablePivotOpts) ColNameBinCountsSumOrDefault() string
- func (opts TablePivotOpts) ColNameHistogramOrDefault() string
- func (opts TablePivotOpts) ColNameHistogramSetOrDefault() string
- func (opts TablePivotOpts) InflateBinName(binName string, binNumber int, isPct bool) string
- func (opts TablePivotOpts) TableColumns(binNames []string) ([]string, map[int]string)
Constants ¶
const ( SortNameAsc = maputil.SortNameAsc SortNameDesc = maputil.SortNameDesc SortValueAsc = maputil.SortValueAsc SortValueDesc = maputil.SortValueDesc )
Variables ¶
This section is empty.
Functions ¶
func SortRowsIndex0 ¶ added in v2.20.1
SortRowsIndex0 is an example function used with `Histogram.TableMap`.
Types ¶
type Histogram ¶
type Histogram struct { Name string Bins map[string]int Counts map[string]int // how many items have counts. Percentages map[string]float64 Order []string // bin ordering for formatting. }
Histogram is used to count how many times an item appears and how many times number of appearances appear. It can be used with simple string keys or `map[string]string` keys which are converted to soerted query strings.
func NewHistogram ¶
func ParseFileCSV ¶
func ParseFileCSV(file string, name string, binNameColIdx, binFrequencyColIdx uint) (*Histogram, error)
ParseFileCSV reads a CSV using default settings of `,` separator, header row and BOM to be stripped. If you have other configurations, use `table.ReadFile()` directly and call `HistogramFromTable()`.
func ParseTable ¶
ParseTable parses a `table.Table` to a `Histogram` given a table, binName column index and binFrequency column index. Empty rows are skipped.
func ReadFileHistogramBins ¶ added in v2.21.9
ReadFileHistogramBins reads a JSON file consisting of a `map[string]int` and populates a `Histogram`.
func (*Histogram) AddMap ¶ added in v2.10.0
AddMap provides a helper function to automatically create url encoded string keys. This can be used with `TableMap` to generate tables with arbitrary columns easily.
func (*Histogram) BinNameExists ¶
func (*Histogram) BinNamesMore ¶ added in v2.20.0
func (*Histogram) BinValueOrDefault ¶ added in v2.20.0
func (*Histogram) GetOrDefault ¶ added in v2.20.0
func (*Histogram) ItemCounts ¶
ItemCounts returns sorted bin names and values.
func (*Histogram) ItemValuesOrdered ¶ added in v2.21.5
ItemValuesOrdered returns bin names and values sorted by the `Order` field. Unordered bins are not included.
func (*Histogram) MapKeySplit ¶ added in v2.16.2
func (hist *Histogram) MapKeySplit(mapKey string, mapValIncl []string) (*HistogramSet, error)
MapKeySplit returns a new `HistogramSet` where the supplied key is the HistogramSet key.
func (*Histogram) MapKeyValues ¶ added in v2.16.2
MapKeyValues returns a list of keys using query string keys.
func (*Histogram) MapKeys ¶ added in v2.10.0
MapKeys returns a list of keys using query string keys.
func (*Histogram) MapKeysFlattenSingle ¶ added in v2.17.0
func (*Histogram) MapKeysReduce ¶ added in v2.17.0
MapKeysReduce returns a new `Histogram` with only the supplied keys present.
func (*Histogram) MapToHistogramSet ¶ added in v2.20.2
func (hist *Histogram) MapToHistogramSet(histName, binName string) (*HistogramSet, error)
func (*Histogram) OrderOrDefault ¶ added in v2.20.0
OrderOrDefault returns a list of histogram bin names defaulting to ordered names and falling back to sorted bin names. If an order is provided, the non-explicitly listed bin names can be included at the end or not included.
func (*Histogram) TableMap ¶ added in v2.10.0
func (hist *Histogram) TableMap(mapCols []string, colNameBinCount string, fnSort func(a, b []string) int) (*table.Table, error)
TableMap is used to generate a table using map keys.
func (*Histogram) TableSetMap ¶ added in v2.16.2
func (hist *Histogram) TableSetMap(cfgs []HistogramMapTableConfig) (*table.TableSet, error)
func (*Histogram) TransformBinNames ¶
TransformBinNames modifies bin names and returns a new histogram.
func (*Histogram) TransformBinNamesMap ¶
TransformBinNamesMap modifies bin names and returns a new histogram. `matchType` can be set to `prefix` to match name prefixes instead of exact match.
func (*Histogram) WriteTableASCII ¶
WriteTable writes an ASCII Table. For CLI apps, pass `os.Stdout` for `io.Writer`.
type HistogramAny ¶ added in v2.11.0
type HistogramMapTableConfig ¶ added in v2.16.2
type HistogramMapTableConfig struct { TableName string TableNamePrefix string SplitKey string SplitValFilterIncl []string // if present, only include these split values ColumnKeys []string // doesn't include count column ColNameCount string // contains filtered or unexported fields }
func (*HistogramMapTableConfig) Inflate ¶ added in v2.16.2
func (cfg *HistogramMapTableConfig) Inflate()
func (*HistogramMapTableConfig) SplitValFilterInclExists ¶ added in v2.16.2
func (cfg *HistogramMapTableConfig) SplitValFilterInclExists(v string) bool
type HistogramMapTableSetConfig ¶ added in v2.16.2
type HistogramMapTableSetConfig struct {
Configs []HistogramMapTableConfig
}
type HistogramSet ¶
func NewHistogramSet ¶
func NewHistogramSet(name string) *HistogramSet
func NewHistogramSetWithData ¶
func NewHistogramSetWithData(name string, data map[string]map[string]int) *HistogramSet
func (*HistogramSet) Add ¶
func (hset *HistogramSet) Add(histName, binName string, binCount int)
Add provides an easy method to add a histogram bin name and count for an existing or new histogram in the set.
func (*HistogramSet) AddDateUIDCount ¶
func (hset *HistogramSet) AddDateUIDCount(dt time.Time, uid string, count int)
func (*HistogramSet) BinNameExists ¶
func (hset *HistogramSet) BinNameExists(binName string) bool
BinNameExists returns a boolean indicating if a bin name exists in any histogram.
func (*HistogramSet) BinNames ¶
func (hset *HistogramSet) BinNames() []string
BinNames returns all the bin names used across all the histograms.
func (*HistogramSet) BinParentCounts ¶ added in v2.16.0
func (hset *HistogramSet) BinParentCounts() map[uint]map[string]uint
BinSetCounts returns a ap where the key is the count of bins and the string is the set name.
func (*HistogramSet) BinValue ¶ added in v2.20.0
func (hset *HistogramSet) BinValue(histName, binName string) int
BinValue the value of a bin.
func (*HistogramSet) DatetimeKeyCount ¶
func (hset *HistogramSet) DatetimeKeyCount() (timeseries.TimeSeries, error)
DatetimeKeyCount returns a TimeSeries when the first key is a RFC3339 time and a sum of items is desired per time.
func (*HistogramSet) DatetimeKeyCountTable ¶
func (*HistogramSet) DatetimeKeyToQuarter ¶
func (hset *HistogramSet) DatetimeKeyToQuarter(name string) (*HistogramSet, error)
DatetimeKeyToQuarter converts a HistogramSet by date to one by quarters.
func (*HistogramSet) FilterHistogramNames ¶ added in v2.17.0
func (hset *HistogramSet) FilterHistogramNames(inFunc, exFunc func(histname string) bool) *HistogramSet
FilterHistogramNames returns a new `HistogramSet` with only the matching histogram names included.
func (*HistogramSet) HistogramBinNames ¶
func (hset *HistogramSet) HistogramBinNames(setName string) []string
HistogramBinNames returns the bin names for a single histogram whose name is provided as a function parameter.
func (*HistogramSet) HistogramNameExists ¶
func (hset *HistogramSet) HistogramNameExists(histName string) bool
HistogramNameExists returns a boolean indicating if the supplied histogram name exists.
func (*HistogramSet) HistogramSetTimeKeyCountWriteXLSX ¶
func (*HistogramSet) ItemCount ¶
func (hset *HistogramSet) ItemCount() uint
ItemCount returns the number of histograms.
func (*HistogramSet) ItemCounts ¶
func (hset *HistogramSet) ItemCounts() *Histogram
ItemCounts returns the number of histograms.
func (*HistogramSet) ItemNames ¶
func (hset *HistogramSet) ItemNames() []string
ItemNames returns the number of histograms.
func (*HistogramSet) LeafStats ¶
func (hset *HistogramSet) LeafStats(name string) *Histogram
LeafStats returns a histogram by combining the histogram bins across histograms, removing the histogram distinction.
func (*HistogramSet) Map ¶ added in v2.16.0
func (hset *HistogramSet) Map() map[string]map[string]int
func (*HistogramSet) MapAdd ¶ added in v2.16.0
func (hset *HistogramSet) MapAdd(m map[string]map[string]int)
func (*HistogramSet) String ¶ added in v2.20.2
func (hset *HistogramSet) String(histNotSet, binNotSet string) string
func (*HistogramSet) Sum ¶ added in v2.11.0
func (hset *HistogramSet) Sum() int
Sum returns the sum of all the histogram bin values.
func (*HistogramSet) Table ¶ added in v2.15.1
func (hset *HistogramSet) Table(colNameHist, colNameBin, colNameCount string) table.Table
func (*HistogramSet) TablePivot ¶ added in v2.17.0
func (hset *HistogramSet) TablePivot(tableName, histColName string, addColumnTotalLeft, addColumnTotalRight, addRowTotalTop, addRowTotalBottom bool) (*table.Table, error)
TablePivot returns a `*table.Table` where the first column is the histogram name and the other columns are the bin names. This is useful for easy visualization of a table and also creating charts such as grouped bar charts.
func (*HistogramSet) ToTimeSeriesDistinct ¶
func (hset *HistogramSet) ToTimeSeriesDistinct() (timeseries.TimeSeries, error)
func (*HistogramSet) TransformBinNamesMap ¶ added in v2.17.0
func (hset *HistogramSet) TransformBinNamesMap(xfMap map[string]string) *HistogramSet
TransformBinNamesMap modifies bin names and returns a new `HistogramSet`.
func (*HistogramSet) TransformHistogramNamesMap ¶
func (hset *HistogramSet) TransformHistogramNamesMap(xfMap map[string]string, matchType string) *HistogramSet
TransformHistogramNamesMap modifies bin names and returns a new `HistogramSet`. `matchType` can be set to `prefix` to match name prefixes instead of exact match.
func (*HistogramSet) TransformNames ¶ added in v2.17.0
func (hset *HistogramSet) TransformNames(xfFuncHist, xfFuncBin func(input string) string) *HistogramSet
func (*HistogramSet) WriteXLSX ¶
func (hset *HistogramSet) WriteXLSX(filename, sheetName, colName1, colName2, colNameCount string) error
WriteXLSX creates an XLSX file where the first column is the histogram name, the second column is the bin name and the third column is the bin count.
func (*HistogramSet) WriteXLSXPivot ¶ added in v2.17.0
func (hset *HistogramSet) WriteXLSXPivot(filename, sheetName, histColName string, addColumnTotalLeft, addColumnTotalRight, addRowTotalTop, addRowTotalBottom bool) error
WriteXLSXPivot creates an XLSX file where the first column is the histogram name and the other columns are the bin names. This is useful for easy visualization of a table and also creating charts such as grouped bar charts.
type HistogramSetMetadata ¶
type HistogramSetMetadata struct { Names []string `json:"names,omitempty"` NameCount int `json:"nameCount,omitempty"` UniqueBinCount int `json:"uniqueBinCount,omitempty"` }
func NewHistogramSetMetadata ¶
func NewHistogramSetMetadata(histSet *HistogramSet) *HistogramSetMetadata
type HistogramSets ¶
type HistogramSets struct { Name string HistogramSetMap map[string]*HistogramSet }
func NewHistogramSets ¶
func NewHistogramSets(name string) *HistogramSets
func NewHistogramSetsCSVs ¶
func NewHistogramSetsCSVs(filenames []string, key1ColIdx, key2ColIdx, uidColIdx uint) (*HistogramSets, table.Table, error)
NewHistogramSetsCSVs expects multiple files to have same columns.
func NewHistogramSetsTable ¶
func NewHistogramSetsTable(tbl table.Table, key1ColIdx, key2ColIdx, uidColIdx uint) (*HistogramSets, error)
func (*HistogramSets) Add ¶
func (hsets *HistogramSets) Add(hsetName, histName, binName string, binCount int, trimSpace bool)
func (*HistogramSets) BinNames ¶
func (hsets *HistogramSets) BinNames() []string
func (*HistogramSets) BinSumsByHset ¶ added in v2.10.0
func (hsets *HistogramSets) BinSumsByHset() *Histogram
func (*HistogramSets) BinValue ¶ added in v2.20.0
func (hsets *HistogramSets) BinValue(hsetName, histName, binName string) int
BinValue the value of a bin.
func (*HistogramSets) Counts ¶
func (hsets *HistogramSets) Counts() *HistogramSetsCounts
func (*HistogramSets) FilterHsetNames ¶ added in v2.17.0
func (hsets *HistogramSets) FilterHsetNames(inFunc, exFunc func(name string) bool) *HistogramSets
func (*HistogramSets) Flatten ¶
func (hsets *HistogramSets) Flatten(name string) *HistogramSet
func (*HistogramSets) ItemCount ¶
func (hsets *HistogramSets) ItemCount() uint
ItemCount returns the number of histogram sets.
func (*HistogramSets) ItemNames ¶ added in v2.12.0
func (hsets *HistogramSets) ItemNames() []string
func (*HistogramSets) Map ¶ added in v2.16.0
func (hsets *HistogramSets) Map() map[string]map[string]map[string]int
func (*HistogramSets) Sum ¶ added in v2.11.0
func (hsets *HistogramSets) Sum() int
func (*HistogramSets) Table ¶
func (hsets *HistogramSets) Table(tableName, colNameHSet, colNameHist, colNameBinName, colNameBinCount string) table.Table
func (*HistogramSets) TablePivot ¶ added in v2.17.0
func (hsets *HistogramSets) TablePivot(opts TablePivotOpts) table.Table
TablePivot returns a `*table.Table` where the first column is the histogram set name, the second column is the histogram name and the other columns are the bin names.
func (*HistogramSets) TransformBinNamesMap ¶ added in v2.17.0
func (hsets *HistogramSets) TransformBinNamesMap(xfBinNames map[string]string) *HistogramSets
func (*HistogramSets) TransformNames ¶ added in v2.17.0
func (hsets *HistogramSets) TransformNames(xfHsetName, xfFuncHistName, xfFuncBinName func(name string) string) *HistogramSets
func (*HistogramSets) Visit ¶
func (hsets *HistogramSets) Visit(visit func(hsetName, histName, binName string, binCount int))
func (*HistogramSets) WriteXLSX ¶
func (hsets *HistogramSets) WriteXLSX(filename, sheetname, colNameHSet, colNameHist, colNameBinName, colNameBinCount string) error
func (*HistogramSets) WriteXLSXPivot ¶ added in v2.17.0
func (hsets *HistogramSets) WriteXLSXPivot(filename string, opts TablePivotOpts) error
type HistogramSetsCounts ¶
type HistogramSetsCounts struct { UIDCounts map[string]map[string]uint UIDCountsKey1 map[string]uint UIDCountsKey2 map[string]uint Key1Names []string Key2Names []string }
HistogramSetsCounts returns UID counts. When used with NewHistogramSetsCSV(), it can provide a sanity check for raw record counts against aggregate query values, e.g. compare counts of raw records to GROUP BY counts.
func NewHistogramSetsCounts ¶
func NewHistogramSetsCounts(hsets HistogramSets) *HistogramSetsCounts
func (*HistogramSetsCounts) Inflate ¶
func (hcounts *HistogramSetsCounts) Inflate()
type TablePivotOpts ¶ added in v2.18.1
type TablePivotOpts struct { TableName string ColNameHistogramSet string ColNameHistogram string ColNameBinPrefix string ColNameBinSuffix string ColNameBinCountsSum string BinNamesOrder []string InclBinsUnordered bool InclBinCounts bool InclBinCountsSum bool InclBinPercentages bool }
func (TablePivotOpts) ColNameBinCountsSumOrDefault ¶ added in v2.18.1
func (opts TablePivotOpts) ColNameBinCountsSumOrDefault() string
func (TablePivotOpts) ColNameHistogramOrDefault ¶ added in v2.18.1
func (opts TablePivotOpts) ColNameHistogramOrDefault() string
func (TablePivotOpts) ColNameHistogramSetOrDefault ¶ added in v2.18.1
func (opts TablePivotOpts) ColNameHistogramSetOrDefault() string
func (TablePivotOpts) InflateBinName ¶ added in v2.18.1
func (opts TablePivotOpts) InflateBinName(binName string, binNumber int, isPct bool) string
func (TablePivotOpts) TableColumns ¶ added in v2.18.1
func (opts TablePivotOpts) TableColumns(binNames []string) ([]string, map[int]string)