From e292a63e3e70d3757d7316df3403efd81da68b26 Mon Sep 17 00:00:00 2001 From: Lorenz Lehmann <lorenz.lehmann@students.muho-mannheim.de> Date: Mon, 12 Feb 2024 08:49:49 +0100 Subject: [PATCH] feat (sources): avoid-repetitions --- sources/gen-sequence.lisp | 871 ++++++++++++++++++++++++++++++++------------------------- 1 files changed, 488 insertions(+), 383 deletions(-) diff --git a/sources/gen-sequence.lisp b/sources/gen-sequence.lisp index f9c2de7..d8424ff 100644 --- a/sources/gen-sequence.lisp +++ b/sources/gen-sequence.lisp @@ -36,133 +36,119 @@ (loop repeat (- number-of-harmonies 1) for database in database - for voice-tie1 in (cond ((atom voice-tie1) (loop repeat number-of-harmonies collect voice-tie1)) - ((< (length voice-tie1) number-of-harmonies) - (append voice-tie1 (loop repeat (- number-of-harmonies (length voice-tie1)) collect (car (reverse voice-tie1))))) + for voice-tie1 in (cond ((atom voice-tie1) (loop repeat (1- number-of-harmonies) collect voice-tie1)) + ((< (length voice-tie1) (1- number-of-harmonies)) + (append voice-tie1 (loop repeat (- (1- number-of-harmonies) (length voice-tie1)) collect (car (reverse voice-tie1))))) (t voice-tie1)) - for voice-tie2 in (cond ((atom voice-tie2) (loop repeat number-of-harmonies collect voice-tie2)) - ((< (length voice-tie2) number-of-harmonies) - (append voice-tie2 (loop repeat (- number-of-harmonies (length voice-tie2)) collect (car (reverse voice-tie2))))) + for voice-tie2 in (cond ((atom voice-tie2) (loop repeat (1- number-of-harmonies) collect voice-tie2)) + ((< (length voice-tie2) (1- number-of-harmonies)) + (append voice-tie2 (loop repeat (- (1- number-of-harmonies) (length voice-tie2)) collect (car (reverse voice-tie2))))) (t voice-tie2)) - for voice-tie3 in (cond ((atom voice-tie3) (loop repeat number-of-harmonies collect voice-tie3)) - ((< (length voice-tie3) number-of-harmonies) - (append voice-tie3 (loop repeat (- number-of-harmonies (length voice-tie3)) collect (car (reverse voice-tie3))))) + for voice-tie3 in (cond ((atom voice-tie3) (loop repeat (1- number-of-harmonies) collect voice-tie3)) + ((< (length voice-tie3) (1- number-of-harmonies)) + (append voice-tie3 (loop repeat (- (1- number-of-harmonies) (length voice-tie3)) collect (car (reverse voice-tie3))))) (t voice-tie3)) - for voice-tie4 in (cond ((atom voice-tie4) (loop repeat number-of-harmonies collect voice-tie4)) - ((< (length voice-tie4) number-of-harmonies) - (append voice-tie4 (loop repeat (- number-of-harmonies (length voice-tie4)) collect (car (reverse voice-tie4))))) + for voice-tie4 in (cond ((atom voice-tie4) (loop repeat (1- number-of-harmonies) collect voice-tie4)) + ((< (length voice-tie4) (1- number-of-harmonies)) + (append voice-tie4 (loop repeat (- (1- number-of-harmonies) (length voice-tie4)) collect (car (reverse voice-tie4))))) (t voice-tie4)) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - for voice-interval1 in (cond ((atom (car voice-interval1)) (loop repeat number-of-harmonies collect voice-interval1)) - ((< (length voice-interval1) number-of-harmonies) - (append voice-interval1 (loop repeat (- number-of-harmonies (length voice-interval1)) collect (car (reverse voice-interval1))))) + for voice-interval1 in (cond ((atom (car voice-interval1)) (loop repeat (1- number-of-harmonies) collect voice-interval1)) + ((< (length voice-interval1) (1- number-of-harmonies)) + (append voice-interval1 (loop repeat (- (1- number-of-harmonies) (length voice-interval1)) collect (car (reverse voice-interval1))))) (t voice-interval1)) - for voice-interval2 in (cond ((atom (car voice-interval2)) (loop repeat number-of-harmonies collect voice-interval2)) - ((< (length voice-interval2) number-of-harmonies) - (append voice-interval2 (loop repeat (- number-of-harmonies (length voice-interval2)) collect (car (reverse voice-interval2))))) + for voice-interval2 in (cond ((atom (car voice-interval2)) (loop repeat (1- number-of-harmonies) collect voice-interval2)) + ((< (length voice-interval2) (1- number-of-harmonies)) + (append voice-interval2 (loop repeat (- (1- number-of-harmonies) (length voice-interval2)) collect (car (reverse voice-interval2))))) (t voice-interval2)) - for voice-interval3 in (cond ((atom (car voice-interval3)) (loop repeat number-of-harmonies collect voice-interval3)) - ((< (length voice-interval3) number-of-harmonies) - (append voice-interval3 (loop repeat (- number-of-harmonies (length voice-interval3)) collect (car (reverse voice-interval3))))) + for voice-interval3 in (cond ((atom (car voice-interval3)) (loop repeat (1- number-of-harmonies) collect voice-interval3)) + ((< (length voice-interval3) (1- number-of-harmonies)) + (append voice-interval3 (loop repeat (- (1- number-of-harmonies) (length voice-interval3)) collect (car (reverse voice-interval3))))) (t voice-interval3)) - for voice-interval4 in (cond ((atom (car voice-interval4)) (loop repeat number-of-harmonies collect voice-interval4)) - ((< (length voice-interval4) number-of-harmonies) - (append voice-interval4 (loop repeat (- number-of-harmonies (length voice-interval4)) collect (car (reverse voice-interval4))))) + for voice-interval4 in (cond ((atom (car voice-interval4)) (loop repeat (1- number-of-harmonies) collect voice-interval4)) + ((< (length voice-interval4) (1- number-of-harmonies)) + (append voice-interval4 (loop repeat (- (1- number-of-harmonies) (length voice-interval4)) collect (car (reverse voice-interval4))))) (t voice-interval4)) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - for voice-counter1 in (if (eq nil voice-counter1) (loop repeat number-of-harmonies collect nil) - - (mat-trans_oml (list (cond ((not (listp (caar voice-counter1))) (loop repeat number-of-harmonies collect (car voice-counter1))) - ((< (length (car voice-counter1)) number-of-harmonies) - (append (car voice-counter1) (loop repeat (- number-of-harmonies (length (car voice-counter1))) - collect (car (reverse (car voice-counter1)))))) - (t (car voice-counter1))) - (cond ((< (length (cadr voice-counter1)) number-of-harmonies) - (append (cadr voice-counter1) (loop repeat (- number-of-harmonies (length (cadr voice-counter1))) - collect (car (reverse (cadr voice-counter1)))))) - (t (cadr voice-counter1)))))) - for voice-counter2 in (if (eq nil voice-counter2) (loop repeat number-of-harmonies collect nil) - - (mat-trans_oml (list (cond ((not (listp (caar voice-counter2))) (loop repeat number-of-harmonies collect (car voice-counter2))) - ((< (length (car voice-counter2)) number-of-harmonies) - (append (car voice-counter2) (loop repeat (- number-of-harmonies (length (car voice-counter2))) - collect (car (reverse (car voice-counter2)))))) - (t (car voice-counter2))) - (cond ((< (length (cadr voice-counter2)) number-of-harmonies) - (append (cadr voice-counter2) (loop repeat (- number-of-harmonies (length (cadr voice-counter2))) - collect (car (reverse (cadr voice-counter2)))))) - (t (cadr voice-counter2)))))) - for voice-counter3 in (if (eq nil voice-counter3) (loop repeat number-of-harmonies collect nil) - - (mat-trans_oml (list (cond ((not (listp (caar voice-counter3))) (loop repeat number-of-harmonies collect (car voice-counter3))) - ((< (length (car voice-counter3)) number-of-harmonies) - (append (car voice-counter3) (loop repeat (- number-of-harmonies (length (car voice-counter3))) - collect (car (reverse (car voice-counter3)))))) - (t (car voice-counter3))) - (cond ((< (length (cadr voice-counter3)) number-of-harmonies) - (append (cadr voice-counter3) (loop repeat (- number-of-harmonies (length (cadr voice-counter3))) - collect (car (reverse (cadr voice-counter3)))))) - (t (cadr voice-counter3)))))) - for voice-counter4 in (if (eq nil voice-counter4) (loop repeat number-of-harmonies collect nil) - - (mat-trans_oml (list (cond ((not (listp (caar voice-counter4))) (loop repeat number-of-harmonies collect (car voice-counter4))) - ((< (length (car voice-counter4)) number-of-harmonies) - (append (car voice-counter4) (loop repeat (- number-of-harmonies (length (car voice-counter4))) - collect (car (reverse (car voice-counter4)))))) - (t (car voice-counter4))) - (cond ((< (length (cadr voice-counter4)) number-of-harmonies) - (append (cadr voice-counter4) (loop repeat (- number-of-harmonies (length (cadr voice-counter4))) - collect (car (reverse (cadr voice-counter4)))))) - (t (cadr voice-counter4)))))) - for voice-counter5 in (if (eq nil voice-counter5) (loop repeat number-of-harmonies collect nil) - - (mat-trans_oml (list (cond ((not (listp (caar voice-counter5))) (loop repeat number-of-harmonies collect (car voice-counter5))) - ((< (length (car voice-counter5)) number-of-harmonies) - (append (car voice-counter5) (loop repeat (- number-of-harmonies (length (car voice-counter5))) - collect (car (reverse (car voice-counter5)))))) - (t (car voice-counter5))) - (cond ((< (length (cadr voice-counter5)) number-of-harmonies) - (append (cadr voice-counter5) (loop repeat (- number-of-harmonies (length (cadr voice-counter5))) - collect (car (reverse (cadr voice-counter5)))))) - (t (cadr voice-counter5)))))) - for voice-counter6 in (if (eq nil voice-counter6) (loop repeat number-of-harmonies collect nil) - - (mat-trans_oml (list (cond ((not (listp (caar voice-counter6))) (loop repeat number-of-harmonies collect (car voice-counter6))) - ((< (length (car voice-counter6)) number-of-harmonies) - (append (car voice-counter6) (loop repeat (- number-of-harmonies (length (car voice-counter6))) - collect (car (reverse (car voice-counter6)))))) - (t (car voice-counter6))) - (cond ((< (length (cadr voice-counter6)) number-of-harmonies) - (append (cadr voice-counter6) (loop repeat (- number-of-harmonies (length (cadr voice-counter6))) - collect (car (reverse (cadr voice-counter6)))))) - (t (cadr voice-counter6)))))) + for voice-counter1 in (cond ((atom voice-counter1) + (loop repeat (1- number-of-harmonies) collect voice-counter1)) + ((listp (caar voice-counter1)) + (if (< (length voice-counter1) (1- number-of-harmonies)) + (loop repeat (- (1- number-of-harmonies) (length voice)) collect (car voice-counter1)) + voice-counter1)) + (t (loop repeat (1- number-of-harmonies) collect voice-counter1))) + + + for voice-counter2 in (cond ((atom voice-counter2) + (loop repeat (1- number-of-harmonies) collect voice-counter2)) + ((listp (caar voice-counter2)) + (if (< (length voice-counter2) (1- number-of-harmonies)) + (loop repeat (- (1- number-of-harmonies) (length voice)) collect (car voice-counter2)) + voice-counter2)) + (t (loop repeat (1- number-of-harmonies) collect voice-counter2))) + + + for voice-counter3 in (cond ((atom voice-counter3) + (loop repeat (1- number-of-harmonies) collect voice-counter3)) + ((listp (caar voice-counter3)) + (if (< (length voice-counter3) (1- number-of-harmonies)) + (loop repeat (- (1- number-of-harmonies) (length voice)) collect (car voice-counter3)) + voice-counter3)) + (t (loop repeat (1- number-of-harmonies) collect voice-counter3))) + + + for voice-counter4 in (cond ((atom voice-counter4) + (loop repeat (1- number-of-harmonies) collect voice-counter4)) + ((listp (caar voice-counter4)) + (if (< (length voice-counter4) (1- number-of-harmonies)) + (loop repeat (- (1- number-of-harmonies) (length voice)) collect (car voice-counter4)) + voice-counter4)) + (t (loop repeat (1- number-of-harmonies) collect voice-counter4))) + + + for voice-counter5 in (cond ((atom voice-counter5) + (loop repeat (1- number-of-harmonies) collect voice-counter5)) + ((listp (caar voice-counter5)) + (if (< (length voice-counter5) (1- number-of-harmonies)) + (loop repeat (- (1- number-of-harmonies) (length voice)) collect (car voice-counter5)) + voice-counter5)) + (t (loop repeat (1- number-of-harmonies) collect voice-counter5))) + + + for voice-counter6 in (cond ((atom voice-counter6) + (loop repeat (1- number-of-harmonies) collect voice-counter6)) + ((listp (caar voice-counter6)) + (if (< (length voice-counter6) (1- number-of-harmonies)) + (loop repeat (- (1- number-of-harmonies) (length voice)) collect (car voice-counter6)) + voice-counter6)) + (t (loop repeat (1- number-of-harmonies) collect voice-counter6))) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - for counter-interval1 in (cond ((atom (car counter-interval1)) (loop repeat number-of-harmonies collect counter-interval1)) - ((< (length counter-interval1) number-of-harmonies) - (append counter-interval1 (loop repeat (- number-of-harmonies (length counter-interval1)) collect (car (reverse counter-interval1))))) + for counter-interval1 in (cond ((atom (car counter-interval1)) (loop repeat (1- number-of-harmonies) collect counter-interval1)) + ((< (length counter-interval1) (1- number-of-harmonies)) + (append counter-interval1 (loop repeat (- (1- number-of-harmonies) (length counter-interval1)) collect (car (reverse counter-interval1))))) (t counter-interval1)) - for counter-interval2 in (cond ((atom (car counter-interval2)) (loop repeat number-of-harmonies collect counter-interval2)) - ((< (length counter-interval2) number-of-harmonies) - (append counter-interval2 (loop repeat (- number-of-harmonies (length counter-interval2)) collect (car (reverse counter-interval2))))) + for counter-interval2 in (cond ((atom (car counter-interval2)) (loop repeat (1- number-of-harmonies) collect counter-interval2)) + ((< (length counter-interval2) (1- number-of-harmonies)) + (append counter-interval2 (loop repeat (- (1- number-of-harmonies) (length counter-interval2)) collect (car (reverse counter-interval2))))) (t counter-interval2)) - for counter-interval3 in (cond ((atom (car counter-interval3)) (loop repeat number-of-harmonies collect counter-interval3)) - ((< (length counter-interval3) number-of-harmonies) - (append counter-interval3 (loop repeat (- number-of-harmonies (length counter-interval3)) collect (car (reverse counter-interval3))))) + for counter-interval3 in (cond ((atom (car counter-interval3)) (loop repeat (1- number-of-harmonies) collect counter-interval3)) + ((< (length counter-interval3) (1- number-of-harmonies)) + (append counter-interval3 (loop repeat (- (1- number-of-harmonies) (length counter-interval3)) collect (car (reverse counter-interval3))))) (t counter-interval3)) - for counter-interval4 in (cond ((atom (car counter-interval4)) (loop repeat number-of-harmonies collect counter-interval4)) - ((< (length counter-interval4) number-of-harmonies) - (append counter-interval4 (loop repeat (- number-of-harmonies (length counter-interval4)) collect (car (reverse counter-interval4))))) + for counter-interval4 in (cond ((atom (car counter-interval4)) (loop repeat (1- number-of-harmonies) collect counter-interval4)) + ((< (length counter-interval4) (1- number-of-harmonies)) + (append counter-interval4 (loop repeat (- (1- number-of-harmonies) (length counter-interval4)) collect (car (reverse counter-interval4))))) (t counter-interval4)) - for counter-interval5 in (cond ((atom (car counter-interval5)) (loop repeat number-of-harmonies collect counter-interval5)) - ((< (length counter-interval5) number-of-harmonies) - (append counter-interval5 (loop repeat (- number-of-harmonies (length counter-interval5)) collect (car (reverse counter-interval5))))) + for counter-interval5 in (cond ((atom (car counter-interval5)) (loop repeat (1- number-of-harmonies) collect counter-interval5)) + ((< (length counter-interval5) (1- number-of-harmonies)) + (append counter-interval5 (loop repeat (- (1- number-of-harmonies) (length counter-interval5)) collect (car (reverse counter-interval5))))) (t counter-interval5)) - for counter-interval6 in (cond ((atom (car counter-interval6)) (loop repeat number-of-harmonies collect counter-interval6)) - ((< (length counter-interval6) number-of-harmonies) - (append counter-interval6 (loop repeat (- number-of-harmonies (length counter-interval6)) collect (car (reverse counter-interval6))))) + for counter-interval6 in (cond ((atom (car counter-interval6)) (loop repeat (1- number-of-harmonies) collect counter-interval6)) + ((< (length counter-interval6) (1- number-of-harmonies)) + (append counter-interval6 (loop repeat (- (1- number-of-harmonies) (length counter-interval6)) collect (car (reverse counter-interval6))))) (t counter-interval6)) @@ -170,33 +156,45 @@ collect - (let* ((second (nconc (list first-harmony) external-list)) + (let* ((second (append (list first-harmony) (reverse external-list))) (first (car (last second)));6000 6700 (second (let* ((temp-base database) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - (temp-base (cond (avoid-repetitions (setq 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)))) - - (if (null looplist) (list (loop repeat (length (first temp-base)) collect -1)) looplist)) - (t temp-base))) + (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 (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))) (temp-base (cond (voice-tie1 - (let ((voice-tie1 (- voice-tie1 1))) - (setq looplist (remove nil + (let* ((voice-tie1 (- voice-tie1 1)) + (looplist (remove nil (loop for a in temp-base collect - + (cond ((eq (nth voice-tie1 a) (nth voice-tie1 first)) a) - ((eq (nth voice-tie1 a) -1) a) - (t nil))))) + ((eq (nth voice-tie1 first) -1) a) + (t nil)))))) (if (null looplist) (loop for a in temp-base collect @@ -205,14 +203,14 @@ (t temp-base))) (temp-base (cond (voice-tie2 - (let ((voice-tie2 (- voice-tie2 1))) - (setq looplist (remove nil + (let* ((voice-tie2 (- voice-tie2 1)) + (looplist (remove nil (loop for a in temp-base collect (cond ((eq (nth voice-tie2 a) (nth voice-tie2 first)) a) - ((eq (nth voice-tie2 a) -1) a) - (t nil))))) + ((eq (nth voice-tie2 first) -1) a) + (t nil)))))) (if (null looplist) (loop for a in temp-base collect @@ -221,14 +219,14 @@ (t temp-base))) (temp-base (cond (voice-tie3 - (let ((voice-tie3 (- voice-tie3 1))) - (setq looplist (remove nil + (let* ((voice-tie3 (- voice-tie3 1)) + (looplist (remove nil (loop for a in temp-base collect (cond ((eq (nth voice-tie3 a) (nth voice-tie3 first)) a) - ((eq (nth voice-tie3 a) -1) a) - (t nil))))) + ((eq (nth voice-tie3 first) -1) a) + (t nil)))))) (if (null looplist) (loop for a in temp-base collect @@ -237,14 +235,14 @@ (t temp-base))) (temp-base (cond (voice-tie4 - (let ((voice-tie4 (- voice-tie4 1))) - (setq looplist (remove nil + (let* ((voice-tie4 (- voice-tie4 1)) + (looplist (remove nil (loop for a in temp-base collect (cond ((eq (nth voice-tie4 a) (nth voice-tie4 first)) a) - ((eq (nth voice-tie4 a) -1) a) - (t nil))))) + ((eq (nth voice-tie4 first) -1) a) + (t nil)))))) (if (null looplist) (loop for a in temp-base collect @@ -252,314 +250,421 @@ looplist))) (t temp-base))) - ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (temp-base (cond (voice-interval1 - (setq looplist (remove nil (loop for a in temp-base + (let ((looplist (remove nil (loop for a in temp-base collect (if (or (find (- (nth 0 a) (nth 0 first)) voice-interval1) - (eq (nth 0 first) -1)) a)))) + (eq (nth 0 first) -1)) a))))) (if (null looplist) (loop for a in temp-base collect - (subs-posn_oml a 0 -1)) looplist)) + (subs-posn_oml a 0 -1)) looplist))) (t temp-base))) (temp-base (cond (voice-interval2 - (setq looplist (remove nil (loop for a in temp-base + (let ((looplist (remove nil (loop for a in temp-base collect (if (or (find (- (nth 1 a) (nth 1 first)) voice-interval2) - (eq (nth 1 first) -1)) a)))) + (eq (nth 1 first) -1)) a))))) (if (null looplist) (loop for a in temp-base collect - (subs-posn_oml a 1 -1)) looplist)) + (subs-posn_oml a 1 -1)) looplist))) (t temp-base))) (temp-base (cond (voice-interval3 - (setq looplist (remove nil (loop for a in temp-base + (let ((looplist (remove nil (loop for a in temp-base collect (if (or (find (- (nth 2 a) (nth 2 first)) voice-interval3) - (eq (nth 2 first) -1)) a)))) + (eq (nth 2 first) -1)) a))))) (if (null looplist) (loop for a in temp-base collect - (subs-posn_oml a 2 -1)) looplist)) + (subs-posn_oml a 2 -1)) looplist))) (t temp-base))) (temp-base (cond (voice-interval4 - (setq looplist (remove nil (loop for a in temp-base + (let ((looplist (remove nil (loop for a in temp-base collect (if (or (find (- (nth 3 a) (nth 3 first)) voice-interval4) - (eq (nth 3 first) -1)) a)))) + (eq (nth 3 first) -1)) a))))) (if (null looplist) (loop for a in temp-base collect - (subs-posn_oml a 3 -1)) looplist)) + (subs-posn_oml a 3 -1)) looplist))) (t temp-base))) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (temp-base (cond (voice-counter1 - (setq looplist (remove nil - (loop for a in temp-base - collect - (let* ((instr-a (1- (first (car voice-counter1)))) ;0 - (instr-b (1- (second (car voice-counter1)))) ;1 - (delta-a (- (nth instr-a a) (nth instr-a first))) - (delta-b (- (nth instr-b a) (nth instr-b first))) - (rule (second voice-counter1))) - (cond (counter-interval1 - (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval1)) 'parallel) - ((and (or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval1)) 'contrary) - ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval1)) 'seiten))) - a)) - - - (t (if (equal rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) 'parallel) - ((or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) 'contrary) - ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) - a))))))) - - - (if (null looplist) - (loop for a in temp-base - collect - (subs-posn_oml a (1- (first (car voice-counter1))) -1)) looplist)) - - - - (t temp-base))) + (cond ((and (or (eq -1 (nth (1- (first (car voice-counter1))) first)) + (eq -1 (nth (1- (second (car voice-counter1))) first))) counter-interval1) - (temp-base (cond (voice-counter2 - (setq looplist (remove nil - (loop for a in temp-base - collect - (let* ((instr-a (1- (first (car voice-counter2)))) ;0 - (instr-b (1- (second (car voice-counter2)))) ;1 - (delta-a (- (nth instr-a a) (nth instr-a first))) - (delta-b (- (nth instr-b a) (nth instr-b first))) - (rule (second voice-counter2))) - (cond (counter-interval2 - (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval2)) 'parallel) - ((and (or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval2)) 'contrary) - ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval2)) 'seiten))) - a)) - - - (t (if (equal rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) 'parallel) - ((or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) 'contrary) - ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) - a))))))) + (remove nil (loop for a in temp-base + collect (let* ((instr-a (1- (first (car voice-counter1)))) ;0 + (instr-b (1- (second (car voice-counter1)))) + (voice-i (- (nth instr-b a) (nth instr-a a))) ) + (if (find voice-i counter-interval1) a))))) + ((or (eq -1 (nth (1- (first (car voice-counter1))) first)) + (eq -1 (nth (1- (second (car voice-counter1))) first))) temp-base) + + (t (let ((looplist (remove nil + (loop for a in temp-base + collect + (let* ((instr-a (1- (first (car voice-counter1)))) ;0 + (instr-b (1- (second (car voice-counter1)))) ;1 + (delta-a (- (nth instr-a a) (nth instr-a first))) + (delta-b (- (nth instr-b a) (nth instr-b first))) + (rule (second voice-counter1))) + (cond + + + + + (counter-interval1 + (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval1)) 'parallel) + ((and (or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval1)) 'contrary) + ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval1)) 'seiten))) + a)) + + + (t (if (eq rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) 'parallel) + ((or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) 'contrary) + ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) + a)))))))) + + + + (if (null looplist) + (loop for a in temp-base + collect + (subs-posn_oml a (1- (first (car voice-counter1))) -1)) looplist))))) - (if (null looplist) - (loop for a in temp-base - collect - (subs-posn_oml a (1- (first (car voice-counter2))) -1)) looplist)) - - (t temp-base))) - (temp-base (cond (voice-counter3 - (setq looplist (remove nil - (loop for a in temp-base - collect - (let* ((instr-a (1- (first (car voice-counter3)))) ;0 - (instr-b (1- (second (car voice-counter3)))) ;1 - (delta-a (- (nth instr-a a) (nth instr-a first))) - (delta-b (- (nth instr-b a) (nth instr-b first))) - (rule (second voice-counter3))) - (cond (counter-interval3 - (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval3)) 'parallel) - ((and (or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval3)) 'contrary) - ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval3)) 'seiten))) - a)) - - - (t (if (equal rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) 'parallel) - ((or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) 'contrary) - ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) - a))))))) +(temp-base (cond (voice-counter2 + (cond ((and (or (eq -1 (nth (1- (first (car voice-counter2))) first)) + (eq -1 (nth (1- (second (car voice-counter2))) first))) counter-interval2) + + (remove nil (loop for a in temp-base + collect (let* ((instr-a (1- (first (car voice-counter2)))) ;0 + (instr-b (1- (second (car voice-counter2)))) + (voice-i (- (nth instr-b a) (nth instr-a a))) ) + (if (find voice-i counter-interval2) a))))) + + ((or (eq -1 (nth (1- (first (car voice-counter2))) first)) + (eq -1 (nth (1- (second (car voice-counter2))) first))) temp-base) + + (t (let ((looplist (remove nil + (loop for a in temp-base + collect + (let* ((instr-a (1- (first (car voice-counter2)))) ;0 + (instr-b (1- (second (car voice-counter2)))) ;1 + (delta-a (- (nth instr-a a) (nth instr-a first))) + (delta-b (- (nth instr-b a) (nth instr-b first))) + (rule (second voice-counter2))) + (cond + + + + + (counter-interval2 + (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval2)) 'parallel) + ((and (or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval2)) 'contrary) + ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval2)) 'seiten))) + a)) + + + (t (if (eq rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) 'parallel) + ((or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) 'contrary) + ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) + a)))))))) + + + + (if (null looplist) + (loop for a in temp-base + collect + (subs-posn_oml a (1- (first (car voice-counter2))) -1)) looplist))))) - (if (null looplist) - (loop for a in temp-base - collect - (subs-posn_oml a (1- (first (car voice-counter3))) -1)) looplist)) - - - - (t temp-base))) + + (t temp-base))) + + (temp-base (cond (voice-counter3 + (cond ((and (or (eq -1 (nth (1- (first (car voice-counter3))) first)) + (eq -1 (nth (1- (second (car voice-counter3))) first))) counter-interval3) - (temp-base (cond (voice-counter4 - (setq looplist (remove nil - (loop for a in temp-base - collect - (let* ((instr-a (1- (first (car voice-counter4)))) ;0 - (instr-b (1- (second (car voice-counter4)))) ;1 - (delta-a (- (nth instr-a a) (nth instr-a first))) - (delta-b (- (nth instr-b a) (nth instr-b first))) - (rule (second voice-counter4))) - (cond (counter-interval4 - (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval4)) 'parallel) - ((and (or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval4)) 'contrary) - ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval4)) 'seiten))) - a)) - - - (t (if (equal rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) 'parallel) - ((or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) 'contrary) - ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) - a))))))) + (remove nil (loop for a in temp-base + collect (let* ((instr-a (1- (first (car voice-counter3)))) ;0 + (instr-b (1- (second (car voice-counter3)))) + (voice-i (- (nth instr-b a) (nth instr-a a))) ) + (if (find voice-i counter-interval3) a))))) + ((or (eq -1 (nth (1- (first (car voice-counter3))) first)) + (eq -1 (nth (1- (second (car voice-counter3))) first))) temp-base) + + (t (let ((looplist (remove nil + (loop for a in temp-base + collect + (let* ((instr-a (1- (first (car voice-counter3)))) ;0 + (instr-b (1- (second (car voice-counter3)))) ;1 + (delta-a (- (nth instr-a a) (nth instr-a first))) + (delta-b (- (nth instr-b a) (nth instr-b first))) + (rule (second voice-counter3))) + (cond + + + + + (counter-interval3 + (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval3)) 'parallel) + ((and (or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval3)) 'contrary) + ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval3)) 'seiten))) + a)) + + + (t (if (eq rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) 'parallel) + ((or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) 'contrary) + ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) + a)))))))) + + + + (if (null looplist) + (loop for a in temp-base + collect + (subs-posn_oml a (1- (first (car voice-counter3))) -1)) looplist))))) - (if (null looplist) - (loop for a in temp-base - collect - (subs-posn_oml a (1- (first (car voice-counter4))) -1)) looplist)) - - - - (t temp-base))) + + (t temp-base))) - (temp-base (cond (voice-counter5 - (setq looplist (remove nil - (loop for a in temp-base - collect - (let* ((instr-a (1- (first (car voice-counter5)))) ;0 - (instr-b (1- (second (car voice-counter5)))) ;1 - (delta-a (- (nth instr-a a) (nth instr-a first))) - (delta-b (- (nth instr-b a) (nth instr-b first))) - (rule (second voice-counter5))) - (cond (counter-interval5 - (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval5)) 'parallel) - ((and (or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval5)) 'contrary) - ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval5)) 'seiten))) - a)) - - - (t (if (equal rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) 'parallel) - ((or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) 'contrary) - ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) - a))))))) + (temp-base (cond (voice-counter4 + (cond ((and (or (eq -1 (nth (1- (first (car voice-counter4))) first)) + (eq -1 (nth (1- (second (car voice-counter4))) first))) counter-interval4) + + (remove nil (loop for a in temp-base + collect (let* ((instr-a (1- (first (car voice-counter4)))) ;0 + (instr-b (1- (second (car voice-counter4)))) + (voice-i (- (nth instr-b a) (nth instr-a a))) ) + (if (find voice-i counter-interval4) a))))) + + ((or (eq -1 (nth (1- (first (car voice-counter4))) first)) + (eq -1 (nth (1- (second (car voice-counter4))) first))) temp-base) + + (t (let ((looplist (remove nil + (loop for a in temp-base + collect + (let* ((instr-a (1- (first (car voice-counter4)))) ;0 + (instr-b (1- (second (car voice-counter4)))) ;1 + (delta-a (- (nth instr-a a) (nth instr-a first))) + (delta-b (- (nth instr-b a) (nth instr-b first))) + (rule (second voice-counter4))) + (cond + + + + + (counter-interval4 + (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval4)) 'parallel) + ((and (or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval4)) 'contrary) + ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval4)) 'seiten))) + a)) + + + (t (if (eq rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) 'parallel) + ((or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) 'contrary) + ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) + a)))))))) + + + + (if (null looplist) + (loop for a in temp-base + collect + (subs-posn_oml a (1- (first (car voice-counter4))) -1)) looplist))))) - (if (null looplist) - (loop for a in temp-base - collect - (subs-posn_oml a (1- (first (car voice-counter5))) -1)) looplist)) - - - - (t temp-base))) + + (t temp-base))) - (temp-base (cond (voice-counter6 - (setq looplist (remove nil - (loop for a in temp-base - collect - (let* ((instr-a (1- (first (car voice-counter6)))) ;0 - (instr-b (1- (second (car voice-counter6)))) ;1 - (delta-a (- (nth instr-a a) (nth instr-a first))) - (delta-b (- (nth instr-b a) (nth instr-b first))) - (rule (second voice-counter6))) - (cond (counter-interval6 - (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval6)) 'parallel) - ((and (or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval6)) 'contrary) - ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) - (find (- (nth instr-b a) (nth instr-a a)) counter-interval6)) 'seiten))) - a)) - - - (t (if (equal rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) - (and (> 0 delta-a) (> 0 delta-b)) - (and (= 0 delta-a) (= 0 delta-b))) 'parallel) - ((or (and (< 0 delta-a) (> 0 delta-b)) - (and (> 0 delta-a) (< 0 delta-b))) 'contrary) - ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) - (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) - a))))))) + (temp-base (cond (voice-counter5 + (cond ((and (or (eq -1 (nth (1- (first (car voice-counter5))) first)) + (eq -1 (nth (1- (second (car voice-counter5))) first))) counter-interval5) + + (remove nil (loop for a in temp-base + collect (let* ((instr-a (1- (first (car voice-counter5)))) ;0 + (instr-b (1- (second (car voice-counter5)))) + (voice-i (- (nth instr-b a) (nth instr-a a))) ) + (if (find voice-i counter-interval5) a))))) + + ((or (eq -1 (nth (1- (first (car voice-counter5))) first)) + (eq -1 (nth (1- (second (car voice-counter5))) first))) temp-base) + + (t (let ((looplist (remove nil + (loop for a in temp-base + collect + (let* ((instr-a (1- (first (car voice-counter5)))) ;0 + (instr-b (1- (second (car voice-counter5)))) ;1 + (delta-a (- (nth instr-a a) (nth instr-a first))) + (delta-b (- (nth instr-b a) (nth instr-b first))) + (rule (second voice-counter5))) + (cond + + + + + (counter-interval5 + (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval5)) 'parallel) + ((and (or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval5)) 'contrary) + ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval5)) 'seiten))) + a)) + + + (t (if (eq rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) 'parallel) + ((or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) 'contrary) + ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) + a)))))))) + + + + (if (null looplist) + (loop for a in temp-base + collect + (subs-posn_oml a (1- (first (car voice-counter5))) -1)) looplist))))) - (if (null looplist) - (loop for a in temp-base - collect - (subs-posn_oml a (1- (first (car voice-counter6))) -1)) looplist)) - - - - (t temp-base))) + + (t temp-base))) + + +(temp-base (cond (voice-counter6 + + (cond ((and (or (eq -1 (nth (1- (first (car voice-counter6))) first)) + (eq -1 (nth (1- (second (car voice-counter6))) first))) counter-interval6) + + (remove nil (loop for a in temp-base + collect (let* ((instr-a (1- (first (car voice-counter6)))) ;0 + (instr-b (1- (second (car voice-counter6)))) + (voice-i (- (nth instr-b a) (nth instr-a a))) ) + (if (find voice-i counter-interval6) a))))) + + ((or (eq -1 (nth (1- (first (car voice-counter6))) first)) + (eq -1 (nth (1- (second (car voice-counter6))) first))) temp-base) + + (t (let ((looplist (remove nil + (loop for a in temp-base + collect + (let* ((instr-a (1- (first (car voice-counter6)))) ;0 + (instr-b (1- (second (car voice-counter6)))) ;1 + (delta-a (- (nth instr-a a) (nth instr-a first))) + (delta-b (- (nth instr-b a) (nth instr-b first))) + (rule (second voice-counter6))) + (cond + + + + + (counter-interval6 + (if (eq rule (cond ((and (or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval6)) 'parallel) + ((and (or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval6)) 'contrary) + ((and (or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) + (find (- (nth instr-b a) (nth instr-a a)) counter-interval6)) 'seiten))) + a)) + + + (t (if (eq rule (cond ((or (and (< 0 delta-a) (< 0 delta-b)) + (and (> 0 delta-a) (> 0 delta-b)) + (and (= 0 delta-a) (= 0 delta-b))) 'parallel) + ((or (and (< 0 delta-a) (> 0 delta-b)) + (and (> 0 delta-a) (< 0 delta-b))) 'contrary) + ((or (and (or (< 0 delta-a) (> 0 delta-a)) (= 0 delta-b)) + (and (= 0 delta-a) (or (< 0 delta-b) (> 0 delta-b)))) 'seiten))) + a)))))))) + + + + (if (null looplist) + (loop for a in temp-base + collect + (subs-posn_oml a (1- (first (car voice-counter6))) -1)) looplist))))) + + + + (t temp-base))) @@ -578,7 +683,7 @@ - (nreverse (push second external-list)) + (push second external-list) (values second)))))) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -- Gitblit v1.9.1