From 6c48319c60c4eb6ad4ff3631f5caa6b297d2e787 Mon Sep 17 00:00:00 2001 From: LYW <leeyeanwoo@diteam.co.kr> Date: 수, 18 8월 2021 09:06:18 +0900 Subject: [PATCH] Merge branch 'feature/#3561_CF_AOI_Review_Align_카메라_끊김_현상_조치' into feature/#3562_CF_AOI_Review_실행_프로그램_경로_변경 --- ReviewHistory/include/akCore/akInterpolation.h | 48 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 48 insertions(+), 0 deletions(-) diff --git a/ReviewHistory/include/akCore/akInterpolation.h b/ReviewHistory/include/akCore/akInterpolation.h new file mode 100644 index 0000000..07c2a08 --- /dev/null +++ b/ReviewHistory/include/akCore/akInterpolation.h @@ -0,0 +1,48 @@ +#pragma once + + +#include "akCoreLinker.h" +#include <vector> + +namespace akCore +{ + class AKCORE_DLLSPEC CakInterpolation + { + public: + struct _Data + { + _Data() + { + x = y = 0; + } + double x; + double y; + }; + + public: + CakInterpolation(); + ~CakInterpolation(); + + //폴리노미얼 데이터 생성(rate:데이터 간격) + void CaculationPolinomial(double min, double max, double rate); + //큐빅스플라인 데이터 생성(rate:점과 점사이의 데이터 갯수) + void CaculationCubicSpline(double rate); + //Linear(rate:점과 점사이의 데이터 갯수) + void CaculationLinear(int step); + + void AddPoint(double x, double y); + inline void ClearPoint(){m_vecInterPoint.clear();}; + + inline _Data GetData(int index); + inline int GetDataNum(){return (int)m_vecInterPoint.size();}; + + + + + protected: + std::vector<_Data> m_vecOrgPoint; + std::vector<_Data> m_vecInterPoint; + private: + void solveTridiag(double* khb, double* diag, double* khp, double* b, int n) ; + }; +} \ No newline at end of file -- Gitblit v1.9.3