/* * 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_RANSAC_H_ #define AV1_ENCODER_RANSAC_H_ #include <stdio.h> #include <stdlib.h> #include <math.h> #include <memory.h> #include "av1/common/warped_motion.h" typedef int (*RansacFunc)(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); /* Each of these functions fits a motion model from a set of corresponding points in 2 frames using RANSAC. */ int ransac_homography(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); int ransac_affine(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); int ransac_hortrapezoid(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); int ransac_vertrapezoid(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); int ransac_rotzoom(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); int ransac_translation(int *matched_points, int npoints, int *num_inliers_by_motion, double *params_by_motion, int num_motions); #endif // AV1_ENCODER_RANSAC_H_