ewma_test.go 7.76 KB
Newer Older
1 2
package metrics

3 4 5 6
import (
	"math"
	"testing"
)
7 8 9 10 11 12 13 14 15 16 17 18 19 20

func BenchmarkEWMA(b *testing.B) {
	a := NewEWMA1()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		a.Update(1)
		a.Tick()
	}
}

func TestEWMA1(t *testing.T) {
	a := NewEWMA1()
	a.Update(3)
	a.Tick()
21
	if rate := a.Rate(); math.Abs(0.6-rate) > epsilon {
22 23 24
		t.Errorf("initial a.Rate(): 0.6 != %v\n", rate)
	}
	elapseMinute(a)
25
	if rate := a.Rate(); math.Abs(0.22072766470286553-rate) > epsilon {
26 27 28
		t.Errorf("1 minute a.Rate(): 0.22072766470286553 != %v\n", rate)
	}
	elapseMinute(a)
29
	if rate := a.Rate(); math.Abs(0.08120116994196772-rate) > epsilon {
30 31 32
		t.Errorf("2 minute a.Rate(): 0.08120116994196772 != %v\n", rate)
	}
	elapseMinute(a)
33
	if rate := a.Rate(); math.Abs(0.029872241020718428-rate) > epsilon {
34 35 36
		t.Errorf("3 minute a.Rate(): 0.029872241020718428 != %v\n", rate)
	}
	elapseMinute(a)
37
	if rate := a.Rate(); math.Abs(0.01098938333324054-rate) > epsilon {
38 39 40
		t.Errorf("4 minute a.Rate(): 0.01098938333324054 != %v\n", rate)
	}
	elapseMinute(a)
41
	if rate := a.Rate(); math.Abs(0.004042768199451294-rate) > epsilon {
42 43 44
		t.Errorf("5 minute a.Rate(): 0.004042768199451294 != %v\n", rate)
	}
	elapseMinute(a)
45
	if rate := a.Rate(); math.Abs(0.0014872513059998212-rate) > epsilon {
46 47 48
		t.Errorf("6 minute a.Rate(): 0.0014872513059998212 != %v\n", rate)
	}
	elapseMinute(a)
49
	if rate := a.Rate(); math.Abs(0.0005471291793327122-rate) > epsilon {
50 51 52
		t.Errorf("7 minute a.Rate(): 0.0005471291793327122 != %v\n", rate)
	}
	elapseMinute(a)
53
	if rate := a.Rate(); math.Abs(0.00020127757674150815-rate) > epsilon {
54 55 56
		t.Errorf("8 minute a.Rate(): 0.00020127757674150815 != %v\n", rate)
	}
	elapseMinute(a)
57
	if rate := a.Rate(); math.Abs(7.404588245200814e-05-rate) > epsilon {
58 59 60
		t.Errorf("9 minute a.Rate(): 7.404588245200814e-05 != %v\n", rate)
	}
	elapseMinute(a)
61
	if rate := a.Rate(); math.Abs(2.7239957857491083e-05-rate) > epsilon {
62 63 64
		t.Errorf("10 minute a.Rate(): 2.7239957857491083e-05 != %v\n", rate)
	}
	elapseMinute(a)
65
	if rate := a.Rate(); math.Abs(1.0021020474147462e-05-rate) > epsilon {
66 67 68
		t.Errorf("11 minute a.Rate(): 1.0021020474147462e-05 != %v\n", rate)
	}
	elapseMinute(a)
69
	if rate := a.Rate(); math.Abs(3.6865274119969525e-06-rate) > epsilon {
70 71 72
		t.Errorf("12 minute a.Rate(): 3.6865274119969525e-06 != %v\n", rate)
	}
	elapseMinute(a)
73
	if rate := a.Rate(); math.Abs(1.3561976441886433e-06-rate) > epsilon {
74 75 76
		t.Errorf("13 minute a.Rate(): 1.3561976441886433e-06 != %v\n", rate)
	}
	elapseMinute(a)
77
	if rate := a.Rate(); math.Abs(4.989172314621449e-07-rate) > epsilon {
78 79 80
		t.Errorf("14 minute a.Rate(): 4.989172314621449e-07 != %v\n", rate)
	}
	elapseMinute(a)
81
	if rate := a.Rate(); math.Abs(1.8354139230109722e-07-rate) > epsilon {
82 83 84 85 86 87 88 89
		t.Errorf("15 minute a.Rate(): 1.8354139230109722e-07 != %v\n", rate)
	}
}

func TestEWMA5(t *testing.T) {
	a := NewEWMA5()
	a.Update(3)
	a.Tick()
90
	if rate := a.Rate(); math.Abs(0.6-rate) > epsilon {
91 92 93
		t.Errorf("initial a.Rate(): 0.6 != %v\n", rate)
	}
	elapseMinute(a)
94
	if rate := a.Rate(); math.Abs(0.49123845184678905-rate) > epsilon {
95 96 97
		t.Errorf("1 minute a.Rate(): 0.49123845184678905 != %v\n", rate)
	}
	elapseMinute(a)
98
	if rate := a.Rate(); math.Abs(0.4021920276213837-rate) > epsilon {
99 100 101
		t.Errorf("2 minute a.Rate(): 0.4021920276213837 != %v\n", rate)
	}
	elapseMinute(a)
102
	if rate := a.Rate(); math.Abs(0.32928698165641596-rate) > epsilon {
103 104 105
		t.Errorf("3 minute a.Rate(): 0.32928698165641596 != %v\n", rate)
	}
	elapseMinute(a)
106
	if rate := a.Rate(); math.Abs(0.269597378470333-rate) > epsilon {
107 108 109
		t.Errorf("4 minute a.Rate(): 0.269597378470333 != %v\n", rate)
	}
	elapseMinute(a)
110
	if rate := a.Rate(); math.Abs(0.2207276647028654-rate) > epsilon {
111 112 113
		t.Errorf("5 minute a.Rate(): 0.2207276647028654 != %v\n", rate)
	}
	elapseMinute(a)
114
	if rate := a.Rate(); math.Abs(0.18071652714732128-rate) > epsilon {
115 116 117
		t.Errorf("6 minute a.Rate(): 0.18071652714732128 != %v\n", rate)
	}
	elapseMinute(a)
118
	if rate := a.Rate(); math.Abs(0.14795817836496392-rate) > epsilon {
119 120 121
		t.Errorf("7 minute a.Rate(): 0.14795817836496392 != %v\n", rate)
	}
	elapseMinute(a)
122
	if rate := a.Rate(); math.Abs(0.12113791079679326-rate) > epsilon {
123 124 125
		t.Errorf("8 minute a.Rate(): 0.12113791079679326 != %v\n", rate)
	}
	elapseMinute(a)
126
	if rate := a.Rate(); math.Abs(0.09917933293295193-rate) > epsilon {
127 128 129
		t.Errorf("9 minute a.Rate(): 0.09917933293295193 != %v\n", rate)
	}
	elapseMinute(a)
130
	if rate := a.Rate(); math.Abs(0.08120116994196763-rate) > epsilon {
131 132 133
		t.Errorf("10 minute a.Rate(): 0.08120116994196763 != %v\n", rate)
	}
	elapseMinute(a)
134
	if rate := a.Rate(); math.Abs(0.06648189501740036-rate) > epsilon {
135 136 137
		t.Errorf("11 minute a.Rate(): 0.06648189501740036 != %v\n", rate)
	}
	elapseMinute(a)
138
	if rate := a.Rate(); math.Abs(0.05443077197364752-rate) > epsilon {
139 140 141
		t.Errorf("12 minute a.Rate(): 0.05443077197364752 != %v\n", rate)
	}
	elapseMinute(a)
142
	if rate := a.Rate(); math.Abs(0.04456414692860035-rate) > epsilon {
143 144 145
		t.Errorf("13 minute a.Rate(): 0.04456414692860035 != %v\n", rate)
	}
	elapseMinute(a)
146
	if rate := a.Rate(); math.Abs(0.03648603757513079-rate) > epsilon {
147 148 149
		t.Errorf("14 minute a.Rate(): 0.03648603757513079 != %v\n", rate)
	}
	elapseMinute(a)
150
	if rate := a.Rate(); math.Abs(0.0298722410207183831020718428-rate) > epsilon {
151 152 153 154 155 156 157 158
		t.Errorf("15 minute a.Rate(): 0.0298722410207183831020718428 != %v\n", rate)
	}
}

func TestEWMA15(t *testing.T) {
	a := NewEWMA15()
	a.Update(3)
	a.Tick()
159
	if rate := a.Rate(); math.Abs(0.6-rate) > epsilon {
160 161 162
		t.Errorf("initial a.Rate(): 0.6 != %v\n", rate)
	}
	elapseMinute(a)
163
	if rate := a.Rate(); math.Abs(0.5613041910189706-rate) > epsilon {
164 165 166
		t.Errorf("1 minute a.Rate(): 0.5613041910189706 != %v\n", rate)
	}
	elapseMinute(a)
167
	if rate := a.Rate(); math.Abs(0.5251039914257684-rate) > epsilon {
168 169 170
		t.Errorf("2 minute a.Rate(): 0.5251039914257684 != %v\n", rate)
	}
	elapseMinute(a)
171
	if rate := a.Rate(); math.Abs(0.4912384518467888184678905-rate) > epsilon {
172 173 174
		t.Errorf("3 minute a.Rate(): 0.4912384518467888184678905 != %v\n", rate)
	}
	elapseMinute(a)
175
	if rate := a.Rate(); math.Abs(0.459557003018789-rate) > epsilon {
176 177 178
		t.Errorf("4 minute a.Rate(): 0.459557003018789 != %v\n", rate)
	}
	elapseMinute(a)
179
	if rate := a.Rate(); math.Abs(0.4299187863442732-rate) > epsilon {
180 181 182
		t.Errorf("5 minute a.Rate(): 0.4299187863442732 != %v\n", rate)
	}
	elapseMinute(a)
183
	if rate := a.Rate(); math.Abs(0.4021920276213831-rate) > epsilon {
184 185 186
		t.Errorf("6 minute a.Rate(): 0.4021920276213831 != %v\n", rate)
	}
	elapseMinute(a)
187
	if rate := a.Rate(); math.Abs(0.37625345116383313-rate) > epsilon {
188 189 190
		t.Errorf("7 minute a.Rate(): 0.37625345116383313 != %v\n", rate)
	}
	elapseMinute(a)
191
	if rate := a.Rate(); math.Abs(0.3519877317060185-rate) > epsilon {
192 193 194
		t.Errorf("8 minute a.Rate(): 0.3519877317060185 != %v\n", rate)
	}
	elapseMinute(a)
195
	if rate := a.Rate(); math.Abs(0.3292869816564153165641596-rate) > epsilon {
196 197 198
		t.Errorf("9 minute a.Rate(): 0.3292869816564153165641596 != %v\n", rate)
	}
	elapseMinute(a)
199
	if rate := a.Rate(); math.Abs(0.3080502714195546-rate) > epsilon {
200 201 202
		t.Errorf("10 minute a.Rate(): 0.3080502714195546 != %v\n", rate)
	}
	elapseMinute(a)
203
	if rate := a.Rate(); math.Abs(0.2881831806538789-rate) > epsilon {
204 205 206
		t.Errorf("11 minute a.Rate(): 0.2881831806538789 != %v\n", rate)
	}
	elapseMinute(a)
207
	if rate := a.Rate(); math.Abs(0.26959737847033216-rate) > epsilon {
208 209 210
		t.Errorf("12 minute a.Rate(): 0.26959737847033216 != %v\n", rate)
	}
	elapseMinute(a)
211
	if rate := a.Rate(); math.Abs(0.2522102307052083-rate) > epsilon {
212 213 214
		t.Errorf("13 minute a.Rate(): 0.2522102307052083 != %v\n", rate)
	}
	elapseMinute(a)
215
	if rate := a.Rate(); math.Abs(0.23594443252115815-rate) > epsilon {
216 217 218
		t.Errorf("14 minute a.Rate(): 0.23594443252115815 != %v\n", rate)
	}
	elapseMinute(a)
219
	if rate := a.Rate(); math.Abs(0.2207276647028646247028654470286553-rate) > epsilon {
220 221 222 223 224 225 226 227 228
		t.Errorf("15 minute a.Rate(): 0.2207276647028646247028654470286553 != %v\n", rate)
	}
}

func elapseMinute(a EWMA) {
	for i := 0; i < 12; i++ {
		a.Tick()
	}
}