-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFps.elm
51 lines (45 loc) · 1.23 KB
/
Fps.elm
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
module Fps where
import Debug exposing (watch)
type alias Fps f =
{ f |
counter: Int
, totalTime: Float
, totalOverDeadline: Int
, lastFps: Float
, lastOverDeadline: Float
, maxFrame: Float
}
initialFps: Fps {}
initialFps =
{ counter = 0
, totalTime = 0
, totalOverDeadline = 0
, lastFps = 0
, lastOverDeadline = 0
, maxFrame = 0
}
-- deadline in ms for reporting high frame times
deadline = 17
-- number of frames to average stats over
numFrames = 60
updateFps: Fps {} -> Float -> Fps {}
updateFps fps t =
let over = if t > deadline then 1 else 0
in if fps.counter == numFrames
then
{ counter = 0
, totalTime = 0
, totalOverDeadline = 0
, lastFps = fps.totalTime / (toFloat fps.counter) |> Debug.watch "avg ms"
, lastOverDeadline = (toFloat fps.totalOverDeadline) / (toFloat fps.counter)
|> Debug.watch ("% frames over " ++ (toString deadline) ++ " ms")
, maxFrame = 0
}
else
{ counter = fps.counter + 1
, totalTime = fps.totalTime + t
, totalOverDeadline = fps.totalOverDeadline + over
, lastFps = fps.lastFps
, lastOverDeadline = fps.lastOverDeadline
, maxFrame = max fps.maxFrame t |> Debug.watch "max frame time"
}