for( i = 0; i < 3; i++ )
{
int is_chroma = !!i;
- int w = ((init->width + 31) & (~31))>>is_chroma;
- int h = ((init->height+6+ 31) & (~31))>>is_chroma;
+ int w = ((init->width >>is_chroma) + 31) & (~31);
+ int h = ((init->height>>is_chroma)+6+ 31) & (~31);
pv->ref_stride[i] = w;
for( i = 0; i < 3; i++ )
{
int is_chroma = !!i;
- int w = ((init->width + 31) & (~31))>>is_chroma;
- int h = ((init->height+6+ 31) & (~31))>>is_chroma;
+ int w = ((init->width >>is_chroma) + 31) & (~31);
+ int h = ((init->height>>is_chroma)+6+ 31) & (~31);
pv->mask[i] = calloc( 1, w*h*sizeof(uint8_t) ) + 3*w;
pv->mask_filtered[i] = calloc( 1, w*h*sizeof(uint8_t) ) + 3*w;
for( i = 0; i < 3; i++ )
{
int is_chroma = !!i;
- int w = ((init->width + 31) & (~31))>>is_chroma;
- int h = ((height+6+ 31) & (~31))>>is_chroma;
+ int w = ((init->width>>is_chroma) + 31) & (~31);
+ int h = ((height>>is_chroma) + 6 + 31) & (~31);
for( j = 0; j < 4; j++ )
{
}
/* Allocate full-height eedi2 buffers */
- height = init->height;
for( i = 0; i < 3; i++ )
{
int is_chroma = !!i;
- int w = ((init->width + 31) & (~31))>>is_chroma;
- int h = ((height+6+ 31) & (~31))>>is_chroma;
+ int w = ((init->width >>is_chroma) + 31) & (~31);
+ int h = ((init->height>>is_chroma)+6+ 31) & (~31);
for( j = 0; j < 5; j++ )
{
* @param prog_diff Sensitivity for detecting different colors on progressive frames
* @param prog_threshold Sensitivity for flagging progressive frames as combed
*/
-int hb_detect_comb( hb_buffer_t * buf, int width, int height, int color_equal, int color_diff, int threshold, int prog_equal, int prog_diff, int prog_threshold )
+int hb_detect_comb( hb_buffer_t * buf, int color_equal, int color_diff, int threshold, int prog_equal, int prog_diff, int prog_threshold )
{
int j, k, n, off, cc_1, cc_2, cc[3];
// int flag[3] ; // debugging flag
uint16_t s1, s2, s3, s4;
cc_1 = 0; cc_2 = 0;
- int offset = 0;
-
if ( buf->s.flags & 16 )
{
/* Frame is progressive, be more discerning. */
/* One pas for Y, one pass for Cb, one pass for Cr */
for( k = 0; k < 3; k++ )
{
- if( k == 1 )
- {
- /* Y has already been checked, now offset by Y's dimensions
- and divide all the other values by 2, since Cr and Cb
- are half-size compared to Y. */
- offset = width * height;
- width >>= 1;
- height >>= 1;
- }
- else if ( k == 2 )
- {
- /* Y and Cb are done, so the offset needs to be bumped
- so it's width*height + (width / 2) * (height / 2) */
- offset *= 5/4;
- }
+ uint8_t * data = buf->plane[k].data;
+ int width = buf->plane[k].width;
+ int stride = buf->plane[k].stride;
+ int height = buf->plane[k].height;
for( j = 0; j < width; ++j )
{
for( n = 0; n < ( height - 4 ); n = n + 2 )
{
/* Look at groups of 4 sequential horizontal lines */
- s1 = ( ( buf->data + offset )[ off + j ] & 0xff );
- s2 = ( ( buf->data + offset )[ off + j + width ] & 0xff );
- s3 = ( ( buf->data + offset )[ off + j + 2 * width ] & 0xff );
- s4 = ( ( buf->data + offset )[ off + j + 3 * width ] & 0xff );
+ s1 = ( ( data )[ off + j ] & 0xff );
+ s2 = ( ( data )[ off + j + stride ] & 0xff );
+ s3 = ( ( data )[ off + j + 2 * stride ] & 0xff );
+ s4 = ( ( data )[ off + j + 3 * stride ] & 0xff );
/* Note if the 1st and 2nd lines are more different in
color than the 1st and 3rd lines are similar in color.*/
++cc_2;
/* Now move down 2 horizontal lines before starting over.*/
- off += 2 * width;
+ off += 2 * stride;
}
}
/* hb_detect_comb()
Analyze a frame for interlacing artifacts, returns true if they're found.
Taken from Thomas Oestreich's 32detect filter in the Transcode project. */
-int hb_detect_comb( hb_buffer_t * buf, int width, int height, int color_equal, int color_diff, int threshold, int prog_equal, int prog_diff, int prog_threshold );
+int hb_detect_comb( hb_buffer_t * buf, int color_equal, int color_diff, int threshold, int prog_equal, int prog_diff, int prog_threshold );
int hb_save_preview( hb_handle_t * h, int title, int preview,
hb_buffer_t *buf );
}
/* Check preview for interlacing artifacts */
- if( hb_detect_comb( vid_buf, vid_info.width, vid_info.height, 10, 30, 9, 10, 30, 9 ) )
+ if( hb_detect_comb( vid_buf, 10, 30, 9, 10, 30, 9 ) )
{
hb_deep_log( 2, "Interlacing detected in preview frame %i", i+1);
interlaced_preview_count++;