Zivid C++ API  2.4.2+1a2e8cfb-1
Defining the Future of 3D Machine Vision
HandEye.h
Go to the documentation of this file.
1 
2 
3 /*******************************************************************************
4 
5  * This file is part of the Zivid 3D Camera API
6 
7  *
8 
9  * Copyright 2015-2021 (C) Zivid AS
10 
11  * All rights reserved.
12 
13  *
14 
15  * Zivid Software License, v1.0
16 
17  *
18 
19  * Redistribution and use in source and binary forms, with or without
20 
21  * modification, are permitted provided that the following conditions are met:
22 
23  *
24 
25  * 1. Redistributions of source code must retain the above copyright notice,
26 
27  * this list of conditions and the following disclaimer.
28 
29  *
30 
31  * 2. Redistributions in binary form must reproduce the above copyright notice,
32 
33  * this list of conditions and the following disclaimer in the documentation
34 
35  * and/or other materials provided with the distribution.
36 
37  *
38 
39  * 3. Neither the name of Zivid AS nor the names of its contributors may be used
40 
41  * to endorse or promote products derived from this software without specific
42 
43  * prior written permission.
44 
45  *
46 
47  * 4. This software, with or without modification, must not be used with any
48 
49  * other 3D camera than from Zivid AS.
50 
51  *
52 
53  * 5. Any software provided in binary form under this license must not be
54 
55  * reverse engineered, decompiled, modified and/or disassembled.
56 
57  *
58 
59  * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
60 
61  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
62 
63  * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
64 
65  * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
66 
67  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
68 
69  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
70 
71  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
72 
73  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
74 
75  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
76 
77  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
78 
79  *
80 
81  * Contact: Zivid Customer Success Team <customersuccess@zivid.com>
82 
83  * Info: http://www.zivid.com
84 
85  ******************************************************************************/
86 
87 
88 
89 #pragma once
90 
92 #include "Zivid/Calibration/Pose.h"
94 
95 #include <Zivid/Matrix.h>
96 
97 #include <vector>
98 
99 namespace Zivid
100 {
101  namespace Calibration
102  {
107  {
108  public:
113 
117 
121 
124  ZIVID_CORE_EXPORT std::string toString() const;
125 
126  private:
127  Pose m_robotPose;
128  DetectionResult m_result;
129  };
130 
132  ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const HandEyeInput &handEyeInput);
133 
138  {
139  public:
144 
148 
152 
155  ZIVID_CORE_EXPORT std::string toString() const;
156 
157  private:
158  float m_rotation;
159  float m_translation;
160  };
161 
163  ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const HandEyeResidual &residual);
164 
169  {
170  public:
174  ZIVID_CORE_EXPORT HandEyeOutput(const Matrix4x4 &transform, const std::vector<HandEyeResidual> &residuals);
175 
178  ZIVID_CORE_EXPORT bool valid() const;
179 
182  ZIVID_CORE_EXPORT explicit operator bool() const;
183 
191 
200  ZIVID_CORE_EXPORT const std::vector<HandEyeResidual> &residuals() const;
201 
204  ZIVID_CORE_EXPORT std::string toString() const;
205 
206  private:
207  Matrix4x4 m_transform;
208  std::vector<HandEyeResidual> m_residuals;
209  };
210 
212  ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const HandEyeOutput &handEyeOutput);
213 
223  ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeInHand(const std::vector<HandEyeInput> &inputs);
224 
234  ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeToHand(const std::vector<HandEyeInput> &inputs);
235 
236  } // namespace Calibration
237 } // namespace Zivid
#define ZIVID_CORE_EXPORT
Definition: CoreExport.h:101
A result returned by the detectFeaturePoints(...) call
Definition: DetectionResult.h:105
Binds together a robot pose and the detection result acquired from the pose
Definition: HandEye.h:107
ZIVID_CORE_EXPORT const DetectionResult & detectionResult() const
Feature detection result.
ZIVID_CORE_EXPORT HandEyeInput(const Pose &robotPose, const DetectionResult &detectionResult)
Constructs a HandEyeInput instance.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the hand-eye calibration input
ZIVID_CORE_EXPORT const Pose & robotPose() const
Robot pose for detected feature points.
The hand-eye calibration result containing the computed pose and reprojection errors for all the inpu...
Definition: HandEye.h:169
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the hand-eye calibration output
ZIVID_CORE_EXPORT const std::vector< HandEyeResidual > & residuals() const
Hand-eye calibration residuals.
ZIVID_CORE_EXPORT HandEyeOutput(const Matrix4x4 &transform, const std::vector< HandEyeResidual > &residuals)
Constructs a HandEyeOutput instance.
ZIVID_CORE_EXPORT bool valid() const
Test if HandEyeOutput is valid.
ZIVID_CORE_EXPORT const Matrix4x4 & transform() const
Hand-eye transform.
Representaton of the estimated errors of a calibrated hand-eye transform
Definition: HandEye.h:138
ZIVID_CORE_EXPORT float translation() const
Translational residual in millimeters.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the hand-eye residual
ZIVID_CORE_EXPORT float rotation() const
Rotational residual in degrees.
ZIVID_CORE_EXPORT HandEyeResidual(float rotation, float translation)
Constructs a hand-eye residual instance.
Describes a robot pose
Definition: Pose.h:103
ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeToHand(const std::vector< HandEyeInput > &inputs)
Performs eye-to-hand calibration.
ZIVID_CORE_EXPORT std::ostream & operator<<(std::ostream &stream, const DetectionResult &result)
Serialize the value to a stream
ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeInHand(const std::vector< HandEyeInput > &inputs)
Performs eye-in-hand calibration.
The main Zivid namespace. All Zivid code is found here
Definition: Application.h:99