Holds pictures both for reference and to overcome reordering delay.
More...
#include <enc_queue.h>
List of all members.
Public Member Functions
- EncQueue ()
- Default Constructor.
- EncQueue (ChromaFormat cf, const int xlen, const int ylen, const unsigned int luma_depth, const unsigned int chroma_depth, bool using_ac)
- Constructor.
- EncQueue (ChromaFormat cf, const int numL1, const int L1sep, const int xlen, const int ylen, const unsigned int luma_depth, const unsigned int chroma_depth, bool interlace, bool using_ac)
- Constructor.
- EncQueue (const EncQueue &cpy)
- Copy constructor.
- EncQueue & operator= (const EncQueue &rhs)
- Operator=.
- ~EncQueue ()
- Destructor.
- EncPicture & GetPicture (const unsigned int pnum)
- Get picture with a given picture number (NOT with a given position in the buffer).
- const EncPicture & GetPicture (const unsigned int pnum) const
- Get picture with a given picture number (NOT with a given position in the buffer).
- EncPicture & GetPicture (const unsigned int pnum, bool &is_present)
- Get picture with a given picture number, setting a flag to true if it's there.
- const EncPicture & GetPicture (const unsigned int pnum, bool &is_present) const
- Get picture with a given picture number, setting a flag to true if it's there.
- bool IsPictureAvail (const unsigned int pnum) const
- Return true if picture with the particular picture number is available else return false.
- std::vector< int > Members () const
- Returns a list of member pictures.
- int Size () const
- Returns the size of the queue.
- void PushPicture (const PictureParams &pp)
- Put a new picture into the top of the buffer.
- void CopyPicture (const EncPicture &picture)
- void SetRetiredPictureNum (const int show_pnum, const int current_coded_pnum)
- Sets the reference picture number that will be cleaned.
- void CleanAll (const int show_pnum, const int current_coded_pnum)
- Delete all expired pictures.
- void CleanRetired (const int show_pnum, const int current_coded_pnum)
- Delete retired reference pictures and expired non-ref pictures.
- void Remove (int pnum)
- Delete picture.
Private Member Functions
- void ClearSlot (const unsigned int pos)
- Clear internal data slot number pos.
Private Attributes
- std::vector< EncPicture * > m_pic_data
- the buffer storing all the values
- std::map< unsigned int,
unsigned int > m_pnum_map
- the map from picture numbers to position in the buffer
Detailed Description
The buffer holds pictures in a stack to overcome both reordering due to bi-directional prediction and use as references for subsequence motion estimation. Pictures, and components of pictures, can be accessed by their picture numbers. GOP parameters can be included in the constructors so that pictures can be given types (I picture, L1 picture or L2 picture) on being pushed onto the stack; alternatively, these parameters can be overridden.
Constructor & Destructor Documentation
dirac::EncQueue::EncQueue |
( |
|
) |
|
dirac::EncQueue::EncQueue |
( |
ChromaFormat |
cf, |
|
|
const int |
xlen, |
|
|
const int |
ylen, |
|
|
const unsigned int |
luma_depth, |
|
|
const unsigned int |
chroma_depth, |
|
|
bool |
using_ac | |
|
) |
| | |
Creates a EncQueue using the chroma format. Suitable for compressing when there are no L2 pictures, or when the temporal prediction structure is to be determined on the fly.
- Parameters:
-
| cf | the Chroma format of pictures in the buffer |
| xlen | the luma width of pictures in the buffer |
| ylen | the luma height of pictures in the buffer |
| luma_depth | the video depth of the luma comp in the buffer |
| chroma_depth | the video depth of the chroma comp in the buffer |
| using_ac | True if using Arithmetic coding to code coefficient data |
dirac::EncQueue::EncQueue |
( |
ChromaFormat |
cf, |
|
|
const int |
numL1, |
|
|
const int |
L1sep, |
|
|
const int |
xlen, |
|
|
const int |
ylen, |
|
|
const unsigned int |
luma_depth, |
|
|
const unsigned int |
chroma_depth, |
|
|
bool |
interlace, |
|
|
bool |
using_ac | |
|
) |
| | |
Creates a EncQueue using the chroma format, the number of L1 pictures between I pictures and the separation in pictures between L1 pictures. Suitable for compressing when there is a full GOP structure or when the temporal prediction structure is to be determined on the fly.
- Parameters:
-
| cf | the Chroma format of pictures in the buffer |
| numL1 | the number of Layer 1 pictures before the next I picture. 0 means that there is only one I picture. |
| L1sep | the number of Layer 2 pictures between Layer 1 pictures |
| xlen | the luma width of pictures in the buffer |
| ylen | the luma height of pictures in the buffer |
| luma_depth | the video depth of the luma comp in the buffer |
| chroma_depth | the video depth of the chroma comp in the buffer |
| interlace | Set true if material is being coded in interlaced mode |
| using_ac | True if using Arithmetic coding to code coefficient data |
dirac::EncQueue::EncQueue |
( |
const EncQueue & |
cpy |
) |
|
Copy constructor. Removes the current contents of the pictureture buffer and copies in the contents of the initialising buffer.
dirac::EncQueue::~EncQueue |
( |
|
) |
|
Member Function Documentation
void dirac::EncQueue::CleanAll |
( |
const int |
show_pnum, |
|
|
const int |
current_coded_pnum | |
|
) |
| | |
Delete pictures which have been output and which are no longer required for reference. Expiry times are set in each picture's picture parameters.
- Parameters:
-
| show_pnum | picture number in display order that can be output |
| current_coded_pnum | picture number in display order of picture currently being coded |
void dirac::EncQueue::CleanRetired |
( |
const int |
show_pnum, |
|
|
const int |
current_coded_pnum | |
|
) |
| | |
Delete pictures which have been output and retired reference pictures. Expiry times are set in each picture's picture parameters.
- Parameters:
-
| show_pnum | picture number in display order that can be output |
| current_coded_pnum | picture number in display order of picture currently being coded |
void dirac::EncQueue::ClearSlot |
( |
const unsigned int |
pos |
) |
[private] |
Clear internal data slot number pos
void dirac::EncQueue::CopyPicture |
( |
const EncPicture & |
picture |
) |
|
Put a copy of a new picture into the buffer.
EncPicture& dirac::EncQueue::GetPicture |
( |
const unsigned int |
pnum |
) |
|
EncPicture& dirac::EncQueue::GetPicture |
( |
const unsigned int |
pnum, |
|
|
bool & |
is_present | |
|
) |
| | |
const EncPicture& dirac::EncQueue::GetPicture |
( |
const unsigned int |
pnum, |
|
|
bool & |
is_present | |
|
) |
| | const |
const EncPicture& dirac::EncQueue::GetPicture |
( |
const unsigned int |
pnum |
) |
const |
bool dirac::EncQueue::IsPictureAvail |
( |
const unsigned int |
pnum |
) |
const |
std::vector<int> dirac::EncQueue::Members |
( |
|
) |
const |
Operator=. Assigns all elements of the rhs to the lhs.
Put a new picture into the top of the buffer. EncPicture parameters associated with the picture will be as given by the picture parameter object.
void dirac::EncQueue::Remove |
( |
int |
pnum |
) |
|
Delete picture.
- Parameters:
-
| pnum | picture number in display order to be deleted from picture buffer |
void dirac::EncQueue::SetRetiredPictureNum |
( |
const int |
show_pnum, |
|
|
const int |
current_coded_pnum | |
|
) |
| | |
Indicate which picture which has been output and which is no longer required for reference. Expiry times are set in each picture's picture parameters.
- Parameters:
-
| show_pnum | picture number in display order that can be output |
| current_coded_pnum | picture number in display order of picture currently being coded |
int dirac::EncQueue::Size |
( |
|
) |
const [inline] |
Member Data Documentation
The documentation for this class was generated from the following file: