github.com/kisexp/xdchain@v0.0.0-20211206025815-490d6b732aa7/metrics/ewma_test.go (about)

     1  package metrics
     2  
     3  import (
     4  	"math"
     5  	"testing"
     6  )
     7  
     8  func BenchmarkEWMA(b *testing.B) {
     9  	a := NewEWMA1()
    10  	b.ResetTimer()
    11  	for i := 0; i < b.N; i++ {
    12  		a.Update(1)
    13  		a.Tick()
    14  	}
    15  }
    16  
    17  func TestEWMA1(t *testing.T) {
    18  	a := NewEWMA1()
    19  	a.Update(3)
    20  	a.Tick()
    21  	if rate := a.Rate(); math.Abs(0.6-rate) > epsilon {
    22  		t.Errorf("initial a.Rate(): 0.6 != %v\n", rate)
    23  	}
    24  	elapseMinute(a)
    25  	if rate := a.Rate(); math.Abs(0.22072766470286553-rate) > epsilon {
    26  		t.Errorf("1 minute a.Rate(): 0.22072766470286553 != %v\n", rate)
    27  	}
    28  	elapseMinute(a)
    29  	if rate := a.Rate(); math.Abs(0.08120116994196772-rate) > epsilon {
    30  		t.Errorf("2 minute a.Rate(): 0.08120116994196772 != %v\n", rate)
    31  	}
    32  	elapseMinute(a)
    33  	if rate := a.Rate(); math.Abs(0.029872241020718428-rate) > epsilon {
    34  		t.Errorf("3 minute a.Rate(): 0.029872241020718428 != %v\n", rate)
    35  	}
    36  	elapseMinute(a)
    37  	if rate := a.Rate(); math.Abs(0.01098938333324054-rate) > epsilon {
    38  		t.Errorf("4 minute a.Rate(): 0.01098938333324054 != %v\n", rate)
    39  	}
    40  	elapseMinute(a)
    41  	if rate := a.Rate(); math.Abs(0.004042768199451294-rate) > epsilon {
    42  		t.Errorf("5 minute a.Rate(): 0.004042768199451294 != %v\n", rate)
    43  	}
    44  	elapseMinute(a)
    45  	if rate := a.Rate(); math.Abs(0.0014872513059998212-rate) > epsilon {
    46  		t.Errorf("6 minute a.Rate(): 0.0014872513059998212 != %v\n", rate)
    47  	}
    48  	elapseMinute(a)
    49  	if rate := a.Rate(); math.Abs(0.0005471291793327122-rate) > epsilon {
    50  		t.Errorf("7 minute a.Rate(): 0.0005471291793327122 != %v\n", rate)
    51  	}
    52  	elapseMinute(a)
    53  	if rate := a.Rate(); math.Abs(0.00020127757674150815-rate) > epsilon {
    54  		t.Errorf("8 minute a.Rate(): 0.00020127757674150815 != %v\n", rate)
    55  	}
    56  	elapseMinute(a)
    57  	if rate := a.Rate(); math.Abs(7.404588245200814e-05-rate) > epsilon {
    58  		t.Errorf("9 minute a.Rate(): 7.404588245200814e-05 != %v\n", rate)
    59  	}
    60  	elapseMinute(a)
    61  	if rate := a.Rate(); math.Abs(2.7239957857491083e-05-rate) > epsilon {
    62  		t.Errorf("10 minute a.Rate(): 2.7239957857491083e-05 != %v\n", rate)
    63  	}
    64  	elapseMinute(a)
    65  	if rate := a.Rate(); math.Abs(1.0021020474147462e-05-rate) > epsilon {
    66  		t.Errorf("11 minute a.Rate(): 1.0021020474147462e-05 != %v\n", rate)
    67  	}
    68  	elapseMinute(a)
    69  	if rate := a.Rate(); math.Abs(3.6865274119969525e-06-rate) > epsilon {
    70  		t.Errorf("12 minute a.Rate(): 3.6865274119969525e-06 != %v\n", rate)
    71  	}
    72  	elapseMinute(a)
    73  	if rate := a.Rate(); math.Abs(1.3561976441886433e-06-rate) > epsilon {
    74  		t.Errorf("13 minute a.Rate(): 1.3561976441886433e-06 != %v\n", rate)
    75  	}
    76  	elapseMinute(a)
    77  	if rate := a.Rate(); math.Abs(4.989172314621449e-07-rate) > epsilon {
    78  		t.Errorf("14 minute a.Rate(): 4.989172314621449e-07 != %v\n", rate)
    79  	}
    80  	elapseMinute(a)
    81  	if rate := a.Rate(); math.Abs(1.8354139230109722e-07-rate) > epsilon {
    82  		t.Errorf("15 minute a.Rate(): 1.8354139230109722e-07 != %v\n", rate)
    83  	}
    84  }
    85  
    86  func TestEWMA5(t *testing.T) {
    87  	a := NewEWMA5()
    88  	a.Update(3)
    89  	a.Tick()
    90  	if rate := a.Rate(); math.Abs(0.6-rate) > epsilon {
    91  		t.Errorf("initial a.Rate(): 0.6 != %v\n", rate)
    92  	}
    93  	elapseMinute(a)
    94  	if rate := a.Rate(); math.Abs(0.49123845184678905-rate) > epsilon {
    95  		t.Errorf("1 minute a.Rate(): 0.49123845184678905 != %v\n", rate)
    96  	}
    97  	elapseMinute(a)
    98  	if rate := a.Rate(); math.Abs(0.4021920276213837-rate) > epsilon {
    99  		t.Errorf("2 minute a.Rate(): 0.4021920276213837 != %v\n", rate)
   100  	}
   101  	elapseMinute(a)
   102  	if rate := a.Rate(); math.Abs(0.32928698165641596-rate) > epsilon {
   103  		t.Errorf("3 minute a.Rate(): 0.32928698165641596 != %v\n", rate)
   104  	}
   105  	elapseMinute(a)
   106  	if rate := a.Rate(); math.Abs(0.269597378470333-rate) > epsilon {
   107  		t.Errorf("4 minute a.Rate(): 0.269597378470333 != %v\n", rate)
   108  	}
   109  	elapseMinute(a)
   110  	if rate := a.Rate(); math.Abs(0.2207276647028654-rate) > epsilon {
   111  		t.Errorf("5 minute a.Rate(): 0.2207276647028654 != %v\n", rate)
   112  	}
   113  	elapseMinute(a)
   114  	if rate := a.Rate(); math.Abs(0.18071652714732128-rate) > epsilon {
   115  		t.Errorf("6 minute a.Rate(): 0.18071652714732128 != %v\n", rate)
   116  	}
   117  	elapseMinute(a)
   118  	if rate := a.Rate(); math.Abs(0.14795817836496392-rate) > epsilon {
   119  		t.Errorf("7 minute a.Rate(): 0.14795817836496392 != %v\n", rate)
   120  	}
   121  	elapseMinute(a)
   122  	if rate := a.Rate(); math.Abs(0.12113791079679326-rate) > epsilon {
   123  		t.Errorf("8 minute a.Rate(): 0.12113791079679326 != %v\n", rate)
   124  	}
   125  	elapseMinute(a)
   126  	if rate := a.Rate(); math.Abs(0.09917933293295193-rate) > epsilon {
   127  		t.Errorf("9 minute a.Rate(): 0.09917933293295193 != %v\n", rate)
   128  	}
   129  	elapseMinute(a)
   130  	if rate := a.Rate(); math.Abs(0.08120116994196763-rate) > epsilon {
   131  		t.Errorf("10 minute a.Rate(): 0.08120116994196763 != %v\n", rate)
   132  	}
   133  	elapseMinute(a)
   134  	if rate := a.Rate(); math.Abs(0.06648189501740036-rate) > epsilon {
   135  		t.Errorf("11 minute a.Rate(): 0.06648189501740036 != %v\n", rate)
   136  	}
   137  	elapseMinute(a)
   138  	if rate := a.Rate(); math.Abs(0.05443077197364752-rate) > epsilon {
   139  		t.Errorf("12 minute a.Rate(): 0.05443077197364752 != %v\n", rate)
   140  	}
   141  	elapseMinute(a)
   142  	if rate := a.Rate(); math.Abs(0.04456414692860035-rate) > epsilon {
   143  		t.Errorf("13 minute a.Rate(): 0.04456414692860035 != %v\n", rate)
   144  	}
   145  	elapseMinute(a)
   146  	if rate := a.Rate(); math.Abs(0.03648603757513079-rate) > epsilon {
   147  		t.Errorf("14 minute a.Rate(): 0.03648603757513079 != %v\n", rate)
   148  	}
   149  	elapseMinute(a)
   150  	if rate := a.Rate(); math.Abs(0.0298722410207183831020718428-rate) > epsilon {
   151  		t.Errorf("15 minute a.Rate(): 0.0298722410207183831020718428 != %v\n", rate)
   152  	}
   153  }
   154  
   155  func TestEWMA15(t *testing.T) {
   156  	a := NewEWMA15()
   157  	a.Update(3)
   158  	a.Tick()
   159  	if rate := a.Rate(); math.Abs(0.6-rate) > epsilon {
   160  		t.Errorf("initial a.Rate(): 0.6 != %v\n", rate)
   161  	}
   162  	elapseMinute(a)
   163  	if rate := a.Rate(); math.Abs(0.5613041910189706-rate) > epsilon {
   164  		t.Errorf("1 minute a.Rate(): 0.5613041910189706 != %v\n", rate)
   165  	}
   166  	elapseMinute(a)
   167  	if rate := a.Rate(); math.Abs(0.5251039914257684-rate) > epsilon {
   168  		t.Errorf("2 minute a.Rate(): 0.5251039914257684 != %v\n", rate)
   169  	}
   170  	elapseMinute(a)
   171  	if rate := a.Rate(); math.Abs(0.4912384518467888184678905-rate) > epsilon {
   172  		t.Errorf("3 minute a.Rate(): 0.4912384518467888184678905 != %v\n", rate)
   173  	}
   174  	elapseMinute(a)
   175  	if rate := a.Rate(); math.Abs(0.459557003018789-rate) > epsilon {
   176  		t.Errorf("4 minute a.Rate(): 0.459557003018789 != %v\n", rate)
   177  	}
   178  	elapseMinute(a)
   179  	if rate := a.Rate(); math.Abs(0.4299187863442732-rate) > epsilon {
   180  		t.Errorf("5 minute a.Rate(): 0.4299187863442732 != %v\n", rate)
   181  	}
   182  	elapseMinute(a)
   183  	if rate := a.Rate(); math.Abs(0.4021920276213831-rate) > epsilon {
   184  		t.Errorf("6 minute a.Rate(): 0.4021920276213831 != %v\n", rate)
   185  	}
   186  	elapseMinute(a)
   187  	if rate := a.Rate(); math.Abs(0.37625345116383313-rate) > epsilon {
   188  		t.Errorf("7 minute a.Rate(): 0.37625345116383313 != %v\n", rate)
   189  	}
   190  	elapseMinute(a)
   191  	if rate := a.Rate(); math.Abs(0.3519877317060185-rate) > epsilon {
   192  		t.Errorf("8 minute a.Rate(): 0.3519877317060185 != %v\n", rate)
   193  	}
   194  	elapseMinute(a)
   195  	if rate := a.Rate(); math.Abs(0.3292869816564153165641596-rate) > epsilon {
   196  		t.Errorf("9 minute a.Rate(): 0.3292869816564153165641596 != %v\n", rate)
   197  	}
   198  	elapseMinute(a)
   199  	if rate := a.Rate(); math.Abs(0.3080502714195546-rate) > epsilon {
   200  		t.Errorf("10 minute a.Rate(): 0.3080502714195546 != %v\n", rate)
   201  	}
   202  	elapseMinute(a)
   203  	if rate := a.Rate(); math.Abs(0.2881831806538789-rate) > epsilon {
   204  		t.Errorf("11 minute a.Rate(): 0.2881831806538789 != %v\n", rate)
   205  	}
   206  	elapseMinute(a)
   207  	if rate := a.Rate(); math.Abs(0.26959737847033216-rate) > epsilon {
   208  		t.Errorf("12 minute a.Rate(): 0.26959737847033216 != %v\n", rate)
   209  	}
   210  	elapseMinute(a)
   211  	if rate := a.Rate(); math.Abs(0.2522102307052083-rate) > epsilon {
   212  		t.Errorf("13 minute a.Rate(): 0.2522102307052083 != %v\n", rate)
   213  	}
   214  	elapseMinute(a)
   215  	if rate := a.Rate(); math.Abs(0.23594443252115815-rate) > epsilon {
   216  		t.Errorf("14 minute a.Rate(): 0.23594443252115815 != %v\n", rate)
   217  	}
   218  	elapseMinute(a)
   219  	if rate := a.Rate(); math.Abs(0.2207276647028646247028654470286553-rate) > epsilon {
   220  		t.Errorf("15 minute a.Rate(): 0.2207276647028646247028654470286553 != %v\n", rate)
   221  	}
   222  }
   223  
   224  func elapseMinute(a EWMA) {
   225  	for i := 0; i < 12; i++ {
   226  		a.Tick()
   227  	}
   228  }