Actually change padding in StftHelper::set_padding
This commit is contained in:
parent
32957c222f
commit
e3e2a2e7d0
2 changed files with 7 additions and 5 deletions
|
@ -221,7 +221,7 @@ impl<const NUM_SIDECHAIN_INPUTS: usize> StftHelper<NUM_SIDECHAIN_INPUTS> {
|
||||||
pub fn set_block_size(&mut self, block_size: usize) {
|
pub fn set_block_size(&mut self, block_size: usize) {
|
||||||
assert!(block_size <= self.main_input_ring_buffers[0].capacity());
|
assert!(block_size <= self.main_input_ring_buffers[0].capacity());
|
||||||
|
|
||||||
self.update_buffers(block_size, self.padding);
|
self.update_buffers(block_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Change the current padding amount. This will clear the buffers, causing the next block to
|
/// Change the current padding amount. This will clear the buffers, causing the next block to
|
||||||
|
@ -233,7 +233,8 @@ impl<const NUM_SIDECHAIN_INPUTS: usize> StftHelper<NUM_SIDECHAIN_INPUTS> {
|
||||||
pub fn set_padding(&mut self, padding: usize) {
|
pub fn set_padding(&mut self, padding: usize) {
|
||||||
assert!(padding <= self.padding_buffers[0].capacity());
|
assert!(padding <= self.padding_buffers[0].capacity());
|
||||||
|
|
||||||
self.update_buffers(self.main_input_ring_buffers[0].len(), padding);
|
self.padding = padding;
|
||||||
|
self.update_buffers(self.main_input_ring_buffers[0].len());
|
||||||
}
|
}
|
||||||
|
|
||||||
/// The number of channels this `StftHelper` was configured for
|
/// The number of channels this `StftHelper` was configured for
|
||||||
|
@ -551,7 +552,7 @@ impl<const NUM_SIDECHAIN_INPUTS: usize> StftHelper<NUM_SIDECHAIN_INPUTS> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update_buffers(&mut self, block_size: usize, padding: usize) {
|
fn update_buffers(&mut self, block_size: usize) {
|
||||||
for main_ring_buffer in &mut self.main_input_ring_buffers {
|
for main_ring_buffer in &mut self.main_input_ring_buffers {
|
||||||
main_ring_buffer.resize(block_size, 0.0);
|
main_ring_buffer.resize(block_size, 0.0);
|
||||||
main_ring_buffer.fill(0.0);
|
main_ring_buffer.fill(0.0);
|
||||||
|
@ -570,7 +571,8 @@ impl<const NUM_SIDECHAIN_INPUTS: usize> StftHelper<NUM_SIDECHAIN_INPUTS> {
|
||||||
self.scratch_buffer.fill(0.0);
|
self.scratch_buffer.fill(0.0);
|
||||||
|
|
||||||
for padding_buffer in &mut self.padding_buffers {
|
for padding_buffer in &mut self.padding_buffers {
|
||||||
padding_buffer.resize(padding, 0.0);
|
// In case this changed since the last call, like in `set_padding()`
|
||||||
|
padding_buffer.resize(self.padding, 0.0);
|
||||||
padding_buffer.fill(0.0);
|
padding_buffer.fill(0.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,7 @@ pub fn blackman(size: usize) -> Vec<f32> {
|
||||||
window
|
window
|
||||||
}
|
}
|
||||||
|
|
||||||
/// The same as [`blackman()`], but filling an existing slice instead.
|
/// The same as [`blackman()`], but filling an existing slice instead. asfasdf
|
||||||
pub fn blackman_in_place(window: &mut [f32]) {
|
pub fn blackman_in_place(window: &mut [f32]) {
|
||||||
let size = window.len();
|
let size = window.len();
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue