Class: Vizcore::Analysis::AdaptiveNormalizer
- Inherits:
-
Object
- Object
- Vizcore::Analysis::AdaptiveNormalizer
- Defined in:
- lib/vizcore/analysis/adaptive_normalizer.rb
Overview
Scales audio features against a rolling amplitude peak for repeatable mappings.
Constant Summary collapse
- DEFAULT_WINDOW_SIZE =
128- DEFAULT_TARGET =
0.85- DEFAULT_FLOOR =
0.05
Instance Method Summary collapse
-
#call(amplitude:, bands:, fft:) ⇒ Hash
Normalized feature values plus the applied gain.
-
#initialize(window_size: DEFAULT_WINDOW_SIZE, target: DEFAULT_TARGET, floor: DEFAULT_FLOOR) ⇒ AdaptiveNormalizer
constructor
A new instance of AdaptiveNormalizer.
Constructor Details
#initialize(window_size: DEFAULT_WINDOW_SIZE, target: DEFAULT_TARGET, floor: DEFAULT_FLOOR) ⇒ AdaptiveNormalizer
Returns a new instance of AdaptiveNormalizer.
14 15 16 17 18 19 |
# File 'lib/vizcore/analysis/adaptive_normalizer.rb', line 14 def initialize(window_size: DEFAULT_WINDOW_SIZE, target: DEFAULT_TARGET, floor: DEFAULT_FLOOR) @window_size = normalize_window_size(window_size) @target = normalize_unit(target, DEFAULT_TARGET) @floor = normalize_unit(floor, DEFAULT_FLOOR) @history = [] end |
Instance Method Details
#call(amplitude:, bands:, fft:) ⇒ Hash
Returns normalized feature values plus the applied gain.
25 26 27 28 29 30 31 32 33 34 35 36 37 |
# File 'lib/vizcore/analysis/adaptive_normalizer.rb', line 25 def call(amplitude:, bands:, fft:) current_amplitude = normalize_unit(amplitude, 0.0) @history << current_amplitude @history.shift while @history.length > @window_size gain = @target / [@history.max.to_f, @floor].max { amplitude: scale_value(current_amplitude, gain), bands: scale_hash(bands, gain), fft: scale_array(fft, gain), gain: gain } end |