Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Make sure the size is large enough for allocating a struct | Chris Robinson | 2023-12-05 | 1 | -1/+2 |
| | |||||
* | Assert that a value is in the expected range | Chris Robinson | 2023-12-04 | 1 | -0/+2 |
| | |||||
* | Remove some unnecessary atomic wrappers | Chris Robinson | 2023-12-03 | 2 | -9/+6 |
| | |||||
* | Handle systems that don't support std::cyl_bessel_i | Chris Robinson | 2023-11-18 | 1 | -2/+45 |
| | |||||
* | Use the C++ standard's regular modified Bessel function | Chris Robinson | 2023-11-08 | 1 | -29/+2 |
| | |||||
* | Precompute a value used multiple times | Chris Robinson | 2023-11-07 | 1 | -19/+9 |
| | |||||
* | Remove an unnecessary struct member | Chris Robinson | 2023-11-04 | 1 | -0/+3 |
| | |||||
* | Remove unnecessary extra macros | Chris Robinson | 2023-10-26 | 1 | -55/+37 |
| | |||||
* | Don't make a float version of complex_fft | Chris Robinson | 2023-10-25 | 2 | -26/+19 |
| | |||||
* | Use a more appropriate type trait to remove a pointer | Chris Robinson | 2023-10-19 | 1 | -1/+1 |
| | |||||
* | Combine some more VADD(VMUL(... into VMADD(... | Chris Robinson | 2023-10-17 | 1 | -48/+44 |
| | |||||
* | Mark some output buffer pointers as RESTRICT | Chris Robinson | 2023-10-16 | 1 | -15/+17 |
| | |||||
* | Replace some function-like macros with real functions | Chris Robinson | 2023-10-16 | 1 | -117/+136 |
| | |||||
* | Avoid some macros that use inputs multiple times | Chris Robinson | 2023-10-16 | 1 | -25/+57 |
| | |||||
* | Constify some parameters | Chris Robinson | 2023-10-16 | 2 | -19/+24 |
| | |||||
* | Use a split filter for the FIR-based UHJ encoders | Chris Robinson | 2023-10-14 | 1 | -0/+4 |
| | | | | | | | | This applies the all-pass filter in two steps, first as a relatively short time-domain FIR filter, then as a series of frequency domain convolutions (using complex multiplies). Time-domain convolution scales poorly, so larger convolutions benefit from being done in the frequency domain (though the first part is still done in the time domain, to avoid longer delays). | ||||
* | Don't use al::vector where not needed | Chris Robinson | 2023-10-12 | 1 | -5/+3 |
| | |||||
* | Remove an unnecessary deque with a custom allocator | Chris Robinson | 2023-10-11 | 1 | -16/+0 |
| | |||||
* | Make and use a separate zconvolve method without scaling | Chris Robinson | 2023-10-11 | 2 | -6/+89 |
| | | | | | | When you're doing hundreds or thousands of separate zconvolve calls into the same buffer, it's more efficient to do the multiply once at the end instead of in each call. | ||||
* | Fix conversion warnings | Chris Robinson | 2023-10-10 | 1 | -19/+21 |
| | |||||
* | Fix array lookup index | Chris Robinson | 2023-10-10 | 1 | -2/+3 |
| | |||||
* | Use size_t and uint for non-negative values and indices | Chris Robinson | 2023-10-10 | 2 | -210/+210 |
| | |||||
* | Use an anonymous namespace instead of static functions | Chris Robinson | 2023-10-10 | 1 | -194/+202 |
| | |||||
* | Combine some VADD(VMUL(... to VMADD(... | Chris Robinson | 2023-10-10 | 1 | -43/+43 |
| | |||||
* | Use a bool instead of an int for 0/1 | Chris Robinson | 2023-10-09 | 1 | -25/+27 |
| | | | | Also update some comments. | ||||
* | Cleanup PFFFT | Chris Robinson | 2023-10-09 | 1 | -571/+604 |
| | | | | | | Make stylization more consistent. Remove SVMUL (they all simulated it with a LD_PS1 on the scalar). Avoid calling LD_PS1 on the same value in a loop. | ||||
* | Avoid std::aligned_storage, it's deprecated in newer C++ | Chris Robinson | 2023-10-08 | 1 | -3/+3 |
| | |||||
* | Remove more type-punning from pffft | Chris Robinson | 2023-10-08 | 1 | -52/+63 |
| | |||||
* | Clean up some more type-punning in pffft | Chris Robinson | 2023-10-08 | 1 | -22/+42 |
| | |||||
* | Avoid some type-punning and clean up pffft a bit | Chris Robinson | 2023-10-08 | 1 | -161/+148 |
| | |||||
* | Update and clarify some comments | Chris Robinson | 2023-10-07 | 2 | -91/+93 |
| | |||||
* | Add a generic GCC vector extension fallback for pffft | Chris Robinson | 2023-10-06 | 1 | -13/+80 |
| | | | | Also combine multiple allocations into one. | ||||
* | Improve NEON shuffling | Chris Robinson | 2023-10-06 | 1 | -21/+3 |
| | |||||
* | Fix x86-64 MSVC check | Chris Robinson | 2023-10-06 | 1 | -1/+1 |
| | |||||
* | Include a copy of PFFFT | Chris Robinson | 2023-10-06 | 2 | -0/+2201 |
| | | | | | This is a notably faster FFT implementation for 32-bit float signals, provided under a 3-clause BSD license. | ||||
* | Clear the 0 and half-frequency bins for the phase shift filter | Chris Robinson | 2023-10-03 | 1 | -2/+5 |
| | | | | | | This doesn't change the filter response, but is more correct since a real signal won't have an imaginary value on them (it can only have a magnitude with a phase of 0 or pi). | ||||
* | Add a wrapper for COM initialization | Chris Robinson | 2023-09-29 | 1 | -0/+38 |
| | | | | | This helps ensure COM is initialized and deinitialized in order relative to other objects (e.g. ComPtr). | ||||
* | Use std::array instead of a C-style array | Chris Robinson | 2023-09-25 | 1 | -1/+2 |
| | |||||
* | Compile with c++20 support (#920) | Deal | 2023-09-25 | 2 | -6/+8 |
| | | | | | * Compile with c++20 support * Update CMakeLists.txt | ||||
* | Shift the appropriate type | Chris Robinson | 2023-09-22 | 2 | -6/+12 |
| | |||||
* | Rename noinline to NOINLINE | Chris Robinson | 2023-09-17 | 1 | -3/+3 |
| | | | | To avoid clashes with compilers that use it as a keyword already | ||||
* | Don't inline some big functions | Chris Robinson | 2023-09-16 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is very dumb. Template functions are implicitly marked inline according to C++, and contrary to popular belief, "inline" *does* influence the compiler's decision to inline a function. A function the compiler may not have decided to inline normally may be inlined anyway, or issue a warning if it still decides not to inline, if explicitly or implicitly marked as such (or does inline it as requested, but then decides to not inline different functions it normally would because of a cumulative code size increase or something). Furthermore, once a function becomes inline due to being a template function, there's no way to undo it. Marking an inline function "noinline" pushes the problem the other way, causing the compiler to not inline a function it may have decided was beneficial to inline. There's no way to declare a template function to be inlined based solely on compiler heuristics, it will always be influenced by the implicit "inline" or explicit "noinline". That's what's happening here. A number of functions had been combined into a smaller number of large-ish template functions to reduce code duplication and ease maintanence, causing them to be implicitly inline as a side-effect. GCC then manages to inline these larger functions as implicitly requested, but in doing so prevents other smaller functions (which are explicitly marked inline) from being inlined due to excessive code increase and issue a warning. The "noinline" is a heavy-handed method of un-pessimizing the optimization pass, on the assumption the compiler apparently doesn't actually want to inline the template functions, but does so because they're technically marked inline. There's no good option here until it gets acknowledged that inline does mean something beyond allowing multiple definitions, and that template (and other types of) function definitions sometimes (if not most often) want to allow multiple definitions but don't want an artificial/detrimental boost in inline prioritization. /rant | ||||
* | Improve the FFT bit reversal computation | Chris Robinson | 2023-09-09 | 2 | -34/+43 |
| | | | | | This also allows to include 11-bit indices in the fast lookup table path, without exceeding GCC's internal limit of compile-time calculations. | ||||
* | Optimize FFT calculations for lengths of 1024 or less | Chris Robinson | 2023-09-09 | 1 | -23/+64 |
| | | | | | This replaces sin/cos calls with an array of 10 complex values for lookup tables, and separates the first loop iteration with a constant x1 multiplier. | ||||
* | Use a bit_cast instead of a union for type-punning | Chris Robinson | 2023-08-25 | 1 | -31/+16 |
| | |||||
* | Fix conversion and maybe-unused warnings with my_fopen | Chris Robinson | 2023-08-18 | 1 | -3/+10 |
| | |||||
* | Use a string_view for the backend open method | Chris Robinson | 2023-08-06 | 2 | -10/+12 |
| | |||||
* | disable unavailable functionality on xbox (#887) | Max Bachmann | 2023-07-26 | 1 | -0/+4 |
| | | | | | * disable unavailable functionality on xbox * use not std version of getenv on xbox | ||||
* | Rename threads.cpp/h to alsem.cpp/h | Chris Robinson | 2023-06-01 | 2 | -5/+6 |
| | |||||
* | Move althrd_setname to its own source | Chris Robinson | 2023-06-01 | 4 | -68/+82 |
| |