- Timestamp:
- 26 Mar 2014, 02:07:30 (11 years ago)
- Location:
- trunk
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk
- Property svn:mergeinfo changed
/branches/SHM-5.1-dev merged: 646,648
- Property svn:mergeinfo changed
-
trunk/source
- Property svn:mergeinfo changed
/branches/SHM-5.1-dev/source merged: 646,648
- Property svn:mergeinfo changed
-
trunk/source/App/TAppEncoder/TAppEncCfg.cpp
r644 r649 1761 1761 m_numLayers = m_numLayers > MAX_LAYERS ? MAX_LAYERS : m_numLayers; 1762 1762 1763 1764 // it can be updated after AVC BL support will be added to the WD 1765 if( m_avcBaseLayerFlag ) 1766 { 1767 m_crossLayerIrapAlignFlag = false; 1768 m_crossLayerPictureTypeAlignFlag = false; 1769 m_crossLayerAlignedIdrOnlyFlag = false; 1770 } 1771 1763 1772 // verify layer configuration parameters 1764 1773 for(UInt layer=0; layer<m_numLayers; layer++) -
trunk/source/App/TAppEncoder/TAppEncTop.cpp
r644 r649 1151 1151 vps->setProfileLevelTierIdx(i, i); 1152 1152 vps->setOutputLayerSetIdx(i, i); 1153 } 1154 1155 for(Int lsIdx = 1; lsIdx < vps->getNumLayerSets(); lsIdx++) 1156 { 1157 // Include the highest layer as output layer 1158 for(UInt layer=0; layer <= vps->getMaxLayerId() ; layer++) 1159 { 1160 if(vps->getLayerIdIncludedFlag(lsIdx, layer)) 1161 { 1162 vps->setOutputLayerFlag(lsIdx, layer, layer == (vps->getMaxLayerId())); 1163 } 1164 } 1165 } 1153 } 1166 1154 #endif 1167 1155 #if VPS_DPB_SIZE_TABLE … … 1175 1163 vps->deriveNumberOfSubDpbs(); 1176 1164 #endif 1165 1166 // derive OutputLayerFlag[i][j] 1167 if( vps->getDefaultTargetOutputLayerIdc() == 1 ) 1168 { 1169 // default_target_output_layer_idc equal to 1 specifies that only the layer with the highest value of nuh_layer_id such that nuh_layer_id equal to nuhLayerIdA and 1170 // AuxId[ nuhLayerIdA ] equal to 0 in each of the output layer sets with index in the range of 1 to vps_num_layer_sets_minus1, inclusive, is an output layer of its output layer set. 1171 1172 // Include the highest layer as output layer for each layer set 1173 for(Int lsIdx = 1; lsIdx < vps->getNumLayerSets(); lsIdx++) 1174 { 1175 for( UInt layer = 0; layer < vps->getNumLayersInIdList(lsIdx); layer++ ) 1176 { 1177 if( vps->getLayerIdIncludedFlag(lsIdx, layer) ) 1178 { 1179 vps->setOutputLayerFlag( lsIdx, layer, layer == vps->getNumLayersInIdList(lsIdx) - 1 ); 1180 } 1181 } 1182 } 1183 } 1184 else 1185 { 1186 // cases when default_target_output_layer_idc is not equal to 1 1187 assert(!"default_target_output_layer_idc not equal to 1 is not yet supported"); 1188 } 1189 1177 1190 // Initialize dpb_size_table() for all ouput layer sets in the VPS extension 1178 1191 for(i = 1; i < vps->getNumOutputLayerSets(); i++) … … 1322 1335 } 1323 1336 } 1324 }1325 1326 if( vps->getAvcBaseLayerFlag() )1327 {1328 vps->setCrossLayerIrapAlignFlag(false);1329 1337 } 1330 1338 #endif -
trunk/source/Lib/TLibDecoder/TDecCAVLC.cpp
r644 r649 1280 1280 Int lsIdx = vps->getOutputLayerSetIdx(i); 1281 1281 #if NUM_OL_FLAGS 1282 for(j = 0; j < vps->getNumLayersInIdList(lsIdx) 1282 for(j = 0; j < vps->getNumLayersInIdList(lsIdx); j++) 1283 1283 #else 1284 1284 for(j = 0; j < vps->getNumLayersInIdList(lsIdx) - 1; j++) … … 1796 1796 if (uiCode) 1797 1797 { 1798 READ_FLAG(uiCode, " only_idr_for_IRAP_across_layers" );1798 READ_FLAG(uiCode, "all_layers_idr_aligned_flag" ); 1799 1799 vps->setCrossLayerIrapAlignFlag(uiCode); 1800 1800 } -
trunk/source/Lib/TLibEncoder/TEncCavlc.cpp
r644 r649 1356 1356 if(vps->getCrossLayerIrapAlignFlag()) 1357 1357 { 1358 WRITE_FLAG(vps->getCrossLayerAlignedIdrOnlyFlag(), " only_idr_for_IRAP_across_layers");1358 WRITE_FLAG(vps->getCrossLayerAlignedIdrOnlyFlag(), "all_layers_idr_aligned_flag"); 1359 1359 } 1360 1360 #endif
Note: See TracChangeset for help on using the changeset viewer.