MP3Loader.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /*
  2. * Copyright (c) 2021, Arne Elster <arne@elster.li>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include "Loader.h"
  8. #include "MP3Types.h"
  9. #include <AK/MemoryStream.h>
  10. #include <AK/Tuple.h>
  11. #include <LibCore/InputBitStream.h>
  12. #include <LibCore/MemoryStream.h>
  13. #include <LibCore/Stream.h>
  14. #include <LibDSP/MDCT.h>
  15. namespace Audio {
  16. namespace MP3::Tables {
  17. struct ScaleFactorBand;
  18. }
  19. class MP3LoaderPlugin : public LoaderPlugin {
  20. public:
  21. explicit MP3LoaderPlugin(NonnullOwnPtr<Core::Stream::SeekableStream> stream);
  22. virtual ~MP3LoaderPlugin() = default;
  23. static Result<NonnullOwnPtr<MP3LoaderPlugin>, LoaderError> try_create(StringView path);
  24. static Result<NonnullOwnPtr<MP3LoaderPlugin>, LoaderError> try_create(Bytes buffer);
  25. virtual LoaderSamples get_more_samples(size_t max_bytes_to_read_from_input = 128 * KiB) override;
  26. virtual MaybeLoaderError reset() override;
  27. virtual MaybeLoaderError seek(int const position) override;
  28. virtual int loaded_samples() override { return m_loaded_samples; }
  29. virtual int total_samples() override { return m_total_samples; }
  30. virtual u32 sample_rate() override { return m_sample_rate; }
  31. virtual u16 num_channels() override { return m_num_channels; }
  32. virtual PcmSampleFormat pcm_format() override { return m_sample_format; }
  33. virtual String format_name() override { return "MP3 (.mp3)"; }
  34. private:
  35. MaybeLoaderError initialize();
  36. MaybeLoaderError synchronize();
  37. MaybeLoaderError build_seek_table();
  38. ErrorOr<MP3::Header, LoaderError> read_header();
  39. ErrorOr<MP3::MP3Frame, LoaderError> read_next_frame();
  40. ErrorOr<MP3::MP3Frame, LoaderError> read_frame_data(MP3::Header const&, bool is_first_frame);
  41. MaybeLoaderError read_side_information(MP3::MP3Frame&);
  42. ErrorOr<size_t, LoaderError> read_scale_factors(MP3::MP3Frame&, InputBitStream& reservoir, size_t granule_index, size_t channel_index);
  43. MaybeLoaderError read_huffman_data(MP3::MP3Frame&, InputBitStream& reservoir, size_t granule_index, size_t channel_index, size_t granule_bits_read);
  44. static AK::Array<float, 576> calculate_frame_exponents(MP3::MP3Frame const&, size_t granule_index, size_t channel_index);
  45. static void reorder_samples(MP3::Granule&, u32 sample_rate);
  46. static void reduce_alias(MP3::Granule&, size_t max_subband_index = 576);
  47. static void process_stereo(MP3::MP3Frame&, size_t granule_index);
  48. static void transform_samples_to_time(Array<float, 576> const& input, size_t input_offset, Array<float, 36>& output, MP3::BlockType block_type);
  49. static void synthesis(Array<float, 1024>& V, Array<float, 32>& samples, Array<float, 32>& result);
  50. static Span<MP3::Tables::ScaleFactorBand const> get_scalefactor_bands(MP3::Granule const&, int samplerate);
  51. AK::Vector<AK::Tuple<size_t, int>> m_seek_table;
  52. AK::Array<AK::Array<AK::Array<float, 18>, 32>, 2> m_last_values {};
  53. AK::Array<AK::Array<float, 1024>, 2> m_synthesis_buffer {};
  54. static DSP::MDCT<36> s_mdct_36;
  55. static DSP::MDCT<12> s_mdct_12;
  56. u32 m_sample_rate { 0 };
  57. u8 m_num_channels { 0 };
  58. PcmSampleFormat m_sample_format { PcmSampleFormat::Int16 };
  59. int m_total_samples { 0 };
  60. size_t m_loaded_samples { 0 };
  61. bool m_is_first_frame { true };
  62. AK::Optional<MP3::MP3Frame> m_current_frame;
  63. u32 m_current_frame_read;
  64. OwnPtr<Core::Stream::BigEndianInputBitStream> m_bitstream;
  65. DuplexMemoryStream m_bit_reservoir;
  66. };
  67. }