Paste number 319875: profiling experiment

Paste number 319875: profiling experiment
Pasted by: rme
When:8 years, 8 months ago
Share:Tweet this! | http://paste.lisp.org/+6UTF
Channel:None
Paste contents:
Raw Source | XML | Display As
(in-package :ccl)

(defun sample-process-loop (process hash)
  (loop
    (map-call-frames (lambda (p context)
                       (declare (ignore context))
                       (incf (gethash (cfp-lfun p) hash 0)))
                     :process process
                     :count 1)
    (sleep 0.001)))


(defun report-samples (h)
  (let ((results (make-array (hash-table-count h) :adjustable t
                             :fill-pointer 0)))
    (maphash (lambda (k v)
               (vector-push-extend (cons k v) results))
             h)
    (setq results (sort results #'> :key 'cdr))
    (dotimes (i (length results))
      (let ((item (aref results i)))
        (format t "~&~5d  ~s" (cdr item) (car item))))))

(defun call-with-sampling (fn)
  (let* ((h (make-hash-table))
         (sampling-process (process-run-function "sampler"
                                                  'sample-process-loop
                                                  *current-process*
                                                  h)))
    (unwind-protect
         (funcall fn)
      (process-kill sampling-process))
    h))

This paste has no annotations.

Colorize as:
Show Line Numbers

Lisppaste pastes can be made by anyone at any time. Imagine a fearsomely comprehensive disclaimer of liability. Now fear, comprehensively.