Sha256: 97f54c3f4ca90a9d24fd7154a4984c53528c326654332c1a8ebe726259c7689f
Contents?: true
Size: 1.41 KB
Versions: 1
Compression:
Stored size: 1.41 KB
Contents
module SPCore class EnvelopeDetector include Hashmake::HashMakeable ARG_SPECS = [ Hashmake::ArgSpec.new(:reqd => true, :key => :sample_rate, :type => Float, :validator => ->(a){ a > 0.0 } ), Hashmake::ArgSpec.new(:reqd => true, :key => :attack_time, :type => Float, :validator => ->(a){ a > 0.0 } ), Hashmake::ArgSpec.new(:reqd => true, :key => :release_time, :type => Float, :validator => ->(a){ a > 0.0 } ), ] attr_reader :envelope, :sample_rate, :attack_time, :release_time def initialize args hash_make EnvelopeDetector::ARG_SPECS, args @g_attack = Math.exp(-1.0 / (sample_rate * attack_time)) @g_release = Math.exp(-1.0 / (sample_rate * release_time)) @envelope = 0.0 end def attack_time= attack_time raise ArgumentError, "attack_time is <= 0.0" if attack_time <= 0.0 @g_attack = Math.exp(-1.0 / (sample_rate * attack_time)) @attack_time = attack_time end def release_time= release_time raise ArgumentError, "release_time is <= 0.0" if release_time <= 0.0 @g_release = Math.exp(-1.0 / (sample_rate * release_time)) @release_time = release_time end def process_sample sample input_abs = sample.abs if @envelope < input_abs @envelope = (@envelope * @g_attack) + ((1.0 - @g_attack) * input_abs) else @envelope = (@envelope * @g_release) + ((1.0 - @g_release) * input_abs) end return @envelope end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
spcore-0.1.2 | lib/spcore/lib/envelope_detector.rb |