v01
This commit is contained in:
171
include/basalt/optical_flow/patterns.h
Normal file
171
include/basalt/optical_flow/patterns.h
Normal file
@@ -0,0 +1,171 @@
|
||||
/**
|
||||
BSD 3-Clause License
|
||||
|
||||
This file is part of the Basalt project.
|
||||
https://gitlab.com/VladyslavUsenko/basalt.git
|
||||
|
||||
Copyright (c) 2019, Vladyslav Usenko and Nikolaus Demmel.
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions are met:
|
||||
|
||||
* Redistributions of source code must retain the above copyright notice, this
|
||||
list of conditions and the following disclaimer.
|
||||
|
||||
* Redistributions in binary form must reproduce the above copyright notice,
|
||||
this list of conditions and the following disclaimer in the documentation
|
||||
and/or other materials provided with the distribution.
|
||||
|
||||
* Neither the name of the copyright holder nor the names of its
|
||||
contributors may be used to endorse or promote products derived from
|
||||
this software without specific prior written permission.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
#pragma once
|
||||
|
||||
#include <Eigen/Dense>
|
||||
|
||||
namespace basalt {
|
||||
|
||||
template <class Scalar>
|
||||
struct Pattern24 {
|
||||
// 00 01
|
||||
//
|
||||
// 02 03 04 05
|
||||
//
|
||||
// 06 07 08 09 10 11
|
||||
//
|
||||
// 12 13 14 15 16 17
|
||||
//
|
||||
// 18 19 20 21
|
||||
//
|
||||
// 22 23
|
||||
//
|
||||
// -----> x
|
||||
// |
|
||||
// |
|
||||
// y
|
||||
|
||||
static constexpr Scalar pattern_raw[][2] = {
|
||||
{-1, 5}, {1, 5},
|
||||
|
||||
{-3, 3}, {-1, 3}, {1, 3}, {3, 3},
|
||||
|
||||
{-5, 1}, {-3, 1}, {-1, 1}, {1, 1}, {3, 1}, {5, 1},
|
||||
|
||||
{-5, -1}, {-3, -1}, {-1, -1}, {1, -1}, {3, -1}, {5, -1},
|
||||
|
||||
{-3, -3}, {-1, -3}, {1, -3}, {3, -3},
|
||||
|
||||
{-1, -5}, {1, -5}
|
||||
|
||||
};
|
||||
|
||||
static constexpr int PATTERN_SIZE =
|
||||
sizeof(pattern_raw) / (2 * sizeof(Scalar));
|
||||
|
||||
typedef Eigen::Matrix<Scalar, 2, PATTERN_SIZE> Matrix2P;
|
||||
static const Matrix2P pattern2;
|
||||
};
|
||||
|
||||
template <class Scalar>
|
||||
const typename Pattern24<Scalar>::Matrix2P Pattern24<Scalar>::pattern2 =
|
||||
Eigen::Map<Pattern24<Scalar>::Matrix2P>((Scalar *)
|
||||
Pattern24<Scalar>::pattern_raw);
|
||||
|
||||
template <class Scalar>
|
||||
struct Pattern52 {
|
||||
// 00 01 02 03
|
||||
//
|
||||
// 04 05 06 07 08 09
|
||||
//
|
||||
// 10 11 12 13 14 15 16 17
|
||||
//
|
||||
// 18 19 20 21 22 23 24 25
|
||||
//
|
||||
// 26 27 28 29 30 31 32 33
|
||||
//
|
||||
// 34 35 36 37 38 39 40 41
|
||||
//
|
||||
// 42 43 44 45 46 47
|
||||
//
|
||||
// 48 49 50 51
|
||||
//
|
||||
// -----> x
|
||||
// |
|
||||
// |
|
||||
// y
|
||||
|
||||
static constexpr Scalar pattern_raw[][2] = {
|
||||
{-3, 7}, {-1, 7}, {1, 7}, {3, 7},
|
||||
|
||||
{-5, 5}, {-3, 5}, {-1, 5}, {1, 5}, {3, 5}, {5, 5},
|
||||
|
||||
{-7, 3}, {-5, 3}, {-3, 3}, {-1, 3}, {1, 3}, {3, 3},
|
||||
{5, 3}, {7, 3},
|
||||
|
||||
{-7, 1}, {-5, 1}, {-3, 1}, {-1, 1}, {1, 1}, {3, 1},
|
||||
{5, 1}, {7, 1},
|
||||
|
||||
{-7, -1}, {-5, -1}, {-3, -1}, {-1, -1}, {1, -1}, {3, -1},
|
||||
{5, -1}, {7, -1},
|
||||
|
||||
{-7, -3}, {-5, -3}, {-3, -3}, {-1, -3}, {1, -3}, {3, -3},
|
||||
{5, -3}, {7, -3},
|
||||
|
||||
{-5, -5}, {-3, -5}, {-1, -5}, {1, -5}, {3, -5}, {5, -5},
|
||||
|
||||
{-3, -7}, {-1, -7}, {1, -7}, {3, -7}
|
||||
|
||||
};
|
||||
|
||||
static constexpr int PATTERN_SIZE =
|
||||
sizeof(pattern_raw) / (2 * sizeof(Scalar));
|
||||
|
||||
typedef Eigen::Matrix<Scalar, 2, PATTERN_SIZE> Matrix2P;
|
||||
static const Matrix2P pattern2;
|
||||
};
|
||||
|
||||
template <class Scalar>
|
||||
const typename Pattern52<Scalar>::Matrix2P Pattern52<Scalar>::pattern2 =
|
||||
Eigen::Map<Pattern52<Scalar>::Matrix2P>((Scalar *)
|
||||
Pattern52<Scalar>::pattern_raw);
|
||||
|
||||
// Same as Pattern52 but twice smaller
|
||||
template <class Scalar>
|
||||
struct Pattern51 {
|
||||
static constexpr int PATTERN_SIZE = Pattern52<Scalar>::PATTERN_SIZE;
|
||||
|
||||
typedef Eigen::Matrix<Scalar, 2, PATTERN_SIZE> Matrix2P;
|
||||
static const Matrix2P pattern2;
|
||||
};
|
||||
|
||||
template <class Scalar>
|
||||
const typename Pattern51<Scalar>::Matrix2P Pattern51<Scalar>::pattern2 =
|
||||
0.5 * Pattern52<Scalar>::pattern2;
|
||||
|
||||
// Same as Pattern52 but 0.75 smaller
|
||||
template <class Scalar>
|
||||
struct Pattern50 {
|
||||
static constexpr int PATTERN_SIZE = Pattern52<Scalar>::PATTERN_SIZE;
|
||||
|
||||
typedef Eigen::Matrix<Scalar, 2, PATTERN_SIZE> Matrix2P;
|
||||
static const Matrix2P pattern2;
|
||||
};
|
||||
|
||||
template <class Scalar>
|
||||
const typename Pattern50<Scalar>::Matrix2P Pattern50<Scalar>::pattern2 =
|
||||
0.75 * Pattern52<Scalar>::pattern2;
|
||||
|
||||
} // namespace basalt
|
||||
Reference in New Issue
Block a user