diff options
author | Eric Wong <normalperson@yhbt.net> | 2014-06-23 07:21:30 +0000 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2014-06-23 08:03:21 +0000 |
commit | 34a5c2c0ae02d261191442acc3907f2346bf2f95 (patch) | |
tree | 68214c227edebf96d83f5fbb1841da861e4a068d /lib/dtas/trimfx.rb | |
parent | a92c8d37a094d76b2b8b691dd6cd9732011d37b3 (diff) | |
download | dtas-34a5c2c0ae02d261191442acc3907f2346bf2f95.tar.gz |
The names are subject to change, but the idea is to make multiple passes over the audio if effects overlap and combine everything afterwards. Unedited portions will be passed through sox (via trim and no other effects)
Diffstat (limited to 'lib/dtas/trimfx.rb')
-rw-r--r-- | lib/dtas/trimfx.rb | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/lib/dtas/trimfx.rb b/lib/dtas/trimfx.rb index 94ccd7a..391bbc2 100644 --- a/lib/dtas/trimfx.rb +++ b/lib/dtas/trimfx.rb @@ -75,4 +75,66 @@ class DTAS::TrimFX @tbeg = tbeg @tlen = tlen end + + def <=>(other) + tbeg <=> other.tbeg + end + + # for stable sorting + class TFXSort < Struct.new(:tfx, :idx) + def <=>(other) + cmp = tfx <=> other.tfx + 0 == cmp ? idx <=> other.idx : cmp + end + end + + # there'll be multiple epochs if ranges overlap + def self.schedule(ary) + sorted = [] + ary.each_with_index { |tfx, i| sorted << TFXSort[tfx, i] } + sorted.sort! + rv = [] + epoch = 0 + prev_end = 0 + defer = [] + begin + while tfxsort = sorted.shift + tfx = tfxsort.tfx + if tfx.tbeg >= prev_end + prev_end = tfx.tbeg + tfx.tlen + (rv[epoch] ||= []) << tfx + else + defer << tfxsort + end + end + if defer[0] + epoch += 1 + sorted = defer + defer = [] + prev_end = 0 + end + end while sorted[0] + rv + end + + def self.expand(ary, total_len) + rv = [] + schedule(ary).each_with_index do |sary, i| + tip = 0 + dst = rv[i] = [] + while tfx = sary.shift + if tfx.tbeg > tip + nfx = new(%W(trim #{tip} =#{tfx.tbeg})) + dst << nfx + dst << tfx + tip = tfx.tbeg + tfx.tlen + end + end + if tip < total_len + nfx = new(%W(trim #{tip} =#{total_len})) + dst << nfx + end + end + rv + end end |