/
function.go
92 lines (80 loc) · 2.61 KB
/
function.go
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package multiplySeries
import (
"context"
"fmt"
"github.com/go-graphite/carbonapi/expr/helper"
"github.com/go-graphite/carbonapi/expr/interfaces"
"github.com/go-graphite/carbonapi/expr/types"
"github.com/go-graphite/carbonapi/pkg/parser"
pb "github.com/go-graphite/protocol/carbonapi_v3_pb"
)
type multiplySeries struct {
interfaces.FunctionBase
}
func GetOrder() interfaces.Order {
return interfaces.Any
}
func New(configFile string) []interfaces.FunctionMetadata {
res := make([]interfaces.FunctionMetadata, 0)
f := &multiplySeries{}
functions := []string{"multiplySeries"}
for _, n := range functions {
res = append(res, interfaces.FunctionMetadata{Name: n, F: f})
}
return res
}
// multiplySeries(factorsSeriesList)
func (f *multiplySeries) Do(ctx context.Context, e parser.Expr, from, until int64, values map[parser.MetricRequest][]*types.MetricData) ([]*types.MetricData, error) {
r := types.MetricData{
FetchResponse: pb.FetchResponse{
Name: fmt.Sprintf("multiplySeries(%s)", e.RawArgs()),
},
Tags: nil,
}
for _, arg := range e.Args() {
series, err := helper.GetSeriesArg(arg, from, until, values)
if err != nil {
return nil, err
}
if r.Tags == nil {
r.Tags = series[0].Tags
}
if r.Values == nil {
r.StepTime = series[0].StepTime
r.StartTime = series[0].StartTime
r.StopTime = series[0].StopTime
r.Values = make([]float64, len(series[0].Values))
copy(r.Values, series[0].Values)
series = series[1:]
}
if r.ConsolidationFunc == "" && len(series) > 0 {
r.ConsolidationFunc = series[0].ConsolidationFunc
}
for _, factor := range series {
for i, v := range r.Values {
r.Values[i] = v * factor.Values[i]
}
}
}
return []*types.MetricData{&r}, nil
}
// Description is auto-generated description, based on output of https://github.com/graphite-project/graphite-web
func (f *multiplySeries) Description() map[string]types.FunctionDescription {
return map[string]types.FunctionDescription{
"multiplySeries": {
Description: "Takes two or more series and multiplies their points. A constant may not be\nused. To multiply by a constant, use the scale() function.\n\nExample:\n\n.. code-block:: none\n\n &target=multiplySeries(Series.dividends,Series.divisors)\n\nThis is an alias for :py:func:`aggregate <aggregate>` with aggregation ``multiply``.",
Function: "multiplySeries(*seriesLists)",
Group: "Combine",
Module: "graphite.render.functions",
Name: "multiplySeries",
Params: []types.FunctionParam{
{
Multiple: true,
Name: "seriesLists",
Required: true,
Type: types.SeriesList,
},
},
},
}
}