-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathschedule.scm
72 lines (56 loc) · 1.78 KB
/
schedule.scm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
(load "test_programs")
;;;;;;;;;;;;;;;;;;;;Accessors;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(define (queue:pop queue) (car queue))
(define (task:program task) (car task))
(define (task:parent task) (cdr task))
(define (program:first-expr program) (car program))
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(define (calc-deps program)
(let loop ((spot (cdr program)) (count 0))
(if (pair? (car spot))
(set! count (+ 1 count)))
(if (= (length spot) 1)
count
(loop (cdr spot) count))))
;Value: calc-deps
(define (number-deps sched queue)
(let qloop ((queue queue))
(if (= (length queue) 0)
sched
(let ((program (task:program (queue:pop queue))))
(let loop ((spot (cdr program))
(re-def `(,(car program))) (count 0))
(if (pair? (car spot))
(begin
(append! re-def `((get-dep ,(+ (length sched) (length queue)))))
(set! queue (append! queue `(,(cons (car spot) (length sched)))))
(set! count (+ 1 count)))
(append! re-def `(,(car spot))))
(if (= (length spot) 1)
(begin
(set! sched (append! sched `(,(cons re-def (cons count (task:parent (queue:pop queue)))))))
(qloop (cdr queue)))
(loop (cdr spot) re-def count)))))))
;Value: number-deps
(define (make-sched program)
(number-deps '() `((,program #f))))
;Value: make-sched
;;;;;;;;;;;;;;;;;;;;;;;;Test Cases;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(pp (make-sched simple-prog))
(
((+ (get-dep 1) 1) 1 #f)
((* 4 5) 0 . 0)
)
(pp (make-sched program))
(
((+ (get-dep 1) (get-dep 2) (get-dep 3)) 3 #f)
((- 4 6) 0 . 0)
((/ 5 (get-dep 4)) 1 . 0)
((+ 7 (get-dep 5)) 1 . 0)
((* 2 (get-dep 6) (get-dep 7)) 2 . 2)
((* 4 5 (get-dep 8)) 1 . 3)
((- 3 4) 0 . 4)
((* 5 6) 0 . 4)
((- 4 6) 0 . 5)
)
(make-sched '(map (lambda (d) (+ d 1)) '(1 2 3)))