GrabBag/Module/HandEyeCalib/Inc/IHandEyeCalib.h

197 lines
6.6 KiB
C
Raw Normal View History

2026-02-04 00:28:38 +08:00
#ifndef IHANDEYECALIB_H
#define IHANDEYECALIB_H
#include <vector>
#include "HandEyeCalib_global.h"
#include "HandEyeCalibTypes.h"
/**
* @brief
* SVD分解的手眼标定算法使Eigen库实现
* OpenCV
*/
class IHandEyeCalib
{
public:
virtual ~IHandEyeCalib() = default;
/**
* @brief ()
* 使SVD分解方法计算两组对应点之间的刚体变换
* @param eyePoints
* @param robotPoints
* @param result (R, T, )
* @return 0
*/
virtual int CalculateRT(
const std::vector<HECPoint3D>& eyePoints,
const std::vector<HECPoint3D>& robotPoints,
HECCalibResult& result) = 0;
/**
* @brief (使)
* @param pointPairs
* @param result
* @return 0
*/
virtual int CalculateRT(
const std::vector<HECCalibPointPair>& pointPairs,
HECCalibResult& result) = 0;
/**
* @brief 使RT矩阵变换点 (: R*p + T)
* @param R
* @param T
* @param srcPoint
* @param dstPoint
*/
virtual void TransformPoint(
const HECRotationMatrix& R,
const HECTranslationVector& T,
const HECPoint3D& srcPoint,
HECPoint3D& dstPoint) = 0;
/**
* @brief 使RT矩阵变换点 ()
* : dstPoint = R * (srcPoint - srcCenter) + dstCenter
* @param R
* @param T
* @param srcCenter
* @param dstCenter
* @param srcPoint
* @param dstPoint
*/
virtual void TransformPointWithCenter(
const HECRotationMatrix& R,
const HECTranslationVector& T,
const HECPoint3D& srcCenter,
const HECPoint3D& dstCenter,
const HECPoint3D& srcPoint,
HECPoint3D& dstPoint) = 0;
/**
* @brief 使 ()
* @param R
* @param srcPoint
* @param dstPoint
*/
virtual void RotatePoint(
const HECRotationMatrix& R,
const HECPoint3D& srcPoint,
HECPoint3D& dstPoint) = 0;
/**
* @brief (ZYX顺序)
* @param R
* @param angles ()
*/
virtual void RotationMatrixToEulerZYX(
const HECRotationMatrix& R,
HECEulerAngles& angles) = 0;
/**
* @brief ()
* @param R
* @param order
* @param angles ()
*/
virtual void RotationMatrixToEuler(
const HECRotationMatrix& R,
HECEulerOrder order,
HECEulerAngles& angles) = 0;
/**
* @brief (ZYX顺序)
* @param angles ()
* @param R
*/
virtual void EulerZYXToRotationMatrix(
const HECEulerAngles& angles,
HECRotationMatrix& R) = 0;
/**
* @brief ()
* @param angles ()
* @param order
* @param R
*/
virtual void EulerToRotationMatrix(
const HECEulerAngles& angles,
HECEulerOrder order,
HECRotationMatrix& R) = 0;
/**
* @brief 姿 ( + 姿)
* 姿
* @param calibResult
* @param eyePoint
* @param eyeDirVectors (X, Y, Z轴方向)
* @param invertYZ Y轴和Z轴方向取反 ()
* @param poseResult 姿
*/
virtual void TransformPose(
const HECCalibResult& calibResult,
const HECPoint3D& eyePoint,
const std::vector<HECPoint3D>& eyeDirVectors,
bool invertYZ,
HECPoseResult& poseResult) = 0;
/**
* @brief
* @param eyePoints
* @param robotPoints
* @param calibResult
* @return (mm)
*/
virtual double CalculateError(
const std::vector<HECPoint3D>& eyePoints,
const std::vector<HECPoint3D>& robotPoints,
const HECCalibResult& calibResult) = 0;
/**
* @brief (Eye-In-Hand)
*
*
* P_base
* P_base = T_end * T_cam * P_cam
* T_end 姿T_cam
*
* AX=XB
*
* @param calibData 姿
* @param result ()
* @return 0
*/
virtual int CalculateEyeInHand(
const std::vector<HECEyeInHandData>& calibData,
HECCalibResult& result) = 0;
/**
* @brief - 使
* 使
*
* @param calibData
* @param targetInBase
* @param result
* @return 0
*/
virtual int CalculateEyeInHandWithTarget(
const std::vector<HECEyeInHandData>& calibData,
const HECPoint3D& targetInBase,
HECCalibResult& result) = 0;
};
/**
* @brief
* @return
*/
IHandEyeCalib* CreateHandEyeCalibInstance();
/**
* @brief
* @param instance
*/
void DestroyHandEyeCalibInstance(IHandEyeCalib* instance);
#endif // IHANDEYECALIB_H