Class: Coltrane::IntervalSequence
- Inherits:
-
Object
- Object
- Coltrane::IntervalSequence
- Extended by:
- Forwardable
- Defined in:
- lib/coltrane/interval_sequence.rb
Overview
It describes a sequence of intervals
Direct Known Subclasses
Instance Attribute Summary collapse
-
#intervals ⇒ Object
readonly
Returns the value of attribute intervals.
Instance Method Summary collapse
- #&(other) ⇒ Object
- #[](x) ⇒ Object
- #all ⇒ Object
- #distances ⇒ Object
- #full_names ⇒ Object
- #has?(interval_name) ⇒ Boolean
-
#initialize(notes: nil, intervals: nil, distances: nil) ⇒ IntervalSequence
constructor
A new instance of IntervalSequence.
- #interval_names ⇒ Object
- #intervals_semitones ⇒ Object
- #inversion(index) ⇒ Object
- #inversions ⇒ Object
- #names ⇒ Object
- #next_inversion ⇒ Object
- #notes_for(root_note) ⇒ Object
- #previous_inversion ⇒ Object
- #shift(ammount) ⇒ Object
- #zero_it ⇒ Object
Constructor Details
#initialize(notes: nil, intervals: nil, distances: nil) ⇒ IntervalSequence
Returns a new instance of IntervalSequence.
47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/coltrane/interval_sequence.rb', line 47 def initialize(notes: nil, intervals: nil, distances: nil) if notes notes = NoteSet[*notes] if notes.is_a?(Array) @intervals = intervals_from_notes(notes) elsif intervals @intervals = intervals.map { |i| IntervalClass[i] } elsif distances @distances = distances @intervals = intervals_from_distances(distances) else require 'pry'; binding.pry raise 'Provide: [notes:] || [intervals:] || [distances:]' end end |
Instance Attribute Details
#intervals ⇒ Object (readonly)
Returns the value of attribute intervals.
7 8 9 |
# File 'lib/coltrane/interval_sequence.rb', line 7 def intervals @intervals end |
Instance Method Details
#&(other) ⇒ Object
138 139 140 141 142 143 |
# File 'lib/coltrane/interval_sequence.rb', line 138 def &(other) case other when Array then intervals & other when IntervalSequence then intervals & other.semitones end end |
#[](x) ⇒ Object
86 87 88 |
# File 'lib/coltrane/interval_sequence.rb', line 86 def [](x) intervals[x] end |
#all ⇒ Object
82 83 84 |
# File 'lib/coltrane/interval_sequence.rb', line 82 def all intervals end |
#distances ⇒ Object
62 63 64 65 66 67 68 69 70 |
# File 'lib/coltrane/interval_sequence.rb', line 62 def distances intervals_semitones[1..-1].each_with_index.map do |n, i| if i.zero? n elsif i < intervals_semitones.size n - intervals_semitones[i] end end + [12 - intervals_semitones.last] end |
#full_names ⇒ Object
126 127 128 |
# File 'lib/coltrane/interval_sequence.rb', line 126 def full_names map(&:full_name) end |
#has?(interval_name) ⇒ Boolean
76 77 78 |
# File 'lib/coltrane/interval_sequence.rb', line 76 def has?(interval_name) @intervals.include?(IntervalClass[interval_name]) end |
#interval_names ⇒ Object
80 81 82 |
# File 'lib/coltrane/interval_sequence.rb', line 80 def names intervals.map(&:name) end |
#intervals_semitones ⇒ Object
118 119 120 |
# File 'lib/coltrane/interval_sequence.rb', line 118 def intervals_semitones map(&:semitones) end |
#inversion(index) ⇒ Object
100 101 102 |
# File 'lib/coltrane/interval_sequence.rb', line 100 def inversion(index) IntervalSequence.new(intervals: intervals.rotate(index)).zero_it end |
#inversions ⇒ Object
112 113 114 115 116 |
# File 'lib/coltrane/interval_sequence.rb', line 112 def inversions Array.new(intervals.length) do |index| inversion(index) end end |
#names ⇒ Object
72 73 74 |
# File 'lib/coltrane/interval_sequence.rb', line 72 def names intervals.map(&:name) end |
#next_inversion ⇒ Object
104 105 106 |
# File 'lib/coltrane/interval_sequence.rb', line 104 def next_inversion inversion(index + 1) end |
#notes_for(root_note) ⇒ Object
130 131 132 133 134 135 136 |
# File 'lib/coltrane/interval_sequence.rb', line 130 def notes_for(root_note) NoteSet[ *intervals.reduce([]) do |memo, interval| memo + [root_note + interval] end ] end |
#previous_inversion ⇒ Object
108 109 110 |
# File 'lib/coltrane/interval_sequence.rb', line 108 def previous_inversion inversion(index - 1) end |
#shift(ammount) ⇒ Object
90 91 92 93 94 |
# File 'lib/coltrane/interval_sequence.rb', line 90 def shift(ammount) IntervalSequence.new(intervals: intervals.map do |i| (i.semitones + ammount) % 12 end) end |
#zero_it ⇒ Object
96 97 98 |
# File 'lib/coltrane/interval_sequence.rb', line 96 def zero_it shift(-intervals.first.semitones) end |