aboutsummaryrefslogtreecommitdiff
;;; nsmc --- n-sphere Monte Carlo method
;;; Copyright © 2021 Arun I <arunisaac@systemreboot.net>
;;; Copyright © 2021 Murugesan Venkatapathi <murugesh@iisc.ac.in>
;;;
;;; This file is part of nsmc.
;;;
;;; nsmc is free software: you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation, either version 3 of the License, or
;;; (at your option) any later version.
;;;
;;; nsmc is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
;;; General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with nsmc.  If not, see <https://www.gnu.org/licenses/>.

(sc-define-syntax (when condition body ...)
  (cond
   (condition
    body ...)))

(sc-define-syntax (unless condition body ...)
  (when (not condition)
    body ...))

(sc-define-syntax (for-i index limit body ...)
  (for ((define index int 0)
        (< index limit)
        (set+ index 1))
    body ...))

(sc-define-syntax (for-i-step index start max step body ...)
  (for ((define index int start)
        (<= index max)
        (set+ index step))
    body ...))

(sc-define-syntax (with-alloc var type allocate free body ...)
  (let* ((var type allocate))
    body ...
    (free var)))

(sc-define-syntax (with-vector var size body ...)
  (with-alloc var gsl-vector*
              (gsl-vector-alloc size)
              gsl-vector-free
              body ...))

(sc-define-syntax (with-rng var body ...)
  (with-alloc var gsl-rng*
              (gsl-rng-alloc gsl-rng-default) gsl-rng-free
              body ...))

(sc-define-syntax (with-rstats var body ...)
  (with-alloc var gsl-rstat-workspace*
              (gsl-rstat-alloc) gsl-rstat-free
              body ...))

(sc-define-syntax (with-rstats* var n body ...)
  (begin
    (declare var (array gsl-rstat-workspace* 3))
    (for-i i n
      (array-set var i (gsl-rstat-alloc)))
    body ...
    (for-i i n
      (gsl-rstat-free (array-get var i)))))

(sc-define-syntax (with-file fp filename mode body ...)
  (with-alloc fp FILE* (begin (fopen filename mode)
                              (unless fp
                                (perror filename)
                                (exit EXIT_FAILURE)))
              fclose
              body ...))

(sc-define-syntax* (with-data-file fp filename mode body ...)
  (let* ((data-file (string-append "data/" filename)))
    `(with-file fp ,data-file ,mode
       ,@(if (string=? mode "w")
             `((fprintf stderr "Writing to %s...\n" ,data-file))
             '())
       ,@body)))