예제 #1
0
def test_make_scale_notes():
    p = Pattern([-8, -7, -4, -2, -1, 0, 1, 2, 7], 'test_pattern')
    scale_notes = make_scale_notes(IONIAN, p, MIDDLE_C)
    expected = {
        -8: 47,  # ti
        -7: 48,  # do
        -4: 53,  # fa
        -2: 57,  # la
        -1: 59,  # ti
        0: 60,  # do
        1: 62,  # re
        2: 64,  # mi
        7: 72,  # do
    }
    for step in expected:
        assert expected[step] == scale_notes[step]
예제 #2
0
파일: exercises.py 프로젝트: pvarsh/solfege
def ascending_triads_descending(length: int) -> Pattern:
    return Pattern(
        flatten([[s, s + 2, s + 4] for s in range(length, 0, -1)]) + [0],
        'Ascending triads descending')
예제 #3
0
파일: exercises.py 프로젝트: pvarsh/solfege
def descending_triads_second_inversion_descending(length: int) -> Pattern:
    return Pattern(
        flatten([[s - 3, s, s + 2] for s in range(length, 0, -1)]) + [0],
        'Descending triads in second inversion descending')
예제 #4
0
파일: exercises.py 프로젝트: pvarsh/solfege
def descending_triads_first_inversion_descending(length: int) -> Pattern:
    return Pattern(
        flatten([[s, s - 3, s - 5] for s in range(length, 0, -1)]) + [0],
        'Descending triads in first inversion descending')
예제 #5
0
파일: exercises.py 프로젝트: pvarsh/solfege
def ascending_triads_second_inversion_ascending(length: int) -> Pattern:
    return Pattern(
        flatten([[s - 5, s, s + 2] for s in range(length)]) + [length],
        'Ascending triads in second inversion ascending')
예제 #6
0
파일: exercises.py 프로젝트: pvarsh/solfege
def ascending_triads_first_inversion_ascending(length: int) -> Pattern:
    return Pattern(
        flatten([[s + 2, s + 4, s + 7] for s in range(length)]) + [length],
        'Ascending triads in first inversion ascending')
예제 #7
0
파일: exercises.py 프로젝트: pvarsh/solfege
def flatten(l):
    return [i for sublist in l for i in sublist]


TUNE_IN_PATTERN = Pattern([
    0,
    2,
    4,
    2,
    0,
    3,
    2,
    1,
    0,
    4,
    5,
    6,
    7,
    0,
    2,
    4,
    7,
    0,
    2,
    4,
    6,
], 'Tune-in-1')


def ascending(length: int) -> Pattern:
    return Pattern(list(range(length + 1)), 'Ascending')
예제 #8
0
파일: exercises.py 프로젝트: pvarsh/solfege
def descending(length: int) -> Pattern:
    return Pattern(list(range(length, -1, -1)), 'Descending')
예제 #9
0
파일: exercises.py 프로젝트: pvarsh/solfege
def descending_thirds_descending(length: int) -> Pattern:
    return Pattern(
        flatten([[s, s - 2] for s in range(length, 0, -1)]) + [0],
        'Descending thirds descending')
예제 #10
0
파일: exercises.py 프로젝트: pvarsh/solfege
def ascending_thirds_ascending(length: int) -> Pattern:
    return Pattern(
        flatten([[s, s + 2] for s in range(length)]) + [length],
        'Ascending thirds ascending')
예제 #11
0
파일: exercises.py 프로젝트: pvarsh/solfege
def three_ascending_notes_descending(length: int) -> Pattern:
    return Pattern(
        flatten([[s, s + 1, s + 2] for s in range(length, 0, -1)]) + [0],
        "Three ascending notes descending")
예제 #12
0
파일: exercises.py 프로젝트: pvarsh/solfege
def three_descending_notes_ascending(length: int) -> Pattern:
    return Pattern(
        flatten([[s + 2, s + 1, s] for s in range(length)]) + [length],
        "Three descending notes ascending")
예제 #13
0
파일: exercises.py 프로젝트: pvarsh/solfege
def three_notes_descending(length: int) -> Pattern:
    return Pattern(
        flatten([[s, s - 1, s - 2] for s in range(length, 0, -1)]) + [0],
        'Three notes descending')
예제 #14
0
파일: exercises.py 프로젝트: pvarsh/solfege
def three_notes_ascending(length: int) -> Pattern:
    return Pattern(
        flatten([s, s + 1, s + 2] for s in range(length)) + [length],
        'Three notes ascending')
예제 #15
0
파일: exercises.py 프로젝트: pvarsh/solfege
def clb_scale_pattern_ascending() -> Pattern:
    return Pattern(
        flatten([[s, s + 1, s + 2, s + 3, s + 4, s + 3, s + 2, s]
                 for s in range(7)]) + [7], 'ChadLB ascending scale exercise')
예제 #16
0
파일: exercises.py 프로젝트: pvarsh/solfege
def clb_scale_pattern_descending() -> Pattern:
    return Pattern(
        flatten([[s, s + 1, s + 2, s + 3, s + 2, s + 1, s, s - 2]
                 for s in range(7, 0, -1)]) + [0],
        'ChadLB ascending scale exercise')
예제 #17
0
파일: exercises.py 프로젝트: pvarsh/solfege
def ascending(length: int) -> Pattern:
    return Pattern(list(range(length + 1)), 'Ascending')
예제 #18
0
파일: exercises.py 프로젝트: pvarsh/solfege
def down_to_root(length: int) -> Pattern:
    return Pattern(
        flatten([list(range(s, -1, -1)) for s in range(length + 1)]),
        'Down to root from every step')
예제 #19
0
파일: exercises.py 프로젝트: pvarsh/solfege
def descending_triads_ascending(length: int) -> Pattern:
    return Pattern(
        flatten([[s + 4, s + 2, s] for s in range(length)]) + [length],
        'Descending triads ascending')