Dirac - A Video Codec

Created by the British Broadcasting Corporation.


seq_decompress.h
Go to the documentation of this file.
1 /* ***** BEGIN LICENSE BLOCK *****
2 *
3 * $Id: seq_decompress.h,v 1.13 2008/05/02 06:05:04 asuraparaju Exp $ $Name: Dirac_1_0_2 $
4 *
5 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
6 *
7 * The contents of this file are subject to the Mozilla Public License
8 * Version 1.1 (the "License"); you may not use this file except in compliance
9 * with the License. You may obtain a copy of the License at
10 * http://www.mozilla.org/MPL/
11 *
12 * Software distributed under the License is distributed on an "AS IS" basis,
13 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
14 * the specific language governing rights and limitations under the License.
15 *
16 * The Original Code is BBC Research and Development code.
17 *
18 * The Initial Developer of the Original Code is the British Broadcasting
19 * Corporation.
20 * Portions created by the Initial Developer are Copyright (C) 2004.
21 * All Rights Reserved.
22 *
23 * Contributor(s): Thomas Davies (Original Author),
24 * Scott R Ladd,
25 * Anuradha Suraparaju
26 * Andrew Kennedy
27 *
28 * Alternatively, the contents of this file may be used under the terms of
29 * the GNU General Public License Version 2 (the "GPL"), or the GNU Lesser
30 * Public License Version 2.1 (the "LGPL"), in which case the provisions of
31 * the GPL or the LGPL are applicable instead of those above. If you wish to
32 * allow use of your version of this file only under the terms of the either
33 * the GPL or LGPL and not to allow others to use your version of this file
34 * under the MPL, indicate your decision by deleting the provisions above
35 * and replace them with the notice and other provisions required by the GPL
36 * or LGPL. If you do not delete the provisions above, a recipient may use
37 * your version of this file under the terms of any one of the MPL, the GPL
38 * or the LGPL.
39 * ***** END LICENSE BLOCK ***** */
40 
41 
42 #ifndef _SEQ_DECOMPRESS_H_
43 #define _SEQ_DECOMPRESS_H_
44 
46 //---------------------------------------//
47 //Class to manage decompressing sequences//
48 //---------------------------------------//
50 
51 #include "libdirac_common/common.h"
53 #include <iostream>
54 
55 namespace dirac
56 {
57  class PictureBuffer;
58  class Picture;
59  class PictureDecompressor;
60 
62 
66  public:
67 
69 
75  SequenceDecompressor(ParseUnitByteIO& parseunit, bool verbosity);
76 
78 
82 
84 
87  void NewAccessUnit(ParseUnitByteIO& parseunit_byteio);
88 
89 
91 
105  const Picture* DecompressNextPicture(ParseUnitByteIO* p_parseunit_byteio);
106 
108  const Picture* GetNextPicture();
109 
111  const PictureParams* GetNextPictureParams() const;
113 
118  bool Finished();
120 
126 
127 
129 
135 
136 
138 
144  private:
146 
152 
154 
160 
161 
162  //Member variables
163 
177  int m_delay;
186  };
187 
188 } // namespace dirac
189 
190 #endif
const Picture * GetNextPicture()
Get the next picture available for display.
Parameters relating to the source material being encoded/decoded.
Definition: common.h:288
const Picture * DecompressNextPicture(ParseUnitByteIO *p_parseunit_byteio)
Decompress the next picture in sequence.
const PictureParams * GetNextPictureParams() const
Get the next picture parameters.
SourceParams & GetSourceParams()
Interrogates for source parameters.
Definition: seq_decompress.h:134
int m_current_code_pnum
Number of the picture in coded order which is to be decoded.
Definition: seq_decompress.h:175
bool m_all_done
Completion flag, returned via the Finished method.
Definition: seq_decompress.h:165
void NewAccessUnit(ParseUnitByteIO &parseunit_byteio)
Marks beginning of a new AccessUnit.
DecoderParams m_decparams
Parameters for the decompression, as provided in constructor.
Definition: seq_decompress.h:167
bool Finished()
Determine if decompression is complete.
Parameters for initialising picture class objects.
Definition: common.h:532
ParseParams m_parse_params
The parse parameters obtained from the stream header.
Definition: seq_decompress.h:169
Parameters for the decoding process.
Definition: common.h:1548
DecoderParams & GetDecoderParams()
Interrogates for coding parameters.
Definition: seq_decompress.h:143
int m_show_pnum
Index, in display order of the picture to be displayed next - computed from delay and current_code_pn...
Definition: seq_decompress.h:181
PictureBuffer * m_pbuffer
A picture buffer used for local storage of pictures whilst pending re-ordering or being used for refe...
Definition: seq_decompress.h:173
SourceParams m_srcparams
The source parameters obtained from the stream header.
Definition: seq_decompress.h:171
SequenceDecompressor & operator=(const SequenceDecompressor &rhs)
Assignment = is private and body-less.
int m_delay
A delay so that we don&#39;t display what we haven&#39;t decoded.
Definition: seq_decompress.h:177
Compress a single image picture.
Definition: picture_decompress.h:61
~SequenceDecompressor()
Destructor.
ParseParams & GetParseParams()
Interrogates for parse parameters.
Definition: seq_decompress.h:125
Definition of class SequenceHeaderByteIO.
Definition: accessunit_byteio.h:51
Holds pictures both for reference and to overcome reordering delay.
Definition: picture_buffer.h:59
PictureDecompressor * m_pdecoder
Picture decompressor object.
Definition: seq_decompress.h:183
Decompresses a sequence of pictures from a stream.
Definition: seq_decompress.h:65
int m_last_picture_read
Index, in display order, of the last picture read.
Definition: seq_decompress.h:179
Represents a collection of data in a Dirac bytestream that can be parsed as a self-contained unit...
Definition: parseunit_byteio.h:72
SequenceDecompressor(ParseUnitByteIO &parseunit, bool verbosity)
Constructor.
Parameters relating to the complexity of encoder/decoder.
Definition: common.h:890
int m_highest_pnum
Highest picture-num processed - for tracking end-of-sequence.
Definition: seq_decompress.h:185
A class for encapsulating all the data relating to a picture.
Definition: picture.h:51

© 2004 British Broadcasting Corporation. Dirac code licensed under the Mozilla Public License (MPL) Version 1.1.
HTML documentation generated by Dimitri van Heesch's excellent Doxygen tool.