1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-13 22:32:03 +00:00

Improves const usage.

This commit is contained in:
Thomas Harte 2019-07-16 22:13:47 -04:00
parent bcbda4d855
commit 19198ea665

View File

@ -62,7 +62,7 @@ template <typename T> class LowpassSpeaker: public Speaker {
std::lock_guard<std::mutex> lock_guard(filter_parameters_mutex_); std::lock_guard<std::mutex> lock_guard(filter_parameters_mutex_);
filter_parameters_.output_cycles_per_second = cycles_per_second; filter_parameters_.output_cycles_per_second = cycles_per_second;
filter_parameters_.parameters_are_dirty = true; filter_parameters_.parameters_are_dirty = true;
output_buffer_.resize(static_cast<std::size_t>(buffer_size)); output_buffer_.resize(std::size_t(buffer_size));
} }
/*! /*!
@ -106,7 +106,7 @@ template <typename T> class LowpassSpeaker: public Speaker {
void run_for(const Cycles cycles) { void run_for(const Cycles cycles) {
if(!delegate_) return; if(!delegate_) return;
std::size_t cycles_remaining = static_cast<size_t>(cycles.as_int()); std::size_t cycles_remaining = size_t(cycles.as_int());
if(!cycles_remaining) return; if(!cycles_remaining) return;
FilterParameters filter_parameters; FilterParameters filter_parameters;
@ -126,7 +126,7 @@ template <typename T> class LowpassSpeaker: public Speaker {
if( filter_parameters.input_cycles_per_second == filter_parameters.output_cycles_per_second && if( filter_parameters.input_cycles_per_second == filter_parameters.output_cycles_per_second &&
filter_parameters.high_frequency_cutoff < 0.0) { filter_parameters.high_frequency_cutoff < 0.0) {
while(cycles_remaining) { while(cycles_remaining) {
std::size_t cycles_to_read = std::min(output_buffer_.size() - output_buffer_pointer_, cycles_remaining); const auto cycles_to_read = std::min(output_buffer_.size() - output_buffer_pointer_, cycles_remaining);
sample_source_.get_samples(cycles_to_read, &output_buffer_[output_buffer_pointer_]); sample_source_.get_samples(cycles_to_read, &output_buffer_[output_buffer_pointer_]);
output_buffer_pointer_ += cycles_to_read; output_buffer_pointer_ += cycles_to_read;
@ -143,11 +143,11 @@ template <typename T> class LowpassSpeaker: public Speaker {
return; return;
} }
// if the output rate is less than the input rate, or an additional cut-off has been specified, use the filter. // If the output rate is less than the input rate, or an additional cut-off has been specified, use the filter.
if( filter_parameters.input_cycles_per_second > filter_parameters.output_cycles_per_second || if( filter_parameters.input_cycles_per_second > filter_parameters.output_cycles_per_second ||
(filter_parameters.input_cycles_per_second == filter_parameters.output_cycles_per_second && filter_parameters.high_frequency_cutoff >= 0.0)) { (filter_parameters.input_cycles_per_second == filter_parameters.output_cycles_per_second && filter_parameters.high_frequency_cutoff >= 0.0)) {
while(cycles_remaining) { while(cycles_remaining) {
std::size_t cycles_to_read = std::min(cycles_remaining, input_buffer_.size() - input_buffer_depth_); const auto cycles_to_read = std::min(cycles_remaining, input_buffer_.size() - input_buffer_depth_);
sample_source_.get_samples(cycles_to_read, &input_buffer_[input_buffer_depth_]); sample_source_.get_samples(cycles_to_read, &input_buffer_[input_buffer_depth_]);
cycles_remaining -= cycles_to_read; cycles_remaining -= cycles_to_read;
input_buffer_depth_ += cycles_to_read; input_buffer_depth_ += cycles_to_read;
@ -165,9 +165,9 @@ template <typename T> class LowpassSpeaker: public Speaker {
// If the next loop around is going to reuse some of the samples just collected, use a memmove to // If the next loop around is going to reuse some of the samples just collected, use a memmove to
// preserve them in the correct locations (TODO: use a longer buffer to fix that) and don't skip // preserve them in the correct locations (TODO: use a longer buffer to fix that) and don't skip
// anything. Otherwise skip as required to get to the next sample batch and don't expect to reuse. // anything. Otherwise skip as required to get to the next sample batch and don't expect to reuse.
uint64_t steps = stepper_->step(); const auto steps = stepper_->step();
if(steps < input_buffer_.size()) { if(steps < input_buffer_.size()) {
int16_t *input_buffer = input_buffer_.data(); auto *const input_buffer = input_buffer_.data();
std::memmove( input_buffer, std::memmove( input_buffer,
&input_buffer[steps], &input_buffer[steps],
sizeof(int16_t) * (input_buffer_.size() - steps)); sizeof(int16_t) * (input_buffer_.size() - steps));
@ -213,15 +213,15 @@ template <typename T> class LowpassSpeaker: public Speaker {
} }
// Make a guess at a good number of taps. // Make a guess at a good number of taps.
std::size_t number_of_taps = static_cast<std::size_t>( std::size_t number_of_taps = std::size_t(
ceilf((filter_parameters.input_cycles_per_second + high_pass_frequency) / high_pass_frequency) ceilf((filter_parameters.input_cycles_per_second + high_pass_frequency) / high_pass_frequency)
); );
number_of_taps = (number_of_taps * 2) | 1; number_of_taps = (number_of_taps * 2) | 1;
output_buffer_pointer_ = 0; output_buffer_pointer_ = 0;
stepper_.reset(new SignalProcessing::Stepper( stepper_.reset(new SignalProcessing::Stepper(
static_cast<uint64_t>(filter_parameters.input_cycles_per_second), uint64_t(filter_parameters.input_cycles_per_second),
static_cast<uint64_t>(filter_parameters.output_cycles_per_second))); uint64_t(filter_parameters.output_cycles_per_second)));
filter_.reset(new SignalProcessing::FIRFilter( filter_.reset(new SignalProcessing::FIRFilter(
static_cast<unsigned int>(number_of_taps), static_cast<unsigned int>(number_of_taps),
@ -230,7 +230,7 @@ template <typename T> class LowpassSpeaker: public Speaker {
high_pass_frequency, high_pass_frequency,
SignalProcessing::FIRFilter::DefaultAttenuation)); SignalProcessing::FIRFilter::DefaultAttenuation));
input_buffer_.resize(static_cast<std::size_t>(number_of_taps)); input_buffer_.resize(std::size_t(number_of_taps));
input_buffer_depth_ = 0; input_buffer_depth_ = 0;
} }
}; };