dds/rs.rkt
2020-03-01 19:20:24 +01:00

45 lines
1.2 KiB
Racket

#lang typed/racket
;;; dds/rs
;;; Definitions for working with reaction systems.
(provide
;; Structures
reaction
;; Type names
Species ReactionSystem
;; Functions
enabled? list-enabled)
;;; =================
;;; Basic definitions
;;; =================
;;; A species is a symbol.
(define-type Species Symbol)
;;; A reaction is a triple of sets, giving the reactants, the
;;; inhibitors, and the products, respectively.
(struct reaction ([reactants : (Setof Symbol)]
[inhibitors : (Setof Symbol)]
[products : (Setof Symbol)]))
;;; A reaction is enabled on a set if all of its reactants are in the
;;; set and none of its inhibitors are.
(: enabled? (-> reaction (Setof Symbol) Boolean))
(define/match (enabled? r s)
[((reaction r i p) s)
(and (subset? r s) (set-empty? (set-intersect i s)))])
;;; A reaction system is a dictionary mapping reaction names to
;;; reactions.
(define-type ReactionSystem (HashTable Symbol reaction))
;;; Returns the list of reaction names enabled on a given set.
(: list-enabled (-> ReactionSystem (Setof Symbol) (Listof Symbol)))
(define (list-enabled rs s)
(for/list ([(name reaction) (in-hash rs)]
#:when (enabled? reaction s))
name))