Skip to content

Commit

Permalink
Add profiling to coalton-library/system
Browse files Browse the repository at this point in the history
  • Loading branch information
Izaakwltn committed Oct 9, 2024
1 parent b75d02f commit 3c5e964
Showing 1 changed file with 63 additions and 0 deletions.
63 changes: 63 additions & 0 deletions library/system.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@
#:time
#:sleep)
(:export
#:get-real-time
#:get-run-time
#+sbcl #:get-bytes-consed
#:Profile
#:make-profile)
(:export

#:LispCondition

Expand Down Expand Up @@ -62,6 +68,63 @@ While the result will always contain microseconds, some implementations may retu
(cl:sleep n)
Unit)))

;;;
;;; Pofiling
;;;

(coalton-toplevel

(declare get-run-time (Unit -> UFix))
(define (get-run-time)
"Gets the run-time."
(lisp UFix ()
(cl:get-internal-run-time)))

(declare get-real-time (Unit -> UFix))
(define (get-real-time)
"Gets the real-time."
(lisp UFix ()
(cl:get-internal-real-time)))

#+sbcl
(declare get-bytes-consed (Unit -> UFix))
#+sbcl
(define (get-bytes-consed)
"Gets the number of bytes consed (only implemented for SBCL"
(lisp UFix ()
(sb-ext:get-bytes-consed)))

(define-struct (Profile :a)
"A profile of a run function."
(output
"The output of the function" :a)
(run-time
"The run time of the run" UFix)
(real-time
"The real time of the run" UFix)
#+sbcl
(bytes-consed
"The number of bytes consed during the run." UFix))

(declare make-profile ((Unit -> :a) -> (Profile :a)))
(define (make-profile f)
"Runs a function, recording profile information and returning a Profile object."
(gc)
(let (#+sbcl
(start-bytes-consed (get-bytes-consed))
(start-run-time (get-run-time))
(start-real-time (get-real-time))
(value (f))
#+sbcl (end-bytes-consed (get-bytes-consed))
(end-run-time (get-run-time))
(end-real-time (get-real-time)))
(Profile
value
(- end-run-time start-run-time)
(- end-real-time start-real-time)
#+sbcl
(- end-bytes-consed start-bytes-consed)))))

;;;
;;; Gathering System information
;;;
Expand Down

0 comments on commit 3c5e964

Please sign in to comment.