Zivid C++ API  1.8.1+6967bc1b-1
Defining the Future of 3D Machine Vision
Calibrate.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-2020 (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 Support <support@zivid.com>
42  * Info: http://www.zivid.com
43  ******************************************************************************/
44 
45 #pragma once
46 
47 #include "Zivid/APIExport.h"
48 #include "Zivid/HandEye/Detector.h"
49 #include "Zivid/HandEye/Pose.h"
50 
51 #include <Zivid/Matrix.h>
52 #include <Zivid/Vector.h>
53 
54 #include <vector>
55 
56 namespace Zivid
57 {
58  namespace HandEye
59  {
63  class CalibrationResidual
64  {
65  public:
70 
73  ZIVID_API_EXPORT double rotation() const;
74 
77  ZIVID_API_EXPORT double translation() const;
78 
81  ZIVID_API_EXPORT std::string toString() const;
82 
83  private:
84  double m_rotation;
85  double m_translation;
86  };
87 
89  ZIVID_API_EXPORT std::ostream &operator<<(std::ostream &stream, const CalibrationResidual &calibrationResidual);
90 
94  class CalibrationInput
95  {
96  public:
100  ZIVID_API_EXPORT CalibrationInput(const Pose &robotPose, const DetectionResult &detectionResult);
101 
104  ZIVID_API_EXPORT const Pose &robotPose() const;
105 
108  ZIVID_API_EXPORT const DetectionResult &detectionResult() const;
109 
112  ZIVID_API_EXPORT std::string toString() const;
113 
114  private:
115  Pose m_robotPose;
116  DetectionResult m_result;
117  };
118 
120  ZIVID_API_EXPORT std::ostream &operator<<(std::ostream &stream, const CalibrationInput &calibrationInput);
121 
125  class CalibrationOutput
126  {
127  public:
132  const std::vector<CalibrationResidual> &perPoseCalibrationResiduals);
133 
136  ZIVID_API_EXPORT bool valid() const;
137 
140  ZIVID_API_EXPORT explicit operator bool() const;
141 
149 
158  ZIVID_API_EXPORT const std::vector<CalibrationResidual> &perPoseCalibrationResiduals() const;
159 
162  ZIVID_API_EXPORT std::string toString() const;
163 
164  private:
165  Matrix4d m_handEyeTransform;
166  std::vector<CalibrationResidual> m_perPoseCalibrationResiduals;
167  };
168 
170  ZIVID_API_EXPORT std::ostream &operator<<(std::ostream &stream, const CalibrationOutput &calibrationOutput);
171 
181  ZIVID_API_EXPORT CalibrationOutput calibrateEyeInHand(const std::vector<CalibrationInput> &input);
182 
192  ZIVID_API_EXPORT CalibrationOutput calibrateEyeToHand(const std::vector<CalibrationInput> &input);
193 
194  } // namespace HandEye
195 } // namespace Zivid
Vector.h
Zivid::HandEye::CalibrationResidual::toString
ZIVID_API_EXPORT std::string toString() const
Get string representation of the calibration residual
Zivid::HandEye::calibrateEyeToHand
ZIVID_API_EXPORT CalibrationOutput calibrateEyeToHand(const std::vector< CalibrationInput > &input)
Performs eye-to-hand calibration.
Zivid::HandEye::CalibrationInput::CalibrationInput
ZIVID_API_EXPORT CalibrationInput(const Pose &robotPose, const DetectionResult &detectionResult)
Constructs a calibration input instance.
Pose.h
Matrix.h
Zivid::HandEye::CalibrationInput::detectionResult
const ZIVID_API_EXPORT DetectionResult & detectionResult() const
Feature detection result.
Zivid::HandEye::CalibrationOutput::perPoseCalibrationResiduals
const ZIVID_API_EXPORT std::vector< CalibrationResidual > & perPoseCalibrationResiduals() const
Calibration residuals.
Zivid::HandEye::CalibrationResidual::rotation
ZIVID_API_EXPORT double rotation() const
Rotational residual in degrees.
Zivid::HandEye::CalibrationOutput::handEyeTransform
const ZIVID_API_EXPORT Matrix4d & handEyeTransform() const
Hand-eye transform.
Zivid::HandEye::CalibrationResidual::CalibrationResidual
ZIVID_API_EXPORT CalibrationResidual(double rotation, double translation)
Constructs a calibration residual instance.
Zivid::HandEye::CalibrationResidual::translation
ZIVID_API_EXPORT double translation() const
Translational residual in millimeters.
Zivid::Matrix4d
Matrix< double, 4, 4 > Matrix4d
Matrix of size 4x4 containing doubles
Definition: Matrix.h:297
APIExport.h
Detector.h
Zivid::HandEye::CalibrationOutput::CalibrationOutput
ZIVID_API_EXPORT CalibrationOutput(const Matrix4d &handEyeTransform, const std::vector< CalibrationResidual > &perPoseCalibrationResiduals)
Constructs a CalibrationOutput instance.
Zivid::HandEye::CalibrationInput::robotPose
const ZIVID_API_EXPORT Pose & robotPose() const
Robot pose for detected feature points.
Zivid::HandEye::calibrateEyeInHand
ZIVID_API_EXPORT CalibrationOutput calibrateEyeInHand(const std::vector< CalibrationInput > &input)
Performs eye-in-hand calibration.
Zivid::HandEye::CalibrationInput::toString
ZIVID_API_EXPORT std::string toString() const
Get string representation of the calibration input
Zivid
The main Zivid namespace. All Zivid code is found here
Definition: Application.h:52
Zivid::HandEye::CalibrationOutput::valid
ZIVID_API_EXPORT bool valid() const
Test if CalibrationOutput is valid.
ZIVID_API_EXPORT
#define ZIVID_API_EXPORT
Definition: APIExport.h:56
Zivid::HandEye::CalibrationOutput::toString
ZIVID_API_EXPORT std::string toString() const
Get string representation of the calibration output
Zivid::HandEye::operator<<
ZIVID_API_EXPORT std::ostream & operator<<(std::ostream &stream, const CalibrationResidual &calibrationResidual)
Serialize the value to a stream