Module note_seq.performance_lib_test

Tests for performance_lib.

Expand source code
# Copyright 2021 The Magenta Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Tests for performance_lib."""

from absl.testing import absltest
from note_seq import performance_lib
from note_seq import sequences_lib
from note_seq import testing_lib
from note_seq.protobuf import music_pb2


class PerformanceLibTest(absltest.TestCase):

  def setUp(self):
    super().setUp()
    self.maxDiff = None  # pylint:disable=invalid-name

    self.note_sequence = music_pb2.NoteSequence()
    self.note_sequence.ticks_per_quarter = 220

  def testFromQuantizedNoteSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.Performance(quantized_sequence)

    self.assertEqual(100, performance.steps_per_second)

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, list(performance))

  def testFromQuantizedNoteSequenceWithVelocity(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 127, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = list(performance_lib.Performance(
        quantized_sequence, num_velocity_bins=127))

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.VELOCITY, 100),
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.VELOCITY, 127),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, performance)

  def testFromQuantizedNoteSequenceWithQuantizedVelocity(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 127, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = list(performance_lib.Performance(
        quantized_sequence, num_velocity_bins=16))

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.VELOCITY, 13),
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.VELOCITY, 16),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, performance)

  def testFromRelativeQuantizedNoteSequence(self):
    self.note_sequence.tempos.add(qpm=60.0)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence(
        self.note_sequence, steps_per_quarter=100)
    performance = performance_lib.MetricPerformance(quantized_sequence)

    self.assertEqual(100, performance.steps_per_quarter)

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, list(performance))

  def testNotePerformanceFromQuantizedNoteSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 97, 0.0, 4.0), (64, 97, 0.0, 3.0), (67, 121, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.NotePerformance(
        quantized_sequence, num_velocity_bins=16)

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        (pe(pe.TIME_SHIFT, 0), pe(pe.NOTE_ON, 60),
         pe(pe.VELOCITY, 13), pe(pe.DURATION, 400)),
        (pe(pe.TIME_SHIFT, 0), pe(pe.NOTE_ON, 64),
         pe(pe.VELOCITY, 13), pe(pe.DURATION, 300)),
        (pe(pe.TIME_SHIFT, 100), pe(pe.NOTE_ON, 67),
         pe(pe.VELOCITY, 16), pe(pe.DURATION, 100)),
    ]
    self.assertEqual(expected_performance, list(performance))

    ns = performance.to_sequence(instrument=0)
    self.assertEqual(self.note_sequence, ns)

  def testProgramAndIsDrumFromQuantizedNoteSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)],
        program=1)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 1, [(36, 100, 0.0, 4.0), (48, 100, 0.0, 4.0)],
        program=2)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 2, [(57, 100, 0.0, 0.1)],
        is_drum=True)
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)

    performance = performance_lib.Performance(quantized_sequence, instrument=0)
    self.assertEqual(1, performance.program)
    self.assertFalse(performance.is_drum)

    performance = performance_lib.Performance(quantized_sequence, instrument=1)
    self.assertEqual(2, performance.program)
    self.assertFalse(performance.is_drum)

    performance = performance_lib.Performance(quantized_sequence, instrument=2)
    self.assertIsNone(performance.program)
    self.assertTrue(performance.is_drum)

    performance = performance_lib.Performance(quantized_sequence)
    self.assertIsNone(performance.program)
    self.assertIsNone(performance.is_drum)

  def testToSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.Performance(quantized_sequence)
    performance_ns = performance.to_sequence()

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithVelocity(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 115, 0.0, 3.0), (67, 127, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.Performance(
        quantized_sequence, num_velocity_bins=127)
    performance_ns = performance.to_sequence()

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithUnmatchedNoteOffs(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 50),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_OFF, 64),
        pe(pe.NOTE_OFF, 67),  # Was not started, should be ignored.
    ]
    for event in perf_events:
      performance.append(event)

    performance_ns = performance.to_sequence()

    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 0.5), (64, 100, 0.0, 0.5)])

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithUnmatchedNoteOns(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
    ]
    for event in perf_events:
      performance.append(event)

    performance_ns = performance.to_sequence()

    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 1.0), (64, 100, 0.0, 1.0)])

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithRepeatedNotes(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 100),
    ]
    for event in perf_events:
      performance.append(event)

    performance_ns = performance.to_sequence()

    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 2.0), (64, 100, 0.0, 2.0), (60, 100, 1.0, 2.0)])

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceRelativeQuantized(self):
    self.note_sequence.tempos.add(qpm=60.0)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence(
        self.note_sequence, steps_per_quarter=100)
    performance = performance_lib.MetricPerformance(quantized_sequence)
    performance_ns = performance.to_sequence(qpm=60.0)

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testSetLengthAddSteps(self):
    performance = performance_lib.Performance(steps_per_second=100)

    performance.set_length(50)
    self.assertEqual(50, performance.num_steps)
    self.assertListEqual([0], performance.steps)

    pe = performance_lib.PerformanceEvent
    perf_events = [pe(pe.TIME_SHIFT, 50)]
    self.assertEqual(perf_events, list(performance))

    performance.set_length(150)
    self.assertEqual(150, performance.num_steps)
    self.assertListEqual([0, 100], performance.steps)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.TIME_SHIFT, 100),
        pe(pe.TIME_SHIFT, 50),
    ]
    self.assertEqual(perf_events, list(performance))

    performance.set_length(200)
    self.assertEqual(200, performance.num_steps)
    self.assertListEqual([0, 100], performance.steps)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.TIME_SHIFT, 100),
        pe(pe.TIME_SHIFT, 100),
    ]
    self.assertEqual(perf_events, list(performance))

  def testSetLengthRemoveSteps(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
    ]
    for event in perf_events:
      performance.append(event)

    performance.set_length(200)
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.NOTE_ON, 67),
    ]
    self.assertEqual(perf_events, list(performance))

    performance.set_length(50)
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 50),
    ]
    self.assertEqual(perf_events, list(performance))

  def testNumSteps(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_OFF, 64),
    ]
    for event in perf_events:
      performance.append(event)

    self.assertEqual(100, performance.num_steps)
    self.assertListEqual([0, 0, 0, 100, 100], performance.steps)

  def testSteps(self):
    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_OFF, 64),
    ]

    performance = performance_lib.Performance(steps_per_second=100)
    for event in perf_events:
      performance.append(event)
    self.assertListEqual([0, 0, 0, 100, 100], performance.steps)

    performance = performance_lib.Performance(
        steps_per_second=100, start_step=100)
    for event in perf_events:
      performance.append(event)
    self.assertListEqual([100, 100, 100, 200, 200], performance.steps)

  def testPeEqAndHash(self):
    pe = performance_lib.PerformanceEvent
    self.assertEqual(pe(pe.NOTE_ON, 60), pe(pe.NOTE_ON, 60))
    self.assertLen(set([pe(pe.NOTE_ON, 60), pe(pe.NOTE_ON, 60)]), 1)


if __name__ == '__main__':
  absltest.main()

Classes

class PerformanceLibTest (*args, **kwargs)

Extension of unittest.TestCase providing more power.

Create an instance of the class that will use the named test method when executed. Raises a ValueError if the instance does not have a method with the specified name.

Expand source code
class PerformanceLibTest(absltest.TestCase):

  def setUp(self):
    super().setUp()
    self.maxDiff = None  # pylint:disable=invalid-name

    self.note_sequence = music_pb2.NoteSequence()
    self.note_sequence.ticks_per_quarter = 220

  def testFromQuantizedNoteSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.Performance(quantized_sequence)

    self.assertEqual(100, performance.steps_per_second)

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, list(performance))

  def testFromQuantizedNoteSequenceWithVelocity(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 127, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = list(performance_lib.Performance(
        quantized_sequence, num_velocity_bins=127))

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.VELOCITY, 100),
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.VELOCITY, 127),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, performance)

  def testFromQuantizedNoteSequenceWithQuantizedVelocity(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 127, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = list(performance_lib.Performance(
        quantized_sequence, num_velocity_bins=16))

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.VELOCITY, 13),
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.VELOCITY, 16),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, performance)

  def testFromRelativeQuantizedNoteSequence(self):
    self.note_sequence.tempos.add(qpm=60.0)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence(
        self.note_sequence, steps_per_quarter=100)
    performance = performance_lib.MetricPerformance(quantized_sequence)

    self.assertEqual(100, performance.steps_per_quarter)

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
    ]
    self.assertEqual(expected_performance, list(performance))

  def testNotePerformanceFromQuantizedNoteSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 97, 0.0, 4.0), (64, 97, 0.0, 3.0), (67, 121, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.NotePerformance(
        quantized_sequence, num_velocity_bins=16)

    pe = performance_lib.PerformanceEvent
    expected_performance = [
        (pe(pe.TIME_SHIFT, 0), pe(pe.NOTE_ON, 60),
         pe(pe.VELOCITY, 13), pe(pe.DURATION, 400)),
        (pe(pe.TIME_SHIFT, 0), pe(pe.NOTE_ON, 64),
         pe(pe.VELOCITY, 13), pe(pe.DURATION, 300)),
        (pe(pe.TIME_SHIFT, 100), pe(pe.NOTE_ON, 67),
         pe(pe.VELOCITY, 16), pe(pe.DURATION, 100)),
    ]
    self.assertEqual(expected_performance, list(performance))

    ns = performance.to_sequence(instrument=0)
    self.assertEqual(self.note_sequence, ns)

  def testProgramAndIsDrumFromQuantizedNoteSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)],
        program=1)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 1, [(36, 100, 0.0, 4.0), (48, 100, 0.0, 4.0)],
        program=2)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 2, [(57, 100, 0.0, 0.1)],
        is_drum=True)
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)

    performance = performance_lib.Performance(quantized_sequence, instrument=0)
    self.assertEqual(1, performance.program)
    self.assertFalse(performance.is_drum)

    performance = performance_lib.Performance(quantized_sequence, instrument=1)
    self.assertEqual(2, performance.program)
    self.assertFalse(performance.is_drum)

    performance = performance_lib.Performance(quantized_sequence, instrument=2)
    self.assertIsNone(performance.program)
    self.assertTrue(performance.is_drum)

    performance = performance_lib.Performance(quantized_sequence)
    self.assertIsNone(performance.program)
    self.assertIsNone(performance.is_drum)

  def testToSequence(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.Performance(quantized_sequence)
    performance_ns = performance.to_sequence()

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithVelocity(self):
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 115, 0.0, 3.0), (67, 127, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
        self.note_sequence, steps_per_second=100)
    performance = performance_lib.Performance(
        quantized_sequence, num_velocity_bins=127)
    performance_ns = performance.to_sequence()

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithUnmatchedNoteOffs(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 50),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_OFF, 64),
        pe(pe.NOTE_OFF, 67),  # Was not started, should be ignored.
    ]
    for event in perf_events:
      performance.append(event)

    performance_ns = performance.to_sequence()

    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 0.5), (64, 100, 0.0, 0.5)])

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithUnmatchedNoteOns(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
    ]
    for event in perf_events:
      performance.append(event)

    performance_ns = performance.to_sequence()

    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 1.0), (64, 100, 0.0, 1.0)])

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceWithRepeatedNotes(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 100),
    ]
    for event in perf_events:
      performance.append(event)

    performance_ns = performance.to_sequence()

    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 2.0), (64, 100, 0.0, 2.0), (60, 100, 1.0, 2.0)])

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testToSequenceRelativeQuantized(self):
    self.note_sequence.tempos.add(qpm=60.0)
    testing_lib.add_track_to_sequence(
        self.note_sequence, 0,
        [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
    quantized_sequence = sequences_lib.quantize_note_sequence(
        self.note_sequence, steps_per_quarter=100)
    performance = performance_lib.MetricPerformance(quantized_sequence)
    performance_ns = performance.to_sequence(qpm=60.0)

    # Make comparison easier by sorting.
    performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
    self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

    self.assertEqual(self.note_sequence, performance_ns)

  def testSetLengthAddSteps(self):
    performance = performance_lib.Performance(steps_per_second=100)

    performance.set_length(50)
    self.assertEqual(50, performance.num_steps)
    self.assertListEqual([0], performance.steps)

    pe = performance_lib.PerformanceEvent
    perf_events = [pe(pe.TIME_SHIFT, 50)]
    self.assertEqual(perf_events, list(performance))

    performance.set_length(150)
    self.assertEqual(150, performance.num_steps)
    self.assertListEqual([0, 100], performance.steps)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.TIME_SHIFT, 100),
        pe(pe.TIME_SHIFT, 50),
    ]
    self.assertEqual(perf_events, list(performance))

    performance.set_length(200)
    self.assertEqual(200, performance.num_steps)
    self.assertListEqual([0, 100], performance.steps)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.TIME_SHIFT, 100),
        pe(pe.TIME_SHIFT, 100),
    ]
    self.assertEqual(perf_events, list(performance))

  def testSetLengthRemoveSteps(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.NOTE_ON, 67),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 67),
    ]
    for event in perf_events:
      performance.append(event)

    performance.set_length(200)
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 64),
        pe(pe.NOTE_ON, 67),
    ]
    self.assertEqual(perf_events, list(performance))

    performance.set_length(50)
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.TIME_SHIFT, 50),
    ]
    self.assertEqual(perf_events, list(performance))

  def testNumSteps(self):
    performance = performance_lib.Performance(steps_per_second=100)

    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_OFF, 64),
    ]
    for event in perf_events:
      performance.append(event)

    self.assertEqual(100, performance.num_steps)
    self.assertListEqual([0, 0, 0, 100, 100], performance.steps)

  def testSteps(self):
    pe = performance_lib.PerformanceEvent
    perf_events = [
        pe(pe.NOTE_ON, 60),
        pe(pe.NOTE_ON, 64),
        pe(pe.TIME_SHIFT, 100),
        pe(pe.NOTE_OFF, 60),
        pe(pe.NOTE_OFF, 64),
    ]

    performance = performance_lib.Performance(steps_per_second=100)
    for event in perf_events:
      performance.append(event)
    self.assertListEqual([0, 0, 0, 100, 100], performance.steps)

    performance = performance_lib.Performance(
        steps_per_second=100, start_step=100)
    for event in perf_events:
      performance.append(event)
    self.assertListEqual([100, 100, 100, 200, 200], performance.steps)

  def testPeEqAndHash(self):
    pe = performance_lib.PerformanceEvent
    self.assertEqual(pe(pe.NOTE_ON, 60), pe(pe.NOTE_ON, 60))
    self.assertLen(set([pe(pe.NOTE_ON, 60), pe(pe.NOTE_ON, 60)]), 1)

Ancestors

  • absl.testing.absltest.TestCase
  • absl.third_party.unittest3_backport.case.TestCase
  • unittest.case.TestCase

Methods

def setUp(self)

Hook method for setting up the test fixture before exercising it.

Expand source code
def setUp(self):
  super().setUp()
  self.maxDiff = None  # pylint:disable=invalid-name

  self.note_sequence = music_pb2.NoteSequence()
  self.note_sequence.ticks_per_quarter = 220
def testFromQuantizedNoteSequence(self)
Expand source code
def testFromQuantizedNoteSequence(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)
  performance = performance_lib.Performance(quantized_sequence)

  self.assertEqual(100, performance.steps_per_second)

  pe = performance_lib.PerformanceEvent
  expected_performance = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_ON, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
  ]
  self.assertEqual(expected_performance, list(performance))
def testFromQuantizedNoteSequenceWithQuantizedVelocity(self)
Expand source code
def testFromQuantizedNoteSequenceWithQuantizedVelocity(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 127, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)
  performance = list(performance_lib.Performance(
      quantized_sequence, num_velocity_bins=16))

  pe = performance_lib.PerformanceEvent
  expected_performance = [
      pe(pe.VELOCITY, 13),
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.VELOCITY, 16),
      pe(pe.NOTE_ON, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
  ]
  self.assertEqual(expected_performance, performance)
def testFromQuantizedNoteSequenceWithVelocity(self)
Expand source code
def testFromQuantizedNoteSequenceWithVelocity(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 127, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)
  performance = list(performance_lib.Performance(
      quantized_sequence, num_velocity_bins=127))

  pe = performance_lib.PerformanceEvent
  expected_performance = [
      pe(pe.VELOCITY, 100),
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.VELOCITY, 127),
      pe(pe.NOTE_ON, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
  ]
  self.assertEqual(expected_performance, performance)
def testFromRelativeQuantizedNoteSequence(self)
Expand source code
def testFromRelativeQuantizedNoteSequence(self):
  self.note_sequence.tempos.add(qpm=60.0)
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence(
      self.note_sequence, steps_per_quarter=100)
  performance = performance_lib.MetricPerformance(quantized_sequence)

  self.assertEqual(100, performance.steps_per_quarter)

  pe = performance_lib.PerformanceEvent
  expected_performance = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_ON, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
  ]
  self.assertEqual(expected_performance, list(performance))
def testNotePerformanceFromQuantizedNoteSequence(self)
Expand source code
def testNotePerformanceFromQuantizedNoteSequence(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 97, 0.0, 4.0), (64, 97, 0.0, 3.0), (67, 121, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)
  performance = performance_lib.NotePerformance(
      quantized_sequence, num_velocity_bins=16)

  pe = performance_lib.PerformanceEvent
  expected_performance = [
      (pe(pe.TIME_SHIFT, 0), pe(pe.NOTE_ON, 60),
       pe(pe.VELOCITY, 13), pe(pe.DURATION, 400)),
      (pe(pe.TIME_SHIFT, 0), pe(pe.NOTE_ON, 64),
       pe(pe.VELOCITY, 13), pe(pe.DURATION, 300)),
      (pe(pe.TIME_SHIFT, 100), pe(pe.NOTE_ON, 67),
       pe(pe.VELOCITY, 16), pe(pe.DURATION, 100)),
  ]
  self.assertEqual(expected_performance, list(performance))

  ns = performance.to_sequence(instrument=0)
  self.assertEqual(self.note_sequence, ns)
def testNumSteps(self)
Expand source code
def testNumSteps(self):
  performance = performance_lib.Performance(steps_per_second=100)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
      pe(pe.NOTE_OFF, 64),
  ]
  for event in perf_events:
    performance.append(event)

  self.assertEqual(100, performance.num_steps)
  self.assertListEqual([0, 0, 0, 100, 100], performance.steps)
def testPeEqAndHash(self)
Expand source code
def testPeEqAndHash(self):
  pe = performance_lib.PerformanceEvent
  self.assertEqual(pe(pe.NOTE_ON, 60), pe(pe.NOTE_ON, 60))
  self.assertLen(set([pe(pe.NOTE_ON, 60), pe(pe.NOTE_ON, 60)]), 1)
def testProgramAndIsDrumFromQuantizedNoteSequence(self)
Expand source code
def testProgramAndIsDrumFromQuantizedNoteSequence(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)],
      program=1)
  testing_lib.add_track_to_sequence(
      self.note_sequence, 1, [(36, 100, 0.0, 4.0), (48, 100, 0.0, 4.0)],
      program=2)
  testing_lib.add_track_to_sequence(
      self.note_sequence, 2, [(57, 100, 0.0, 0.1)],
      is_drum=True)
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)

  performance = performance_lib.Performance(quantized_sequence, instrument=0)
  self.assertEqual(1, performance.program)
  self.assertFalse(performance.is_drum)

  performance = performance_lib.Performance(quantized_sequence, instrument=1)
  self.assertEqual(2, performance.program)
  self.assertFalse(performance.is_drum)

  performance = performance_lib.Performance(quantized_sequence, instrument=2)
  self.assertIsNone(performance.program)
  self.assertTrue(performance.is_drum)

  performance = performance_lib.Performance(quantized_sequence)
  self.assertIsNone(performance.program)
  self.assertIsNone(performance.is_drum)
def testSetLengthAddSteps(self)
Expand source code
def testSetLengthAddSteps(self):
  performance = performance_lib.Performance(steps_per_second=100)

  performance.set_length(50)
  self.assertEqual(50, performance.num_steps)
  self.assertListEqual([0], performance.steps)

  pe = performance_lib.PerformanceEvent
  perf_events = [pe(pe.TIME_SHIFT, 50)]
  self.assertEqual(perf_events, list(performance))

  performance.set_length(150)
  self.assertEqual(150, performance.num_steps)
  self.assertListEqual([0, 100], performance.steps)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.TIME_SHIFT, 100),
      pe(pe.TIME_SHIFT, 50),
  ]
  self.assertEqual(perf_events, list(performance))

  performance.set_length(200)
  self.assertEqual(200, performance.num_steps)
  self.assertListEqual([0, 100], performance.steps)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.TIME_SHIFT, 100),
      pe(pe.TIME_SHIFT, 100),
  ]
  self.assertEqual(perf_events, list(performance))
def testSetLengthRemoveSteps(self)
Expand source code
def testSetLengthRemoveSteps(self):
  performance = performance_lib.Performance(steps_per_second=100)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 64),
      pe(pe.NOTE_ON, 67),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 67),
  ]
  for event in perf_events:
    performance.append(event)

  performance.set_length(200)
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 64),
      pe(pe.NOTE_ON, 67),
  ]
  self.assertEqual(perf_events, list(performance))

  performance.set_length(50)
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.TIME_SHIFT, 50),
  ]
  self.assertEqual(perf_events, list(performance))
def testSteps(self)
Expand source code
def testSteps(self):
  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_OFF, 60),
      pe(pe.NOTE_OFF, 64),
  ]

  performance = performance_lib.Performance(steps_per_second=100)
  for event in perf_events:
    performance.append(event)
  self.assertListEqual([0, 0, 0, 100, 100], performance.steps)

  performance = performance_lib.Performance(
      steps_per_second=100, start_step=100)
  for event in perf_events:
    performance.append(event)
  self.assertListEqual([100, 100, 100, 200, 200], performance.steps)
def testToSequence(self)
Expand source code
def testToSequence(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)
  performance = performance_lib.Performance(quantized_sequence)
  performance_ns = performance.to_sequence()

  # Make comparison easier by sorting.
  performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
  self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

  self.assertEqual(self.note_sequence, performance_ns)
def testToSequenceRelativeQuantized(self)
Expand source code
def testToSequenceRelativeQuantized(self):
  self.note_sequence.tempos.add(qpm=60.0)
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 100, 0.0, 3.0), (67, 100, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence(
      self.note_sequence, steps_per_quarter=100)
  performance = performance_lib.MetricPerformance(quantized_sequence)
  performance_ns = performance.to_sequence(qpm=60.0)

  # Make comparison easier by sorting.
  performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
  self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

  self.assertEqual(self.note_sequence, performance_ns)
def testToSequenceWithRepeatedNotes(self)
Expand source code
def testToSequenceWithRepeatedNotes(self):
  performance = performance_lib.Performance(steps_per_second=100)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
      pe(pe.NOTE_ON, 60),
      pe(pe.TIME_SHIFT, 100),
  ]
  for event in perf_events:
    performance.append(event)

  performance_ns = performance.to_sequence()

  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 2.0), (64, 100, 0.0, 2.0), (60, 100, 1.0, 2.0)])

  # Make comparison easier by sorting.
  performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
  self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

  self.assertEqual(self.note_sequence, performance_ns)
def testToSequenceWithUnmatchedNoteOffs(self)
Expand source code
def testToSequenceWithUnmatchedNoteOffs(self):
  performance = performance_lib.Performance(steps_per_second=100)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 50),
      pe(pe.NOTE_OFF, 60),
      pe(pe.NOTE_OFF, 64),
      pe(pe.NOTE_OFF, 67),  # Was not started, should be ignored.
  ]
  for event in perf_events:
    performance.append(event)

  performance_ns = performance.to_sequence()

  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 0.5), (64, 100, 0.0, 0.5)])

  # Make comparison easier by sorting.
  performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
  self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

  self.assertEqual(self.note_sequence, performance_ns)
def testToSequenceWithUnmatchedNoteOns(self)
Expand source code
def testToSequenceWithUnmatchedNoteOns(self):
  performance = performance_lib.Performance(steps_per_second=100)

  pe = performance_lib.PerformanceEvent
  perf_events = [
      pe(pe.NOTE_ON, 60),
      pe(pe.NOTE_ON, 64),
      pe(pe.TIME_SHIFT, 100),
  ]
  for event in perf_events:
    performance.append(event)

  performance_ns = performance.to_sequence()

  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 1.0), (64, 100, 0.0, 1.0)])

  # Make comparison easier by sorting.
  performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
  self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

  self.assertEqual(self.note_sequence, performance_ns)
def testToSequenceWithVelocity(self)
Expand source code
def testToSequenceWithVelocity(self):
  testing_lib.add_track_to_sequence(
      self.note_sequence, 0,
      [(60, 100, 0.0, 4.0), (64, 115, 0.0, 3.0), (67, 127, 1.0, 2.0)])
  quantized_sequence = sequences_lib.quantize_note_sequence_absolute(
      self.note_sequence, steps_per_second=100)
  performance = performance_lib.Performance(
      quantized_sequence, num_velocity_bins=127)
  performance_ns = performance.to_sequence()

  # Make comparison easier by sorting.
  performance_ns.notes.sort(key=lambda n: (n.start_time, n.pitch))
  self.note_sequence.notes.sort(key=lambda n: (n.start_time, n.pitch))

  self.assertEqual(self.note_sequence, performance_ns)