annotate foosdk/sdk/foobar2000/shared/audio_math.h @ 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 #pragma once
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 <stdint.h>
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
4 #if SIZE_MAX < UINT64_MAX
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
5 #define audio_sample_size 32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
6 #else
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
7 #define audio_sample_size 64
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
8 #endif
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
9
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
10 #if audio_sample_size == 32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
11 typedef float audio_sample;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
12 #define audio_sample_asm dword
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
13 #elif audio_sample_size == 64
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
14 typedef double audio_sample;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
15 #define audio_sample_asm qword
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
16 #else
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
17 #error wrong audio_sample_size
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
18 #endif
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
19
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
20 #define audio_sample_bytes (audio_sample_size/8)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
21
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
22 /*
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
23 PROBLEM:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
24 audio_math is implemented in pfc (pfc::audio_math) and in shared.dll (::audio_math)
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
25 We must overlay shared.dll methods on top of PFC ones
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
26 */
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
27
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
28 namespace audio_math
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 //! p_source/p_output can point to same buffer
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
31 void SHARED_EXPORT scale(const audio_sample * p_source,t_size p_count,audio_sample * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
32 void SHARED_EXPORT convert_to_int16(const audio_sample * p_source,t_size p_count,t_int16 * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
33 void SHARED_EXPORT convert_to_int32(const audio_sample * p_source,t_size p_count,t_int32 * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
34 audio_sample SHARED_EXPORT convert_to_int16_calculate_peak(const audio_sample * p_source,t_size p_count,t_int16 * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
35 void SHARED_EXPORT convert_from_int16(const t_int16 * p_source,t_size p_count,audio_sample * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
36 void SHARED_EXPORT convert_from_int32(const t_int32 * p_source,t_size p_count,audio_sample * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
37 audio_sample SHARED_EXPORT convert_to_int32_calculate_peak(const audio_sample * p_source,t_size p_count,t_int32 * p_output,audio_sample p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
38 audio_sample SHARED_EXPORT calculate_peak(const audio_sample * p_source,t_size p_count);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
39 void SHARED_EXPORT kill_denormal(audio_sample * p_buffer,t_size p_count);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
40 void SHARED_EXPORT add_offset(audio_sample * p_buffer,audio_sample p_delta,t_size p_count);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
41 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
42
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
43 namespace audio_math_shareddll = audio_math;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
44 typedef pfc::audio_math audio_math_pfc;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
45
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
46 // Overlay class, overrides specific pfc::audio_math methods
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
47 class fb2k_audio_math : public audio_math_pfc {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
48 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
49 static void scale(const audio_sample * p_source,t_size p_count,audio_sample * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
50 audio_math_shareddll::scale(p_source, p_count, p_output, p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
51 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
52 static void convert_to_int16(const audio_sample * p_source,t_size p_count,t_int16 * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
53 audio_math_shareddll::convert_to_int16(p_source, p_count, p_output, p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
54 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
55 static void convert_to_int32(const audio_sample * p_source,t_size p_count,t_int32 * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
56 audio_math_shareddll::convert_to_int32(p_source, p_count, p_output, p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
57 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
58 static audio_sample convert_to_int16_calculate_peak(const audio_sample * p_source,t_size p_count,t_int16 * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
59 return audio_math_shareddll::convert_to_int16_calculate_peak(p_source,p_count,p_output,p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
60 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
61 static void convert_from_int16(const t_int16 * p_source,t_size p_count,audio_sample * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
62 audio_math_shareddll::convert_from_int16(p_source,p_count,p_output,p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
63 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
64 static void convert_from_int32(const t_int32 * p_source,t_size p_count,audio_sample * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
65 audio_math_shareddll::convert_from_int32(p_source,p_count,p_output,p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
66 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
67 static audio_sample convert_to_int32_calculate_peak(const audio_sample * p_source,t_size p_count,t_int32 * p_output,audio_sample p_scale) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
68 return audio_math_shareddll::convert_to_int32_calculate_peak(p_source,p_count,p_output,p_scale);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
69 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
70 static audio_sample calculate_peak(const audio_sample * p_source,t_size p_count) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
71 return audio_math_shareddll::calculate_peak(p_source,p_count);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
72 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
73 static void kill_denormal(audio_sample * p_buffer,t_size p_count) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
74 audio_math_shareddll::kill_denormal(p_buffer, p_count);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
75 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
76 static void add_offset(audio_sample * p_buffer,audio_sample p_delta,t_size p_count) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
77 audio_math_shareddll::add_offset(p_buffer,p_delta,p_count);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
78 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
79 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
80
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
81 // Anyone trying to talk to audio_math namespace will reach fb2k_audio_math which calls the right thing
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
82 #define audio_math fb2k_audio_math