[Mp4-tech] [H.264] Possible FMO bug in JM?

Alejandro Moya Molina almomo1 gmail.com
Sun Dec 25 02:14:28 ESTEDT 2005


Hi, everyone!
Maybe this is one of my typical "lapsus", which I have after braimstorming myself for days with some possible answer to my doubt, but I need you to make it clear to me.
In line 522 of "fmo.c" in JM versions 9.3 and 10.1 I read these lines: 
      if( k++ < sizeOfUpperLeftGroup )
        MapUnitToSliceGroupMap[ i * img->PicWidthInMbs + j ] = 1 - pps->slice_group_change_direction_flag;
      else
        MapUnitToSliceGroupMap[ i * img->PicWidthInMbs + j ] = pps->slice_group_change_direction_flag;
which belong to "FmoGenerateType5MapUnitMap" function. Then, if you take the standard in page 88/89, you may read this:
    if( k++ < sizeOfUpperLeftGroup )
      mapUnitToSliceGroupMap[ i * PicWidthInMbs + j ] = slice_group_change_direction_flag
    else 
      mapUnitToSliceGroupMap[ i * PicWidthInMbs + j ] = 1 - slice_group_change_direction_flag
which might seem the same at a first glance but they aren't: the condition is the same but the if-else order is reversed.
Would you mind being so kind to explain this, please? I analysed some stream coded with JM 9.3 using more than one Slice Group and I noticed that the coder executes the same bad code below to encode the map.
Thank you very much in advance and have you all a MERRY CHRISTMAS AND A HAPPY NEW YEAR!!!
-------------- next part --------------
An HTML attachment was scrubbed...
URL: /pipermail/mp4-tech/attachments/20051225/7401881c/attachment.html


More information about the Mp4-tech mailing list