-
Notifications
You must be signed in to change notification settings - Fork 0
/
image.hpp
executable file
·110 lines (89 loc) · 4.21 KB
/
image.hpp
1
2
3
4
5
6
7
8
9
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
// 230201057
// ------------------------------
// Written by Mustafa Ozuysal
// Contact <mustafaozuysal@iyte.edu.tr> for comments and bug reports
// ------------------------------
// Copyright (c) 2018, Mustafa Ozuysal
// 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 holders nor the
// names of his/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 OWNER 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.
// ------------------------------
#ifndef IMAGE_HPP
#define IMAGE_HPP
#include <string>
#include <vector>
#include "types.hpp"
#include "util.hpp"
#include "keypoint.hpp"
#include "descriptor.hpp"
using std::vector;
namespace ceng391 {
class Image {
public:
Image(int width, int height, int n_channels, int step = -1);
~Image();
static Image* new_gray(int width, int height);
static Image* new_rgb(int width, int height);
static Image* new_copy(Image *img);
int w () const { return m_width; }
int h () const { return m_height; }
int n_ch() const { return m_n_channels; }
int step() const { return m_step; }
uchar* data() { return m_data; }
const uchar* data() const { return m_data; }
uchar* data(int y) { return m_data + y*m_step; }
const uchar* data(int y) const { return m_data + y*m_step; }
void set_rect(int x, int y, int width, int height, uchar value);
void set_rect(int x, int y, int width, int height, uchar red, uchar green, uchar blue);
void set(uchar value) { set_rect(0, 0, m_width, m_height, value); }
void set_zero() { set(0); }
void to_grayscale();
void to_rgb();
void rotate(Image *rotated, double theta, double tx, double ty) const;
void rotate_centered(Image *rotated, double theta) const;
void smooth_x(float sigma);
void smooth_y(float sigma);
void smooth(float sigma_x, float sigma_y);
short *deriv_x() const;
short *deriv_y() const;
bool write_pnm(const std::string& filename) const;
bool read_pnm (const std::string& filename);
std::vector<Keypoint> harris_corners(float threshold, float k,
float sigma);
std::vector<Descriptor> compute_brief(const std::vector<Keypoint>& keys);
static std::vector<Match> match_brief(const std::vector<Descriptor>& d0,
const std::vector<Descriptor>& d1);
static int find_homography(const std::vector<Match> &matches,
const std::vector<Keypoint> &keys1,
const std::vector<Keypoint> &keys2,
double* h);
private:
int m_width;
int m_height;
int m_n_channels;
int m_step;
uchar* m_data;
};
}
#endif