mutate
Functions
Copies argument. |
|
Ejects |
|
Extracts |
|
Fuses |
|
Changes logical tie to tuplet. |
|
Replaces |
|
Scales |
|
Splits |
|
Swaps |
|
Transposes notes and chords in |
|
Wraps |
- abjad.mutate.copy(argument, n=1) list[Component] [source]
Copies argument.
Copies explicit clefs:
>>> staff = abjad.Staff("c'8 cs'8 d'8 ef'8 e'8 f'8 fs'8 g'8") >>> clef = abjad.Clef("treble") >>> abjad.attach(clef, staff[0]) >>> clef = abjad.Clef("bass") >>> abjad.attach(clef, staff[4]) >>> copied_notes = abjad.mutate.copy(staff[:2]) >>> staff.extend(copied_notes) >>> abjad.show(staff)
Does not copy implicit clefs:
>>> staff = abjad.Staff("c'8 cs'8 d'8 ef'8 e'8 f'8 fs'8 g'8") >>> clef = abjad.Clef("treble") >>> abjad.attach(clef, staff[0]) >>> clef = abjad.Clef("bass") >>> abjad.attach(clef, staff[4]) >>> copied_notes = abjad.mutate.copy(staff[2:4]) >>> staff.extend(copied_notes)
Copy components one time:
>>> staff = abjad.Staff(r"c'8 d'8 e'8 f'8") >>> staff.extend(r"g'8 a'8 b'8 c''8") >>> score = abjad.Score([staff], name="Score") >>> time_signature = abjad.TimeSignature((2, 4)) >>> abjad.attach(time_signature, staff[0]) >>> abjad.show(staff)
>>> selection = staff[2:4] >>> result = abjad.mutate.copy(selection) >>> new_staff = abjad.Staff(result) >>> abjad.show(new_staff)
>>> staff[2] is new_staff[0] False
- abjad.mutate.eject_contents(container: Container) list[Component] [source]
Ejects
container
contents.Ejects leaves from container:
>>> container = abjad.Container("c'4 ~ c'4 d'4 ~ d'4") >>> abjad.show(container)
>>> leaves = abjad.mutate.eject_contents(container) >>> leaves [Note("c'4"), Note("c'4"), Note("d'4"), Note("d'4")]
Leaves can be added to a new container:
>>> staff = abjad.Staff(leaves, lilypond_type="RhythmicStaff") >>> abjad.show(staff)
Old container is empty:
>>> container Container()
- abjad.mutate.extract(argument)[source]
Extracts
argument
from score.Leaves children of
argument
in score.Extract tuplets:
>>> voice = abjad.Voice() >>> voice.append(abjad.Tuplet((3, 2), "c'4 e'4")) >>> voice.append(abjad.Tuplet((3, 2), "d'4 f'4")) >>> leaves = abjad.select.leaves(voice) >>> staff = abjad.Staff([voice]) >>> score = abjad.Score([staff], name="Score") >>> time_signature = abjad.TimeSignature((3, 4)) >>> abjad.attach(time_signature, leaves[0]) >>> abjad.hairpin("p < f", leaves) >>> abjad.show(staff)
>>> empty_tuplet = abjad.mutate.extract(voice[-1]) >>> empty_tuplet = abjad.mutate.extract(voice[0]) >>> abjad.show(staff)
Scales tuplet contents and then extracts tuplet:
>>> voice = abjad.Voice() >>> staff = abjad.Staff([voice]) >>> voice.append(abjad.Tuplet((3, 2), "c'4 e'4")) >>> voice.append(abjad.Tuplet((3, 2), "d'4 f'4")) >>> score = abjad.Score([staff], name="Score") >>> leaves = abjad.select.leaves(staff) >>> abjad.hairpin("p < f", leaves) >>> time_signature = abjad.TimeSignature((3, 4)) >>> abjad.attach(time_signature, leaves[0]) >>> abjad.show(staff)
>>> abjad.mutate.scale(voice[-1], abjad.Fraction(3, 2)) >>> empty_tuplet = abjad.mutate.extract(voice[-1]) >>> abjad.mutate.scale(voice[0], abjad.Fraction(3, 2)) >>> empty_tuplet = abjad.mutate.extract(voice[0]) >>> abjad.show(voice)
Extracting out-of-score component does nothing and returns component:
>>> tuplet = abjad.Tuplet((3, 2), "c'4 e'4") >>> abjad.show(tuplet)
>>> abjad.mutate.extract(tuplet) Tuplet('2:3', "c'4 e'4")
>>> abjad.show(tuplet)
Returns
argument
.
- abjad.mutate.fuse(argument) Tuplet | list[Leaf] [source]
Fuses
argument
.Fuses in-score leaves:
>>> staff = abjad.Staff("c'8 d'8 e'8 f'8") >>> abjad.show(staff)
>>> abjad.mutate.fuse(staff[1:]) [Note("d'4.")]
>>> abjad.show(staff)
Fuses parent-contiguous tuplets in selection:
>>> tuplet_1 = abjad.Tuplet((2, 3), "c'8 d' e'") >>> tuplet_2 = abjad.Tuplet((2, 3), "c'16 d' e'") >>> voice = abjad.Voice([tuplet_1, tuplet_2]) >>> staff = abjad.Staff([voice]) >>> abjad.beam(tuplet_1[:]) >>> abjad.slur(tuplet_2[:]) >>> abjad.show(staff)
>>> tuplets = voice[:] >>> abjad.mutate.fuse(tuplets) Tuplet('3:2', "c'8 d'8 e'8 c'16 d'16 e'16")
>>> abjad.show(staff)
Returns new tuplet in selection.
Fuses zero or more parent-contiguous
tuplets
.Allows in-score
tuplets
.Allows outside-of-score
tuplets
.All
tuplets
must carry the same multiplier.All
tuplets
must be of the same type.REGRESSION. Trims tie from fused note:
>>> staff = abjad.Staff("d'8 ~ d'32 ~ d'16 d'32") >>> abjad.show(staff)
>>> logical_tie = abjad.select.logical_tie(staff[0]) >>> abjad.mutate.fuse(logical_tie) [Note("d'8..")]
>>> abjad.show(staff)
>>> abjad.get.has_indicator(staff[0], abjad.Tie) False
- abjad.mutate.logical_tie_to_tuplet(argument, proportions, *, tag: Tag | None = None) Tuplet [source]
Changes logical tie to tuplet.
>>> voice = abjad.Voice(r"df'8 c'8 ~ c'16 cqs''4") >>> staff = abjad.Staff([voice]) >>> score = abjad.Score([staff], name="Score") >>> abjad.attach(abjad.Dynamic("p"), voice[0]) >>> abjad.attach(abjad.StartHairpin("<"), voice[0]) >>> abjad.attach(abjad.Dynamic("f"), voice[-1]) >>> abjad.override(staff).DynamicLineSpanner.staff_padding = 3 >>> time_signature = abjad.TimeSignature((9, 16)) >>> abjad.attach(time_signature, voice[0]) >>> abjad.show(staff)
>>> logical_tie = abjad.select.logical_tie(voice[1]) >>> abjad.mutate.logical_tie_to_tuplet(logical_tie, [2, 1, 1, 1]) Tuplet('5:3', "c'8 c'16 c'16 c'16")
>>> abjad.show(staff)
>>> voice = abjad.Voice(r"c'8 ~ c'16 cqs''4") >>> staff = abjad.Staff([voice]) >>> score = abjad.Score([staff], name="Score") >>> abjad.hairpin("p < f", voice[:]) >>> abjad.override(staff).DynamicLineSpanner.staff_padding = 3 >>> time_signature = abjad.TimeSignature((7, 16)) >>> abjad.attach(time_signature, voice[0]) >>> abjad.show(staff)
- abjad.mutate.replace(argument, recipients, *, wrappers: bool = False) None [source]
Replaces
argument
(and contents ofargument
) withrecipients
.Replaces in-score tuplet (and children of tuplet) with notes. Functions exactly the same as container setitem:
>>> tuplet_1 = abjad.Tuplet((2, 3), "c'4 d'4 e'4") >>> tuplet_2 = abjad.Tuplet((2, 3), "d'4 e'4 f'4") >>> voice = abjad.Voice([tuplet_1, tuplet_2]) >>> leaves = abjad.select.leaves(voice) >>> abjad.hairpin("p < f", leaves) >>> abjad.slur(leaves) >>> abjad.show(voice)
>>> notes = abjad.makers.make_notes("c' d' e' f' c' d' e' f'", (1, 16)) >>> abjad.mutate.replace([tuplet_1], notes) >>> abjad.attach(abjad.Dynamic("p"), voice[0]) >>> abjad.attach(abjad.StartHairpin("<"), voice[0]) >>> abjad.show(voice)
Preserves both hairpin and slur.
Copies no wrappers when
wrappers
is false:>>> staff = abjad.Staff("c'2 f'4 g'") >>> abjad.attach(abjad.Clef("alto"), staff[0]) >>> abjad.show(staff)
>>> for leaf in staff: ... leaf, abjad.get.effective(leaf, abjad.Clef) ... (Note("c'2"), Clef(name='alto', hide=False)) (Note("f'4"), Clef(name='alto', hide=False)) (Note("g'4"), Clef(name='alto', hide=False))
>>> chord = abjad.Chord("<d' e'>2") >>> abjad.mutate.replace(staff[0], chord) >>> abjad.show(staff)
>>> for leaf in staff: ... leaf, abjad.get.effective(leaf, abjad.Clef) ... (Chord("<d' e'>2"), None) (Note("f'4"), None) (Note("g'4"), None)
>>> abjad.wf.wellformed(staff) True
Set
wrappers
to true to copy all wrappers from one leaf to another leaf (and avoid full-score update). Only works from one leaf to another leaf:>>> staff = abjad.Staff("c'2 f'4 g'") >>> abjad.attach(abjad.Clef("alto"), staff[0]) >>> abjad.show(staff)
>>> for leaf in staff: ... leaf, abjad.get.effective(leaf, abjad.Clef) ... (Note("c'2"), Clef(name='alto', hide=False)) (Note("f'4"), Clef(name='alto', hide=False)) (Note("g'4"), Clef(name='alto', hide=False))
>>> chord = abjad.Chord("<d' e'>2") >>> abjad.mutate.replace(staff[0], chord, wrappers=True) >>> abjad.show(staff)
>>> for leaf in staff: ... leaf, abjad.get.effective(leaf, abjad.Clef) ... (Chord("<d' e'>2"), Clef(name='alto', hide=False)) (Note("f'4"), Clef(name='alto', hide=False)) (Note("g'4"), Clef(name='alto', hide=False))
>>> abjad.wf.wellformed(staff) True
Todo
Fix.
Introduces duplicate ties:
>>> staff = abjad.Staff("c'2 ~ c'2") >>> tied_notes = abjad.makers.make_notes(0, abjad.Duration(5, 8)) >>> abjad.mutate.replace(staff[:1], tied_notes)
>>> string = abjad.lilypond(staff) >>> print(string) \new Staff { c'2 ~ c'8 c'2 }
- abjad.mutate.scale(argument, multiplier) None [source]
Scales
argument
bymultiplier
.Scales note duration by dot-generating multiplier:
>>> staff = abjad.Staff("c'8 ( d'8 e'8 f'8 )") >>> abjad.show(staff)
>>> abjad.mutate.scale(staff[1], abjad.Fraction(3, 2)) >>> abjad.show(staff)
Scales tied leaves by dot-generating mutliplier:
>>> staff = abjad.Staff(r"c'8 \accent ~ c'8 d'8") >>> score = abjad.Score([staff], name="Score") >>> time_signature = abjad.TimeSignature((3, 8)) >>> abjad.attach(time_signature, staff[0]) >>> abjad.show(staff)
>>> logical_tie = abjad.select.logical_tie(staff[0]) >>> logical_tie = abjad.mutate.scale(logical_tie, abjad.Fraction(3, 2)) >>> abjad.show(staff)
Scales leaves in container by dot-generating multiplier:
>>> container = abjad.Container(r"c'8 ( d'8 e'8 f'8 )") >>> abjad.show(container)
>>> abjad.mutate.scale(container, abjad.Fraction(3, 2)) >>> abjad.show(container)
Scales leaves in tuplet:
>>> staff = abjad.Staff() >>> score = abjad.Score([staff], name="Score") >>> tuplet = abjad.Tuplet((4, 5), "c'8 d'8 e'8 f'8 g'8") >>> staff.append(tuplet) >>> time_signature = abjad.TimeSignature((4, 8)) >>> leaf = abjad.get.leaf(staff, 0) >>> abjad.attach(time_signature, leaf) >>> abjad.show(staff)
>>> abjad.mutate.scale(tuplet, abjad.Fraction(2)) >>> abjad.show(staff)
Scales leaves carrying LilyPond multiplier:
>>> note = abjad.Note("c'8", multiplier=(1, 2)) >>> abjad.show(note)
>>> abjad.mutate.scale(note, abjad.Fraction(1, 2)) >>> abjad.show(note)
- abjad.mutate.split(argument, durations, *, cyclic: bool = False, tag: Tag | None = None) list[list[Component]] [source]
Splits
argument
bydurations
.Splits leaves cyclically and ties split notes:
>>> voice = abjad.Voice("c'1 d'1") >>> abjad.hairpin("p < f", voice[:]) >>> abjad.override(voice).DynamicLineSpanner.staff_padding = 4 >>> abjad.show(voice)
>>> durations = [(3, 4)] >>> result = abjad.mutate.split( ... voice[:], ... durations, ... cyclic=True, ... ) >>> abjad.show(voice)
Splits custom voice and preserves context name:
>>> voice = abjad.Voice( ... "c'4 d' e' f'", ... lilypond_type="CustomVoice", ... name="1", ... ) >>> staff = abjad.Staff([voice]) >>> abjad.hairpin("p < f", voice[:]) >>> abjad.override(staff).DynamicLineSpanner.staff_padding = 3 >>> abjad.show(staff)
>>> durations = [(1, 8)] >>> result = abjad.mutate.split( ... staff[:], ... durations, ... cyclic=True, ... ) >>> abjad.show(staff)
>>> for voice in staff: ... voice ... Voice("c'8", lilypond_type='CustomVoice', name='1') Voice("c'8", lilypond_type='CustomVoice', name='1') Voice("d'8", lilypond_type='CustomVoice', name='1') Voice("d'8", lilypond_type='CustomVoice', name='1') Voice("e'8", lilypond_type='CustomVoice', name='1') Voice("e'8", lilypond_type='CustomVoice', name='1') Voice("f'8", lilypond_type='CustomVoice', name='1') Voice("f'8", lilypond_type='CustomVoice', name='1')
Splits parallel container:
>>> voice_1 = abjad.Voice( ... "e''4 ( es'' f'' fs'' )", ... name="Voice_1", ... ) >>> voice_2 = abjad.Voice( ... r"c'4 \p \< cs' d' ds' \f", ... name="Voice_2", ... ) >>> abjad.override(voice_1).Stem.direction = abjad.UP >>> abjad.override(voice_1).Slur.direction = abjad.UP >>> container = abjad.Container( ... [voice_1, voice_2], ... simultaneous=True, ... ) >>> abjad.override(voice_2).Stem.direction = abjad.DOWN >>> staff = abjad.Staff([container]) >>> abjad.show(staff)
>>> durations = [(3, 8)] >>> result = abjad.mutate.split( ... container, ... durations, ... cyclic=False, ... ) >>> abjad.show(staff)
>>> string = abjad.lilypond(staff) >>> print(string) \new Staff { << \context Voice = "Voice_1" \with { \override Slur.direction = #up \override Stem.direction = #up } { e''4 ( es''8 ~ } \context Voice = "Voice_2" \with { \override Stem.direction = #down } { c'4 \p \< cs'8 ~ } >> << \context Voice = "Voice_1" \with { \override Slur.direction = #up \override Stem.direction = #up } { es''8 f''4 fs''4 ) } \context Voice = "Voice_2" \with { \override Stem.direction = #down } { cs'8 d'4 ds'4 \f } >> }
Splits leaves with articulations:
>>> staff = abjad.Staff("c'4 d' e' f'") >>> abjad.attach(abjad.Articulation("^"), staff[0]) >>> abjad.attach(abjad.LaissezVibrer(), staff[1]) >>> abjad.attach(abjad.Articulation("^"), staff[2]) >>> abjad.attach(abjad.LaissezVibrer(), staff[3]) >>> abjad.show(staff)
>>> durations = [(1, 8)] >>> result = abjad.mutate.split( ... staff[:], ... durations, ... cyclic=True, ... ) >>> abjad.show(staff)
REGRESSION. Preserves tie:
>>> staff = abjad.Staff("d'2 ~ d'") >>> abjad.show(staff)
>>> result = abjad.mutate.split(staff[0], [(1, 32)]) >>> abjad.show(staff)
REGRESSION. Leaf independent after-grace leaves unchanged:
>>> music_voice = abjad.Voice("c'4 d' e' f'", name="MusicVoice") >>> container = abjad.IndependentAfterGraceContainer("af'4 gf'4") >>> music_voice.insert(3, container) >>> staff = abjad.Staff([music_voice]) >>> lilypond_file = abjad.LilyPondFile([staff]) >>> abjad.show(lilypond_file)
>>> result = abjad.mutate.split(music_voice[:], [(1, 8)], cyclic=True) >>> abjad.show(staff)
- abjad.mutate.swap(argument, container)[source]
Swaps
argument
for emptycontainer
.Swaps containers for tuplet:
>>> voice = abjad.Voice() >>> staff = abjad.Staff([voice]) >>> score = abjad.Score([staff], name="Score") >>> voice.append(abjad.Container("c'4 d'4 e'4")) >>> voice.append(abjad.Container("d'4 e'4 f'4")) >>> abjad.attach(abjad.TimeSignature((3, 4)), voice[0][0]) >>> leaves = abjad.select.leaves(voice) >>> abjad.hairpin("p < f", leaves) >>> measures = voice[:] >>> abjad.slur(leaves) >>> abjad.show(voice)
>>> containers = voice[:] >>> tuplet = abjad.Tuplet((2, 3), []) >>> tuplet.denominator = 4 >>> abjad.mutate.swap(containers, tuplet) >>> abjad.show(voice)
REGRESSION: context indicators survive swap:
>>> prototype = abjad.TimeSignature >>> for component in abjad.iterate.components(voice): ... time_signature = abjad.get.effective(component, prototype) ... print(component, time_signature) ... Voice("{ 2/3 c'4 d'4 e'4 d'4 e'4 f'4 }") TimeSignature(pair=(3, 4), hide=False, partial=None) Tuplet('3:2', "c'4 d'4 e'4 d'4 e'4 f'4") TimeSignature(pair=(3, 4), hide=False, partial=None) Note("c'4") TimeSignature(pair=(3, 4), hide=False, partial=None) Note("d'4") TimeSignature(pair=(3, 4), hide=False, partial=None) Note("e'4") TimeSignature(pair=(3, 4), hide=False, partial=None) Note("d'4") TimeSignature(pair=(3, 4), hide=False, partial=None) Note("e'4") TimeSignature(pair=(3, 4), hide=False, partial=None) Note("f'4") TimeSignature(pair=(3, 4), hide=False, partial=None)
Returns none.
- abjad.mutate.transpose(argument, interval)[source]
Transposes notes and chords in
argument
byinterval
.Todo
Move to abjad.pitch package.
Transposes notes and chords in staff:
>>> staff = abjad.Staff() >>> score = abjad.Score([staff], name="Score") >>> staff.extend("c'4 d'4 e'4 r4") >>> abjad.attach(abjad.TimeSignature((4, 4)), staff[0]) >>> staff.extend("d'4 e'4 <f' a' c''>4") >>> abjad.attach(abjad.TimeSignature((3, 4)), staff[4]) >>> abjad.show(staff)
>>> abjad.mutate.transpose(staff, "+m3") >>> abjad.show(staff)
Returns none.
- abjad.mutate.wrap(argument, container)[source]
Wraps
argument
in emptycontainer
.Wraps in-score notes in tuplet:
>>> staff = abjad.Staff("c'8 [ ( d' e' ] ) c' [ ( d' e' ] )") >>> abjad.show(staff)
>>> tuplet = abjad.Tuplet((2, 3), []) >>> abjad.mutate.wrap(staff[-3:], tuplet) >>> abjad.show(staff)
Wraps outside-score notes in tuplet:
>>> notes = abjad.makers.make_notes([0, 2, 4], [(1, 8)]) >>> tuplet = abjad.Tuplet((2, 3), []) >>> abjad.mutate.wrap(notes, tuplet) >>> abjad.show(tuplet)
(This usage merely substitutes for the tuplet initializer.)
Wraps leaves in container:
>>> notes = [abjad.Note(n, (1, 8)) for n in range(8)] >>> staff = abjad.Staff(notes) >>> score = abjad.Score([staff], name="Score") >>> abjad.attach(abjad.TimeSignature((4, 8)), staff[0]) >>> container = abjad.Container() >>> abjad.mutate.wrap(staff[:4], container) >>> abjad.show(staff)
Wraps each leaf in tuplet:
>>> notes = [abjad.Note(n, (1, 1)) for n in range(4)] >>> staff = abjad.Staff(notes) >>> for note in staff: ... tuplet = abjad.Tuplet((2, 3)) ... abjad.mutate.wrap(note, tuplet) ...
Raises exception on nonempty
container
:>>> import pytest >>> staff = abjad.Staff("c'8 [ ( d' e' ] ) c' [ ( d' e' ] )") >>> tuplet = abjad.Tuplet((2, 3), "g'8 a' fs'") >>> abjad.mutate.wrap(staff[-3:], tuplet) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/Users/trevor/abjad/abjad/mutate.py", line 2778, in wrap raise Exception(f"must be empty container: {container!r}.") Exception: must be empty container: Tuplet('3:2', "g'8 a'8 fs'8").
REGRESSION. Contexted indicators (like time signature) survive wrap:
>>> staff = abjad.Staff("c'4 d' e' f'") >>> score = abjad.Score([staff], name="Score") >>> leaves = abjad.select.leaves(staff) >>> abjad.attach(abjad.TimeSignature((3, 8)), leaves[0]) >>> container = abjad.Container() >>> abjad.mutate.wrap(leaves, container) >>> abjad.show(staff)
>>> prototype = abjad.TimeSignature >>> for component in abjad.iterate.components(staff): ... time_signature = abjad.get.effective(component, prototype) ... print(component, time_signature) ... Staff("{ c'4 d'4 e'4 f'4 }") TimeSignature(pair=(3, 8), hide=False, partial=None) Container("c'4 d'4 e'4 f'4") TimeSignature(pair=(3, 8), hide=False, partial=None) Note("c'4") TimeSignature(pair=(3, 8), hide=False, partial=None) Note("d'4") TimeSignature(pair=(3, 8), hide=False, partial=None) Note("e'4") TimeSignature(pair=(3, 8), hide=False, partial=None) Note("f'4") TimeSignature(pair=(3, 8), hide=False, partial=None)
Returns none.