17#ifndef __math_average_space_h__
18#define __math_average_space_h__
20#include <unsupported/Eigen/MatrixFunctions>
22#include <Eigen/Geometry>
37 Eigen::Matrix<default_type, 8, 4>
get_cuboid_corners (
const Eigen::Matrix<default_type, 4, 1>& xzx1);
38 Eigen::Matrix<default_type, 8, 4>
get_bounding_box (
const Header& header,
const Eigen::Transform<default_type, 3, Eigen::Projective>& voxel2scanner);
41 const vector<Eigen::Transform<default_type, 3, Eigen::Projective>>& transform_header_with,
42 int voxel_subsampling = 1,
43 Eigen::Matrix<default_type, 4, 1> padding = Eigen::Matrix<default_type, 4, 1>(1.0, 1.0, 1.0, 1.0));
45 template<
class ImageType1,
class ImageType2>
47 const ImageType1& im1,
48 const ImageType2& im2,
49 Eigen::Transform<default_type, 3, Eigen::Projective> transform_1 = Eigen::Transform<default_type, 3, Eigen::Projective>::Identity(),
50 Eigen::Transform<default_type, 3, Eigen::Projective> transform_2 = Eigen::Transform<default_type, 3, Eigen::Projective>::Identity(),
51 Eigen::Matrix<default_type, 4, 1> padding = Eigen::Matrix<default_type, 4, 1>(1.0, 1.0, 1.0, 1.0),
52 int voxel_subsampling = 1) {
double matrix_average(vector< Eigen::MatrixXd > const &mat_in, Eigen::MatrixXd &mat_avg, bool verbose=false)
Eigen::Matrix< default_type, 8, 4 > get_bounding_box(const Header &header, const Eigen::Transform< default_type, 3, Eigen::Projective > &voxel2scanner)
Header compute_minimum_average_header(const vector< Header > &input_headers, const vector< Eigen::Transform< default_type, 3, Eigen::Projective > > &transform_header_with, int voxel_subsampling=1, Eigen::Matrix< default_type, 4, 1 > padding=Eigen::Matrix< default_type, 4, 1 >(1.0, 1.0, 1.0, 1.0))
Eigen::Matrix< default_type, 8, 4 > get_cuboid_corners(const Eigen::Matrix< default_type, 4, 1 > &xzx1)