Fix #1498: Fix decoder mismatch for RGB content when LFNST is disabled
Though Fix#1497 removed the encoder crash, it also inadvertently changed the behaviour when LFNST is disabled as the original code the loop upper bound can change during the processing of the loop. This did not happen in the fix and this generated decoder mismatches.
This fix replaces the simpler #1497 fix but maintains the existing behaviour when LFNST is disabled.
This fix has been tested with the 5 RGB sequences in the HBD CTC (single frame AI at 6 QP) and the 8 RGB TGM sequences in the non-420 CTC (single frame AI at 4 QP).
For the following configurations identical results were achieved with and without the fix (i.e. the code prior to #1497) LFNST=1, TS=1, BDPCM=1 LFNST=1, TS=1, BDPCM=0 LFNST=1, TS=0, BDPCM=0 LFNST=0, TS=1, BDPCM=0 LFNST=0, TS=1, BDPCM=1
For the following configuration results were obtained with the fix. Without the fix all encoder simulations resulted in SEGV. LFNST=0, TS=0, BDPCM=0
My apologies for the erroneous fix #1497.
Merge request reports
Activity
- Resolved by Xiang Li
Attempted to simplify for loop by extracting an element into a break statement.
The loop structure is complicated as LFNST does not use the trModes structure in all cases.
I wonder if the readability of the code would be improved by having two loops - one for LFNST and one for non-LFNST - but that is beyond the scope of this fix.
mentioned in commit 20dc81ce