quantizer
Functions
Quantizer function. |
- abjadext.nauert.quantizer.quantize(q_event_sequence: QEventSequence, q_schema: QSchema | None = None, grace_handler: GraceHandler | None = None, heuristic: Heuristic | None = None, job_handler: JobHandler | None = None, attack_point_optimizer: AttackPointOptimizer | None = None, attach_tempos: bool = True) Voice [source]
Quantizer function.
Quantizes sequences of attack-points, encapsulated by
QEventSequences
, into score trees.>>> durations = [1000] * 8 >>> pitches = range(8) >>> q_event_sequence = nauert.QEventSequence.from_millisecond_pitch_pairs( ... tuple(zip(durations, pitches)) ... )
Quantization defaults to outputting into a 4/4, quarter=60 musical structure:
>>> result = nauert.quantize(q_event_sequence) >>> staff = abjad.Staff([result]) >>> score = abjad.Score([staff]) >>> abjad.show(score)
However, the behavior of the
quantize
function can be modified at call-time. Passing aQSchema
instance will alter the macro-structure of the output.Here, we quantize using settings specified by a
MeasurewiseQSchema
, which will cause thequantize
function to group the output into measures with different tempi and time signatures:>>> measurewise_q_schema = nauert.MeasurewiseQSchema( ... {"tempo": ((1, 4), 78), "time_signature": (2, 4)}, ... {"tempo": ((1, 8), 57), "time_signature": (5, 4)}, ... )
>>> result = nauert.quantize( ... q_event_sequence, ... q_schema=measurewise_q_schema, ... ) >>> staff = abjad.Staff([result]) >>> score = abjad.Score([staff]) >>> abjad.show(score)
Here we quantize using settings specified by a
BeatwiseQSchema
, which keeps the output of thequantize
function “flattened”, without measures or explicit time signatures. The default beat-wise settings of quarter=60 persists until the third “beatspan”:>>> beatwise_q_schema = nauert.BeatwiseQSchema( ... { ... 2: {"tempo": ((1, 4), 120)}, ... 5: {"tempo": ((1, 4), 90)}, ... 7: {"tempo": ((1, 4), 30)}, ... } ... )
>>> result = nauert.quantize( ... q_event_sequence, ... q_schema=beatwise_q_schema, ... ) >>> staff = abjad.Staff([result]) >>> score = abjad.Score([staff]) >>> abjad.show(score)
Note that
TieChains
are generally fused together in the above example, but break at tempo changes.The use of BeatwiseQSchema and MeasurewiseAttackPointOptimizer is not supported. Please raise an issue if you would like this to be supported in the future.
>>> q_schema = nauert.BeatwiseQSchema() >>> attack_point_optimizer = nauert.MeasurewiseAttackPointOptimizer() >>> result = nauert.quantize( ... q_event_sequence, ... attack_point_optimizer=attack_point_optimizer, ... q_schema=q_schema, ... ) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/Users/trevor/abjad-ext-nauert/abjadext/nauert/quantizer.py", line 280, in quantize notation = q_target( ^^^^^^^^^ File "/Users/trevor/abjad-ext-nauert/abjadext/nauert/qtargets.py", line 85, in __call__ raise TypeError(message) TypeError: BeatwiseQTarget is not supposed to be used together with MeasurewiseAttackPointOptimizer.
Other keyword arguments are:
grace_handler
: aGraceHandler
instance controls whether and how grace notes are used in the output. Options currently includeCollapsingGraceHandler
,ConcatenatingGraceHandler
andDiscardingGraceHandler
.heuristic
: aHeuristic
instance controls how output rhythms are selected from a pool of candidates. Options currently include theDistanceHeuristic
class.job_handler
: aJobHandler
instance controls whether or not parallel processing is used during the quantization process. Options include theSerialJobHandler
andParallelJobHandler
classes.attack_point_optimizer
: anAttackPointOptimizer
instance controls whether and how logical ties are re-notated. Options currently includeMeasurewiseAttackPointOptimizer
,NaiveAttackPointOptimizer
andNullAttackPointOptimizer
.
Refer to the reference pages for
BeatwiseQSchema
andMeasurewiseQSchema
for more information on controlling thequantize
function’s output, and to the reference onSearchTree
for information on controlling the rhythmic complexity of that same output.