OpenMusic-Library zur regelbasierten Harmonie und Stimmführung.
Lorenz Lehmann
12.02.24 e292a63e3e70d3757d7316df3403efd81da68b26
feat (sources): avoid-repetitions

gen-sequence: allow simultaneous use of avoid-repetitions and voice-tie
1 files modified
24 ■■■■ changed files
sources/gen-sequence.lisp 24 ●●●● patch | view | raw | blame | history
sources/gen-sequence.lisp
@@ -162,13 +162,25 @@
                                      
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
                          (temp-base (cond (avoid-repetitions (let ((looplist
                          (temp-base (cond (avoid-repetitions
                                            (let* ((tie-list (mapcar '1- (remove nil (list voice-tie1 voice-tie2 voice-tie3 voice-tie4))))
                                                    (sub-list (cond
                                                               (tie-list (flat_oml (mapcar #'(lambda (l) (subs-posn_oml (loop repeat (length first) collect -2) l -1)) tie-list)))
                                                               (t '(-2 -2 -2 -2))))
                                                    (looplist
                                                                    (remove nil (loop for a in temp-base
                                                                                      collect (if
                                                                                                  (car
                                                                                                   (remove nil
                                                                                                           (mapcar #'(lambda (l) (eq (car l) (cadr l)))
                                                                                                                   (mat-trans_oml (list first a))))) nil a)))))
                                                                       collect (let ((harmony
                                                                                      (remove nil (loop for i in sub-list
                                                                                                        for n1 in first
                                                                                                        for n2 in a
                                                                                                        collect (if (cond ((eq i -1) (eq n1 n2))
                                                                                                                          (t (not (eq n1 n2))))
                                                                                                                    n2)))))
                                                                                 (if (eq (length first) (length harmony)) harmony))))))
                                                                    
                                             (if (null looplist) (list (loop repeat (length (first temp-base)) collect -1)) looplist)))
                                           (t temp-base)))