MP3Loader.cpp 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904
  1. /*
  2. * Copyright (c) 2021, Arne Elster <arne@elster.li>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include "MP3Loader.h"
  7. #include "MP3HuffmanTables.h"
  8. #include "MP3Tables.h"
  9. #include "MP3Types.h"
  10. #include <AK/Endian.h>
  11. #include <AK/FixedArray.h>
  12. #include <LibCore/File.h>
  13. namespace Audio {
  14. DSP::MDCT<12> MP3LoaderPlugin::s_mdct_12;
  15. DSP::MDCT<36> MP3LoaderPlugin::s_mdct_36;
  16. MP3LoaderPlugin::MP3LoaderPlugin(NonnullOwnPtr<SeekableStream> stream)
  17. : LoaderPlugin(move(stream))
  18. {
  19. }
  20. MaybeLoaderError MP3LoaderPlugin::skip_id3(SeekableStream& stream)
  21. {
  22. // FIXME: This is a bit of a hack until we have a proper ID3 reader and MP3 demuxer.
  23. // Based on https://mutagen-specs.readthedocs.io/en/latest/id3/id3v2.2.html
  24. char identifier_buffer[3] = { 0, 0, 0 };
  25. auto read_identifier = StringView(TRY(stream.read_some({ &identifier_buffer[0], sizeof(identifier_buffer) })));
  26. if (read_identifier == "ID3"sv) {
  27. [[maybe_unused]] auto version = TRY(stream.read_value<u8>());
  28. [[maybe_unused]] auto revision = TRY(stream.read_value<u8>());
  29. [[maybe_unused]] auto flags = TRY(stream.read_value<u8>());
  30. auto size = 0;
  31. for (auto i = 0; i < 4; i++) {
  32. // Each byte has a zeroed most significant bit to prevent it from looking like a sync code.
  33. auto byte = TRY(stream.read_value<u8>());
  34. size <<= 7;
  35. size |= byte & 0x7F;
  36. }
  37. TRY(stream.seek(size, SeekMode::FromCurrentPosition));
  38. } else if (read_identifier != "TAG"sv) {
  39. MUST(stream.seek(-static_cast<int>(read_identifier.length()), SeekMode::FromCurrentPosition));
  40. }
  41. return {};
  42. }
  43. bool MP3LoaderPlugin::sniff(SeekableStream& stream)
  44. {
  45. auto skip_id3_result = skip_id3(stream);
  46. if (skip_id3_result.is_error())
  47. return false;
  48. return !synchronize_and_read_header(stream, 0).is_error();
  49. }
  50. ErrorOr<NonnullOwnPtr<LoaderPlugin>, LoaderError> MP3LoaderPlugin::create(NonnullOwnPtr<SeekableStream> stream)
  51. {
  52. auto loader = make<MP3LoaderPlugin>(move(stream));
  53. TRY(loader->initialize());
  54. return loader;
  55. }
  56. MaybeLoaderError MP3LoaderPlugin::initialize()
  57. {
  58. TRY(build_seek_table());
  59. m_bitstream = TRY(try_make<BigEndianInputBitStream>(MaybeOwned<Stream>(*m_stream)));
  60. TRY(seek(0));
  61. auto header = TRY(synchronize_and_read_header());
  62. m_sample_rate = header.samplerate;
  63. m_num_channels = header.channel_count();
  64. m_loaded_samples = 0;
  65. TRY(seek(0));
  66. return {};
  67. }
  68. MaybeLoaderError MP3LoaderPlugin::reset()
  69. {
  70. TRY(seek(0));
  71. m_current_frame = {};
  72. m_synthesis_buffer = {};
  73. m_loaded_samples = 0;
  74. TRY(m_bit_reservoir.discard(m_bit_reservoir.used_buffer_size()));
  75. m_bitstream->align_to_byte_boundary();
  76. return {};
  77. }
  78. MaybeLoaderError MP3LoaderPlugin::seek(int const position)
  79. {
  80. auto seek_entry = m_seek_table.seek_point_before(position);
  81. if (seek_entry.has_value()) {
  82. TRY(m_stream->seek(seek_entry->byte_offset, SeekMode::SetPosition));
  83. m_loaded_samples = seek_entry->sample_index;
  84. }
  85. m_current_frame = {};
  86. m_synthesis_buffer = {};
  87. TRY(m_bit_reservoir.discard(m_bit_reservoir.used_buffer_size()));
  88. m_bitstream->align_to_byte_boundary();
  89. return {};
  90. }
  91. ErrorOr<Vector<FixedArray<Sample>>, LoaderError> MP3LoaderPlugin::load_chunks(size_t samples_to_read_from_input)
  92. {
  93. int samples_to_read = samples_to_read_from_input;
  94. Vector<FixedArray<Sample>> frames;
  95. while (samples_to_read > 0) {
  96. FixedArray<Sample> samples = TRY(FixedArray<Sample>::create(MP3::frame_size));
  97. if (!m_current_frame.has_value()) {
  98. auto maybe_frame = read_next_frame();
  99. if (maybe_frame.is_error()) {
  100. if (m_stream->is_eof()) {
  101. return Vector<FixedArray<Sample>> {};
  102. }
  103. return maybe_frame.release_error();
  104. }
  105. m_current_frame = maybe_frame.release_value();
  106. if (!m_current_frame.has_value())
  107. break;
  108. }
  109. bool const is_stereo = m_current_frame->header.channel_count() == 2;
  110. size_t current_frame_read = 0;
  111. for (; current_frame_read < MP3::granule_size; current_frame_read++) {
  112. auto const left_sample = m_current_frame->channels[0].granules[0].pcm[current_frame_read / 32][current_frame_read % 32];
  113. auto const right_sample = is_stereo ? m_current_frame->channels[1].granules[0].pcm[current_frame_read / 32][current_frame_read % 32] : left_sample;
  114. samples[current_frame_read] = Sample { left_sample, right_sample };
  115. samples_to_read--;
  116. }
  117. for (; current_frame_read < MP3::frame_size; current_frame_read++) {
  118. auto const left_sample = m_current_frame->channels[0].granules[1].pcm[(current_frame_read - MP3::granule_size) / 32][(current_frame_read - MP3::granule_size) % 32];
  119. auto const right_sample = is_stereo ? m_current_frame->channels[1].granules[1].pcm[(current_frame_read - MP3::granule_size) / 32][(current_frame_read - MP3::granule_size) % 32] : left_sample;
  120. samples[current_frame_read] = Sample { left_sample, right_sample };
  121. samples_to_read--;
  122. }
  123. m_loaded_samples += samples.size();
  124. TRY(frames.try_append(move(samples)));
  125. m_current_frame = {};
  126. }
  127. return frames;
  128. }
  129. MaybeLoaderError MP3LoaderPlugin::build_seek_table()
  130. {
  131. VERIFY(MUST(m_stream->tell()) == 0);
  132. TRY(skip_id3(*m_stream));
  133. int sample_count = 0;
  134. size_t frame_count = 0;
  135. m_seek_table = {};
  136. while (true) {
  137. auto error_or_header = synchronize_and_read_header();
  138. if (error_or_header.is_error())
  139. break;
  140. if (frame_count % 10 == 0) {
  141. auto frame_pos = TRY(m_stream->tell()) - error_or_header.value().header_size;
  142. TRY(m_seek_table.insert_seek_point({ static_cast<u64>(sample_count), frame_pos }));
  143. }
  144. frame_count++;
  145. sample_count += MP3::frame_size;
  146. TRY(m_stream->seek(error_or_header.value().frame_size - error_or_header.value().header_size, SeekMode::FromCurrentPosition));
  147. }
  148. m_total_samples = sample_count;
  149. return {};
  150. }
  151. ErrorOr<MP3::Header, LoaderError> MP3LoaderPlugin::read_header(SeekableStream& stream, size_t sample_index)
  152. {
  153. auto bitstream = BigEndianInputBitStream(MaybeOwned<Stream>(stream));
  154. if (TRY(bitstream.read_bits(4)) != 0xF)
  155. return LoaderError { LoaderError::Category::Format, sample_index, "Frame header did not start with sync code." };
  156. MP3::Header header;
  157. header.id = TRY(bitstream.read_bit());
  158. header.layer = MP3::Tables::LayerNumberLookup[TRY(bitstream.read_bits(2))];
  159. if (header.layer <= 0)
  160. return LoaderError { LoaderError::Category::Format, sample_index, "Frame header contains invalid layer number." };
  161. header.protection_bit = TRY(bitstream.read_bit());
  162. header.bitrate = MP3::Tables::BitratesPerLayerLookup[header.layer - 1][TRY(bitstream.read_bits(4))];
  163. if (header.bitrate <= 0)
  164. return LoaderError { LoaderError::Category::Format, sample_index, "Frame header contains invalid bitrate." };
  165. header.samplerate = MP3::Tables::SampleratesLookup[TRY(bitstream.read_bits(2))];
  166. if (header.samplerate <= 0)
  167. return LoaderError { LoaderError::Category::Format, sample_index, "Frame header contains invalid samplerate." };
  168. header.padding_bit = TRY(bitstream.read_bit());
  169. header.private_bit = TRY(bitstream.read_bit());
  170. header.mode = static_cast<MP3::Mode>(TRY(bitstream.read_bits(2)));
  171. header.mode_extension = static_cast<MP3::ModeExtension>(TRY(bitstream.read_bits(2)));
  172. header.copyright_bit = TRY(bitstream.read_bit());
  173. header.original_bit = TRY(bitstream.read_bit());
  174. header.emphasis = static_cast<MP3::Emphasis>(TRY(bitstream.read_bits(2)));
  175. header.header_size = 4;
  176. if (!header.protection_bit) {
  177. header.crc16 = TRY(bitstream.read_bits<u16>(16));
  178. header.header_size += 2;
  179. }
  180. header.frame_size = 144 * header.bitrate * 1000 / header.samplerate + header.padding_bit;
  181. header.slot_count = header.frame_size - ((header.channel_count() == 2 ? 32 : 17) + header.header_size);
  182. return header;
  183. }
  184. ErrorOr<MP3::Header, LoaderError> MP3LoaderPlugin::synchronize_and_read_header(SeekableStream& stream, size_t sample_index)
  185. {
  186. while (!stream.is_eof()) {
  187. bool last_was_all_set = false;
  188. while (!stream.is_eof()) {
  189. u8 byte = TRY(stream.read_value<u8>());
  190. if (last_was_all_set && (byte & 0xF0) == 0xF0) {
  191. // Seek back, since there is still data we have not consumed within the current byte.
  192. // read_header() will consume and check these 4 bits itself and then continue reading
  193. // the rest of the data from there.
  194. TRY(stream.seek(-1, SeekMode::FromCurrentPosition));
  195. break;
  196. }
  197. last_was_all_set = byte == 0xFF;
  198. }
  199. auto header_start = TRY(stream.tell());
  200. auto header_result = read_header(stream, sample_index);
  201. if (header_result.is_error() || header_result.value().id != 1 || header_result.value().layer != 3) {
  202. TRY(stream.seek(header_start, SeekMode::SetPosition));
  203. continue;
  204. }
  205. return header_result.value();
  206. }
  207. return LoaderError { LoaderError::Category::Format, sample_index, "Failed to synchronize." };
  208. }
  209. ErrorOr<MP3::Header, LoaderError> MP3LoaderPlugin::synchronize_and_read_header()
  210. {
  211. auto header = TRY(MP3LoaderPlugin::synchronize_and_read_header(*m_stream, m_loaded_samples));
  212. if (m_bitstream)
  213. m_bitstream->align_to_byte_boundary();
  214. return header;
  215. }
  216. ErrorOr<MP3::MP3Frame, LoaderError> MP3LoaderPlugin::read_next_frame()
  217. {
  218. return read_frame_data(TRY(synchronize_and_read_header()));
  219. }
  220. ErrorOr<MP3::MP3Frame, LoaderError> MP3LoaderPlugin::read_frame_data(MP3::Header const& header)
  221. {
  222. MP3::MP3Frame frame { header };
  223. TRY(read_side_information(frame));
  224. auto maybe_buffer = ByteBuffer::create_uninitialized(header.slot_count);
  225. if (maybe_buffer.is_error())
  226. return LoaderError { LoaderError::Category::IO, m_loaded_samples, "Out of memory" };
  227. auto& buffer = maybe_buffer.value();
  228. size_t old_reservoir_size = m_bit_reservoir.used_buffer_size();
  229. TRY(m_bitstream->read_until_filled(buffer));
  230. TRY(m_bit_reservoir.write_until_depleted(buffer));
  231. // If we don't have enough data in the reservoir to process this frame, skip it (but keep the data).
  232. if (old_reservoir_size < static_cast<size_t>(frame.main_data_begin))
  233. return frame;
  234. TRY(m_bit_reservoir.discard(old_reservoir_size - frame.main_data_begin));
  235. BigEndianInputBitStream reservoir_stream { MaybeOwned<Stream>(m_bit_reservoir) };
  236. for (size_t granule_index = 0; granule_index < 2; granule_index++) {
  237. for (size_t channel_index = 0; channel_index < header.channel_count(); channel_index++) {
  238. size_t scale_factor_size = TRY(read_scale_factors(frame, reservoir_stream, granule_index, channel_index));
  239. TRY(read_huffman_data(frame, reservoir_stream, granule_index, channel_index, scale_factor_size));
  240. if (frame.channels[channel_index].granules[granule_index].block_type == MP3::BlockType::Short) {
  241. reorder_samples(frame.channels[channel_index].granules[granule_index], frame.header.samplerate);
  242. // Only reduce alias for lowest 2 bands as they're long.
  243. // Afaik this is not mentioned in the ISO spec, but it is addressed in the
  244. // changelog for the ISO compliance tests.
  245. if (frame.channels[channel_index].granules[granule_index].mixed_block_flag)
  246. reduce_alias(frame.channels[channel_index].granules[granule_index], 36);
  247. } else {
  248. reduce_alias(frame.channels[channel_index].granules[granule_index]);
  249. }
  250. }
  251. if (header.mode == MP3::Mode::JointStereo) {
  252. process_stereo(frame, granule_index);
  253. }
  254. }
  255. for (size_t granule_index = 0; granule_index < 2; granule_index++) {
  256. for (size_t channel_index = 0; channel_index < header.channel_count(); channel_index++) {
  257. auto& granule = frame.channels[channel_index].granules[granule_index];
  258. for (size_t i = 0; i < MP3::granule_size; i += 18) {
  259. MP3::BlockType block_type = granule.block_type;
  260. if (i < 36 && granule.mixed_block_flag) {
  261. // ISO/IEC 11172-3: if mixed_block_flag is set, the lowest two subbands are transformed with normal window.
  262. block_type = MP3::BlockType::Normal;
  263. }
  264. Array<float, 36> output;
  265. transform_samples_to_time(granule.samples, i, output, block_type);
  266. int const subband_index = i / 18;
  267. for (size_t sample_index = 0; sample_index < 18; sample_index++) {
  268. // overlap add
  269. granule.filter_bank_input[subband_index][sample_index] = output[sample_index] + m_last_values[channel_index][subband_index][sample_index];
  270. m_last_values[channel_index][subband_index][sample_index] = output[sample_index + 18];
  271. // frequency inversion
  272. if (subband_index % 2 == 1 && sample_index % 2 == 1)
  273. granule.filter_bank_input[subband_index][sample_index] *= -1;
  274. }
  275. }
  276. }
  277. }
  278. Array<float, 32> in_samples;
  279. for (size_t channel_index = 0; channel_index < frame.header.channel_count(); channel_index++) {
  280. for (size_t granule_index = 0; granule_index < 2; granule_index++) {
  281. auto& granule = frame.channels[channel_index].granules[granule_index];
  282. for (size_t sample_index = 0; sample_index < 18; sample_index++) {
  283. for (size_t band_index = 0; band_index < 32; band_index++) {
  284. in_samples[band_index] = granule.filter_bank_input[band_index][sample_index];
  285. }
  286. synthesis(m_synthesis_buffer[channel_index], in_samples, granule.pcm[sample_index]);
  287. }
  288. }
  289. }
  290. return frame;
  291. }
  292. MaybeLoaderError MP3LoaderPlugin::read_side_information(MP3::MP3Frame& frame)
  293. {
  294. frame.main_data_begin = TRY(m_bitstream->read_bits(9));
  295. if (frame.header.channel_count() == 1) {
  296. frame.private_bits = TRY(m_bitstream->read_bits(5));
  297. } else {
  298. frame.private_bits = TRY(m_bitstream->read_bits(3));
  299. }
  300. for (size_t channel_index = 0; channel_index < frame.header.channel_count(); channel_index++) {
  301. for (size_t scale_factor_selection_info_band = 0; scale_factor_selection_info_band < 4; scale_factor_selection_info_band++) {
  302. frame.channels[channel_index].scale_factor_selection_info[scale_factor_selection_info_band] = TRY(m_bitstream->read_bit());
  303. }
  304. }
  305. for (size_t granule_index = 0; granule_index < 2; granule_index++) {
  306. for (size_t channel_index = 0; channel_index < frame.header.channel_count(); channel_index++) {
  307. auto& granule = frame.channels[channel_index].granules[granule_index];
  308. granule.part_2_3_length = TRY(m_bitstream->read_bits(12));
  309. granule.big_values = TRY(m_bitstream->read_bits(9));
  310. granule.global_gain = TRY(m_bitstream->read_bits(8));
  311. granule.scalefac_compress = TRY(m_bitstream->read_bits(4));
  312. granule.window_switching_flag = TRY(m_bitstream->read_bit());
  313. if (granule.window_switching_flag) {
  314. granule.block_type = static_cast<MP3::BlockType>(TRY(m_bitstream->read_bits(2)));
  315. granule.mixed_block_flag = TRY(m_bitstream->read_bit());
  316. for (size_t region = 0; region < 2; region++)
  317. granule.table_select[region] = TRY(m_bitstream->read_bits(5));
  318. for (size_t window = 0; window < 3; window++)
  319. granule.sub_block_gain[window] = TRY(m_bitstream->read_bits(3));
  320. granule.region0_count = (granule.block_type == MP3::BlockType::Short && !granule.mixed_block_flag) ? 8 : 7;
  321. granule.region1_count = 36;
  322. } else {
  323. for (size_t region = 0; region < 3; region++)
  324. granule.table_select[region] = TRY(m_bitstream->read_bits(5));
  325. granule.region0_count = TRY(m_bitstream->read_bits(4));
  326. granule.region1_count = TRY(m_bitstream->read_bits(3));
  327. }
  328. granule.preflag = TRY(m_bitstream->read_bit());
  329. granule.scalefac_scale = TRY(m_bitstream->read_bit());
  330. granule.count1table_select = TRY(m_bitstream->read_bit());
  331. }
  332. }
  333. return {};
  334. }
  335. // From ISO/IEC 11172-3 (2.4.3.4.7.1)
  336. Array<float, MP3::granule_size> MP3LoaderPlugin::calculate_frame_exponents(MP3::MP3Frame const& frame, size_t granule_index, size_t channel_index)
  337. {
  338. Array<float, MP3::granule_size> exponents;
  339. auto fill_band = [&exponents](float exponent, size_t start, size_t end) {
  340. for (size_t j = start; j <= end; j++) {
  341. exponents[j] = exponent;
  342. }
  343. };
  344. auto const& channel = frame.channels[channel_index];
  345. auto const& granule = frame.channels[channel_index].granules[granule_index];
  346. auto const scale_factor_bands = get_scalefactor_bands(granule, frame.header.samplerate);
  347. float const scale_factor_multiplier = granule.scalefac_scale ? 1 : 0.5;
  348. int const gain = granule.global_gain - 210;
  349. if (granule.block_type != MP3::BlockType::Short) {
  350. for (size_t band_index = 0; band_index < 22; band_index++) {
  351. float const exponent = gain / 4.0f - (scale_factor_multiplier * (channel.scale_factors[band_index] + granule.preflag * MP3::Tables::Pretab[band_index]));
  352. fill_band(AK::pow<float>(2.0, exponent), scale_factor_bands[band_index].start, scale_factor_bands[band_index].end);
  353. }
  354. } else {
  355. size_t band_index = 0;
  356. size_t sample_count = 0;
  357. if (granule.mixed_block_flag) {
  358. while (sample_count < 36) {
  359. float const exponent = gain / 4.0f - (scale_factor_multiplier * (channel.scale_factors[band_index] + granule.preflag * MP3::Tables::Pretab[band_index]));
  360. fill_band(AK::pow<float>(2.0, exponent), scale_factor_bands[band_index].start, scale_factor_bands[band_index].end);
  361. sample_count += scale_factor_bands[band_index].width;
  362. band_index++;
  363. }
  364. }
  365. float const gain0 = (gain - 8 * granule.sub_block_gain[0]) / 4.0;
  366. float const gain1 = (gain - 8 * granule.sub_block_gain[1]) / 4.0;
  367. float const gain2 = (gain - 8 * granule.sub_block_gain[2]) / 4.0;
  368. while (sample_count < MP3::granule_size && band_index < scale_factor_bands.size()) {
  369. float const exponent0 = gain0 - (scale_factor_multiplier * channel.scale_factors[band_index + 0]);
  370. float const exponent1 = gain1 - (scale_factor_multiplier * channel.scale_factors[band_index + 1]);
  371. float const exponent2 = gain2 - (scale_factor_multiplier * channel.scale_factors[band_index + 2]);
  372. fill_band(AK::pow<float>(2.0, exponent0), scale_factor_bands[band_index + 0].start, scale_factor_bands[band_index + 0].end);
  373. sample_count += scale_factor_bands[band_index + 0].width;
  374. fill_band(AK::pow<float>(2.0, exponent1), scale_factor_bands[band_index + 1].start, scale_factor_bands[band_index + 1].end);
  375. sample_count += scale_factor_bands[band_index + 1].width;
  376. fill_band(AK::pow<float>(2.0, exponent2), scale_factor_bands[band_index + 2].start, scale_factor_bands[band_index + 2].end);
  377. sample_count += scale_factor_bands[band_index + 2].width;
  378. band_index += 3;
  379. }
  380. while (sample_count < MP3::granule_size)
  381. exponents[sample_count++] = 0;
  382. }
  383. return exponents;
  384. }
  385. ErrorOr<size_t, LoaderError> MP3LoaderPlugin::read_scale_factors(MP3::MP3Frame& frame, BigEndianInputBitStream& reservoir, size_t granule_index, size_t channel_index)
  386. {
  387. auto& channel = frame.channels[channel_index];
  388. auto const& granule = channel.granules[granule_index];
  389. size_t band_index = 0;
  390. size_t bits_read = 0;
  391. if (granule.window_switching_flag && granule.block_type == MP3::BlockType::Short) {
  392. if (granule.mixed_block_flag) {
  393. for (size_t i = 0; i < 8; i++) {
  394. auto const bits = MP3::Tables::ScalefacCompressSlen1[granule.scalefac_compress];
  395. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  396. bits_read += bits;
  397. }
  398. for (size_t i = 3; i < 12; i++) {
  399. auto const bits = i <= 5 ? MP3::Tables::ScalefacCompressSlen1[granule.scalefac_compress] : MP3::Tables::ScalefacCompressSlen2[granule.scalefac_compress];
  400. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  401. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  402. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  403. bits_read += 3 * bits;
  404. }
  405. } else {
  406. for (size_t i = 0; i < 12; i++) {
  407. auto const bits = i <= 5 ? MP3::Tables::ScalefacCompressSlen1[granule.scalefac_compress] : MP3::Tables::ScalefacCompressSlen2[granule.scalefac_compress];
  408. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  409. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  410. channel.scale_factors[band_index++] = TRY(reservoir.read_bits(bits));
  411. bits_read += 3 * bits;
  412. }
  413. }
  414. channel.scale_factors[band_index++] = 0;
  415. channel.scale_factors[band_index++] = 0;
  416. channel.scale_factors[band_index++] = 0;
  417. } else {
  418. if ((channel.scale_factor_selection_info[0] == 0) || (granule_index == 0)) {
  419. for (band_index = 0; band_index < 6; band_index++) {
  420. auto const bits = MP3::Tables::ScalefacCompressSlen1[granule.scalefac_compress];
  421. channel.scale_factors[band_index] = TRY(reservoir.read_bits(bits));
  422. bits_read += bits;
  423. }
  424. }
  425. if ((channel.scale_factor_selection_info[1] == 0) || (granule_index == 0)) {
  426. for (band_index = 6; band_index < 11; band_index++) {
  427. auto const bits = MP3::Tables::ScalefacCompressSlen1[granule.scalefac_compress];
  428. channel.scale_factors[band_index] = TRY(reservoir.read_bits(bits));
  429. bits_read += bits;
  430. }
  431. }
  432. if ((channel.scale_factor_selection_info[2] == 0) || (granule_index == 0)) {
  433. for (band_index = 11; band_index < 16; band_index++) {
  434. auto const bits = MP3::Tables::ScalefacCompressSlen2[granule.scalefac_compress];
  435. channel.scale_factors[band_index] = TRY(reservoir.read_bits(bits));
  436. bits_read += bits;
  437. }
  438. }
  439. if ((channel.scale_factor_selection_info[3] == 0) || (granule_index == 0)) {
  440. for (band_index = 16; band_index < 21; band_index++) {
  441. auto const bits = MP3::Tables::ScalefacCompressSlen2[granule.scalefac_compress];
  442. channel.scale_factors[band_index] = TRY(reservoir.read_bits(bits));
  443. bits_read += bits;
  444. }
  445. }
  446. channel.scale_factors[21] = 0;
  447. }
  448. return bits_read;
  449. }
  450. MaybeLoaderError MP3LoaderPlugin::read_huffman_data(MP3::MP3Frame& frame, BigEndianInputBitStream& reservoir, size_t granule_index, size_t channel_index, size_t granule_bits_read)
  451. {
  452. auto const exponents = calculate_frame_exponents(frame, granule_index, channel_index);
  453. auto& granule = frame.channels[channel_index].granules[granule_index];
  454. auto const scale_factor_bands = get_scalefactor_bands(granule, frame.header.samplerate);
  455. size_t const scale_factor_band_index1 = granule.region0_count + 1;
  456. size_t const scale_factor_band_index2 = min(scale_factor_bands.size() - 1, scale_factor_band_index1 + granule.region1_count + 1);
  457. bool const is_short_granule = granule.window_switching_flag && granule.block_type == MP3::BlockType::Short;
  458. size_t const region1_start = is_short_granule ? 36 : scale_factor_bands[scale_factor_band_index1].start;
  459. size_t const region2_start = is_short_granule ? MP3::granule_size : scale_factor_bands[scale_factor_band_index2].start;
  460. auto requantize = [](int const sample, float const exponent) -> float {
  461. int const sign = sample < 0 ? -1 : 1;
  462. int const magnitude = AK::abs(sample);
  463. return sign * AK::pow<float>(static_cast<float>(magnitude), 4 / 3.0) * exponent;
  464. };
  465. size_t count = 0;
  466. // 2.4.3.4.6: "Decoding is done until all Huffman code bits have been decoded
  467. // or until quantized values representing 576 frequency lines have been decoded,
  468. // whichever comes first."
  469. auto max_count = min(granule.big_values * 2, MP3::granule_size);
  470. for (; count < max_count; count += 2) {
  471. MP3::Tables::Huffman::HuffmanTreeXY const* tree = nullptr;
  472. if (count < region1_start) {
  473. tree = &MP3::Tables::Huffman::HuffmanTreesXY[granule.table_select[0]];
  474. } else if (count < region2_start) {
  475. tree = &MP3::Tables::Huffman::HuffmanTreesXY[granule.table_select[1]];
  476. } else {
  477. tree = &MP3::Tables::Huffman::HuffmanTreesXY[granule.table_select[2]];
  478. }
  479. if (!tree || tree->nodes.is_empty()) {
  480. return LoaderError { LoaderError::Category::Format, m_loaded_samples, "Frame references invalid huffman table." };
  481. }
  482. // Assumption: There's enough bits to read. 32 is just a placeholder for "unlimited".
  483. // There are no 32 bit long huffman codes in the tables.
  484. auto const entry = MP3::Tables::Huffman::huffman_decode(reservoir, tree->nodes, 32);
  485. granule_bits_read += entry.bits_read;
  486. if (!entry.code.has_value())
  487. return LoaderError { LoaderError::Category::Format, m_loaded_samples, "Frame contains invalid huffman data." };
  488. int x = entry.code->symbol.x;
  489. int y = entry.code->symbol.y;
  490. if (x == 15 && tree->linbits > 0) {
  491. x += TRY(reservoir.read_bits(tree->linbits));
  492. granule_bits_read += tree->linbits;
  493. }
  494. if (x != 0) {
  495. if (TRY(reservoir.read_bit()))
  496. x = -x;
  497. granule_bits_read++;
  498. }
  499. if (y == 15 && tree->linbits > 0) {
  500. y += TRY(reservoir.read_bits(tree->linbits));
  501. granule_bits_read += tree->linbits;
  502. }
  503. if (y != 0) {
  504. if (TRY(reservoir.read_bit()))
  505. y = -y;
  506. granule_bits_read++;
  507. }
  508. granule.samples[count + 0] = requantize(x, exponents[count + 0]);
  509. granule.samples[count + 1] = requantize(y, exponents[count + 1]);
  510. }
  511. ReadonlySpan<MP3::Tables::Huffman::HuffmanNode<MP3::Tables::Huffman::HuffmanVWXY>> count1table = granule.count1table_select ? MP3::Tables::Huffman::TreeB : MP3::Tables::Huffman::TreeA;
  512. // count1 is not known. We have to read huffman encoded values
  513. // until we've exhausted the granule's bits. We know the size of
  514. // the granule from part2_3_length, which is the number of bits
  515. // used for scalefactors and huffman data (in the granule).
  516. while (granule_bits_read < granule.part_2_3_length && count <= MP3::granule_size - 4) {
  517. auto const entry = MP3::Tables::Huffman::huffman_decode(reservoir, count1table, granule.part_2_3_length - granule_bits_read);
  518. granule_bits_read += entry.bits_read;
  519. if (!entry.code.has_value())
  520. return LoaderError { LoaderError::Category::Format, m_loaded_samples, "Frame contains invalid huffman data." };
  521. int v = entry.code->symbol.v;
  522. if (v != 0) {
  523. if (granule_bits_read >= granule.part_2_3_length)
  524. break;
  525. if (TRY(reservoir.read_bit()))
  526. v = -v;
  527. granule_bits_read++;
  528. }
  529. int w = entry.code->symbol.w;
  530. if (w != 0) {
  531. if (granule_bits_read >= granule.part_2_3_length)
  532. break;
  533. if (TRY(reservoir.read_bit()))
  534. w = -w;
  535. granule_bits_read++;
  536. }
  537. int x = entry.code->symbol.x;
  538. if (x != 0) {
  539. if (granule_bits_read >= granule.part_2_3_length)
  540. break;
  541. if (TRY(reservoir.read_bit()))
  542. x = -x;
  543. granule_bits_read++;
  544. }
  545. int y = entry.code->symbol.y;
  546. if (y != 0) {
  547. if (granule_bits_read >= granule.part_2_3_length)
  548. break;
  549. if (TRY(reservoir.read_bit()))
  550. y = -y;
  551. granule_bits_read++;
  552. }
  553. granule.samples[count + 0] = requantize(v, exponents[count + 0]);
  554. granule.samples[count + 1] = requantize(w, exponents[count + 1]);
  555. granule.samples[count + 2] = requantize(x, exponents[count + 2]);
  556. granule.samples[count + 3] = requantize(y, exponents[count + 3]);
  557. count += 4;
  558. }
  559. if (granule_bits_read > granule.part_2_3_length) {
  560. return LoaderError { LoaderError::Category::Format, m_loaded_samples, "Read too many bits from bit reservoir." };
  561. }
  562. // 2.4.3.4.6: "If there are more Huffman code bits than necessary to decode 576 values
  563. // they are regarded as stuffing bits and discarded."
  564. for (size_t i = granule_bits_read; i < granule.part_2_3_length; i++) {
  565. TRY(reservoir.read_bit());
  566. }
  567. return {};
  568. }
  569. void MP3LoaderPlugin::reorder_samples(MP3::Granule& granule, u32 sample_rate)
  570. {
  571. float tmp[MP3::granule_size] = {};
  572. size_t band_index = 0;
  573. size_t subband_index = 0;
  574. auto scale_factor_bands = get_scalefactor_bands(granule, sample_rate);
  575. if (granule.mixed_block_flag) {
  576. while (subband_index < 36) {
  577. for (size_t frequency_line_index = 0; frequency_line_index < scale_factor_bands[band_index].width; frequency_line_index++) {
  578. tmp[subband_index] = granule.samples[subband_index];
  579. subband_index++;
  580. }
  581. band_index++;
  582. }
  583. }
  584. while (subband_index < MP3::granule_size && band_index <= 36) {
  585. for (size_t frequency_line_index = 0; frequency_line_index < scale_factor_bands[band_index].width; frequency_line_index++) {
  586. tmp[subband_index++] = granule.samples[scale_factor_bands[band_index + 0].start + frequency_line_index];
  587. tmp[subband_index++] = granule.samples[scale_factor_bands[band_index + 1].start + frequency_line_index];
  588. tmp[subband_index++] = granule.samples[scale_factor_bands[band_index + 2].start + frequency_line_index];
  589. }
  590. band_index += 3;
  591. }
  592. for (size_t i = 0; i < MP3::granule_size; i++)
  593. granule.samples[i] = tmp[i];
  594. }
  595. void MP3LoaderPlugin::reduce_alias(MP3::Granule& granule, size_t max_subband_index)
  596. {
  597. for (size_t subband = 0; subband < max_subband_index - 18; subband += 18) {
  598. for (size_t i = 0; i < 8; i++) {
  599. size_t const idx1 = subband + 17 - i;
  600. size_t const idx2 = subband + 18 + i;
  601. auto const d1 = granule.samples[idx1];
  602. auto const d2 = granule.samples[idx2];
  603. granule.samples[idx1] = d1 * MP3::Tables::AliasReductionCs[i] - d2 * MP3::Tables::AliasReductionCa[i];
  604. granule.samples[idx2] = d2 * MP3::Tables::AliasReductionCs[i] + d1 * MP3::Tables::AliasReductionCa[i];
  605. }
  606. }
  607. }
  608. void MP3LoaderPlugin::process_stereo(MP3::MP3Frame& frame, size_t granule_index)
  609. {
  610. size_t band_index_ms_start = 0;
  611. size_t band_index_ms_end = 0;
  612. size_t band_index_intensity_start = 0;
  613. size_t band_index_intensity_end = 0;
  614. auto& granule_left = frame.channels[0].granules[granule_index];
  615. auto& granule_right = frame.channels[1].granules[granule_index];
  616. auto get_last_nonempty_band = [](Span<float> samples, ReadonlySpan<MP3::Tables::ScaleFactorBand> bands) -> size_t {
  617. size_t last_nonempty_band = 0;
  618. for (size_t i = 0; i < bands.size(); i++) {
  619. bool is_empty = true;
  620. for (size_t l = bands[i].start; l < bands[i].end; l++) {
  621. if (samples[l] != 0) {
  622. is_empty = false;
  623. break;
  624. }
  625. }
  626. if (!is_empty)
  627. last_nonempty_band = i;
  628. }
  629. return last_nonempty_band;
  630. };
  631. auto process_ms_stereo = [&](MP3::Tables::ScaleFactorBand const& band) {
  632. float const SQRT_2 = AK::sqrt(2.0);
  633. for (size_t i = band.start; i <= band.end; i++) {
  634. float const m = granule_left.samples[i];
  635. float const s = granule_right.samples[i];
  636. granule_left.samples[i] = (m + s) / SQRT_2;
  637. granule_right.samples[i] = (m - s) / SQRT_2;
  638. }
  639. };
  640. auto process_intensity_stereo = [&](MP3::Tables::ScaleFactorBand const& band, float intensity_stereo_ratio) {
  641. for (size_t i = band.start; i <= band.end; i++) {
  642. float const sample_left = granule_left.samples[i];
  643. float const coeff_l = intensity_stereo_ratio / (1 + intensity_stereo_ratio);
  644. float const coeff_r = 1 / (1 + intensity_stereo_ratio);
  645. granule_left.samples[i] = sample_left * coeff_l;
  646. granule_right.samples[i] = sample_left * coeff_r;
  647. }
  648. };
  649. auto scale_factor_bands = get_scalefactor_bands(granule_right, frame.header.samplerate);
  650. if (has_flag(frame.header.mode_extension, MP3::ModeExtension::MsStereo)) {
  651. band_index_ms_start = 0;
  652. band_index_ms_end = scale_factor_bands.size();
  653. }
  654. if (has_flag(frame.header.mode_extension, MP3::ModeExtension::IntensityStereo)) {
  655. band_index_intensity_start = get_last_nonempty_band(granule_right.samples, scale_factor_bands);
  656. band_index_intensity_end = scale_factor_bands.size();
  657. band_index_ms_end = band_index_intensity_start;
  658. }
  659. for (size_t band_index = band_index_ms_start; band_index < band_index_ms_end; band_index++) {
  660. process_ms_stereo(scale_factor_bands[band_index]);
  661. }
  662. for (size_t band_index = band_index_intensity_start; band_index < band_index_intensity_end; band_index++) {
  663. auto const intensity_stereo_position = frame.channels[1].scale_factors[band_index];
  664. if (intensity_stereo_position == 7) {
  665. if (has_flag(frame.header.mode_extension, MP3::ModeExtension::MsStereo))
  666. process_ms_stereo(scale_factor_bands[band_index]);
  667. continue;
  668. }
  669. float const intensity_stereo_ratio = AK::tan(intensity_stereo_position * AK::Pi<float> / 12);
  670. process_intensity_stereo(scale_factor_bands[band_index], intensity_stereo_ratio);
  671. }
  672. }
  673. void MP3LoaderPlugin::transform_samples_to_time(Array<float, MP3::granule_size> const& input, size_t input_offset, Array<float, 36>& output, MP3::BlockType block_type)
  674. {
  675. if (block_type == MP3::BlockType::Short) {
  676. size_t const N = 12;
  677. Array<float, N * 3> temp_out;
  678. Array<float, N / 2> temp_in;
  679. for (size_t k = 0; k < N / 2; k++)
  680. temp_in[k] = input[input_offset + 3 * k + 0];
  681. s_mdct_12.transform(temp_in, Span<float>(temp_out).slice(0, N));
  682. for (size_t i = 0; i < N; i++)
  683. temp_out[i + 0] *= MP3::Tables::WindowBlockTypeShort[i];
  684. for (size_t k = 0; k < N / 2; k++)
  685. temp_in[k] = input[input_offset + 3 * k + 1];
  686. s_mdct_12.transform(temp_in, Span<float>(temp_out).slice(12, N));
  687. for (size_t i = 0; i < N; i++)
  688. temp_out[i + 12] *= MP3::Tables::WindowBlockTypeShort[i];
  689. for (size_t k = 0; k < N / 2; k++)
  690. temp_in[k] = input[input_offset + 3 * k + 2];
  691. s_mdct_12.transform(temp_in, Span<float>(temp_out).slice(24, N));
  692. for (size_t i = 0; i < N; i++)
  693. temp_out[i + 24] *= MP3::Tables::WindowBlockTypeShort[i];
  694. Span<float> idmct1 = Span<float>(temp_out).slice(0, 12);
  695. Span<float> idmct2 = Span<float>(temp_out).slice(12, 12);
  696. Span<float> idmct3 = Span<float>(temp_out).slice(24, 12);
  697. for (size_t i = 0; i < 6; i++)
  698. output[i] = 0;
  699. for (size_t i = 6; i < 12; i++)
  700. output[i] = idmct1[i - 6];
  701. for (size_t i = 12; i < 18; i++)
  702. output[i] = idmct1[i - 6] + idmct2[i - 12];
  703. for (size_t i = 18; i < 24; i++)
  704. output[i] = idmct2[i - 12] + idmct3[i - 18];
  705. for (size_t i = 24; i < 30; i++)
  706. output[i] = idmct3[i - 18];
  707. for (size_t i = 30; i < 36; i++)
  708. output[i] = 0;
  709. } else {
  710. s_mdct_36.transform(ReadonlySpan<float>(input).slice(input_offset, 18), output);
  711. for (size_t i = 0; i < 36; i++) {
  712. switch (block_type) {
  713. case MP3::BlockType::Normal:
  714. output[i] *= MP3::Tables::WindowBlockTypeNormal[i];
  715. break;
  716. case MP3::BlockType::Start:
  717. output[i] *= MP3::Tables::WindowBlockTypeStart[i];
  718. break;
  719. case MP3::BlockType::End:
  720. output[i] *= MP3::Tables::WindowBlockTypeEnd[i];
  721. break;
  722. case MP3::BlockType::Short:
  723. VERIFY_NOT_REACHED();
  724. break;
  725. }
  726. }
  727. }
  728. }
  729. // ISO/IEC 11172-3 (Figure A.2)
  730. void MP3LoaderPlugin::synthesis(Array<float, 1024>& V, Array<float, 32>& samples, Array<float, 32>& result)
  731. {
  732. for (size_t i = 1023; i >= 64; i--) {
  733. V[i] = V[i - 64];
  734. }
  735. for (size_t i = 0; i < 64; i++) {
  736. V[i] = 0;
  737. for (size_t k = 0; k < 32; k++) {
  738. float const N = MP3::Tables::SynthesisSubbandFilterCoefficients[i][k];
  739. V[i] += N * samples[k];
  740. }
  741. }
  742. Array<float, 512> U;
  743. for (size_t i = 0; i < 8; i++) {
  744. for (size_t j = 0; j < 32; j++) {
  745. U[i * 64 + j] = V[i * 128 + j];
  746. U[i * 64 + 32 + j] = V[i * 128 + 96 + j];
  747. }
  748. }
  749. Array<float, 512> W;
  750. for (size_t i = 0; i < 512; i++) {
  751. W[i] = U[i] * MP3::Tables::WindowSynthesis[i];
  752. }
  753. for (size_t j = 0; j < 32; j++) {
  754. result[j] = 0;
  755. for (size_t k = 0; k < 16; k++) {
  756. result[j] += W[j + 32 * k];
  757. }
  758. }
  759. }
  760. ReadonlySpan<MP3::Tables::ScaleFactorBand> MP3LoaderPlugin::get_scalefactor_bands(MP3::Granule const& granule, int samplerate)
  761. {
  762. switch (granule.block_type) {
  763. case MP3::BlockType::Short:
  764. switch (samplerate) {
  765. case 32000:
  766. return granule.mixed_block_flag ? MP3::Tables::ScaleFactorBandMixed32000 : MP3::Tables::ScaleFactorBandShort32000;
  767. case 44100:
  768. return granule.mixed_block_flag ? MP3::Tables::ScaleFactorBandMixed44100 : MP3::Tables::ScaleFactorBandShort44100;
  769. case 48000:
  770. return granule.mixed_block_flag ? MP3::Tables::ScaleFactorBandMixed48000 : MP3::Tables::ScaleFactorBandShort48000;
  771. }
  772. break;
  773. case MP3::BlockType::Normal:
  774. [[fallthrough]];
  775. case MP3::BlockType::Start:
  776. [[fallthrough]];
  777. case MP3::BlockType::End:
  778. switch (samplerate) {
  779. case 32000:
  780. return MP3::Tables::ScaleFactorBandLong32000;
  781. case 44100:
  782. return MP3::Tables::ScaleFactorBandLong44100;
  783. case 48000:
  784. return MP3::Tables::ScaleFactorBandLong48000;
  785. }
  786. }
  787. VERIFY_NOT_REACHED();
  788. }
  789. }