Zivid C++ API 2.11.1+de9b5dae-1
InfieldCorrection.h
Go to the documentation of this file.
1/*******************************************************************************
2 * This file is part of the Zivid API
3 *
4 * Copyright 2015-2024 (C) Zivid AS
5 * All rights reserved.
6 *
7 * Zivid Software License, v1.0
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
14 *
15 * 2. Redistributions in binary form must reproduce the above copyright notice,
16 * this list of conditions and the following disclaimer in the documentation
17 * and/or other materials provided with the distribution.
18 *
19 * 3. Neither the name of Zivid AS nor the names of its contributors may be used
20 * to endorse or promote products derived from this software without specific
21 * prior written permission.
22 *
23 * 4. This software, with or without modification, must not be used with any
24 * other 3D camera than from Zivid AS.
25 *
26 * 5. Any software provided in binary form under this license must not be
27 * reverse engineered, decompiled, modified and/or disassembled.
28 *
29 * THIS SOFTWARE IS PROVIDED BY ZIVID AS "AS IS" AND ANY EXPRESS OR IMPLIED
30 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
31 * MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
32 * DISCLAIMED. IN NO EVENT SHALL ZIVID AS OR CONTRIBUTORS BE LIABLE FOR ANY
33 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
34 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
35 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
36 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
38 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 *
40 * Contact: Zivid Customer Success Team <customersuccess@zivid.com>
41 * Info: http://www.zivid.com
42 ******************************************************************************/
43
44#pragma once
45
47#include "Zivid/Camera.h"
49#include "Zivid/Detail/Pimpl.h"
51#include "Zivid/Point.h"
52
53#include <chrono>
54#include <iosfwd>
55#include <string>
56#include <vector>
57
58namespace Zivid
59{
60 namespace Experimental
61 {
62 namespace Calibration
63 {
74
82
100
111 {
112 public:
120
123
126
129
132 ZIVID_CORE_EXPORT explicit operator bool() const;
133
137
139 ZIVID_CORE_EXPORT std::string toString() const;
140
141 private:
142 Zivid::Calibration::DetectionResult m_detectionResult;
144 };
145
147 ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const InfieldCorrectionInput &input);
148
158 {
160
161 public:
173
177
180 ZIVID_CORE_EXPORT std::string toString() const;
181 };
182
185 std::ostream &stream,
186 const CameraVerification &cameraVerification);
187
190 {
192
193 public:
210
213 ZIVID_CORE_EXPORT float zMin() const;
214
217 ZIVID_CORE_EXPORT float zMax() const;
218
221 ZIVID_CORE_EXPORT std::string toString() const;
222 };
223
225 ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const AccuracyEstimate &accuracyEstimate);
226
229 {
231
232 public:
240
243 ZIVID_CORE_EXPORT std::string toString() const;
244 };
245
247 ZIVID_CORE_EXPORT std::ostream &operator<<(std::ostream &stream, const CameraCorrection &cameraCorrection);
248
262
285 computeCameraCorrection(const std::vector<InfieldCorrectionInput> &dataset);
286
298 Zivid::Camera &camera,
299 const CameraCorrection &cameraCorrection);
300
304
313
321 ZIVID_CORE_EXPORT std::chrono::time_point<std::chrono::system_clock> cameraCorrectionTimestamp(
322 const Zivid::Camera &camera);
323
324 } // namespace Calibration
325 } // namespace Experimental
326} // namespace Zivid
#define ZIVID_CORE_EXPORT
Definition CoreExport.h:56
#define ZIVID_PIMPL_VALUE_SEMANTICS(ClassName, Attributes)
Definition Pimpl.h:51
A result returned by the detectFeaturePoints(...) call.
Definition DetectionResult.h:61
Interface to one Zivid camera.
Definition Camera.h:68
A dimension accuracy estimate for a specific working volume.
Definition InfieldCorrection.h:190
ZIVID_CORE_EXPORT float zMax() const
The range of validity of the accuracy estimate (upper end)
ZIVID_CORE_EXPORT float zMin() const
The range of validity of the accuracy estimate (lower end)
ZIVID_CORE_EXPORT float dimensionAccuracy() const
The estimated dimension accuracy error obtained if the correction is applied.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the accuracy estimate.
An in-field correction that may be written to a camera.
Definition InfieldCorrection.h:229
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the camera correction.
ZIVID_CORE_EXPORT AccuracyEstimate accuracyEstimate() const
Get an estimate for expected dimension accuracy if the correction is applied to the camera.
An assessment of the current dimension trueness of a camera at a specific location.
Definition InfieldCorrection.h:158
ZIVID_CORE_EXPORT Zivid::PointXYZ position() const
Get the location at which the measurement was made.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the camera assessment.
ZIVID_CORE_EXPORT float localDimensionTrueness() const
Get the estimated local dimension trueness error.
Container for input-data needed by in-field verification and correction functions.
Definition InfieldCorrection.h:111
ZIVID_CORE_EXPORT InfieldCorrectionInput(const Zivid::Calibration::DetectionResult &detectionResult)
Constructs an InfieldCorrectionInput instance.
ZIVID_CORE_EXPORT const Zivid::Calibration::DetectionResult & detectionResult() const
Get the stored feature-point detection result.
ZIVID_CORE_EXPORT InfieldCorrectionDetectionStatus status() const
Get detection status/validity as an enum.
ZIVID_CORE_EXPORT std::string statusDescription() const
Get human-readable description of the status. Useful for feedback if valid() is false.
ZIVID_CORE_EXPORT bool valid() const
Check if the data is valid for use with in-field verification and correction.
ZIVID_CORE_EXPORT std::string toString() const
Get string representation of the in-field correction input.
A frame captured by a Zivid camera.
Definition Frame.h:70
ZIVID_CORE_EXPORT std::chrono::time_point< std::chrono::system_clock > cameraCorrectionTimestamp(const Zivid::Camera &camera)
Get the time at which the camera's in-field correction was created.
ZIVID_CORE_EXPORT Zivid::Calibration::DetectionResult detectFeaturePoints(Zivid::Camera &camera)
Detects feature points from a calibration object.
ZIVID_CORE_EXPORT Zivid::Frame captureCalibrationBoard(Zivid::Camera &camera)
Capture the calibration board.
ZIVID_CORE_EXPORT CameraVerification verifyCamera(const InfieldCorrectionInput &input)
Verify the current camera trueness based on a single measurement.
ZIVID_CORE_EXPORT std::ostream & operator<<(std::ostream &stream, const InfieldCorrectionInput &input)
Serialize the value to a stream.
ZIVID_CORE_EXPORT void resetCameraCorrection(Zivid::Camera &camera)
Reset the in-field correction on a camera to factory settings.
InfieldCorrectionDetectionStatus
Definition InfieldCorrectionDetectionStatus.h:58
ZIVID_CORE_EXPORT CameraCorrection computeCameraCorrection(const std::vector< InfieldCorrectionInput > &dataset)
Calculate new in-field camera correction.
ZIVID_CORE_EXPORT void writeCameraCorrection(Zivid::Camera &camera, const CameraCorrection &cameraCorrection)
Write the in-field correction on a camera.
ZIVID_CORE_EXPORT bool hasCameraCorrection(const Zivid::Camera &camera)
Check if the camera has an in-field correction written to it.
The main Zivid namespace. All Zivid code is found here.
Definition Application.h:54
Point with three coordinates as float.
Definition Point.h:60