2021-04-28 12:43:51 +08:00
|
|
|
#ifndef CORE_FMT_TRAITS_H
|
|
|
|
#define CORE_FMT_TRAITS_H
|
|
|
|
|
2023-05-31 23:57:33 +08:00
|
|
|
#include <stddef.h>
|
2021-04-28 12:43:51 +08:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2023-05-31 23:57:33 +08:00
|
|
|
#include "albyte.h"
|
2021-04-28 12:43:51 +08:00
|
|
|
#include "buffer_storage.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace al {
|
|
|
|
|
|
|
|
extern const int16_t muLawDecompressionTable[256];
|
|
|
|
extern const int16_t aLawDecompressionTable[256];
|
|
|
|
|
|
|
|
|
|
|
|
template<FmtType T>
|
|
|
|
struct FmtTypeTraits { };
|
|
|
|
|
|
|
|
template<>
|
|
|
|
struct FmtTypeTraits<FmtUByte> {
|
|
|
|
using Type = uint8_t;
|
|
|
|
|
|
|
|
template<typename OutT>
|
2023-05-31 23:57:33 +08:00
|
|
|
static constexpr inline OutT to(const Type val) noexcept
|
|
|
|
{ return val*OutT{1.0/128.0} - OutT{1.0}; }
|
2021-04-28 12:43:51 +08:00
|
|
|
};
|
|
|
|
template<>
|
|
|
|
struct FmtTypeTraits<FmtShort> {
|
|
|
|
using Type = int16_t;
|
|
|
|
|
|
|
|
template<typename OutT>
|
2023-05-31 23:57:33 +08:00
|
|
|
static constexpr inline OutT to(const Type val) noexcept { return val*OutT{1.0/32768.0}; }
|
2021-04-28 12:43:51 +08:00
|
|
|
};
|
|
|
|
template<>
|
|
|
|
struct FmtTypeTraits<FmtFloat> {
|
|
|
|
using Type = float;
|
|
|
|
|
|
|
|
template<typename OutT>
|
2023-05-31 23:57:33 +08:00
|
|
|
static constexpr inline OutT to(const Type val) noexcept { return val; }
|
2021-04-28 12:43:51 +08:00
|
|
|
};
|
|
|
|
template<>
|
|
|
|
struct FmtTypeTraits<FmtDouble> {
|
|
|
|
using Type = double;
|
|
|
|
|
|
|
|
template<typename OutT>
|
2023-05-31 23:57:33 +08:00
|
|
|
static constexpr inline OutT to(const Type val) noexcept { return static_cast<OutT>(val); }
|
2021-04-28 12:43:51 +08:00
|
|
|
};
|
|
|
|
template<>
|
|
|
|
struct FmtTypeTraits<FmtMulaw> {
|
|
|
|
using Type = uint8_t;
|
|
|
|
|
|
|
|
template<typename OutT>
|
2023-05-31 23:57:33 +08:00
|
|
|
static constexpr inline OutT to(const Type val) noexcept
|
2021-04-28 12:43:51 +08:00
|
|
|
{ return muLawDecompressionTable[val] * OutT{1.0/32768.0}; }
|
|
|
|
};
|
|
|
|
template<>
|
|
|
|
struct FmtTypeTraits<FmtAlaw> {
|
|
|
|
using Type = uint8_t;
|
|
|
|
|
|
|
|
template<typename OutT>
|
2023-05-31 23:57:33 +08:00
|
|
|
static constexpr inline OutT to(const Type val) noexcept
|
2021-04-28 12:43:51 +08:00
|
|
|
{ return aLawDecompressionTable[val] * OutT{1.0/32768.0}; }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
template<FmtType SrcType, typename DstT>
|
2023-05-31 23:57:33 +08:00
|
|
|
inline void LoadSampleArray(DstT *RESTRICT dst, const al::byte *src, const size_t srcstep,
|
|
|
|
const size_t samples) noexcept
|
2021-04-28 12:43:51 +08:00
|
|
|
{
|
|
|
|
using TypeTraits = FmtTypeTraits<SrcType>;
|
|
|
|
using SampleType = typename TypeTraits::Type;
|
|
|
|
|
|
|
|
const SampleType *RESTRICT ssrc{reinterpret_cast<const SampleType*>(src)};
|
|
|
|
for(size_t i{0u};i < samples;i++)
|
|
|
|
dst[i] = TypeTraits::template to<DstT>(ssrc[i*srcstep]);
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace al
|
|
|
|
|
|
|
|
#endif /* CORE_FMT_TRAITS_H */
|