aboutsummaryrefslogtreecommitdiff
path: root/module/util/tree.scm
diff options
context:
space:
mode:
authorHugo Hörnquist <hugo@lysator.liu.se>2020-08-24 20:34:11 +0200
committerHugo Hörnquist <hugo@lysator.liu.se>2020-08-24 20:34:11 +0200
commitd3afa54144748685d12c159407194e03538e98de (patch)
tree7a260d6ed4e52e2e1c72729a0922551e3790ba97 /module/util/tree.scm
parent. (diff)
downloadcalp-d3afa54144748685d12c159407194e03538e98de.tar.gz
calp-d3afa54144748685d12c159407194e03538e98de.tar.xz
Move util modules into calp module..
Diffstat (limited to 'module/util/tree.scm')
-rw-r--r--module/util/tree.scm40
1 files changed, 0 insertions, 40 deletions
diff --git a/module/util/tree.scm b/module/util/tree.scm
deleted file mode 100644
index 474dc272..00000000
--- a/module/util/tree.scm
+++ /dev/null
@@ -1,40 +0,0 @@
-(define-module (util tree)
- #:use-module (srfi srfi-1)
- #:use-module (util)
- #:export (make-tree left-subtree
- right-subtree
- length-of-longst-branch
- tree-map))
-
-;; Constructs a binary tree where each node's children is partitioned
-;; into a left and right branch using @var{pred?}.
-;; Has thee form @var{(node left-subtree right-subtree)}. A leaf has
-;; both it's children equal to @var{null}.
-(define (make-tree pred? lst)
- (unless (null? lst)
- (let* ((head tail (partition (lambda (el) (pred? (car lst) el))
- (cdr lst))))
- (list (car lst)
- (make-tree pred? head)
- (make-tree pred? tail)))))
-
-(define (left-subtree tree)
- (list-ref tree 1))
-
-(define (right-subtree tree)
- (list-ref tree 2))
-
-;; Length includes current node, so the length of a leaf is 1.
-(define (length-of-longst-branch tree)
- (if (null? tree)
- ;; Having the @var{1+} outside the @var{max} also works,
- ;; but leads to events overlapping many other to be thinner.
- ;; Having it inside makes all events as evenly wide as possible.
- 0 (max (1+ (length-of-longst-branch (left-subtree tree)))
- (length-of-longst-branch (right-subtree tree)))))
-
-(define (tree-map proc tree)
- (unless (null? tree)
- (list (proc (car tree))
- (tree-map proc (left-subtree tree))
- (tree-map proc (right-subtree tree)))))