US20130177074A1 - Image Processing Apparatus - Google Patents
Image Processing Apparatus Download PDFInfo
- Publication number
- US20130177074A1 US20130177074A1 US13/733,216 US201313733216A US2013177074A1 US 20130177074 A1 US20130177074 A1 US 20130177074A1 US 201313733216 A US201313733216 A US 201313733216A US 2013177074 A1 US2013177074 A1 US 2013177074A1
- Authority
- US
- United States
- Prior art keywords
- unit
- motion image
- encoding
- image data
- mode
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/60—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
- H04N19/61—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
-
- H04N19/00169—
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/124—Quantisation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/136—Incoming video signal characteristics or properties
- H04N19/14—Coding unit complexity, e.g. amount of activity or edge presence estimation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/146—Data rate or code amount at the encoder output
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/146—Data rate or code amount at the encoder output
- H04N19/152—Data rate or code amount at the encoder output by measuring the fullness of the transmission buffer
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/156—Availability of hardware or computational resources, e.g. encoding based on power-saving criteria
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/162—User input
Definitions
- the present invention relates to an image processing apparatus, and more particularly to an apparatus encoding an image signal.
- the MPEG system is an encoding system combining intra-frame encoding, which performs encoding only using the image data in a single frame, and inter-frame prediction encoding, which encodes a difference (prediction error) with a reference frame.
- inter-frame prediction encoding the image data in one frame is divided into blocks, each including a predetermined number of pixels, and a block which has the minimum difference with the image data of the reference frame is detected among the blocks. Then, a motion vector to the reference block is obtained, and the motion vector is encoded together with the difference data.
- variable length encoding The method of transforming codes to those having different lengths according to the occurrence frequencies of data is called as variable length encoding.
- variable length encoding the larger the deviation of the occurrence frequency of data is, the smaller the whole data amount becomes. In this manner, the use of variable length codes enables the reduction of average data amount in comparison with that of the fixed length encoding while the quality of the reproduced signals are kept to be equal.
- the transfer rates of the encoded data are not constant. Consequently, it becomes a problem how to control the data rates of image data when the image data encoded by the MPEG encoding is recorded on a storage medium having a limitation of its recording rate such as a magnetic tape, an optical disc or the like.
- GOP group of picture
- the image data for one frame is divided into blocks, each referred to as a macro block and including a predetermined number of pixels, and motion compensation prediction, orthogonal transform and quantization are performed on every macro block. And by controlling quantization steps used in quantization processing, the code amounts of each GOP can be controlled to be substantially constant (see, for example, Japanese Patent Application Laid-Open No. H07-184195).
- Test Model 5 of MPEG 2
- the complexity is also called as activity, and is a factor indicating a feature of an input image.
- devices for obtaining a reproduced image of a high image quality corresponding to the feature of the image within a limited code amount have been performed (see, for example, Japanese Patent Application Laid-Open No. 2003-37843 corresponding to United States Patent Published Application No. 2003/0067979).
- a DVD recorder, a HDD recorder, a disk video camera and the like have appeared as a household apparatus for recording the image data subjected to MPEG encoding in this manner.
- Many apparatus of this kind are equipped with a plurality of modes (image quality modes) having different target data rates of image data to efficiently use limited recording capacities. That is, when a target rate is set to be high, while an image having a high image quality can be recorded, a large storage capacity becomes necessary, and a recordable time becomes short. Moreover, when the target rate is set to be low, the recordable time becomes long, but the image quality of a recorded image becomes low.
- the related art described above performs encoding using the information of complexity regardless of the data rate of encoded image data.
- the information of the complexity acts, as a disturbance, on the configuration performing code amount control on the basis of a generated code amount.
- TM 5 of MPEG 2 a device of preventing the deterioration of a flat portion of an image by assigning a relatively much code amount to a block having little complexity is performed.
- the related art performs encoding using the information of complexity regardless of the data rate of encoded image data
- the related art has a problem in which a generated code amount exceeds the number of bits assigned to a frame when there are many macro blocks having small values of complexity.
- an image processing apparatus comprises: encoding means for encoding an input motion image signal to generate encoded motion image data; recording means for recording the encoded motion image data on a recording medium; complexity detection means for detecting complexity of a motion image according to the input motion image data; remaining amount detection means for detecting a record remaining capacity of the recording medium; and control means having a first mode for controlling the encoding means based on information of the complexity detected by the complexity detection means so as to adjust a code amount of the encoded motion image data output from the encoding means, and a second mode for controlling the encoding means without using the information of the complexity detected by the complexity detection means so as to adjust the code amount of the encoded motion image data output from the encoding means; wherein the control means switches over the first mode and the second mode on the basis of an output of the remaining amount detection means.
- FIG. 1 is a diagram showing the configuration of a recording apparatus as a first embodiment of the present invention
- FIG. 2 is a flowchart showing the setting processing of a quantization step in the first embodiment
- FIG. 3 is a diagram showing the configuration of a recording apparatus as a third embodiment of the present invention.
- FIG. 4 is a flowchart showing the setting processing of a quantization step in the third embodiment
- FIG. 5 is a diagram showing the configuration of a recording apparatus as a fourth embodiment of the present invention.
- FIG. 6 is a flowchart showing the setting processing of a quantization step in the fourth embodiment.
- FIG. 1 is a block diagram of the recording apparatus according to the present invention.
- the recording apparatus is composed of a block-division unit 101 , a motion compensation unit 102 , an orthogonal transform unit 103 , a quantization unit 104 , a variable length encoding unit 105 , a recording unit 106 , an average value calculation unit 107 , an activity calculation unit 108 , a multiplication unit 109 , a reference quantization step determination unit 110 , a bit-assignment unit 111 and an activity control unit 112 .
- the block-division unit 101 divides each frame of input motion image data into macro blocks, each composed of 16 pixels in horizontal direction ⁇ 16 pixels in vertical direction. And the block-division unit 101 outputs the image data of the macro blocks (hereinafter referred to as MB data) to the motion compensation unit 102 and the activity calculation unit 108 .
- MB data image data of the macro blocks
- the motion compensation unit 102 includes an inverse quantization unit, an inverse orthogonal transform unit and a motion compensation unit, all not shown. And when an encoding object frame is an intra-frame encoding frame, the motion compensation unit 102 outputs input MB data to the orthogonal transform unit 103 as it is. Moreover, when the encoding object frame is an inter-frame encoding frame, the motion compensation unit 102 performs the well-known procedure to obtain prediction error data between the MB data of the present frame, which has been input from the block-division unit 101 , and the image data of a reference frame to output the obtained prediction error data to the orthogonal transform unit 103 .
- the orthogonal transform unit 103 performs the DCT processing of the MB data or the prediction error data from the motion compensation unit 102 to convert the data into transform coefficients, and outputs the transform coefficients to the quantization unit 104 .
- the quantization unit 104 quantizes the input transform coefficients on the basis of the quantization step obtained from the multiplication unit 109 .
- the values which the transform coefficients can take (hereinafter referred to as the number of levels) are controlled based on the quantization step. That is, when the quantization step is large, the number of levels decreases, and thereby the number of 0's increases and significant coefficients other than 0 decrease. Consequently, the encoded data amount after the variable length encoding also decreases.
- the encoded data amount can be controlled by adjusting the quantization step in this manner, the data rate of the encoded data output from the variable length encoding unit 105 can be controlled.
- the transform coefficients quantized by the quantization unit 104 are output to the variable length encoding unit 105 and to the motion compensation unit 102 .
- the variable length encoding unit 105 performs the variable length encoding of the transform coefficient quantized by the quantization unit 104 , and outputs the encoded transform coefficient (hereinafter referred to as encoded data) to the recording unit 106 .
- the recording unit 106 has a not shown buffer memory, and stores the encoded data once in the buffer memory. After that, the recording unit 106 reads the encoded data at suitable timing to record the encoded data onto a recording medium M.
- An operation unit 113 includes a recording switch, a stop switch and the like, and a user can operates the recording switch to instruct a start of recording. Moreover, the user can operate the stop switch to instruct a stop of recording.
- the activity control unit 112 calculates the remaining recording capacity w of the recording medium M, and the total recording time t of the image data recorded on the recording medium M. Then, the activity control unit 112 generates a flag for adjusting the activity detected by the activity calculation unit 108 using the remaining recording capacity w and a plurality of threshold values set beforehand.
- threshold values Th 1 and Th 2 are obtained as follows.
- Th 1 WTh 1 ⁇ t, Th 2 ⁇ WTh 2 ⁇ t
- WTh 1 and WTh 2 denote previously-set reference values, and WTh 1 >WTh 2 . Consequently, Th 1 >Th 2 .
- the remaining recording capacity w is compared with these threshold values Th 1 and Th 2 , and it is detected which state of the following three states is satisfied. And two flags, flag 1 and flag 2 , are set according to each state.
- the activity control unit 112 judges that the remaining recording capacity runs short, and sets the flag 2 to on to output the flag 2 to the activity calculation unit 108 . Moreover, when the condition (i) is not satisfied, the flag 2 is made to be off.
- the activity calculation unit 108 obtains an activity from each macro block unit.
- the activity at a jth macro block act j is obtained in accordance with the following formula.
- var i,j is a dispersion value of the pixel values in an ith sub-block when the jth macro block is divided into four blocks.
- a macro block is composed of 16 pixels ⁇ 16 pixels
- a sub-block is composed of 8 pixels ⁇ 8 pixels.
- the number of pixels of each sub-block is 64, and the dispersion value is obtained every 64 pixels.
- the activity may be calculated using the dynamic range of pixel values instead of the dispersion value of pixel values.
- the activity calculation unit 108 transforms the activity obtained in this manner to the normalized activity Nact j as the following formula using an average value of quantization steps obtained by the average value calculation unit 107 .
- Nact j ( m ⁇ act j +avg)/( act j +m ⁇ avg) (2)
- avg denotes the average value of the quantization steps obtained by the average value calculation unit 107
- m denotes an arbitrary natural number. It is provided that a given initial value is set as the average value avg at an early stage of encoding.
- the activity of the macro block becomes small.
- the activity becomes large.
- the activity is normalized based on the average value of the quantization steps of the preceding frame output from the average value calculation unit 107 , and the normalized activity is output. Then, the multiplication unit 109 corrects the reference quantization step obtained by the reference quantization step determination unit 110 based on the normalized activity to determine the quantization step.
- the calculation result of an activity is changed based on the state of the activity control flag output from the activity control unit 112 .
- the activity calculation unit 108 transforms Nact j into Nact′ j in accordance with the states of the activity flag 1 and the activity flag 2 like the following formula, and outputs the transformed Nact′ j to the multiplication unit 109 .
- Nact′ j Nact j +dec (at Nact j +dec ⁇ 1.0)
- Nact′ j 1.0 (at Nactj+dec ⁇ 1.0 and Nact j ⁇ 1.0).
- Nact′ j 1.0 (provided at Nact j ⁇ 1.0).
- dec denotes a constant of 0.1 ⁇ dec ⁇ 1.0.
- Nact j when the flag 2 is on, it is judged that the remaining recording capacity of the recording medium M is left very little. Accordingly, in order to remove the influences of the activity to data rate control, when Nact j is smaller than 1.0, Nact j is set to 1.0, and it is output to the multiplication unit 109. However, when Nact j is 1.0 or more, it is output as it is. Alternatively, the value 1.0 may be set to be always output without performing the calculation of Nact j .
- the flag 1 when the flag 1 is on, it is judged that the remaining recording capacity of the recording medium M has run short. Accordingly, in order to make the influence by the activity to data rate control small, when the normalized activity Nact j is smaller than 1.0, Nact′ j , to which the correction value dec is added, is output to the multiplication unit 109 .
- the threshold values for distinguishing the remaining recording capacity of the recording medium M are set as two values in the present embodiment, the judgment of the remaining recording capacity can be also changed stepwise by increasing the number of the threshold values. At that time, the dec may be stepwise changed according to the remaining recording capacity.
- the multiplication unit 109 multiplies the reference quantization step output from the reference quantization step determination unit 110 by the normalized activity Nact j or Nact′ j , both output from the activity calculation unit 108 , to adjust the quantization step. And the quantization step is output to the quantization unit 104 while the quantization step is also output to the average value calculation unit 107 .
- the average value calculation unit 107 calculates the average value of the quantization steps for one frame, and outputs the quantization step to bit-assignment unit 111 while the average value calculation unit 107 also outputs the quantization step to the activity calculation unit 108 .
- the bit-assignment unit 111 determines the code amount (the number of bits) to be assigned to a frame which is intended to be coded after this, on the basis of the code amount generated up to the preceding frame by the variable length encoding unit 105 and the target data rate.
- the reference quantization step determination unit 110 determines reference quantization steps qI j , qP j , and qB j to each macro block on the basis of the number of the code amounts generated up to the preceding macro block and the assigned code amount.
- j indicates a macro block number
- I, P and B indicates the type of a picture.
- the reference quantization step qI j is obtained by the following formula on the basis of the dI j .
- dI 0 denotes the buffer fullness at an initial stage, which is the last buffer fullness dIMB cnt when the last I picture has been encoded. It is provided that an initial value is an arbitrary constant.
- B j denotes the total number of the bits in the image generated up to the jth block
- MB cnt denotes the total number of the macro blocks in the image
- r denotes a reaction parameter.
- the above formula reflects the difference between the assigned number of bits generated up to the preceding macro block and the number of bits actually generated when Ti bits are uniformly assigned to each macro-bit on virtual buffer fullness.
- the reference quantization step determination unit 110 works so as to reduce the numbers of the generated bits of the subsequent frames.
- the reference quantization step determination unit 110 works so as to enlarge the number of the generated bits of the subsequent frames.
- the similar method is used also in the P picture and the B picture to determine the reference quantization steps.
- Step S 201 it is judged whether a motion image signal is input or not. As a result of the judgment, when a motion image signal is input, the processing progresses to Step S 202 , and the remaining recording capacity of the recording medium M is detected. Next, at Step S 203 , the activity calculation unit 108 detects the activity Nact of each macro block of the input motion image signal.
- Step S 204 the processing progresses to Step S 204 , and the activity control unit 112 sets the activity control flags 1 and 2 on the basis of the remaining recording capacity.
- Step S 205 the reference quantization step determination unit 110 determines reference quantization step.
- Step S 206 the processing progresses to Step S 206 , and the activity calculation unit 108 changes the activity Nact on the basis of the states of the flags 1 and 2 to send the changed activity Nact to the multiplication unit 109 .
- Step S 207 the multiplication unit 109 multiplies the reference quantization step from the reference quantization step determination unit 110 by the activity from the activity calculation unit 108 to adjust the value of the multiplied reference quantization step, and the multiplication unit 109 sends the adjusted reference quantization step to the quantization unit 104 .
- Step S 208 it is judged whether the input of the motion image data stops and all processing has been completed or not.
- the processing returns to Step S 202 .
- a quantization step is determined without using activity. Consequently, when the remaining recording capacity is little left, the influence of the activity given to data rate control as a disturbance can be removed.
- the image encoding apparatus according to the second embodiment has the construction similar to one shown in FIG. 1
- the image encoding apparatus of the second embodiment is made to allow a user to arbitrarily set a target data rate (image quality) of a motion image signal with the operation unit 113 .
- the present embodiment is configured to be equipped with three image quality modes of a high image quality mode, a standard mode and a long time mode.
- the user can arbitrarily select any one of these three image quality modes.
- the target data rate of the high image quality mode is the highest, and the target data rates of the standard mode and the long time mode become lower in this order after that.
- the activity control unit 112 calculates the remaining recording capacity w of the recording medium M, and the recording time up to now. Then, the activity control unit 112 generates a flag for adjusting the activity detected by the activity calculation unit 108 on the basis of the remaining recording capacity w and the information mode of the image quality mode set by the operation unit 113 .
- the average data rates (target data rates) changes according to the record modes mode.
- the average bit rate becomes larger, and the capacity of a recording medium more rapidly becomes less. Accordingly, the value of a threshold value is changed according to a mode.
- the processing similar to that in the first embodiment is executed.
- the remaining recording capacity is compared with the threshold values in each mode to discriminate which state of the followings is satisfied, in the present embodiment.
- states of the two control flags 1 and 2 are set similarly in the first embodiment on the basis of any one of the three states (i), (ii) and (iii) in each mode.
- the activity calculation unit 108 changes the activity similarly in the first embodiment on the basis of the state of the flags 1 and 2 set in each mode, and sends the changed activity to the multiplication unit 109 .
- the reference quantization step determination unit 110 calculates the reference quantization step according to the assigned number of bits from the bit-assignment unit 111 , and sends the calculated reference quantization step to the multiplication unit 109 .
- the bit-assignment unit 111 changes the assigned number of bits on the basis of the image quality mode set by the operation unit 113 , i.e. the target data rate.
- the assigned number of bits also becomes larger than that in the standard mode.
- the multiplication unit 109 multiplies the quantization step from the reference quantization step determination unit 110 by the activity from the activity calculation unit 108 , and sends the multiplied quantization step to the quantization unit 104 .
- the quantization step is determined without using the activity. Consequently, when the remaining recording capacity runs short, the influence of the activity given to data rate control as a disturbance can be removed.
- the threshold. value for distinguishing the state of the remaining recording capacity is changed according to the image quality mode, it becomes possible to change the control state of the quantization step using the activity to the optimal state according to the image quality mode.
- the number of the modes may be increased to more stepwise perform the activity control according to the image quality.
- the number of the modes may be reduced conversely to decrease the number of steps of the activity control according to the image quality.
- the quantization step is determined without using the activity.
- the image quality mode target data rate
- FIG. 3 is a diagram showing the configuration of a recording apparatus 300 according to the present embodiment.
- the recording apparatus 300 is composed of a block-division unit 301 , a motion compensation unit 302 , an orthogonal transform unit 303 , a quantization unit 304 , a variable length encoding unit 305 , a recording unit 306 , a complexity calculation unit 307 , a switch 308 , a quantization step setting unit 309 , a generated code calculation unit 310 and an operation unit 312 .
- the block-division unit 301 divides each frame of input motion image data into macro blocks, each composed of 16 pixels in horizontal direction ⁇ 16 pixels in vertical direction. And the block-division unit 301 outputs the image data of the macro blocks to the motion compensation unit 302 while the block-division unit 301 also outputs the image data to the complexity calculation unit 307 .
- the motion compensation unit 302 When an encoding object frame is an intra-frame encoding frame, the motion compensation unit 302 outputs input MB data to the orthogonal transform unit 303 as it is. Moreover, when the encoding object frame is an inter-frame encoding frame, the motion compensation unit 302 performs a well-known procedure to obtain prediction error data between the MB data of the present frame, which has been input from the block-division unit 301 , and the image data of a reference frame to output the obtained prediction error data to the orthogonal transform unit 303 .
- the orthogonal transform unit 303 performs the DCT processing of the MB data or the prediction error data from the motion compensation unit 302 to convert the data into transform coefficients, and outputs the transform coefficients to the quantization unit 304 .
- the quantization unit 304 quantizes the input transform coefficients based on the quantization step obtained from the quantization step setting unit 309 . Because the encoded data amount can be controlled by adjusting the quantization step, it is possible to control the data rate of the encoded data output from the variable length encoding unit 305 .
- the transform coefficients quantized by the quantization unit 304 are output to the variable length encoding unit 305 while the transform coefficients are also output to the motion compensation unit 302 .
- the variable length encoding unit 305 performs the variable length encoding of the transform coefficient quantized by the quantization unit 304 , and outputs the encoded transform coefficient to the recording unit 306 .
- the recording unit 306 has a not shown buffer memory, and once stores the encoded data in the buffer memory. After that, the recording unit 306 reads the encoded data at an appropriate timing to record the encoded data onto a recording medium M.
- the complexity calculation unit 307 calculates the complexity (activity) of each macro block as will be described later, and outputs the calculated complexity to the switch 308 .
- the switch 308 sends the complexity information from the complexity calculation unit 307 to the quantization step setting unit 309 in accordance with the image quality mode selected with the operation unit 312 .
- the quantization step setting unit 309 sets the quantization step to each macro block on the basis of the image quality mode set with the operation unit 312 , the generated code amount from the generated code amount calculation unit 310 , and the complexity information supplied through the switch 308 .
- the operation unit 312 includes a recording switch, a stop switch, a setting switch of an image quality mode, and the like.
- a user can operate the recording switch to instruct a start of recording.
- the user can operate the stop switch to instruct a stop of recording.
- the flow of FIG. 4 is executed every frame.
- Step S 401 the complexity of each macro block of the present frame in input motion image data is calculated by the complexity calculation unit 307 (Step S 401 ).
- each block is calculated in accordance with the above formula (1).
- the dispersion value var i,j of a sub-block is calculated in accordance with the following formula.
- normalized complexity information is calculated based on the calculated complexity by the complexity calculation unit 307 (Step S 402 ).
- the normalized complexity is calculated in accordance with the above formula (2).
- a control unit 311 detects the present target data rate based on the image quality mode set by the operation unit 312 (Step S 403 ). Next, the control unit 311 distinguishes whether the present target data rate is larger than a threshold value R 1 or not (Step S 404 ).
- the control unit 311 turns on the switch 308 (Step S 405 ). And the control unit 311 controls the quantization step setting unit 309 to set a quantization step on the basis of the information of the generated code amount detected by the generated code amount calculation unit 310 and the target data rate (Step S 406 ). And the control unit 311 adjusts the set quantization step on the basis of the normalized complexity information obtained by the complexity calculation unit 307 (Step S 407 ). To put it concretely, the control unit 311 adjusts the quantization step by multiplying the set quantization step by the normalized complexity information. And the control unit 311 outputs the adjusted quantization step to the quantization unit 304 (Step S 408 ).
- the control unit 311 turns off the switch 308 (Step S 410 ). And the control unit 311 controls the quantization step setting unit 309 to set the quantization step on the basis of the information of the generated code amount detected by the generated code amount calculation unit 310 and the target data rate so that the encoded data rate may become equal to the target data rate (Step S 411 ). And the control unit 311 outputs the quantization step to the quantization unit 304 (Step S 412 ).
- Step S 409 the control unit 311 completes the processing (Step S 409 ).
- the quantization step is adjusted according to the complexity of an image to perform quantization, the image can be quantized using a visual characteristic.
- a quantization step is set without using the complexity information to perform the quantization, the deterioration of image quality such as the generation of block noises caused by the use of the complexity information can be prevented.
- FIG. 5 is a diagram showing the configuration of a recording apparatus according to the fourth embodiment.
- the components similar to those of FIG. 3 are denoted by the same reference numerals as those in FIG. 3 .
- variable bit rate system indicates a method of dynamically changing the code amount to be assigned to each scene in accordance with the complexity of the pattern of an image to be encoded.
- the method assigns more amounts of codes to a scene of a complicated pattern, and assigns fewer amounts of codes to an image of a relatively flat pattern.
- the present embodiment uses a well-known technique as the concrete variable bit rate system, and compares the code amount of the encoded image data generated just before with a predetermined value to perform encoding without using the complexity information when the code amount becomes lower than the predetermined value.
- Step S 401 the complexity of each macro block of one frame is calculated.
- Step S 402 normalized complexity is calculated.
- the normalized complexity defined as the formula (2) is obtained based on the average of the complexity of each macro block and the complexity in the picture encoded just before.
- a target data rate is detected (Step S 403 ), and the information of a generated code amount per unit time is detected by the generated code amount calculation unit 310 (Step S 601 ).
- the generated code amount per group of picture is detected.
- a quantization step is set based on the code amount per GOP.
- the GOP is a unit composed of the number of frames processed within a range of from an I picture to the next I picture, and is a basic unit of encoding in the MPEG system.
- Step S 602 the generated code amount per unit time is compared with a predetermined threshold value N 2 to discriminate whether the generated code amount is larger than N 2 or not. Because the data rate is encoded while being dynamically changed in the VBR system, the generated code amount per GOP also significantly changes. At Step S 602 , it is possible to know whether the code amount generated per GOP is smaller than the predetermined code amount N 2 or not in this manner.
- the control unit 311 turns on the switch 308 (Step S 405 ). Then the control unit 311 controls the quantization step setting unit 309 to set a quantization step on the basis of the information of the generated code amount detected by the generated code amount calculation unit 310 and the target data rate (Step S 406 ). And the control unit 311 adjusts the set quantization step on the basis of the normalized complexity information obtained by the complexity calculation unit 307 (Step S 407 ). To put it concretely, the control unit 311 adjusts the quantization step by multiplying the set quantization step by the normalized complexity information. And the control unit 311 outputs the adjusted quantization step to the quantization unit 304 (Step S 408 ).
- the control unit 311 turns off the switch 308 (Step S 410 ). And the control unit 311 controls the quantization step setting unit 309 to set the quantization step on the basis of the information of the generated code amount detected by the generated code amount calculation unit 310 and the target data rate (Step S 411 ). And the control unit 311 outputs the quantization step to the quantization unit 304 (Step S 412 ).
- Step S 409 the control unit 311 completes the processing (Step S 409 ).
- the quantization step is adjusted according to the complexity of an image to perform quantization, the image can be quantized using a visual characteristic.
- Each means and each step of the image processing methods which constitute the embodiments of the present invention can be realized by the operation of programs stored in a RAM, a ROM or the like of a computer.
- the programs and a recording medium which records the programs and can be read by a computer are included in the present invention.
- the present invention can be realized as the embodiments of a system, an apparatus, a method, a program, a storage medium and the like. To put it concretely, the present invention may be applied to a system composed of a plurality of pieces of equipment, or may be applied to an apparatus composed of one piece of equipment.
- the present invention includes a case where a program of software realizing the functions of the embodiments described above (the programs corresponding to the flowcharts shown in FIGS. 2 and 4 in the embodiments) is directly or remotely supplied to a system or an apparatus and the functions are attained by the computer of the system or the apparatus which reads the supplied program to execute it.
- the program codes themselves which are installed in a computer in order to realize the functional processing of the present invention are also ones realizing the present invention. That is, the present invention includes the computer program itself for realizing the functional processing of the present invention.
- the program may be in a form of object codes, a program executed by an interpreter, script data supplied to an OS or the like.
- a recording medium for supplying a program there are, for example, a floppy disk (registered trademark), a hard disk, an optical disc, a magneto-optical disc, an MO, a CD-ROM, a CD-R, a CD-RW, a magnetic tape, a nonvolatile memory card, a ROM, a DVD (DVD-ROM, DVD-R) and the like.
- a program can be also supplied by connecting with a homepage in the Internet using the browser of a client computer to download the computer program itself of the present invention or a compressed file including an automatic installing function to a recording medium such as a hard disk.
- the present invention can be also realized by dividing the program codes constituting the program of the present invention into a plurality of files to download the respective files from different home pages. That is, a WWW server which allows a plurality of users to download a program file for realizing the functional processing of the present invention with a computer is also included in the present invention.
- the realization of the present invention is also possible by encoding the program of the present invention to store the encoded program into a storage medium such as a CD-ROM and the like for distributing the program widely among users, and by allowing a user who clears a predetermined condition to download key information for deciphering the code from a home page through the Internet to use the key information for executing the encoded program to install the encoded program into a computer.
- a storage medium such as a CD-ROM and the like for distributing the program widely among users
- the functions of the embodiments described above can be also realized by the execution of a part of or the whole actual processing by an OS operating on the computer based on the instructions of the program.
- the functions of the embodiments described above can be also realized by writing the program read from a recording medium into a feature expansion board inserted into a computer or a memory installed on a feature expansion unit connected to a computer before the execution of a part of or the whole actual processing by a CPU or the like provided on the feature expansion board or the feature expansion unit based on the instructions of the program.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Computing Systems (AREA)
- Theoretical Computer Science (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
An image processing apparatus encodes an input motion image signal, records encoded motion image data on a recording medium, detects complexity of a motion image according to the input motion image data, detects a remaining recording capacity of the recording medium, and has a first mode for controlling the encoding unit based on information of the detected complexity of the motion image so as to adjust a code amount of the encoded motion image data and has a second mode for controlling the encoding without using the information of the detected complexity of the motion image so as to adjust the code amount of the encoded motion image data, wherein the first mode and the second mode are determined based on the remaining recording capacity.
Description
- The present invention relates to an image processing apparatus, and more particularly to an apparatus encoding an image signal.
- 2. Description of Related Art
- Conventionally, as a technique of encoding motion image data to compress an information amount, the MPEG system is known. The MPEG system is an encoding system combining intra-frame encoding, which performs encoding only using the image data in a single frame, and inter-frame prediction encoding, which encodes a difference (prediction error) with a reference frame. In the inter-frame prediction encoding, the image data in one frame is divided into blocks, each including a predetermined number of pixels, and a block which has the minimum difference with the image data of the reference frame is detected among the blocks. Then, a motion vector to the reference block is obtained, and the motion vector is encoded together with the difference data.
- The level distributions of the generated signals of prediction residuals in the prediction encoding and of orthogonal transform coefficients in transform encoding have considerable deviations. Accordingly, by assigning codes having different lengths according to the occurrence frequencies of signal levels, the average value of data amounts can be made shorter than the data amounts of fixed length codes. The method of transforming codes to those having different lengths according to the occurrence frequencies of data is called as variable length encoding. In case of using the variable length encoding, the larger the deviation of the occurrence frequency of data is, the smaller the whole data amount becomes. In this manner, the use of variable length codes enables the reduction of average data amount in comparison with that of the fixed length encoding while the quality of the reproduced signals are kept to be equal.
- Because the code amount of each scene is different from each other in the MPEG encoding, the transfer rates of the encoded data are not constant. Consequently, it becomes a problem how to control the data rates of image data when the image data encoded by the MPEG encoding is recorded on a storage medium having a limitation of its recording rate such as a magnetic tape, an optical disc or the like.
- As a control method of a data rate, there is a method called as a group of picture (GOP) method, which controls the code amount of one GOP to be constant on a unit basis of the predetermined number of frames.
- To put it concretely, in the MPEG encoding, the image data for one frame is divided into blocks, each referred to as a macro block and including a predetermined number of pixels, and motion compensation prediction, orthogonal transform and quantization are performed on every macro block. And by controlling quantization steps used in quantization processing, the code amounts of each GOP can be controlled to be substantially constant (see, for example, Japanese Patent Application Laid-Open No. H07-184195).
- Moreover, in Test Model 5 (TM 5) of
MPEG 2, it is also taken in consideration to adjust the code amount to be assigned to each block in a pictures, by using the factor called as the complexity of an image. The complexity is also called as activity, and is a factor indicating a feature of an input image. In this manner, devices for obtaining a reproduced image of a high image quality corresponding to the feature of the image within a limited code amount have been performed (see, for example, Japanese Patent Application Laid-Open No. 2003-37843 corresponding to United States Patent Published Application No. 2003/0067979). - In recent years, a DVD recorder, a HDD recorder, a disk video camera and the like have appeared as a household apparatus for recording the image data subjected to MPEG encoding in this manner. Many apparatus of this kind are equipped with a plurality of modes (image quality modes) having different target data rates of image data to efficiently use limited recording capacities. That is, when a target rate is set to be high, while an image having a high image quality can be recorded, a large storage capacity becomes necessary, and a recordable time becomes short. Moreover, when the target rate is set to be low, the recordable time becomes long, but the image quality of a recorded image becomes low.
- The related art described above performs encoding using the information of complexity regardless of the data rate of encoded image data.
- And, as described above, when the target data rate of image data to be recorded is set to be low, the assignment of a code amount according to the complexity (visual characteristic) is performed under a condition in which an assigned code amount per frame is small.
- The information of the complexity acts, as a disturbance, on the configuration performing code amount control on the basis of a generated code amount.
- Consequently, when a target data rate is low, there is a case where the image quality becomes deteriorated on the contrary in comparison with that of an image encoded without using the complexity, such as a case where block noises are conspicuous and the like.
- Moreover, in the above TM 5 of
MPEG 2, a device of preventing the deterioration of a flat portion of an image by assigning a relatively much code amount to a block having little complexity is performed. - However, because the related art performs encoding using the information of complexity regardless of the data rate of encoded image data, the related art has a problem in which a generated code amount exceeds the number of bits assigned to a frame when there are many macro blocks having small values of complexity.
- For example, it is necessary for a disk video camera to certify the recordable time of a recording medium within an error range.
- However, there is a problem that the recordable time cannot be certified when the generated code amount changes in this manner.
- It is an object of the present invention to settle the problems described above.
- Moreover, it is another object of the present invention to provide an image processing apparatus capable of guaranteeing a recording time necessary for a recording medium by performing code amount control certainly.
- In order to attain such objects, according to one scope of the present invention, an image processing apparatus comprises: encoding means for encoding an input motion image signal to generate encoded motion image data; recording means for recording the encoded motion image data on a recording medium; complexity detection means for detecting complexity of a motion image according to the input motion image data; remaining amount detection means for detecting a record remaining capacity of the recording medium; and control means having a first mode for controlling the encoding means based on information of the complexity detected by the complexity detection means so as to adjust a code amount of the encoded motion image data output from the encoding means, and a second mode for controlling the encoding means without using the information of the complexity detected by the complexity detection means so as to adjust the code amount of the encoded motion image data output from the encoding means; wherein the control means switches over the first mode and the second mode on the basis of an output of the remaining amount detection means.
- Other objects and features of the present invention will become clear from the following embodiments and the description of the attached drawings.
-
FIG. 1 is a diagram showing the configuration of a recording apparatus as a first embodiment of the present invention; -
FIG. 2 is a flowchart showing the setting processing of a quantization step in the first embodiment; -
FIG. 3 is a diagram showing the configuration of a recording apparatus as a third embodiment of the present invention; -
FIG. 4 is a flowchart showing the setting processing of a quantization step in the third embodiment; -
FIG. 5 is a diagram showing the configuration of a recording apparatus as a fourth embodiment of the present invention; and -
FIG. 6 is a flowchart showing the setting processing of a quantization step in the fourth embodiment. - In the following, a suitable embodiment of an image processing apparatus according to the present invention is described in detail with reference to
FIG. 1 . -
FIG. 1 is a block diagram of the recording apparatus according to the present invention. - As shown in
FIG. 1 , the recording apparatus is composed of a block-division unit 101, amotion compensation unit 102, anorthogonal transform unit 103, aquantization unit 104, a variablelength encoding unit 105, arecording unit 106, an averagevalue calculation unit 107, anactivity calculation unit 108, amultiplication unit 109, a reference quantizationstep determination unit 110, a bit-assignment unit 111 and anactivity control unit 112. - The block-
division unit 101 divides each frame of input motion image data into macro blocks, each composed of 16 pixels in horizontal direction×16 pixels in vertical direction. And the block-division unit 101 outputs the image data of the macro blocks (hereinafter referred to as MB data) to themotion compensation unit 102 and theactivity calculation unit 108. - The
motion compensation unit 102 includes an inverse quantization unit, an inverse orthogonal transform unit and a motion compensation unit, all not shown. And when an encoding object frame is an intra-frame encoding frame, themotion compensation unit 102 outputs input MB data to theorthogonal transform unit 103 as it is. Moreover, when the encoding object frame is an inter-frame encoding frame, themotion compensation unit 102 performs the well-known procedure to obtain prediction error data between the MB data of the present frame, which has been input from the block-division unit 101, and the image data of a reference frame to output the obtained prediction error data to theorthogonal transform unit 103. - The
orthogonal transform unit 103 performs the DCT processing of the MB data or the prediction error data from themotion compensation unit 102 to convert the data into transform coefficients, and outputs the transform coefficients to thequantization unit 104. - The
quantization unit 104 quantizes the input transform coefficients on the basis of the quantization step obtained from themultiplication unit 109. The values which the transform coefficients can take (hereinafter referred to as the number of levels) are controlled based on the quantization step. That is, when the quantization step is large, the number of levels decreases, and thereby the number of 0's increases and significant coefficients other than 0 decrease. Consequently, the encoded data amount after the variable length encoding also decreases. - Moreover, when the quantization step is small, the number of 0's decreases and the significant coefficients therefore increase. Consequently, the encoded data amount after the variable length encoding also increases.
- Because the encoded data amount can be controlled by adjusting the quantization step in this manner, the data rate of the encoded data output from the variable
length encoding unit 105 can be controlled. The transform coefficients quantized by thequantization unit 104 are output to the variablelength encoding unit 105 and to themotion compensation unit 102. - The variable
length encoding unit 105 performs the variable length encoding of the transform coefficient quantized by thequantization unit 104, and outputs the encoded transform coefficient (hereinafter referred to as encoded data) to therecording unit 106. Therecording unit 106 has a not shown buffer memory, and stores the encoded data once in the buffer memory. After that, therecording unit 106 reads the encoded data at suitable timing to record the encoded data onto a recording medium M. - An
operation unit 113 includes a recording switch, a stop switch and the like, and a user can operates the recording switch to instruct a start of recording. Moreover, the user can operate the stop switch to instruct a stop of recording. - When recording is started, the
activity control unit 112 calculates the remaining recording capacity w of the recording medium M, and the total recording time t of the image data recorded on the recording medium M. Then, theactivity control unit 112 generates a flag for adjusting the activity detected by theactivity calculation unit 108 using the remaining recording capacity w and a plurality of threshold values set beforehand. - In the present embodiment, threshold values Th1 and Th2 (provided Th1>Th2) are obtained as follows.
-
Th1=WTh1×t, Th2−WTh2×t - Here, WTh1 and WTh2 denote previously-set reference values, and WTh1>WTh2. Consequently, Th1>Th2.
- Then, the remaining recording capacity w is compared with these threshold values Th1 and Th2, and it is detected which state of the following three states is satisfied. And two flags,
flag 1 andflag 2, are set according to each state. -
w<Th2 (i) -
Th2<w<Th1 (ii) -
Th1<w (iii) - In case of the state (i) as a comparison result, the
activity control unit 112 judges that the remaining recording capacity runs short, and sets theflag 2 to on to output theflag 2 to theactivity calculation unit 108. Moreover, when the condition (i) is not satisfied, theflag 2 is made to be off. - Moreover, in case of (ii), it is judged that the remaining recording capacity has run short, and then a
flag 1 is turned on and is output to theactivity calculation unit 108. Moreover, when the condition is not satisfied, theflag 1 is made to be off. - In case of (iii), it is judged that the remaining recording capacity of the recording medium M has a sufficient surplus, and nothing is performed to the
activity calculation unit 108. Although the number of threshold values is set as two in the present embodiment, the judgment of the remaining recording capacity of the recording medium can be also changed stepwise by increasing the number of the threshold values. - The
activity calculation unit 108 obtains an activity from each macro block unit. The activity at a jth macro block actj is obtained in accordance with the following formula. -
act j=1+min(var i,j) (1) - Here, vari,j is a dispersion value of the pixel values in an ith sub-block when the jth macro block is divided into four blocks. In the present embodiment, a macro block is composed of 16 pixels×16 pixels, and a sub-block is composed of 8 pixels×8 pixels. The number of pixels of each sub-block is 64, and the dispersion value is obtained every 64 pixels.
- In addition, in the
activity calculation unit 108, the activity may be calculated using the dynamic range of pixel values instead of the dispersion value of pixel values. Theactivity calculation unit 108 transforms the activity obtained in this manner to the normalized activity Nactj as the following formula using an average value of quantization steps obtained by the averagevalue calculation unit 107. -
Nact j=(m×act j+avg)/(act j +m×avg) (2) - Here, avg denotes the average value of the quantization steps obtained by the average
value calculation unit 107, and m denotes an arbitrary natural number. It is provided that a given initial value is set as the average value avg at an early stage of encoding. - For example, when a flat part is included in a macro block, the activity of the macro block becomes small. When an edge is included in the flat part, the activity becomes large. Moreover, when an activity is output to the
multiplication unit 109, the activity is normalized based on the average value of the quantization steps of the preceding frame output from the averagevalue calculation unit 107, and the normalized activity is output. Then, themultiplication unit 109 corrects the reference quantization step obtained by the reference quantizationstep determination unit 110 based on the normalized activity to determine the quantization step. - Moreover, in the present embodiment, the calculation result of an activity is changed based on the state of the activity control flag output from the
activity control unit 112. - The
activity calculation unit 108 transforms Nactj into Nact′j in accordance with the states of theactivity flag 1 and theactivity flag 2 like the following formula, and outputs the transformed Nact′j to themultiplication unit 109. - When the
flag 1 is on, -
Nact′ j =Nact j +dec (at Nact j +dec<1.0) -
Nact′ j=1.0 (at Nactj+dec≧1.0 and Nact j<1.0). - When the
flag 2 is on, -
Nact′ j=1.0 (provided at Nact j<1.0). - Here, dec denotes a constant of 0.1≦dec≦1.0.
- First, when the
flag 2 is on, it is judged that the remaining recording capacity of the recording medium M is left very little. Accordingly, in order to remove the influences of the activity to data rate control, when Nactj is smaller than 1.0, Nactj is set to 1.0, and it is output to themultiplication unit 109. However, when Nactj is 1.0 or more, it is output as it is. Alternatively, the value 1.0 may be set to be always output without performing the calculation of Nactj. - On the other hand, when the
flag 1 is on, it is judged that the remaining recording capacity of the recording medium M has run short. Accordingly, in order to make the influence by the activity to data rate control small, when the normalized activity Nactj is smaller than 1.0, Nact′j, to which the correction value dec is added, is output to themultiplication unit 109. In addition, although the threshold values for distinguishing the remaining recording capacity of the recording medium M are set as two values in the present embodiment, the judgment of the remaining recording capacity can be also changed stepwise by increasing the number of the threshold values. At that time, the dec may be stepwise changed according to the remaining recording capacity. - The
multiplication unit 109 multiplies the reference quantization step output from the reference quantizationstep determination unit 110 by the normalized activity Nactj or Nact′j, both output from theactivity calculation unit 108, to adjust the quantization step. And the quantization step is output to thequantization unit 104 while the quantization step is also output to the averagevalue calculation unit 107. - The average
value calculation unit 107 calculates the average value of the quantization steps for one frame, and outputs the quantization step to bit-assignment unit 111 while the averagevalue calculation unit 107 also outputs the quantization step to theactivity calculation unit 108. - The bit-
assignment unit 111 determines the code amount (the number of bits) to be assigned to a frame which is intended to be coded after this, on the basis of the code amount generated up to the preceding frame by the variablelength encoding unit 105 and the target data rate. - The reference quantization
step determination unit 110 determines reference quantization steps qIj, qPj, and qBj to each macro block on the basis of the number of the code amounts generated up to the preceding macro block and the assigned code amount. Here, j indicates a macro block number, and I, P and B indicates the type of a picture. - For example, in case of obtaining qIj, first the buffer fullness dIj in the jth block of an I picture is obtained by the following formula.
-
dI j =dI 0 +B j−1−(Ti(j−1))/MB cnt - And the reference quantization step qIj is obtained by the following formula on the basis of the dIj.
-
qI j=3ldI j /r - Here, dI0 denotes the buffer fullness at an initial stage, which is the last buffer fullness dIMBcnt when the last I picture has been encoded. It is provided that an initial value is an arbitrary constant. Moreover, Bj denotes the total number of the bits in the image generated up to the jth block, MBcnt denotes the total number of the macro blocks in the image, and r denotes a reaction parameter.
- The above formula reflects the difference between the assigned number of bits generated up to the preceding macro block and the number of bits actually generated when Ti bits are uniformly assigned to each macro-bit on virtual buffer fullness.
- Consequently, according to the above formula, when the number of bits generated in the preceding macro block is large, the virtual buffer fullness becomes large, and thereby the reference quantization step becomes large. As a result, the reference quantization
step determination unit 110 works so as to reduce the numbers of the generated bits of the subsequent frames. - On the other hand, when the number of the generated bits of the preceding macro block is small, the virtual buffer fullness becomes small, and thereby the reference quantization step becomes small. As a result, the reference quantization
step determination unit 110 works so as to enlarge the number of the generated bits of the subsequent frames. In addition, the similar method is used also in the P picture and the B picture to determine the reference quantization steps. - Next, the determination processing of a quantization step by the image processing apparatus of the present embodiment is described with reference to the flowchart of
FIG. 2 . - At Step S201, it is judged whether a motion image signal is input or not. As a result of the judgment, when a motion image signal is input, the processing progresses to Step S202, and the remaining recording capacity of the recording medium M is detected. Next, at Step S203, the
activity calculation unit 108 detects the activity Nact of each macro block of the input motion image signal. - Next, the processing progresses to Step S204, and the
activity control unit 112 sets theactivity control flags step determination unit 110 determines reference quantization step. Next, the processing progresses to Step S206, and theactivity calculation unit 108 changes the activity Nact on the basis of the states of theflags multiplication unit 109. And at Step S207, themultiplication unit 109 multiplies the reference quantization step from the reference quantizationstep determination unit 110 by the activity from theactivity calculation unit 108 to adjust the value of the multiplied reference quantization step, and themultiplication unit 109 sends the adjusted reference quantization step to thequantization unit 104. - After that, at Step S208, it is judged whether the input of the motion image data stops and all processing has been completed or not. When a motion image signal is successively input, the processing returns to Step S202.
- As described above, according to the present embodiment, when the remaining recording capacity of a recording medium is little, a quantization step is determined without using activity. Consequently, when the remaining recording capacity is little left, the influence of the activity given to data rate control as a disturbance can be removed.
- Consequently, it becomes possible to surely perform the code amount control on the basis of a generated code amount, and to certify the recording time obtained in the recording medium.
- Next a second embodiment is described. However, although the image encoding apparatus according to the second embodiment has the construction similar to one shown in
FIG. 1 , the image encoding apparatus of the second embodiment is made to allow a user to arbitrarily set a target data rate (image quality) of a motion image signal with theoperation unit 113. - That is, the present embodiment is configured to be equipped with three image quality modes of a high image quality mode, a standard mode and a long time mode. The user can arbitrarily select any one of these three image quality modes. And the target data rate of the high image quality mode is the highest, and the target data rates of the standard mode and the long time mode become lower in this order after that.
- When recording is started, the
activity control unit 112 calculates the remaining recording capacity w of the recording medium M, and the recording time up to now. Then, theactivity control unit 112 generates a flag for adjusting the activity detected by theactivity calculation unit 108 on the basis of the remaining recording capacity w and the information mode of the image quality mode set by theoperation unit 113. - In the present embodiment, the case where there are the following three kinds of modes as recording modes mode is described:
-
- high image quality mode: mode=high
- standard mode: mode=mid
- long time mode: mode=low
- First, predetermined reference values whigh, wmid and wlow in each mode are set so that they satisfy whigh>wmid>wlow, and threshold values are set to be Thhigh=whigh×t, Thmid=wmid×t, and Thlow=wlow×t.
- As described above, the average data rates (target data rates) changes according to the record modes mode.
- For example, at the time of mode=high, compared with mode=mid and mode=low, the average bit rate becomes larger, and the capacity of a recording medium more rapidly becomes less. Accordingly, the value of a threshold value is changed according to a mode.
- After setting the threshold values to be references in accordance with the recording modes, the processing similar to that in the first embodiment is executed. When it is supposed that two threshold values are set to each mode as the first embodiment, the remaining recording capacity is compared with the threshold values in each mode to discriminate which state of the followings is satisfied, in the present embodiment.
- When mode=high
-
w<Thhigh2 (i) -
Th high2<w<Thhigh1 (ii) -
Th high1<w (iii) - When mode=mid
-
w<Thmid2 (i) -
Th mid2<w<Thmid1 (ii) -
Th mid1<w (iii) - When mode=low
-
wlow<Th2 (i) -
Th low2<w<Thlow1 (ii) -
Th low1<w (iii) - (Provided that
Th low 1<Th mid 1<Th high 1,Th low 2<Th mid 2, Thhigh 2) - And the states of the two
control flags - The
activity calculation unit 108 changes the activity similarly in the first embodiment on the basis of the state of theflags multiplication unit 109. - Moreover, the reference quantization
step determination unit 110 calculates the reference quantization step according to the assigned number of bits from the bit-assignment unit 111, and sends the calculated reference quantization step to themultiplication unit 109. At this time, in the present embodiment, the bit-assignment unit 111 changes the assigned number of bits on the basis of the image quality mode set by theoperation unit 113, i.e. the target data rate. - As described above, because the target data rate becomes high in the high image quality mode compared with that in the standard image quality mode, the assigned number of bits also becomes larger than that in the standard mode.
- After that, like the first embodiment, the
multiplication unit 109 multiplies the quantization step from the reference quantizationstep determination unit 110 by the activity from theactivity calculation unit 108, and sends the multiplied quantization step to thequantization unit 104. - As described above, according to the present embodiment, when the remaining recording capacity of a recording medium is little, the quantization step is determined without using the activity. Consequently, when the remaining recording capacity runs short, the influence of the activity given to data rate control as a disturbance can be removed.
- Moreover, because the threshold. value for distinguishing the state of the remaining recording capacity is changed according to the image quality mode, it becomes possible to change the control state of the quantization step using the activity to the optimal state according to the image quality mode.
- In addition, although three image quality modes are set in the present embodiment, the number of the modes may be increased to more stepwise perform the activity control according to the image quality. Moreover, the number of the modes may be reduced conversely to decrease the number of steps of the activity control according to the image quality.
- Next a third embodiment is described.
- In the above first and the second embodiments, when there was little remaining recording capacity of a recording medium, the quantization step is determined without using the activity.
- In the present embodiment, according to the image quality mode (target data rate), it is controlled whether the quantization step is determined using the activity or not.
-
FIG. 3 is a diagram showing the configuration of a recording apparatus 300 according to the present embodiment. - As shown in
FIG. 3 , the recording apparatus 300 is composed of a block-division unit 301, amotion compensation unit 302, anorthogonal transform unit 303, aquantization unit 304, a variablelength encoding unit 305, arecording unit 306, acomplexity calculation unit 307, aswitch 308, a quantizationstep setting unit 309, a generatedcode calculation unit 310 and anoperation unit 312. - The block-
division unit 301 divides each frame of input motion image data into macro blocks, each composed of 16 pixels in horizontal direction×16 pixels in vertical direction. And the block-division unit 301 outputs the image data of the macro blocks to themotion compensation unit 302 while the block-division unit 301 also outputs the image data to thecomplexity calculation unit 307. - When an encoding object frame is an intra-frame encoding frame, the
motion compensation unit 302 outputs input MB data to theorthogonal transform unit 303 as it is. Moreover, when the encoding object frame is an inter-frame encoding frame, themotion compensation unit 302 performs a well-known procedure to obtain prediction error data between the MB data of the present frame, which has been input from the block-division unit 301, and the image data of a reference frame to output the obtained prediction error data to theorthogonal transform unit 303. - The
orthogonal transform unit 303 performs the DCT processing of the MB data or the prediction error data from themotion compensation unit 302 to convert the data into transform coefficients, and outputs the transform coefficients to thequantization unit 304. - The
quantization unit 304 quantizes the input transform coefficients based on the quantization step obtained from the quantizationstep setting unit 309. Because the encoded data amount can be controlled by adjusting the quantization step, it is possible to control the data rate of the encoded data output from the variablelength encoding unit 305. The transform coefficients quantized by thequantization unit 304 are output to the variablelength encoding unit 305 while the transform coefficients are also output to themotion compensation unit 302. - The variable
length encoding unit 305 performs the variable length encoding of the transform coefficient quantized by thequantization unit 304, and outputs the encoded transform coefficient to therecording unit 306. Therecording unit 306 has a not shown buffer memory, and once stores the encoded data in the buffer memory. After that, therecording unit 306 reads the encoded data at an appropriate timing to record the encoded data onto a recording medium M. - The
complexity calculation unit 307 calculates the complexity (activity) of each macro block as will be described later, and outputs the calculated complexity to theswitch 308. Theswitch 308 sends the complexity information from thecomplexity calculation unit 307 to the quantizationstep setting unit 309 in accordance with the image quality mode selected with theoperation unit 312. The quantizationstep setting unit 309 sets the quantization step to each macro block on the basis of the image quality mode set with theoperation unit 312, the generated code amount from the generated codeamount calculation unit 310, and the complexity information supplied through theswitch 308. - The
operation unit 312 includes a recording switch, a stop switch, a setting switch of an image quality mode, and the like. A user can operate the recording switch to instruct a start of recording. Moreover, the user can operate the stop switch to instruct a stop of recording. In the present embodiment, there are two modes of a standard mode and a high image quality mode as image quality modes. Then, in the high image quality mode, the target data rate is set to be higher than that in the standard mode. - In the following, the setting processing of a quantization step in the present embodiment is described with reference to the flowchart of
FIG. 4 . - The flow of
FIG. 4 is executed every frame. - When recording is started, first, the complexity of each macro block of the present frame in input motion image data is calculated by the complexity calculation unit 307 (Step S401).
- The complexity of each block is calculated in accordance with the above formula (1). Moreover, the dispersion value vari,j of a sub-block is calculated in accordance with the following formula.
-
var i,j=Σ(Pk−P)2/64 - Moreover, normalized complexity information is calculated based on the calculated complexity by the complexity calculation unit 307 (Step S402). The normalized complexity is calculated in accordance with the above formula (2).
- Moreover, a
control unit 311 detects the present target data rate based on the image quality mode set by the operation unit 312 (Step S403). Next, thecontrol unit 311 distinguishes whether the present target data rate is larger than a threshold value R1 or not (Step S404). - When the target data rate is larger than the threshold value R1, the
control unit 311 turns on the switch 308 (Step S405). And thecontrol unit 311 controls the quantizationstep setting unit 309 to set a quantization step on the basis of the information of the generated code amount detected by the generated codeamount calculation unit 310 and the target data rate (Step S406). And thecontrol unit 311 adjusts the set quantization step on the basis of the normalized complexity information obtained by the complexity calculation unit 307 (Step S407). To put it concretely, thecontrol unit 311 adjusts the quantization step by multiplying the set quantization step by the normalized complexity information. And thecontrol unit 311 outputs the adjusted quantization step to the quantization unit 304 (Step S408). - On the other hand, when the target data rate is equal to or less than the threshold value R1 at Step S404, the
control unit 311 turns off the switch 308 (Step S410). And thecontrol unit 311 controls the quantizationstep setting unit 309 to set the quantization step on the basis of the information of the generated code amount detected by the generated codeamount calculation unit 310 and the target data rate so that the encoded data rate may become equal to the target data rate (Step S411). And thecontrol unit 311 outputs the quantization step to the quantization unit 304 (Step S412). - Then, when an instruction of recording stop is issued, the
control unit 311 completes the processing (Step S409). - Thus, in the present embodiment, because, when the target data rate is higher than the threshold value, the quantization step is adjusted according to the complexity of an image to perform quantization, the image can be quantized using a visual characteristic.
- Moreover, because, when the target data rate is lower than the threshold value, a quantization step is set without using the complexity information to perform the quantization, the deterioration of image quality such as the generation of block noises caused by the use of the complexity information can be prevented.
- Next a fourth embodiment is described.
-
FIG. 5 is a diagram showing the configuration of a recording apparatus according to the fourth embodiment. The components similar to those ofFIG. 3 are denoted by the same reference numerals as those inFIG. 3 . - The apparatus shown in
FIG. 5 encodes image data by a variable bit rate (VBR) system. Here, the variable bit rate system indicates a method of dynamically changing the code amount to be assigned to each scene in accordance with the complexity of the pattern of an image to be encoded. - To put it concretely, the method assigns more amounts of codes to a scene of a complicated pattern, and assigns fewer amounts of codes to an image of a relatively flat pattern. The present embodiment uses a well-known technique as the concrete variable bit rate system, and compares the code amount of the encoded image data generated just before with a predetermined value to perform encoding without using the complexity information when the code amount becomes lower than the predetermined value.
- Next, the setting processing of a quantization step in the present embodiment is described with reference to the flowchart of
FIG. 6 . In addition, the processing similar to that in the flow ofFIG. 4 is denoted by the same reference numeral as the one inFIG. 4 inFIG. 6 . Moreover, the flow ofFIG. 6 is executed every frame. - When recording is started, the complexity of each macro block of one frame is calculated (Step S401). Next, normalized complexity is calculated (Step S402). In the present embodiment, the normalized complexity defined as the formula (2) is obtained based on the average of the complexity of each macro block and the complexity in the picture encoded just before.
- Next, a target data rate is detected (Step S403), and the information of a generated code amount per unit time is detected by the generated code amount calculation unit 310 (Step S601). In the present embodiment, for example, the generated code amount per group of picture (GOP) is detected. Then, a quantization step is set based on the code amount per GOP. The GOP is a unit composed of the number of frames processed within a range of from an I picture to the next I picture, and is a basic unit of encoding in the MPEG system.
- Next, the generated code amount per unit time is compared with a predetermined threshold value N2 to discriminate whether the generated code amount is larger than N2 or not (Step S602). Because the data rate is encoded while being dynamically changed in the VBR system, the generated code amount per GOP also significantly changes. At Step S602, it is possible to know whether the code amount generated per GOP is smaller than the predetermined code amount N2 or not in this manner.
- When the generated code amount is larger than N2, the
control unit 311 turns on the switch 308 (Step S405). Then thecontrol unit 311 controls the quantizationstep setting unit 309 to set a quantization step on the basis of the information of the generated code amount detected by the generated codeamount calculation unit 310 and the target data rate (Step S406). And thecontrol unit 311 adjusts the set quantization step on the basis of the normalized complexity information obtained by the complexity calculation unit 307 (Step S407). To put it concretely, thecontrol unit 311 adjusts the quantization step by multiplying the set quantization step by the normalized complexity information. And thecontrol unit 311 outputs the adjusted quantization step to the quantization unit 304 (Step S408). - On the other hand, when the target data rate is equal to or less than the threshold value R1 at Step S404, the
control unit 311 turns off the switch 308 (Step S410). And thecontrol unit 311 controls the quantizationstep setting unit 309 to set the quantization step on the basis of the information of the generated code amount detected by the generated codeamount calculation unit 310 and the target data rate (Step S411). And thecontrol unit 311 outputs the quantization step to the quantization unit 304 (Step S412). - Then, when an instruction of recording stop is issued, the
control unit 311 completes the processing (Step S409). - Thus, in the present embodiment, because, when the generated code amount per unit time is higher than the threshold value, the quantization step is adjusted according to the complexity of an image to perform quantization, the image can be quantized using a visual characteristic.
- Moreover, because, when the generated code amount per unit time is lower than the threshold value, a quantization step is set without using the complexity information to perform the quantization, the deterioration of image quality such as the generation of block noises caused by the use of the complexity information can be prevented. Other Embodiments according to the Present Invention
- Each means and each step of the image processing methods which constitute the embodiments of the present invention can be realized by the operation of programs stored in a RAM, a ROM or the like of a computer. The programs and a recording medium which records the programs and can be read by a computer are included in the present invention.
- Moreover, the present invention can be realized as the embodiments of a system, an apparatus, a method, a program, a storage medium and the like. To put it concretely, the present invention may be applied to a system composed of a plurality of pieces of equipment, or may be applied to an apparatus composed of one piece of equipment.
- In addition, the present invention includes a case where a program of software realizing the functions of the embodiments described above (the programs corresponding to the flowcharts shown in
FIGS. 2 and 4 in the embodiments) is directly or remotely supplied to a system or an apparatus and the functions are attained by the computer of the system or the apparatus which reads the supplied program to execute it. - Consequently, the program codes themselves which are installed in a computer in order to realize the functional processing of the present invention are also ones realizing the present invention. That is, the present invention includes the computer program itself for realizing the functional processing of the present invention.
- In this case, as long as it has the function of a program, the program may be in a form of object codes, a program executed by an interpreter, script data supplied to an OS or the like.
- As a recording medium for supplying a program, there are, for example, a floppy disk (registered trademark), a hard disk, an optical disc, a magneto-optical disc, an MO, a CD-ROM, a CD-R, a CD-RW, a magnetic tape, a nonvolatile memory card, a ROM, a DVD (DVD-ROM, DVD-R) and the like.
- In addition, as a program supplying method, a program can be also supplied by connecting with a homepage in the Internet using the browser of a client computer to download the computer program itself of the present invention or a compressed file including an automatic installing function to a recording medium such as a hard disk.
- Moreover, the present invention can be also realized by dividing the program codes constituting the program of the present invention into a plurality of files to download the respective files from different home pages. That is, a WWW server which allows a plurality of users to download a program file for realizing the functional processing of the present invention with a computer is also included in the present invention.
- Moreover, the realization of the present invention is also possible by encoding the program of the present invention to store the encoded program into a storage medium such as a CD-ROM and the like for distributing the program widely among users, and by allowing a user who clears a predetermined condition to download key information for deciphering the code from a home page through the Internet to use the key information for executing the encoded program to install the encoded program into a computer.
- Moreover, in addition to the realization of the embodiments described above by executing a read program with a computer, the functions of the embodiments described above can be also realized by the execution of a part of or the whole actual processing by an OS operating on the computer based on the instructions of the program.
- Moreover, the functions of the embodiments described above can be also realized by writing the program read from a recording medium into a feature expansion board inserted into a computer or a memory installed on a feature expansion unit connected to a computer before the execution of a part of or the whole actual processing by a CPU or the like provided on the feature expansion board or the feature expansion unit based on the instructions of the program.
- This application claims priority from Japanese Patent Application Nos. 2005-144554 filed May 17, 2005 and 2005-144555 filed May 17, 2005, which are hereby incorporated by reference herein.
Claims (12)
1-5. (canceled)
6. An image processing apparatus comprising at least a computer processor and memory, said computer processor and memory configured to function as:
an encoding unit that encodes an input motion image signal to generate encoded motion image data;
a recording unit that records the encoded motion image data on a recording medium;
a complexity detection unit that detects complexity of a motion image according to the input motion image data;
a rate setting unit that arbitrarily sets a target data rate of the encoded motion image data output from said encoding unit; and
a control unit that controls said encoding unit so that a data rate of the encoded motion image data comes to be the target data rate set by said rate setting unit,
wherein said control unit has a first mode of controlling said encoding unit on the basis of information of the complexity detected by said complexity detection unit so as to adjust the data rate of the encoded motion image data output from said encoding unit, and a second mode of controlling said encoding unit without using the information of the complexity detected by said complexity detection unit so as to adjust the data rate of the encoded motion image data output from said encoding unit, and switches over the first mode and the second mode according to the target data rate set by said rate setting unit.
7. An apparatus according to claim 6 ,
wherein said rate setting unit is capable of setting the target data rate between a first data rate and a second data rate, which is lower than the first data rate, and
wherein said control unit selects the first mode when the first data rate is set, and selects the second mode when the second data rate is set.
8. An apparatus according to claim 6 , wherein
said control unit selects the first mode when the target data rate is larger than a predetermined rate, and selects the second mode when the target data rate is equal to or less than the predetermined rate.
9. An apparatus according to claim 6 ,
wherein said encoding unit includes a quantization unit quantizing the motion image data by using a set quantization step, and a variable length encoding unit performing variable length encoding of data output from said quantization unit; and
wherein said control unit includes a quantization step setting unit setting the quantization step on the basis of the code amount of the encoded image data output from said variable length encoding unit, and an adjustment unit adjusting the quantization step set by said quantization step setting unit on the basis of the information of the complexity, and said control unit outputs the quantization step adjusted by said adjustment unit to said quantization unit in the first mode, and outputs the quantization step set by said quantization step setting unit to said quantization unit in the second mode.
10. An image processing apparatus comprising at least a computer processor and memory, said computer processor and memory configured to function as:
an encoding unit that encodes an input motion image signal to generate encoded motion image data;
a unit that records the encoded motion image data on a recording medium;
a complexity detection unit that detects complexity of a motion image according to the input motion image data;
a code amount detection unit that detects a code amount of the encoded motion image data output from said encoding unit per unit time; and
a control unit that controls said encoding unit to adjust a data rate of the encoded motion image data,
wherein said control unit has a first mode of controlling said encoding unit on the basis of information of the complexity detected by said complexity detection unit so as to adjust the data rate of the encoded motion image data output from said encoding unit, and a second mode of controlling said encoding unit without using the information of the complexity detected by said complexity detection unit so as to adjust the data rate of the encoded motion image data output from said encoding unit, and switches over the first mode and the second mode according to the code amount detected by said code amount detection unit.
11. An apparatus according to claim 10 , wherein
said control unit adjusts the data rate of the encoded motion image data on the basis of the code amount per unit time, detected by said code amount detection unit.
12. An apparatus according to claim 10 , wherein
said control unit selects the first mode when the detected code amount is larger than a predetermined threshold value, and selects the second mode when the detected code amount is equal to or less than the predetermined threshold value.
13. An apparatus according to claim 10 ,
wherein said encoding unit includes a quantization unit quantizing the motion image data by using a set quantization step, and a variable length encoding unit performing variable length encoding of data output from said quantization unit; and
wherein said control unit includes a quantization step setting unit setting the quantization step on the basis of the code amount of the encoded image data output from said variable length encoding unit, and an adjustment unit adjusting the quantization step set by said quantization step setting unit on the basis of the information of the complexity, and said control unit outputs the quantization step adjusted by said adjustment unit to said quantization unit in the first mode, and outputs the quantization step set by said quantization step setting unit to said quantization unit in the second mode.
14. (canceled)
15. An image processing method comprising:
an encoding step of encoding an input motion image signal to generate encoded motion image data;
a recording step of recording the encoded motion image data on a recording medium;
a complexity detection step of detecting complexity of a motion image according to the input motion image data;
a rate setting step of arbitrarily setting a target data rate of the encoded motion image data output at said encoding step; and
a control step of controlling said encoding step so that a data rate of the encoded motion image data comes to be the target data rate set at said rate setting step,
wherein said control step has a first mode of controlling said encoding step on the basis of information of the complexity detected at said complexity detection step so as to adjust the data rate of the encoded motion image data output at said encoding step, and a second mode of controlling said encoding step without using the information of the complexity detected at said complexity detection step so as to adjust the data rate of the encoded motion image data output at said encoding step, and switches over the first mode and the second mode according to the target data rate set at said rate setting step.
16. An image processing method comprising:
an encoding step of encoding an input motion image signal to generate encoded motion image data;
a recording step of recording the encoded motion image data on a recording medium;
a complexity detection step of detecting complexity of a motion image according to the input motion image data;
a code amount detection step of detecting a code amount of the encoded motion image data output at said encoding step per unit time; and
a control step of controlling said encoding step to adjust a data rate of the encoded motion image data,
wherein said control step has a first mode of controlling said encoding step on the basis of information of the complexity detected at said complexity detection step so as to adjust the data rate of the encoded motion image data output at said encoding step, and a second mode of controlling said encoding step without using the information of the complexity detected at said complexity detection step so as to adjust the data rate of the encoded motion image data output at said encoding step, and includes a step of switching over the first mode and the second mode according to the code amount detected at said code amount detection step.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/733,216 US20130177074A1 (en) | 2005-05-17 | 2013-01-03 | Image Processing Apparatus |
Applications Claiming Priority (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2005144554A JP4510696B2 (en) | 2005-05-17 | 2005-05-17 | Image processing apparatus and image processing method |
JP2005144555A JP4590306B2 (en) | 2005-05-17 | 2005-05-17 | Image processing device |
JP2005-144555 | 2005-05-17 | ||
JP2005-144554 | 2005-05-17 | ||
US11/409,313 US8363717B2 (en) | 2005-05-17 | 2006-04-24 | Image processing apparatus |
US13/733,216 US20130177074A1 (en) | 2005-05-17 | 2013-01-03 | Image Processing Apparatus |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/409,313 Division US8363717B2 (en) | 2005-05-17 | 2006-04-24 | Image processing apparatus |
Publications (1)
Publication Number | Publication Date |
---|---|
US20130177074A1 true US20130177074A1 (en) | 2013-07-11 |
Family
ID=36590216
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/409,313 Expired - Fee Related US8363717B2 (en) | 2005-05-17 | 2006-04-24 | Image processing apparatus |
US13/733,216 Abandoned US20130177074A1 (en) | 2005-05-17 | 2013-01-03 | Image Processing Apparatus |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/409,313 Expired - Fee Related US8363717B2 (en) | 2005-05-17 | 2006-04-24 | Image processing apparatus |
Country Status (2)
Country | Link |
---|---|
US (2) | US8363717B2 (en) |
EP (1) | EP1725039A1 (en) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150237375A1 (en) * | 2014-02-19 | 2015-08-20 | Megachips Corporation | Moving image coding apparatus, moving image coding method, storage medium, and integrated circuit |
US10003821B2 (en) | 2015-10-27 | 2018-06-19 | Canon Kabushiki Kaisha | Image encoding apparatus and method of controlling same |
US10097840B2 (en) | 2015-10-27 | 2018-10-09 | Canon Kabushiki Kaisha | Image encoding apparatus, control method thereof, and storage medium |
US10277902B2 (en) | 2016-08-22 | 2019-04-30 | Canon Kabushiki Kaisha | Image encoding apparatus and control method thereof |
US10356408B2 (en) | 2015-11-27 | 2019-07-16 | Canon Kabushiki Kaisha | Image encoding apparatus and method of controlling the same |
US10638162B2 (en) | 2015-10-23 | 2020-04-28 | Canon Kabushiki Kaisha | Coding method and decoding processing method |
US11140392B2 (en) | 2018-06-15 | 2021-10-05 | Canon Kabushiki Kaisha | Image encoding apparatus, image decoding apparatus, control methods thereof, and non- transitory computer-readable storage medium |
US11785352B2 (en) | 2021-02-10 | 2023-10-10 | Canon Kabushiki Kaisha | Image encoding apparatus, method for controlling the same, and non-transitory computer-readable storage medium |
Families Citing this family (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080152009A1 (en) * | 2006-12-21 | 2008-06-26 | Emrah Akyol | Scaling the complexity of video encoding |
EP2290984A4 (en) * | 2008-05-16 | 2011-08-10 | Sharp Kk | Video recording apparatus |
JP5618128B2 (en) * | 2010-02-22 | 2014-11-05 | ソニー株式会社 | Encoding apparatus, encoding method, and program |
JP5947641B2 (en) * | 2012-07-06 | 2016-07-06 | キヤノン株式会社 | Moving picture coding apparatus, control method therefor, and computer program |
US9460119B2 (en) * | 2012-10-25 | 2016-10-04 | Nec Corporation | Information processing device, information processing method, and recording medium |
US10009626B2 (en) * | 2014-01-29 | 2018-06-26 | Ecole De Technologie Superieure | Method and system for rate-constrained search ordering |
US9979970B2 (en) * | 2014-08-08 | 2018-05-22 | Qualcomm Incorporated | System and method for determining buffer fullness for display stream compression |
WO2016119046A1 (en) | 2015-01-29 | 2016-08-04 | Ecole De Technologie Superieure | Methods and systems for determining motion vectors in a motion estimation process of a video encoder |
US10356428B2 (en) | 2015-04-13 | 2019-07-16 | Qualcomm Incorporated | Quantization parameter (QP) update classification for display stream compression (DSC) |
US10284849B2 (en) | 2015-04-13 | 2019-05-07 | Qualcomm Incorporated | Quantization parameter (QP) calculation for display stream compression (DSC) based on complexity measure |
US10244255B2 (en) | 2015-04-13 | 2019-03-26 | Qualcomm Incorporated | Rate-constrained fallback mode for display stream compression |
US9936203B2 (en) * | 2015-04-13 | 2018-04-03 | Qualcomm Incorporated | Complex region detection for display stream compression |
JP6906324B2 (en) * | 2017-02-20 | 2021-07-21 | キヤノン株式会社 | Coding device, coding method, and program |
JP7016660B2 (en) * | 2017-10-05 | 2022-02-07 | キヤノン株式会社 | Coding device, its control method, and control program, and image pickup device. |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6493385B1 (en) * | 1997-10-23 | 2002-12-10 | Mitsubishi Denki Kabushiki Kaisha | Image encoding method, image encoder, image decoding method, and image decoder |
Family Cites Families (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH07184195A (en) | 1993-12-22 | 1995-07-21 | Sharp Corp | Picture coder |
US5650860A (en) * | 1995-12-26 | 1997-07-22 | C-Cube Microsystems, Inc. | Adaptive quantization |
KR100450155B1 (en) | 1996-03-02 | 2004-12-14 | 도이체 톰손-브란트 게엠베하 | Method and apparatus for encoding or decoding digital video data |
US5812790A (en) * | 1996-09-09 | 1998-09-22 | Sonic Solutions | Variable encoding rate plan generation |
EP1051853B1 (en) * | 1998-01-26 | 2003-06-18 | STMicroelectronics Asia Pacific Pte Ltd. | One-pass variable bit rate moving pictures encoding |
JP3097665B2 (en) | 1998-06-19 | 2000-10-10 | 日本電気株式会社 | Time-lapse recorder with anomaly detection function |
US6532262B1 (en) | 1998-07-22 | 2003-03-11 | Matsushita Electric Industrial Co., Ltd. | Coding method and apparatus and recorder |
US6600793B1 (en) * | 1998-09-30 | 2003-07-29 | Agere Systems Inc. | Minimal overhead early late timing recovery |
US6963608B1 (en) * | 1998-10-02 | 2005-11-08 | General Instrument Corporation | Method and apparatus for providing rate control in a video encoder |
JP4362793B2 (en) | 1999-07-05 | 2009-11-11 | 日本ビクター株式会社 | Video encoding apparatus and method |
EP1063851B1 (en) | 1999-06-22 | 2007-08-01 | Victor Company Of Japan, Ltd. | Apparatus and method of encoding moving picture signal |
US6535251B1 (en) * | 1999-10-26 | 2003-03-18 | Sharplabs Of America, Inc. | Video encoder and method for adjusting quantization step in real time |
US6904094B1 (en) * | 2000-09-20 | 2005-06-07 | General Instrument Corporation | Processing mode selection for channels in a video multi-processor system |
EP1329109A2 (en) * | 2000-10-10 | 2003-07-23 | Koninklijke Philips Electronics N.V. | Video bitrate control method and device for digital video recording |
WO2002058401A1 (en) * | 2001-01-22 | 2002-07-25 | Stmicroelectronics Asia Pacific Pte Ltd | Method and apparatus for video buffer verifier underflow and overflow control |
JP2003037843A (en) | 2001-07-23 | 2003-02-07 | Sony Corp | Picture processor, method therefor, recording medium and program thereof |
JP2003037844A (en) | 2001-07-23 | 2003-02-07 | Sharp Corp | Moving picture coding apparatus |
JP4186543B2 (en) | 2002-08-01 | 2008-11-26 | ソニー株式会社 | Encoding apparatus, encoding method, program, and recording medium |
US7675970B2 (en) * | 2004-01-12 | 2010-03-09 | General Instrument Corporation | Method and apparatus for processing a bitstream in a digital video transcoder |
US7697608B2 (en) * | 2004-02-03 | 2010-04-13 | Sony Corporation | Scalable MPEG video/macro block rate control |
JP4514203B2 (en) | 2004-06-11 | 2010-07-28 | キヤノン株式会社 | Motion vector detection apparatus and method |
-
2006
- 2006-04-24 US US11/409,313 patent/US8363717B2/en not_active Expired - Fee Related
- 2006-04-26 EP EP06113162A patent/EP1725039A1/en not_active Withdrawn
-
2013
- 2013-01-03 US US13/733,216 patent/US20130177074A1/en not_active Abandoned
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6493385B1 (en) * | 1997-10-23 | 2002-12-10 | Mitsubishi Denki Kabushiki Kaisha | Image encoding method, image encoder, image decoding method, and image decoder |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150237375A1 (en) * | 2014-02-19 | 2015-08-20 | Megachips Corporation | Moving image coding apparatus, moving image coding method, storage medium, and integrated circuit |
US10057576B2 (en) * | 2014-02-19 | 2018-08-21 | Megachips Corporation | Moving image coding apparatus, moving image coding method, storage medium, and integrated circuit |
US10638162B2 (en) | 2015-10-23 | 2020-04-28 | Canon Kabushiki Kaisha | Coding method and decoding processing method |
US10003821B2 (en) | 2015-10-27 | 2018-06-19 | Canon Kabushiki Kaisha | Image encoding apparatus and method of controlling same |
US10097840B2 (en) | 2015-10-27 | 2018-10-09 | Canon Kabushiki Kaisha | Image encoding apparatus, control method thereof, and storage medium |
US10356408B2 (en) | 2015-11-27 | 2019-07-16 | Canon Kabushiki Kaisha | Image encoding apparatus and method of controlling the same |
US10277902B2 (en) | 2016-08-22 | 2019-04-30 | Canon Kabushiki Kaisha | Image encoding apparatus and control method thereof |
US11140392B2 (en) | 2018-06-15 | 2021-10-05 | Canon Kabushiki Kaisha | Image encoding apparatus, image decoding apparatus, control methods thereof, and non- transitory computer-readable storage medium |
US11785352B2 (en) | 2021-02-10 | 2023-10-10 | Canon Kabushiki Kaisha | Image encoding apparatus, method for controlling the same, and non-transitory computer-readable storage medium |
Also Published As
Publication number | Publication date |
---|---|
US20060262848A1 (en) | 2006-11-23 |
EP1725039A1 (en) | 2006-11-22 |
US8363717B2 (en) | 2013-01-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8363717B2 (en) | Image processing apparatus | |
US7023914B2 (en) | Video encoding apparatus and method | |
EP0660612B1 (en) | Image encoding apparatus | |
US7590296B2 (en) | Image coding apparatus and method in which a loop filter performs a filtering process on each image block of an image | |
US7925108B2 (en) | Encoding device and dynamic image recording system having the encoding device | |
EP1949705B1 (en) | Image signal processing apparatus | |
US8587683B2 (en) | Imaging apparatus having improved usability when moving images and still images are recorded | |
US8090020B2 (en) | Moving picture encoding device, fade scene detection device and storage medium | |
JP4358215B2 (en) | Video encoding apparatus and method | |
JP2008283560A (en) | Information processing apparatus and method thereof | |
US20080187052A1 (en) | Video coding device, video recording device, video coding method, and video coding program | |
JP4795223B2 (en) | Image processing device | |
RU2485711C2 (en) | Method of controlling video bitrate, apparatus for controlling video bitrate, machine-readable recording medium on which video bitrate control program is recorded | |
US8774268B2 (en) | Moving image encoding apparatus and method for controlling the same | |
US8306110B2 (en) | Moving image coding apparatus and method using copy pictures depending on virtual buffer verifier occupancy | |
US20060126735A1 (en) | Image-encoding apparatus, image-encoding method, computer program, and computer-readable medium | |
US8913200B2 (en) | Encoding apparatus, encoding method, and program | |
JP4510696B2 (en) | Image processing apparatus and image processing method | |
JP5355234B2 (en) | Encoding apparatus and encoding method | |
JP4747109B2 (en) | Calculation amount adjustment device | |
US20130201367A1 (en) | Image encoding apparatus and its control method | |
JP2004241879A (en) | Apparatus and method for image processing, recording medium, and program | |
EP1189451A1 (en) | Digital video encoder | |
JP2006115483A (en) | Electronic camera and program for image processing | |
JP4850683B2 (en) | Video signal processing apparatus, video signal processing method, program, and storage medium |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |