203 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			203 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
 | 
						|
 *
 | 
						|
 * This source code is subject to the terms of the BSD 2 Clause License and
 | 
						|
 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
 | 
						|
 * was not distributed with this source code in the LICENSE file, you can
 | 
						|
 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
 | 
						|
 * Media Patent License 1.0 was not distributed with this source code in the
 | 
						|
 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef AV1_ENCODER_FIRSTPASS_H_
 | 
						|
#define AV1_ENCODER_FIRSTPASS_H_
 | 
						|
 | 
						|
#include "av1/encoder/lookahead.h"
 | 
						|
#include "av1/encoder/ratectrl.h"
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
#if CONFIG_FP_MB_STATS
 | 
						|
 | 
						|
#define FPMB_DCINTRA_MASK 0x01
 | 
						|
 | 
						|
#define FPMB_MOTION_ZERO_MASK 0x02
 | 
						|
#define FPMB_MOTION_LEFT_MASK 0x04
 | 
						|
#define FPMB_MOTION_RIGHT_MASK 0x08
 | 
						|
#define FPMB_MOTION_UP_MASK 0x10
 | 
						|
#define FPMB_MOTION_DOWN_MASK 0x20
 | 
						|
 | 
						|
#define FPMB_ERROR_SMALL_MASK 0x40
 | 
						|
#define FPMB_ERROR_LARGE_MASK 0x80
 | 
						|
#define FPMB_ERROR_SMALL_TH 2000
 | 
						|
#define FPMB_ERROR_LARGE_TH 48000
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  uint8_t *mb_stats_start;
 | 
						|
  uint8_t *mb_stats_end;
 | 
						|
} FIRSTPASS_MB_STATS;
 | 
						|
#endif
 | 
						|
 | 
						|
#if CONFIG_EXT_REFS
 | 
						|
// Length of the bi-predictive frame group (BFG)
 | 
						|
// NOTE: Currently each BFG contains one backward ref (BWF) frame plus a certain
 | 
						|
//       number of bi-predictive frames.
 | 
						|
#define BFG_INTERVAL 2
 | 
						|
// The maximum number of extra ALT_REF's
 | 
						|
// NOTE: This number cannot be greater than 2 or the reference frame buffer will
 | 
						|
//       overflow.
 | 
						|
#define MAX_EXT_ARFS 2
 | 
						|
#define MIN_EXT_ARF_INTERVAL 4
 | 
						|
#endif  // CONFIG_EXT_REFS
 | 
						|
 | 
						|
#define VLOW_MOTION_THRESHOLD 950
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  double frame;
 | 
						|
  double weight;
 | 
						|
  double intra_error;
 | 
						|
  double coded_error;
 | 
						|
  double sr_coded_error;
 | 
						|
  double pcnt_inter;
 | 
						|
  double pcnt_motion;
 | 
						|
  double pcnt_second_ref;
 | 
						|
  double pcnt_neutral;
 | 
						|
  double intra_skip_pct;
 | 
						|
  double inactive_zone_rows;  // Image mask rows top and bottom.
 | 
						|
  double inactive_zone_cols;  // Image mask columns at left and right edges.
 | 
						|
  double MVr;
 | 
						|
  double mvr_abs;
 | 
						|
  double MVc;
 | 
						|
  double mvc_abs;
 | 
						|
  double MVrv;
 | 
						|
  double MVcv;
 | 
						|
  double mv_in_out_count;
 | 
						|
  double new_mv_count;
 | 
						|
  double duration;
 | 
						|
  double count;
 | 
						|
} FIRSTPASS_STATS;
 | 
						|
 | 
						|
typedef enum {
 | 
						|
  KF_UPDATE = 0,
 | 
						|
  LF_UPDATE = 1,
 | 
						|
  GF_UPDATE = 2,
 | 
						|
  ARF_UPDATE = 3,
 | 
						|
  OVERLAY_UPDATE = 4,
 | 
						|
#if CONFIG_EXT_REFS
 | 
						|
  BRF_UPDATE = 5,            // Backward Reference Frame
 | 
						|
  LAST_BIPRED_UPDATE = 6,    // Last Bi-predictive Frame
 | 
						|
  BIPRED_UPDATE = 7,         // Bi-predictive Frame, but not the last one
 | 
						|
  INTNL_OVERLAY_UPDATE = 8,  // Internal Overlay Frame
 | 
						|
  FRAME_UPDATE_TYPES = 9
 | 
						|
#else
 | 
						|
  FRAME_UPDATE_TYPES = 5
 | 
						|
#endif  // CONFIG_EXT_REFS
 | 
						|
} FRAME_UPDATE_TYPE;
 | 
						|
 | 
						|
#define FC_ANIMATION_THRESH 0.15
 | 
						|
typedef enum {
 | 
						|
  FC_NORMAL = 0,
 | 
						|
  FC_GRAPHICS_ANIMATION = 1,
 | 
						|
  FRAME_CONTENT_TYPES = 2
 | 
						|
} FRAME_CONTENT_TYPE;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  unsigned char index;
 | 
						|
  RATE_FACTOR_LEVEL rf_level[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
  FRAME_UPDATE_TYPE update_type[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
  unsigned char arf_src_offset[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
  unsigned char arf_update_idx[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
  unsigned char arf_ref_idx[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
#if CONFIG_EXT_REFS
 | 
						|
  unsigned char brf_src_offset[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
  unsigned char bidir_pred_enabled[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
#endif  // CONFIG_EXT_REFS
 | 
						|
  int bit_allocation[(MAX_LAG_BUFFERS * 2) + 1];
 | 
						|
} GF_GROUP;
 | 
						|
 | 
						|
typedef struct {
 | 
						|
  unsigned int section_intra_rating;
 | 
						|
  FIRSTPASS_STATS total_stats;
 | 
						|
  FIRSTPASS_STATS this_frame_stats;
 | 
						|
  const FIRSTPASS_STATS *stats_in;
 | 
						|
  const FIRSTPASS_STATS *stats_in_start;
 | 
						|
  const FIRSTPASS_STATS *stats_in_end;
 | 
						|
  FIRSTPASS_STATS total_left_stats;
 | 
						|
  int first_pass_done;
 | 
						|
  int64_t bits_left;
 | 
						|
  double modified_error_min;
 | 
						|
  double modified_error_max;
 | 
						|
  double modified_error_left;
 | 
						|
  double mb_av_energy;
 | 
						|
 | 
						|
#if CONFIG_FP_MB_STATS
 | 
						|
  uint8_t *frame_mb_stats_buf;
 | 
						|
  uint8_t *this_frame_mb_stats;
 | 
						|
  FIRSTPASS_MB_STATS firstpass_mb_stats;
 | 
						|
#endif
 | 
						|
  // An indication of the content type of the current frame
 | 
						|
  FRAME_CONTENT_TYPE fr_content_type;
 | 
						|
 | 
						|
  // Projected total bits available for a key frame group of frames
 | 
						|
  int64_t kf_group_bits;
 | 
						|
 | 
						|
  // Error score of frames still to be coded in kf group
 | 
						|
  int64_t kf_group_error_left;
 | 
						|
 | 
						|
  // The fraction for a kf groups total bits allocated to the inter frames
 | 
						|
  double kfgroup_inter_fraction;
 | 
						|
 | 
						|
  int sr_update_lag;
 | 
						|
 | 
						|
  int kf_zeromotion_pct;
 | 
						|
  int last_kfgroup_zeromotion_pct;
 | 
						|
  int gf_zeromotion_pct;
 | 
						|
  int active_worst_quality;
 | 
						|
  int baseline_active_worst_quality;
 | 
						|
  int extend_minq;
 | 
						|
  int extend_maxq;
 | 
						|
  int extend_minq_fast;
 | 
						|
 | 
						|
  GF_GROUP gf_group;
 | 
						|
} TWO_PASS;
 | 
						|
 | 
						|
struct AV1_COMP;
 | 
						|
 | 
						|
void av1_init_first_pass(struct AV1_COMP *cpi);
 | 
						|
void av1_rc_get_first_pass_params(struct AV1_COMP *cpi);
 | 
						|
void av1_first_pass(struct AV1_COMP *cpi, const struct lookahead_entry *source);
 | 
						|
void av1_end_first_pass(struct AV1_COMP *cpi);
 | 
						|
 | 
						|
void av1_init_second_pass(struct AV1_COMP *cpi);
 | 
						|
void av1_rc_get_second_pass_params(struct AV1_COMP *cpi);
 | 
						|
void av1_twopass_postencode_update(struct AV1_COMP *cpi);
 | 
						|
 | 
						|
// Post encode update of the rate control parameters for 2-pass
 | 
						|
void av1_twopass_postencode_update(struct AV1_COMP *cpi);
 | 
						|
 | 
						|
void av1_init_subsampling(struct AV1_COMP *cpi);
 | 
						|
 | 
						|
void av1_calculate_coded_size(struct AV1_COMP *cpi, int *scaled_frame_width,
 | 
						|
                              int *scaled_frame_height);
 | 
						|
 | 
						|
#if CONFIG_EXT_REFS
 | 
						|
static INLINE int get_number_of_extra_arfs(int interval, int arf_pending) {
 | 
						|
  if (arf_pending && MAX_EXT_ARFS > 0)
 | 
						|
    return interval >= MIN_EXT_ARF_INTERVAL * (MAX_EXT_ARFS + 1)
 | 
						|
               ? MAX_EXT_ARFS
 | 
						|
               : interval >= MIN_EXT_ARF_INTERVAL * MAX_EXT_ARFS
 | 
						|
                     ? MAX_EXT_ARFS - 1
 | 
						|
                     : 0;
 | 
						|
  else
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
#endif
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}  // extern "C"
 | 
						|
#endif
 | 
						|
 | 
						|
#endif  // AV1_ENCODER_FIRSTPASS_H_
 |