/* * Copyright (c) 2020, 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 AOM_AV1_ENCODER_GLOBAL_MOTION_FACADE_H_ #define AOM_AV1_ENCODER_GLOBAL_MOTION_FACADE_H_ #ifdef __cplusplus extern "C" { #endif struct yv12_buffer_config; struct AV1_COMP; // Allocates memory for members of GlobalMotionData. static AOM_INLINE void gm_alloc_data(AV1_COMP *cpi, GlobalMotionData *gm_data) { AV1_COMMON *cm = &cpi->common; GlobalMotionInfo *gm_info = &cpi->gm_info; CHECK_MEM_ERROR(cm, gm_data->segment_map, aom_malloc(sizeof(*gm_data->segment_map) * gm_info->segment_map_w * gm_info->segment_map_h)); av1_zero_array(gm_data->motion_models, RANSAC_NUM_MOTIONS); for (int m = 0; m < RANSAC_NUM_MOTIONS; m++) { CHECK_MEM_ERROR(cm, gm_data->motion_models[m].inliers, aom_malloc(sizeof(*gm_data->motion_models[m].inliers) * 2 * MAX_CORNERS)); } } // Deallocates the memory allocated for members of GlobalMotionData. static AOM_INLINE void gm_dealloc_data(GlobalMotionData *gm_data) { aom_free(gm_data->segment_map); gm_data->segment_map = NULL; for (int m = 0; m < RANSAC_NUM_MOTIONS; m++) { aom_free(gm_data->motion_models[m].inliers); gm_data->motion_models[m].inliers = NULL; } } void av1_compute_gm_for_valid_ref_frames( AV1_COMP *cpi, struct aom_internal_error_info *error_info, YV12_BUFFER_CONFIG *ref_buf[REF_FRAMES], int frame, MotionModel *motion_models, uint8_t *segment_map, int segment_map_w, int segment_map_h); void av1_compute_global_motion_facade(struct AV1_COMP *cpi); #ifdef __cplusplus } // extern "C" #endif #endif // AOM_AV1_ENCODER_GLOBAL_MOTION_FACADE_H_