-
Notifications
You must be signed in to change notification settings - Fork 0
/
cameraCalibrationStruct.idl
120 lines (108 loc) · 3.91 KB
/
cameraCalibrationStruct.idl
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
111
112
113
114
115
116
117
118
119
120
/* Copyright (c) 2015, LAAS/CNRS
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. 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.
*
* 3. 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.
*/
#ifndef CAMERACALIBRATION_STRUCT_H
#define CAMERACALIBRATION_STRUCT_H
module calibrationParameters
{
struct timestamp
{
unsigned long sec;
unsigned long usec;
};
struct std_msgs__Header
{
unsigned long seq; /*uint32_t*/
timestamp stamp;
string frame_id;
};
struct sensor_msgs__RegionOfInterest
{
unsigned long x_offset;
unsigned long y_offset;
unsigned long height;
unsigned long width;
boolean do_rectify;
};
struct sensor_msgs__CameraInfo
{
std_msgs__Header header;
unsigned long height; /*Image dimension with which the camera was calibrated*/
unsigned long width; /*Image dimension with which the camera was calibrated*/
string distortion_model; /*For most cameras is 'plumb_bob'*/
sequence<double> D; /*Distortion parameters. For 'plumb_bob': (k1, k2, t1, t2, k3)*/
double K[9]; /*Intrinsic camera matrix for the raw (distorted) images [3x3]*/
double R[9]; /*Rectification matrix [3x3]*/
double P[12]; /*Projection/camera matrix [3x4]*/
unsigned long binning_x;
unsigned long binning_y;
sensor_msgs__RegionOfInterest roi;
};
struct geometry_msgs__Vector3
{
double x;
double y;
double z;
};
struct geometry_msgs__Quaternion
{
double x;
double y;
double z;
double w;
};
struct geometry_msgs__Transform
{
geometry_msgs__Vector3 translation;
geometry_msgs__Quaternion rotation;
};
struct geometry_msgs__TransformStamped
{
std_msgs__Header header;
string child_frame_id;
geometry_msgs__Transform transform;
};
struct tf__tfMessage
{
sequence<geometry_msgs__TransformStamped> transforms;
};
/*intrinsic: extrinsic:
fx 0 cx 0 r11 r12 r13 tx tx lx
0 fy cy 0 r21 r22 r23 ty ty = -R.l l= ly
0 0 1 0 r31 r32 r33 tz tz lz
0 0 0 1*/
struct cameraParameters
{
double intrinsic[12];
double extrinsic[16];
};
#pragma masquerade ros sensor_msgs__CameraInfo sensor_msgs/CameraInfo
#pragma masquerade ros tf__tfMessage tf/tfMessage
};
#endif