Zivid C++ API  2.3.1+1a22cbf1-1
Defining the Future of 3D Machine Vision
HandEye.h
Go to the documentation of this file.
1 
2 /*******************************************************************************
3  * This file is part of the Zivid 3D Camera API
4  *
5  * Copyright 2015-2022 (C) Zivid AS
6  * All rights reserved.
7  *
8  * Zivid Software License, v1.0
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions are met:
12  *
13  * 1. Redistributions of source code must retain the above copyright notice,
14  * this list of conditions and the following disclaimer.
15  *
16  * 2. Redistributions in binary form must reproduce the above copyright notice,
17  * this list of conditions and the following disclaimer in the documentation
18  * and/or other materials provided with the distribution.
19  *
20  * 3. Neither the name of Zivid AS nor the names of its contributors may be used
21  * to endorse or promote products derived from this software without specific
22  * prior written permission.
23  *
24  * 4. This software, with or without modification, must not be used with any
25  * other 3D camera than from Zivid AS.
26  *
27  * 5. Any software provided in binary form under this license must not be
28  * reverse engineered, decompiled, modified and/or disassembled.
29  *
30  * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
31  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
32  * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
33  * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
34  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
35  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
36  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
37  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
38  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
39  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
40  *
41  * Contact: Zivid Customer Success Team <customersuccess@zivid.com>
42  * Info: http://www.zivid.com
43  ******************************************************************************/
44 
45 #pragma once
46 
48 #include "Zivid/Calibration/Pose.h"
50 
51 #include <Zivid/Matrix.h>
52 
53 #include <vector>
54 
55 namespace Zivid
56 {
57  namespace Calibration
58  {
63  {
64  public:
69 
73 
77 
80  ZIVID_CORE_EXPORT std::string toString() const;
81 
82  private:
83  Pose m_robotPose;
84  DetectionResult m_result;
85  };
86 
88  ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const HandEyeInput &handEyeInput);
89 
94  {
95  public:
100 
104 
108 
111  ZIVID_CORE_EXPORT std::string toString() const;
112 
113  private:
114  float m_rotation;
115  float m_translation;
116  };
117 
119  ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const HandEyeResidual &residual);
120 
125  {
126  public:
130  ZIVID_CORE_EXPORT HandEyeOutput(const Matrix4x4 &transform, const std::vector<HandEyeResidual> &residuals);
131 
134  ZIVID_CORE_EXPORT bool valid() const;
135 
138  ZIVID_CORE_EXPORT explicit operator bool() const;
139 
147 
156  ZIVID_CORE_EXPORT const std::vector<HandEyeResidual> &residuals() const;
157 
160  ZIVID_CORE_EXPORT std::string toString() const;
161 
162  private:
163  Matrix4x4 m_transform;
164  std::vector<HandEyeResidual> m_residuals;
165  };
166 
168  ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const HandEyeOutput &handEyeOutput);
169 
179  ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeInHand(const std::vector<HandEyeInput> &input);
180 
190  ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeToHand(const std::vector<HandEyeInput> &input);
191 
192  } // namespace Calibration
193 } // namespace Zivid
#define ZIVID_CORE_EXPORT
Definition: CoreExport.h:57
A result returned by the detectFeaturePoints(...) call
Definition: DetectionResult.h:61
Binds together a robot pose and the detection result acquired from the pose
Definition: HandEye.h:63
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:125
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:94
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:59
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 > &input)
Performs eye-in-hand calibration.
ZIVID_CORE_EXPORT HandEyeOutput calibrateEyeToHand(const std::vector< HandEyeInput > &input)
Performs eye-to-hand calibration.
The main Zivid namespace. All Zivid code is found here
Definition: Application.h:55