mirror of
https://github.com/prometheus/prometheus.git
synced 2025-03-05 20:59:13 -08:00
make code ready for review
Signed-off-by: Ziqi Zhao <zhaoziqi9146@gmail.com>
This commit is contained in:
parent
4787c879bc
commit
eab3c93e80
|
@ -218,56 +218,6 @@ func (h *FloatHistogram) Add(other *FloatHistogram) *FloatHistogram {
|
||||||
h.Count += other.Count
|
h.Count += other.Count
|
||||||
h.Sum += other.Sum
|
h.Sum += other.Sum
|
||||||
|
|
||||||
// TODO(beorn7): If needed, this can be optimized by inspecting the
|
|
||||||
// spans in other and create missing buckets in h in batches.
|
|
||||||
var iInSpan, index int32
|
|
||||||
for iSpan, iBucket, it := -1, -1, other.floatBucketIterator(true, h.ZeroThreshold, h.Schema); it.Next(); {
|
|
||||||
b := it.At()
|
|
||||||
h.PositiveSpans, h.PositiveBuckets, iSpan, iBucket, iInSpan = addBucket(
|
|
||||||
b, h.PositiveSpans, h.PositiveBuckets, iSpan, iBucket, iInSpan, index,
|
|
||||||
)
|
|
||||||
index = b.Index
|
|
||||||
}
|
|
||||||
for iSpan, iBucket, it := -1, -1, other.floatBucketIterator(false, h.ZeroThreshold, h.Schema); it.Next(); {
|
|
||||||
b := it.At()
|
|
||||||
h.NegativeSpans, h.NegativeBuckets, iSpan, iBucket, iInSpan = addBucket(
|
|
||||||
b, h.NegativeSpans, h.NegativeBuckets, iSpan, iBucket, iInSpan, index,
|
|
||||||
)
|
|
||||||
index = b.Index
|
|
||||||
}
|
|
||||||
return h
|
|
||||||
}
|
|
||||||
|
|
||||||
func (h *FloatHistogram) AddNew(other *FloatHistogram) *FloatHistogram {
|
|
||||||
switch {
|
|
||||||
case other.CounterResetHint == h.CounterResetHint:
|
|
||||||
// Adding apples to apples, all good. No need to change anything.
|
|
||||||
case h.CounterResetHint == GaugeType:
|
|
||||||
// Adding something else to a gauge. That's probably OK. Outcome is a gauge.
|
|
||||||
// Nothing to do since the receiver is already marked as gauge.
|
|
||||||
case other.CounterResetHint == GaugeType:
|
|
||||||
// Similar to before, but this time the receiver is "something else" and we have to change it to gauge.
|
|
||||||
h.CounterResetHint = GaugeType
|
|
||||||
case h.CounterResetHint == UnknownCounterReset:
|
|
||||||
// With the receiver's CounterResetHint being "unknown", this could still be legitimate
|
|
||||||
// if the caller knows what they are doing. Outcome is then again "unknown".
|
|
||||||
// No need to do anything since the receiver's CounterResetHint is already "unknown".
|
|
||||||
case other.CounterResetHint == UnknownCounterReset:
|
|
||||||
// Similar to before, but now we have to set the receiver's CounterResetHint to "unknown".
|
|
||||||
h.CounterResetHint = UnknownCounterReset
|
|
||||||
default:
|
|
||||||
// All other cases shouldn't actually happen.
|
|
||||||
// They are a direct collision of CounterReset and NotCounterReset.
|
|
||||||
// Conservatively set the CounterResetHint to "unknown" and isse a warning.
|
|
||||||
h.CounterResetHint = UnknownCounterReset
|
|
||||||
// TODO(trevorwhitney): Actually issue the warning as soon as the plumbing for it is in place
|
|
||||||
}
|
|
||||||
|
|
||||||
otherZeroCount := h.reconcileZeroBuckets(other)
|
|
||||||
h.ZeroCount += otherZeroCount
|
|
||||||
h.Count += other.Count
|
|
||||||
h.Sum += other.Sum
|
|
||||||
|
|
||||||
otherPositiveSpans := other.PositiveSpans
|
otherPositiveSpans := other.PositiveSpans
|
||||||
otherPositiveBuckets := other.PositiveBuckets
|
otherPositiveBuckets := other.PositiveBuckets
|
||||||
otherNegativeSpans := other.NegativeSpans
|
otherNegativeSpans := other.NegativeSpans
|
||||||
|
@ -277,10 +227,8 @@ func (h *FloatHistogram) AddNew(other *FloatHistogram) *FloatHistogram {
|
||||||
otherNegativeSpans, otherNegativeBuckets = mergeToSchema(other.NegativeSpans, other.NegativeBuckets, other.Schema, h.Schema)
|
otherNegativeSpans, otherNegativeBuckets = mergeToSchema(other.NegativeSpans, other.NegativeBuckets, other.Schema, h.Schema)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(beorn7): If needed, this can be optimized by inspecting the
|
h.PositiveSpans, h.PositiveBuckets = addBuckets(h.Schema, h.ZeroThreshold, false, h.PositiveSpans, h.PositiveBuckets, otherPositiveSpans, otherPositiveBuckets)
|
||||||
// spans in other and create missing buckets in h in batches.
|
h.NegativeSpans, h.NegativeBuckets = addBuckets(h.Schema, h.ZeroThreshold, false, h.NegativeSpans, h.NegativeBuckets, otherNegativeSpans, otherNegativeBuckets)
|
||||||
h.PositiveSpans, h.PositiveBuckets = addBuckets(h.Schema, h.ZeroThreshold, h.PositiveSpans, h.PositiveBuckets, otherPositiveSpans, otherPositiveBuckets)
|
|
||||||
h.NegativeSpans, h.NegativeBuckets = addBuckets(h.Schema, h.ZeroThreshold, h.NegativeSpans, h.NegativeBuckets, otherNegativeSpans, otherNegativeBuckets)
|
|
||||||
return h
|
return h
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -291,25 +239,17 @@ func (h *FloatHistogram) Sub(other *FloatHistogram) *FloatHistogram {
|
||||||
h.Count -= other.Count
|
h.Count -= other.Count
|
||||||
h.Sum -= other.Sum
|
h.Sum -= other.Sum
|
||||||
|
|
||||||
// TODO(beorn7): If needed, this can be optimized by inspecting the
|
otherPositiveSpans := other.PositiveSpans
|
||||||
// spans in other and create missing buckets in h in batches.
|
otherPositiveBuckets := other.PositiveBuckets
|
||||||
var iInSpan, index int32
|
otherNegativeSpans := other.NegativeSpans
|
||||||
for iSpan, iBucket, it := -1, -1, other.floatBucketIterator(true, h.ZeroThreshold, h.Schema); it.Next(); {
|
otherNegativeBuckets := other.NegativeBuckets
|
||||||
b := it.At()
|
if other.Schema != h.Schema {
|
||||||
b.Count *= -1
|
otherPositiveSpans, otherPositiveBuckets = mergeToSchema(other.PositiveSpans, other.PositiveBuckets, other.Schema, h.Schema)
|
||||||
h.PositiveSpans, h.PositiveBuckets, iSpan, iBucket, iInSpan = addBucket(
|
otherNegativeSpans, otherNegativeBuckets = mergeToSchema(other.NegativeSpans, other.NegativeBuckets, other.Schema, h.Schema)
|
||||||
b, h.PositiveSpans, h.PositiveBuckets, iSpan, iBucket, iInSpan, index,
|
|
||||||
)
|
|
||||||
index = b.Index
|
|
||||||
}
|
|
||||||
for iSpan, iBucket, it := -1, -1, other.floatBucketIterator(false, h.ZeroThreshold, h.Schema); it.Next(); {
|
|
||||||
b := it.At()
|
|
||||||
b.Count *= -1
|
|
||||||
h.NegativeSpans, h.NegativeBuckets, iSpan, iBucket, iInSpan = addBucket(
|
|
||||||
b, h.NegativeSpans, h.NegativeBuckets, iSpan, iBucket, iInSpan, index,
|
|
||||||
)
|
|
||||||
index = b.Index
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
h.PositiveSpans, h.PositiveBuckets = addBuckets(h.Schema, h.ZeroThreshold, true, h.PositiveSpans, h.PositiveBuckets, otherPositiveSpans, otherPositiveBuckets)
|
||||||
|
h.NegativeSpans, h.NegativeBuckets = addBuckets(h.Schema, h.ZeroThreshold, true, h.NegativeSpans, h.NegativeBuckets, otherNegativeSpans, otherNegativeBuckets)
|
||||||
return h
|
return h
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1080,16 +1020,19 @@ func mergeToSchema(originSpans []Span, originBuckets []float64, originSchema, ta
|
||||||
return targetSpans, targetBuckets
|
return targetSpans, targetBuckets
|
||||||
}
|
}
|
||||||
|
|
||||||
func addBuckets(schema int32, threshold float64, spansA []Span, bucketsA []float64, spansB []Span, bucketsB []float64) ([]Span, []float64) {
|
// addBuckets add two groups of Spans by inspecting the
|
||||||
|
// spans in other and create missing buckets in origin in batches.
|
||||||
|
func addBuckets(schema int32, threshold float64, negative bool, spansA []Span, bucketsA []float64, spansB []Span, bucketsB []float64) ([]Span, []float64) {
|
||||||
var (
|
var (
|
||||||
iSpan int = -1
|
iSpan int = -1
|
||||||
iBucket int = -1
|
iBucket int = -1
|
||||||
iInSpan int32
|
iInSpan int32
|
||||||
indexA int32
|
indexA int32
|
||||||
indexB int32 = 0
|
indexB int32
|
||||||
bIdxB int = 0
|
bIdxB int
|
||||||
lowerThanThreshold = true
|
bucketB float64
|
||||||
deltaIndex int32
|
deltaIndex int32
|
||||||
|
lowerThanThreshold = true
|
||||||
)
|
)
|
||||||
|
|
||||||
for _, spanB := range spansB {
|
for _, spanB := range spansB {
|
||||||
|
@ -1100,17 +1043,22 @@ func addBuckets(schema int32, threshold float64, spansA []Span, bucketsA []float
|
||||||
}
|
}
|
||||||
lowerThanThreshold = false
|
lowerThanThreshold = false
|
||||||
|
|
||||||
|
bucketB = bucketsB[bIdxB]
|
||||||
|
if negative {
|
||||||
|
bucketB *= -1
|
||||||
|
}
|
||||||
|
|
||||||
if iSpan == -1 {
|
if iSpan == -1 {
|
||||||
if len(spansA) == 0 || spansA[0].Offset > indexB {
|
if len(spansA) == 0 || spansA[0].Offset > indexB {
|
||||||
// Add bucket before all others.
|
// Add bucket before all others.
|
||||||
bucketsA = append(bucketsA, 0)
|
bucketsA = append(bucketsA, 0)
|
||||||
copy(bucketsA[1:], bucketsA)
|
copy(bucketsA[1:], bucketsA)
|
||||||
bucketsA[0] = bucketsB[bIdxB]
|
bucketsA[0] = bucketB
|
||||||
if len(spansA) > 0 && spansA[0].Offset == indexB+1 { // bIndex just preceed spansA[0] by one step
|
if len(spansA) > 0 && spansA[0].Offset == indexB+1 {
|
||||||
spansA[0].Length++
|
spansA[0].Length++
|
||||||
spansA[0].Offset--
|
spansA[0].Offset--
|
||||||
goto nextLoop
|
goto nextLoop
|
||||||
} else { // if not create new span
|
} else {
|
||||||
spansA = append(spansA, Span{})
|
spansA = append(spansA, Span{})
|
||||||
copy(spansA[1:], spansA)
|
copy(spansA[1:], spansA)
|
||||||
spansA[0] = Span{Offset: indexB, Length: 1}
|
spansA[0] = Span{Offset: indexB, Length: 1}
|
||||||
|
@ -1123,7 +1071,7 @@ func addBuckets(schema int32, threshold float64, spansA []Span, bucketsA []float
|
||||||
}
|
}
|
||||||
} else if spansA[0].Offset == indexB {
|
} else if spansA[0].Offset == indexB {
|
||||||
// Just add to first bucket.
|
// Just add to first bucket.
|
||||||
bucketsA[0] += bucketsB[bIdxB]
|
bucketsA[0] += bucketB
|
||||||
goto nextLoop
|
goto nextLoop
|
||||||
}
|
}
|
||||||
iSpan, iBucket, iInSpan = 0, 0, 0
|
iSpan, iBucket, iInSpan = 0, 0, 0
|
||||||
|
@ -1136,7 +1084,7 @@ func addBuckets(schema int32, threshold float64, spansA []Span, bucketsA []float
|
||||||
// Bucket is in current span.
|
// Bucket is in current span.
|
||||||
iBucket += int(deltaIndex)
|
iBucket += int(deltaIndex)
|
||||||
iInSpan += deltaIndex
|
iInSpan += deltaIndex
|
||||||
bucketsA[iBucket] += bucketsB[bIdxB]
|
bucketsA[iBucket] += bucketB
|
||||||
break
|
break
|
||||||
} else {
|
} else {
|
||||||
deltaIndex -= remainingInSpan
|
deltaIndex -= remainingInSpan
|
||||||
|
@ -1146,7 +1094,7 @@ func addBuckets(schema int32, threshold float64, spansA []Span, bucketsA []float
|
||||||
// Bucket is in gap behind previous span (or there are no further spans).
|
// Bucket is in gap behind previous span (or there are no further spans).
|
||||||
bucketsA = append(bucketsA, 0)
|
bucketsA = append(bucketsA, 0)
|
||||||
copy(bucketsA[iBucket+1:], bucketsA[iBucket:])
|
copy(bucketsA[iBucket+1:], bucketsA[iBucket:])
|
||||||
bucketsA[iBucket] = bucketsB[bIdxB]
|
bucketsA[iBucket] = bucketB
|
||||||
if deltaIndex == 0 {
|
if deltaIndex == 0 {
|
||||||
// Directly after previous span, extend previous span.
|
// Directly after previous span, extend previous span.
|
||||||
if iSpan < len(spansA) {
|
if iSpan < len(spansA) {
|
||||||
|
|
|
@ -16,7 +16,6 @@ package histogram
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
"math/rand"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
@ -2253,495 +2252,3 @@ func TestFloatBucketIteratorTargetSchema(t *testing.T) {
|
||||||
}
|
}
|
||||||
require.False(t, it.Next(), "negative iterator not exhausted")
|
require.False(t, it.Next(), "negative iterator not exhausted")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFloatHistogramAddNew(t *testing.T) {
|
|
||||||
cases := []struct {
|
|
||||||
name string
|
|
||||||
in1, in2, expected *FloatHistogram
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
"same bucket layout",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {1, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {1, 3}},
|
|
||||||
PositiveBuckets: []float64{0, 0, 2, 3, 6},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {1, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 5, 7, 13},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{4, 2, 9, 10},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"same bucket layout, defined differently",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {1, 1}, {0, 2}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {1, 2}, {0, 1}},
|
|
||||||
PositiveBuckets: []float64{0, 0, 2, 3, 6},
|
|
||||||
NegativeSpans: []Span{{3, 7}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 0, 0, 0, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {1, 1}, {0, 2}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 5, 7, 13},
|
|
||||||
NegativeSpans: []Span{{3, 5}, {0, 2}},
|
|
||||||
NegativeBuckets: []float64{4, 2, 0, 0, 0, 9, 10},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"non-overlapping spans",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{0, 2}, {3, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 3, 6},
|
|
||||||
NegativeSpans: []Span{{-9, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.001,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 4}, {0, 6}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 5, 4, 3, 4, 7, 2, 3, 6},
|
|
||||||
NegativeSpans: []Span{{-9, 2}, {3, 2}, {5, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4, 3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"non-overlapping inverted order",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{0, 2}, {3, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 3, 6},
|
|
||||||
NegativeSpans: []Span{{-9, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {0, 5}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 5, 4, 3, 4, 7, 2, 3, 6},
|
|
||||||
NegativeSpans: []Span{{-9, 2}, {3, 2}, {5, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4, 3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"overlapping spans",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{-1, 4}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 4}, {0, 4}},
|
|
||||||
PositiveBuckets: []float64{1, 5, 4, 2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"overlapping spans inverted order",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{-1, 4}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 5}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 5, 4, 2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"schema change",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
Schema: 0,
|
|
||||||
PositiveSpans: []Span{{-1, 4}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
Schema: 1,
|
|
||||||
PositiveSpans: []Span{{-4, 3}, {5, 5}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 0, 3, 2, 2, 3, 4},
|
|
||||||
NegativeSpans: []Span{{6, 3}, {6, 4}},
|
|
||||||
NegativeBuckets: []float64{3, 0.5, 0.5, 2, 3, 2, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 19,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-2, 5}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 5, 4, 2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"larger zero bucket in first histogram",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 1,
|
|
||||||
ZeroCount: 17,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{1, 2}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 1,
|
|
||||||
ZeroCount: 29,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{1, 2}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"larger zero bucket in second histogram",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 1,
|
|
||||||
ZeroCount: 17,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{1, 2}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 1,
|
|
||||||
ZeroCount: 29,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{1, 5}},
|
|
||||||
PositiveBuckets: []float64{2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"larger zero threshold in first histogram ends up inside a populated bucket of second histogram",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.2,
|
|
||||||
ZeroCount: 17,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{1, 2}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.25,
|
|
||||||
ZeroCount: 29,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-1, 1}, {1, 5}},
|
|
||||||
PositiveBuckets: []float64{0, 2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"larger zero threshold in second histogram ends up inside a populated bucket of first histogram",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
PositiveSpans: []Span{{-2, 2}, {2, 3}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 4, 7},
|
|
||||||
NegativeSpans: []Span{{3, 2}, {3, 2}},
|
|
||||||
NegativeBuckets: []float64{3, 1, 5, 6},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.2,
|
|
||||||
ZeroCount: 17,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
PositiveSpans: []Span{{1, 2}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.25,
|
|
||||||
ZeroCount: 29,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{1, 5}},
|
|
||||||
PositiveBuckets: []float64{2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"schema change combined with larger zero bucket in second histogram",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
Schema: 0,
|
|
||||||
PositiveSpans: []Span{{-2, 5}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{2, 5, 4, 2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.25,
|
|
||||||
ZeroCount: 12,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
Schema: 1,
|
|
||||||
PositiveSpans: []Span{{-3, 2}, {5, 5}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 3, 2, 2, 3, 4},
|
|
||||||
NegativeSpans: []Span{{6, 3}, {6, 4}},
|
|
||||||
NegativeBuckets: []float64{3, 0.5, 0.5, 2, 3, 2, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.25,
|
|
||||||
ZeroCount: 22,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-1, 7}},
|
|
||||||
PositiveBuckets: []float64{6, 4, 2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"schema change combined with larger zero bucket in first histogram",
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.25,
|
|
||||||
ZeroCount: 8,
|
|
||||||
Count: 21,
|
|
||||||
Sum: 1.234,
|
|
||||||
Schema: 0,
|
|
||||||
PositiveSpans: []Span{{-1, 4}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 3, 6, 2, 5},
|
|
||||||
NegativeSpans: []Span{{4, 2}, {1, 2}},
|
|
||||||
NegativeBuckets: []float64{1, 1, 4, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.01,
|
|
||||||
ZeroCount: 11,
|
|
||||||
Count: 30,
|
|
||||||
Sum: 2.345,
|
|
||||||
Schema: 1,
|
|
||||||
PositiveSpans: []Span{{-4, 3}, {5, 5}},
|
|
||||||
PositiveBuckets: []float64{1, 0, 0, 3, 2, 2, 3, 4},
|
|
||||||
NegativeSpans: []Span{{6, 3}, {6, 4}},
|
|
||||||
NegativeBuckets: []float64{3, 0.5, 0.5, 2, 3, 2, 4},
|
|
||||||
},
|
|
||||||
&FloatHistogram{
|
|
||||||
ZeroThreshold: 0.25,
|
|
||||||
ZeroCount: 20,
|
|
||||||
Count: 51,
|
|
||||||
Sum: 3.579,
|
|
||||||
PositiveSpans: []Span{{-1, 4}, {0, 3}},
|
|
||||||
PositiveBuckets: []float64{5, 4, 2, 6, 10, 9, 5},
|
|
||||||
NegativeSpans: []Span{{3, 3}, {1, 3}},
|
|
||||||
NegativeBuckets: []float64{3, 2, 1, 4, 9, 6},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, c := range cases {
|
|
||||||
t.Run(c.name, func(t *testing.T) {
|
|
||||||
require.Equal(t, c.expected, c.in1.AddNew(c.in2))
|
|
||||||
// Has it also happened in-place?
|
|
||||||
require.Equal(t, c.expected, c.in1)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func BenchmarkAddOld(b *testing.B) {
|
|
||||||
for n := 0; n < b.N; n++ {
|
|
||||||
b.StopTimer()
|
|
||||||
f1 := createRandomFloatHistogram(50)
|
|
||||||
f2 := createRandomFloatHistogram(50)
|
|
||||||
b.StartTimer()
|
|
||||||
f1.Add(f2)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func BenchmarkAddNew(b *testing.B) {
|
|
||||||
for n := 0; n < b.N; n++ {
|
|
||||||
b.StopTimer()
|
|
||||||
f1 := createRandomFloatHistogram(50)
|
|
||||||
f2 := createRandomFloatHistogram(50)
|
|
||||||
b.StartTimer()
|
|
||||||
f1.AddNew(f2)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func createRandomFloatHistogram(spanNum int32) *FloatHistogram {
|
|
||||||
f := &FloatHistogram{}
|
|
||||||
f.PositiveSpans, f.PositiveBuckets = createRandomSpans(spanNum)
|
|
||||||
f.NegativeSpans, f.NegativeBuckets = createRandomSpans(spanNum)
|
|
||||||
return f
|
|
||||||
}
|
|
||||||
|
|
||||||
func createRandomSpans(spanNum int32) ([]Span, []float64) {
|
|
||||||
Spans := make([]Span, spanNum)
|
|
||||||
Buckets := make([]float64, 0)
|
|
||||||
for i := 0; i < int(spanNum); i++ {
|
|
||||||
Spans[i].Offset = rand.Int31n(spanNum) + 1
|
|
||||||
Spans[i].Length = uint32(rand.Int31n(spanNum) + 1)
|
|
||||||
for j := 0; j < int(Spans[i].Length); j++ {
|
|
||||||
Buckets = append(Buckets, float64(rand.Int31n(spanNum)+1))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return Spans, Buckets
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue