Linear Predictive Coding: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
|||
Line 117: | Line 117: | ||
loc '''2380''' in file | loc '''2380''' in file | ||
word | word | ||
==References== |
Revision as of 17:16, 14 February 2025
EditDate | 2025-2-13 |
---|
Related Threads: Arts, Anarchist Spellbook, Religion and Philosophy, STEM
This is the heart of both fLaC compression and predicting the next sound, I think
Going to decode here and see how easily it can be introduced into my playAlong code.Web References https://en.wikipedia.org/wiki/Linear prediction
Linear Predictive Coding
Line Number | Code Package | LOC purpose | Operation Description |
---|---|---|---|
2987 | SDC | read_residual_partitioned_rice | sample += u; Key parameters
|
2883 | SDC | read_subframe_lpc | break |
2889 | SDC | Do Full Decode | |
2892 | SDC | Get Warm-up values | 8 previously stored warm-up values based on order=8 |
Next set of routines are hidden because they are primarily used to determine whether we are 32 bit or 64 bit architecture. We will always be 64 bit. | |||
2898 | SDC | FLAC__lpc_restore_signal_wide(decoder->private_->residual[channel], decoder->private_->frame.header.blocksize-order, subframe->qlp_coeff, order, subframe->quantization_level, decoder->private_->output[channel]+order);
| |
1238 | LPC | void FLAC__lpc_restore_signal_wide(const FLAC__int32 * flac_restrict residual, uint32_t data_len, const FLAC__int32 * flac_restrict qlp_coeff, uint32_t order, int lp_quantization, FLAC__int32 * flac_restrict data)
0x55555585f390 0000 0000 -> c670ffff = ffff70c6 = 30 testBigEndian.raw file.
81FB FFFF 81FD FFFF FE06 0000 D0FC FFFF 09FE FFFF 8AFE FFFF 2504 0000 76F9 FFFF
| |
1264 | LPC | FLAC__lpc_restore_signal_wide | *(data++) = (FLAC__int32)(*(r++) + (sum >> lp_quantization));
0xffffffffeea8a9d8»0xd = 7FFFFFFFF7545 7FFFFFFFF7545 + 0xfffffb81 = 80000FFFF70C6 |
Next Edit
Pertinent Code
960 LPC FLAC__int32 predictor_sum_bps = FLAC__lpc_max_prediction_before_shift_bps(subframe_bps, qlp_coeff, order) - lp_quantization; 1264 LPC *(data++) = (FLAC__int32)(*(r++) + (sum >> lp_quantization)); First result:
- Little Endian in Memory C670FFFF
- Big Endian as read FFFF70C6
- testBigEndian.raw 0030 FF70C6
Notes for code analysis
4 bytes / int 32 Bits.
little endian memory dump of in storage buffer
19 7F D1 4F 19 7F D1 4F 19 7F D1 4F FD 44 01 37 56 26 0A 25 B2 EE F6 7F 9D 10 5D 79 62 33 5B 9F B4 0E 65 24 15 7A 35 13 370144FD4FD17F19 at 2380 in test.flac.
File
3701 44FD 4FD1 4FD1 7F19 7FF6 EEB2 250A 2656 does not line up with contiguous memory location. Only 64 bit word valid in memory (if reversed) loc 2380 in file
word
References
- ↑
2894 SDC call FLAC lpc max bps if(FLAC__lpc_max_residual_bps(bps, subframe->qlp_coeff, order, subframe->quantization_level) <= 32 && FLAC__lpc_max_prediction_before_shift_bps(bps, subframe->qlp_coeff, order) <= 32) Checking that absolute sub of qlp_coeff + bps <= 32 bits Does nothing to calculate value. Used to determine whether 64 bit wide or not we follow 64 bit wide path!
958 LPC FLAC__lpc_max_residual_bps uint32_t FLAC__lpc_max_residual_bps(uint32_t subframe_bps, const FLAC__int32 * flac_restrict qlp_coeff, uint32_t order, int lp_quantization) Variables
- uint32_t subframe_bps = 24
- qlp_coeff = qlp_coeff const FLAC__int32 * restrict 0x555555859efc
Address 0 - 3 4 - 7 8 - B C - F 0000555555859EF0 08000000 0F000000 0D000000 E51D0000 0000555555859F00 282E0000 E0E2FFFF F4CFFFFF 170C0000 0000555555859F10 17210000 72010000 6EF2FFFF
- uint32_t order = 8
- lp_quantization = 13 0xD
960 LPC FLAC__lpc_max_residual_bps FLAC__int32 predictor_sum_bps = FLAC__lpc_max_prediction_before_shift_bps(subframe_bps, qlp_coeff, order) - lp_quantization; - subframe_bps = 0x18 = 24
- qlp_coeff = qlp_coeff const FLAC__int32 * restrict 0x555555859efc
Address 0 - 3 4 - 7 8 - B C - F 0000555555859EF0 08000000 0F000000 0D000000 E51D0000 0000555555859F00 282E0000 E0E2FFFF F4CFFFFF 170C0000 0000555555859F10 17210000 72010000 6EF2FFFF
- uint32_t order = 8
predictor_sum_bps = 0x1c = 28
948 LPC FLAC__lpc_max_prediction_before_shift_bps FLAC__int32 abs_sum_of_qlp_coeff = 0; 951 LPC FLAC__lpc_max_prediction_before_shift_bps for(i = 0; i < order; i++) abs_sum_of_qlp_coeff += abs(qlp_coeff[i]); Iterative based on i < order = 8 if abs_sum_of_qlp_coeff = 0 = 1 - qlp_coeff = qlp_coeff const FLAC__int32 * restrict 0x555555859efc
Address 0 - 3 4 - 7 8 - B C - F 0000555555859EF0 08000000 0F000000 0D000000 E51D0000 0000555555859F00 282E0000 E0E2FFFF F4CFFFFF 170C0000 0000555555859F10 17210000 72010000 6EF2FFFF
- uint32_t order = 8
abs_sum_of_qlp_coeff = 0xd56b = 54635
}}