Sha256: 7284dbc732295253f29d46b5dc043c183ff6884026948d038917b242728e4520
Contents?: true
Size: 1.36 KB
Versions: 19
Compression:
Stored size: 1.36 KB
Contents
# frozen_string_literal: true # A harmonic interval is the diatonic interval between two notes sounding together. class HeadMusic::HarmonicInterval attr_reader :voice1, :voice2, :position def initialize(voice1, voice2, position) @voice1 = voice1 @voice2 = voice2 @position = position.is_a?(String) ? HeadMusic::Position.new(voice1.composition, position) : position end def diatonic_interval @diatonic_interval ||= HeadMusic::DiatonicInterval.new(lower_pitch, upper_pitch) end def voices [voice1, voice2].compact end def notes @notes ||= voices.map { |voice| voice.note_at(position) }.compact.sort_by(&:pitch) end def lower_note notes.first end def upper_note notes.last end def pitches @pitches ||= notes.map(&:pitch).sort_by(&:to_i) end def lower_pitch pitches.first end def upper_pitch pitches.last end def pitch_orientation return if lower_pitch == upper_pitch if lower_note.voice == voice1 :up elsif lower_note.voice == voice2 :down end end def to_s "#{diatonic_interval} at #{position}" end def method_missing(method_name, *args, &block) respond_to_missing?(method_name) ? diatonic_interval.send(method_name, *args, &block) : super end def respond_to_missing?(method_name, *_args) diatonic_interval.respond_to?(method_name) end end
Version data entries
19 entries across 19 versions & 1 rubygems