annotate foosdk/sdk/foobar2000/helpers/VisUtils.cpp @ 1:20d02a178406 default tip

*: check in everything else yay
author Paper <paper@tflc.us>
date Mon, 05 Jan 2026 02:15:46 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
1 #include "StdAfx.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
2
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
3 #include "VisUtils.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
4
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
5 namespace VisUtils {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
6 void PrepareFFTChunk(audio_chunk const & source, audio_chunk & out, double centerOffset) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
7 const t_uint32 channels = source.get_channel_count();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
8 const t_uint32 sampleRate = source.get_sample_rate();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
9 FB2K_DYNAMIC_ASSERT( sampleRate > 0 );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
10 out.set_channels(channels, source.get_channel_config());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
11 out.set_sample_rate(sampleRate);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
12 const t_size inSize = source.get_sample_count();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
13 const t_size fftSize = MatchFFTSize(inSize);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
14 out.set_sample_count(fftSize);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
15 out.set_data_size(fftSize * channels);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
16 if (fftSize >= inSize) { //rare case with *REALLY* small input
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
17 pfc::memcpy_t( out.get_data(), source.get_data(), inSize * channels );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
18 pfc::memset_null_t( out.get_data() + inSize * channels, (fftSize - inSize) * channels );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
19 } else { //inSize > fftSize, we're using a subset of source chunk for the job, pick a subset around centerOffset.
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
20 const double baseOffset = pfc::max_t<double>(0, centerOffset - 0.5 * (double)fftSize / (double)sampleRate);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
21 const t_size baseSample = pfc::min_t<t_size>( (t_size) audio_math::time_to_samples(baseOffset, sampleRate), inSize - fftSize);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
22 pfc::memcpy_t( out.get_data(), source.get_data() + baseSample * channels, fftSize * channels);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
23 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
24 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
25
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
26 bool IsValidFFTSize(t_size p_size) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
27 return p_size >= 2 && (p_size & (p_size - 1)) == 0;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
28 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
29
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
30 t_size MatchFFTSize(t_size samples) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
31 if (samples <= 2) return 2;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
32 t_size mask = 1;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
33 while(!IsValidFFTSize(samples)) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
34 samples &= ~mask; mask <<= 1;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
35 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
36 return samples;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
37 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
38 };