summaryrefslogtreecommitdiff
path: root/simulation.scm
diff options
context:
space:
mode:
authorEkaitz Zarraga <ekaitz@elenq.tech>2024-12-15 21:00:21 +0100
committerEkaitz Zarraga <ekaitz@elenq.tech>2024-12-15 21:00:21 +0100
commit6a14fc35a2684b5be69df7dc4046a3b9c459627d (patch)
tree2bfde8da6c5cd63d6f396af8ec09bd87d43545d4 /simulation.scm
parent8b5dd05f7781aec971f457ad9c375e12fad8f136 (diff)
simulation: send events to radio, messages to devices
Diffstat (limited to 'simulation.scm')
-rw-r--r--simulation.scm78
1 files changed, 43 insertions, 35 deletions
diff --git a/simulation.scm b/simulation.scm
index 01f31a1..c667750 100644
--- a/simulation.scm
+++ b/simulation.scm
@@ -20,6 +20,12 @@
(let ((now (gettimeofday)))
(format #t "~a~a - ~?~%" (car now) (cdr now) f data)))
+(define-record-type <event>
+ (make-event type data)
+ event?
+ (type event-type)
+ (data event-data))
+
(define-record-type <message>
(make-message id device-id channel-n uplink? body)
message?
@@ -29,6 +35,11 @@
(uplink? message-uplink?)
(body message-body))
+(define-record-type <device>
+ (make-device channel thunk)
+ device?
+ (channel device-channel)
+ (thunk device-thunk))
(define (rand-time)
(random 20))
@@ -50,9 +61,10 @@
(define current-message 0)
(forever
(sleep (rand-time))
- (put-message upstream-chn (make-message current-message id channel #t 'data-start))
- (sleep time-on-air)
- (put-message upstream-chn (make-message current-message id channel #t 'data-end))
+ (let ((message (make-message current-message id channel #t 'data)))
+ (put-message upstream-chn (make-event 'start message))
+ (sleep time-on-air)
+ (put-message upstream-chn (make-event 'end message)))
(set! current-message (1+ current-message))
(sleep receive-delay-1)
(atomic-box-set! listening? #t)
@@ -107,40 +119,36 @@
(lambda ()
(forever
- (let ((msg (get-message in)))
- (match (message-body msg)
- ('data-start
- (set! started (cons msg started)))
- ('data-end
- (set! started
- (remove! (lambda (x)
- (and (= (message-id msg) (message-id x))
- (= (message-device-id msg) (message-device-id x)))) started))
- (if (interference? msg started)
- (ll "Interference!!!!!!")
- (if (message-uplink? msg)
- (hash-for-each (lambda (k gateway)
- (put-message (device-channel gateway)
- (make-message (message-id msg)
- (message-device-id msg)
- (message-channel-n msg)
- #t
- 'data)))
- gateways)
- (put-message
- (device-channel (hash-ref end-devices (message-device-id msg)))
- (make-message (message-id msg)
- (message-device-id msg)
- (message-channel-n msg)
- #f
- 'ack))))))))))
+ (let ((ev (get-message in)))
+ (match (event-type ev)
+ ('start
+ (let ((msg (event-data ev)))
+ (ll "Device ~a started ~a of message ~a"
+ (message-device-id msg)
+ (message-body msg)
+ (message-id msg))
+ (set! started (cons msg started))))
+ ('end
+ (let ((msg (event-data ev)))
+ (ll "Device ~a finished ~a of message ~a"
+ (message-device-id msg)
+ (message-body msg)
+ (message-id msg))
+ (set! started
+ (remove! (lambda (x)
+ (and (= (message-id msg) (message-id x))
+ (= (message-device-id msg) (message-device-id x)))) started))
+ (if (interference? msg started)
+ (ll "Interference!!!!!!")
+ (if (message-uplink? msg)
+ (hash-table-walk gateways
+ (lambda (k gateway)
+ (put-message (device-channel gateway) msg)))
+ (put-message
+ (device-channel (hash-ref end-devices (message-device-id msg)))
+ msg))))))))))
-(define-record-type <device>
- (make-device channel thunk)
- device?
- (channel device-channel)
- (thunk device-thunk))
(define (run-simulation)