This file summarizes accuracy test for loops of constant duration using the oclock.Timer
class. Tests are done using the performance_test function (see Readme.md), e.g.
from oclock.performance import performance_test
performance_test(dt=0.1, nloops=1000, fmax=0.5, plot=True, precise=True)
Below are some results on timing accuracy in an Unix Environment (MacOS) and Windows, using nloops=1000
, fmax=0.5
for various values of dt
. Regular Timer means with precise=False
while Precise Timer means with precise=True
.
Requested dt (ms) |
1000 |
100 |
40 |
10 |
1 |
average dt - requested dt (ms) |
0.0012 |
0.00012 |
0.00016 |
0.00005 |
0.00023 |
standard deviation in dt (ms) |
0.48 |
0.36 |
0.31 |
0.23 |
0.08 |
Corresponding graphs:
data:image/s3,"s3://crabby-images/e4fe5/e4fe51f8c9698bdd3c0f499bf65727287faf1b22" alt=""
data:image/s3,"s3://crabby-images/d6e18/d6e189a6c4b28d8ad08b95d052989354268e0387" alt=""
data:image/s3,"s3://crabby-images/fd769/fd769f5422fd548a74fa2992ba644208af49b396" alt=""
data:image/s3,"s3://crabby-images/a003b/a003b467522590d67534cea01177a58724d8c842" alt=""
data:image/s3,"s3://crabby-images/02291/022918905f9eaf4a08f9a73e67a8ae8b449c546f" alt=""
Requested dt (ms) |
1000 |
100 |
40 |
10 |
1 |
average dt - requested dt (ms) |
3.6E-5 |
3.4E-5 |
2.8E-5 |
3.0E-5 |
1.2E-5 |
standard deviation in dt (ms) |
0.0118 |
0.0104 |
0.0117 |
0.0105 |
0.0073 |
data:image/s3,"s3://crabby-images/35c0c/35c0c3e60e9ae670a86c0932063a4cb4ce515394" alt=""
data:image/s3,"s3://crabby-images/fd730/fd7306b360d4befc5ed385a4e85e02fd3400a1be" alt=""
data:image/s3,"s3://crabby-images/32567/325676d7f9056200f7f43f80008a3c70b5160ad2" alt=""
data:image/s3,"s3://crabby-images/2f6c0/2f6c0b47c666133d08bc35d6ab52d0acc04832bc" alt=""
data:image/s3,"s3://crabby-images/e1ab0/e1ab002784e69e7c95d369b2debf206871fb1f95" alt=""
Requested dt (ms) |
1000 |
100 |
40 |
10 |
1 |
average dt - requested dt (ms) |
0.014 |
0.0015 |
0.0013 |
1.2 |
1.1 |
standard deviation in dt (ms) |
7.0 |
7.1 |
7.0 |
5.6 |
1.9 |
data:image/s3,"s3://crabby-images/593b5/593b534119dc42a434977fa8702ab01f6693b77c" alt=""
data:image/s3,"s3://crabby-images/6b577/6b577df1378c7f6f97bebde861f50fb7eb5f9c5e" alt=""
data:image/s3,"s3://crabby-images/b7f10/b7f1061e9ebc703d60ff8d91d10949843f2e88f0" alt=""
data:image/s3,"s3://crabby-images/24932/24932eadffd813397eea6625ee4a24d2598035f7" alt=""
data:image/s3,"s3://crabby-images/b7a73/b7a734b88a0c6fb2d389cf6f53443eb068b85855" alt=""
Requested dt (ms) |
1000 |
100 |
40 |
10 |
1 |
average dt - requested dt (ms) |
1.3E-5 |
1.5E-5 |
1.6E-5 |
6.7E-6 |
1.5E-6 |
standard deviation in dt (ms) |
0.0066 |
0.0100 |
0.0088 |
0.0068 |
0.0036 |
data:image/s3,"s3://crabby-images/7110b/7110b4ee391ee2f771d16e0d394ea333f7b87440" alt=""
data:image/s3,"s3://crabby-images/0a8d2/0a8d26606cf526a3539ef4188d1dcf4957b515eb" alt=""
data:image/s3,"s3://crabby-images/1cfce/1cfce25fe76b4de2c63249afa954f6c74b6df98f" alt=""
data:image/s3,"s3://crabby-images/2f882/2f882ce8357291457a5650bb04811918d72420c9" alt=""
data:image/s3,"s3://crabby-images/c28c9/c28c9dd9cfb5f436851b6d27dbd4ce4371862756" alt=""