CN104517032A - 一种基于b样条曲线的数据点的拟合方法及装置 - Google Patents
一种基于b样条曲线的数据点的拟合方法及装置 Download PDFInfo
- Publication number
- CN104517032A CN104517032A CN201410722418.3A CN201410722418A CN104517032A CN 104517032 A CN104517032 A CN 104517032A CN 201410722418 A CN201410722418 A CN 201410722418A CN 104517032 A CN104517032 A CN 104517032A
- Authority
- CN
- China
- Prior art keywords
- rightarrow
- data point
- centerdot
- spline curves
- point
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Landscapes
- Image Generation (AREA)
Abstract
本发明涉及测量技术领域,公开了一种基于B样条曲线的数据点的拟合方法及装置。其中,该方法包括:将未知曲面的测量数据点Qi(i=0,1,…,n)作为B样条曲线的控制点定义节点向量t0=…=tk-1=0,tr-k+1=…=tr=1,其中,设根据控制点和节点向量构造B样条曲线其中,k为曲线的阶数,r=n+k;在所构造的B样条曲线上,获得与每一个数据点最近的点设更新为作为新的控制点,构造曲线重复在所构造的B样条曲线上,获得与每一个数据点最近的点直至最短间距,其中最短间距在误差限内。本发明实现了数据点的精确拟合,满足了拟合需求。
Description
技术领域
本发明涉及测量技术领域,主要适用于基于B样条曲线的数据点的拟合方法及装置。
背景技术
在自由未知曲面的测量中,需要对测量得到的数据点进行拟合,曲线的拟合重构是曲面拟合重构的基础,但是现有的对曲线或曲面进行拟合的方法的拟合精度不高,不能满足拟合需求。
发明内容
本发明所要解决的技术问题是提供一种基于B样条曲线的数据点的拟合方法及装置,它能够对数据点进行精确拟合,满足了拟合需求。
为解决上述技术问题,本发明提供了一种基于B样条曲线的数据点的拟合方法,包括:
将未知曲面的测量数据点Qi(i=0,1,...,n)作为B样条曲线的控制点
定义节点向量t0=...=tk-1=0,tr-k+1=...=tr=1, 其中,设τ0=0,
根据所述控制点和所述节点向量构造B样条曲线其中,k为曲线的阶数,r=n+k;
在所构造的B样条曲线上,找到与每一个数据点最近的点
设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线重复所述在所构造的B样条曲线上,找到与每一个数据点最近的点直至最短间距在误差限内。
进一步地,所述在所构造的B样条曲线上,找到与每一个数据点 最近的点包括:通过牛顿迭代的方法在所述构造的B样条曲线上,找到与每一个数据点最近的点
进一步地,还包括:在第j次迭代中,设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为Oi,j,与曲率圆的交点为Mi,j;比较在r(ti,j)切线方向投影()与|r(ti,j)Mi,j|的大小;
若则
若则
若则Δt=0,即找到与当前数据点最近的点
进一步地,所述重复所述在所构造的B样条曲线上,找到与每一个数据点最近的点直至最短间距在误差限内,包括:重复所述牛顿迭代的方法直到第α次迭代后,在误差限内。
进一步地,所述误差限为1e-9。
本发明提供的一种基于B样条曲线的数据点的拟合装置,包括:
控制点设置模块,用于将未知曲面的测量数据点Qi(i=0,1,...,n)作为B样 条曲线的控制点
节点向量定义模块,用于定义节点向量t0=...=tk-1=0,tr-k+1=...=tr=1, 其中,设τ0=0,
B样条曲线构造模块,用于根据所述控制点和所述节点向量构造B样条曲线其中,k为曲线的阶数,r=n+k;
数据点获取模块,用于在所构造的B样条曲线上,找到与每一个数据点最近的点
校验模块,用于设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线重复所述在所构造的B样条曲线上,找到与每一个数据点最近的点直至最短间距在误差限内。
进一步地,所述数据点获取模块,具体用于通过牛顿迭代的方法在所述构造的B样条曲线上,找到与每一个数据点最近的点
进一步地,所述数据点获取模块,包括:
比较单元,用于在第j次迭代中,设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为Oi,j,与曲率圆的交点为Mi,j;比较在r(ti,j)切线方向投影()与|r(ti,j)Mi,j|的大小;
若则
若则
若则Δt=0,即找到与当前数据点最近的点
数据点获取执行单元,用于将当前数据点的位置加上步长Δt构成新的数据点,并构造B样条曲线,在所述构造的B样条曲线上,找到与每一个数据点 最近的点
进一步地,所述校验模块,包括:
曲线重构单元,用于设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线
循环执行单元,用于重复所述牛顿迭代的方法直到第α次迭代后, 在误差限内。
进一步地,所述误差限为1e-9。
本发明的有益效果在于:
本发明提供的基于B样条曲线的数据点的拟合方法及装置,将需要拟合的数据点作为控制点,并定义节点向量,产生B样条曲线,同时在B样条曲线上寻找与已知数据点距离最近的点,并且利用该最近点与数据点的向量更新控制点,产生新的曲线,重复进行该过程直到需要拟合的数据点与曲线的最短距离满足误差限,从而实现了数据点的精确拟合,满足了拟合需求。
附图说明
图1为本发明实施例提供的基于B样条曲线的数据点的拟合方法的流程图;
图2为通过本发明实施例提供的基于B样条曲线的数据点的拟合方法对未知曲面的测量数据点进行B样条曲线拟合的曲线图。
具体实施方式
为进一步阐述本发明为达成预定发明目的所采取的技术手段及功效,以下结合附图及较佳实施例,对依据本发明提出的基于B样条曲线的数据点的拟合方法及装置的具体实施方式及工作原理进行详细说明。
参见图1,本发明实施例提供的基于B样条曲线的数据点的拟合方法,包括:
步骤S110:将未知曲面的测量数据点Qi(i=0,1,...,n)作为B样条曲线的控制点
步骤S120:定义节点向量t0=...=tk-1=0,tr-k+1=...=tr=1, 其中,设τ0=0,
步骤S130:根据控制点和节点向量构造B样条曲线其中,k为曲线的阶数,r=n+k;
步骤S140:在所构造的B样条曲线上,获得与每一个数据点 最近的点 即满足也即向量 的切线正交;在本发明实施例中,通过牛顿迭代的方法在构造的B样条曲线上,获得与每一个数据点最近的点 需要说明的是,在第j次迭代中,设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为Oi,j,与曲率圆的交点为Mi,j;比较 在r(ti,j)切线方向投影与|r(ti,j)Mi,j|的大小;
若则
若则
若则Δt=0,即获得与当前数据点最近的点
步骤S150:设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线重复在所构造的B样条曲线上,获得与每一个数据点最近的点直至最短间距,其中最短间距在误差限内。在本发明实施例中,重复牛顿迭代的方法直到第α次迭代后,在误差限内。其中,误差限为1e-9。
本发明实施例提供的一种基于B样条曲线的数据点的拟合装置,包括:
控制点设置模块,用于将未知曲面的测量数据点Qi(i=0,1,...,n)作为B样条曲线的控制点
节点向量定义模块,用于定义节点向量t0=...=tk-1=0,tr-k+1=...=tr=1, 其中,设τ0=0,
B样条曲线构造模块,用于根据控制点和节点向量构造B样条曲线 其中,k为曲线的阶数,r=n+k;
数据点获取模块,用于在所构造的B样条曲线上,获得与每一个数据点最近的点 即满足也即向量和的切线正交;在本发明实施例中,数据点获取模块,具体用于通过牛顿迭代的方法在构造的B样条曲线上,获得与每一个数据 点最近的点
对本模块进行具体的说明,数据点获取模块,包括:
比较单元,用于在第j次迭代中,设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为Oi,j,与曲率圆的交点为Mi,j;比较在r(ti,j)切线方向投影)与|r(ti,j)Mi,j|的大小;
若则
若则
若则Δt=0,即获得与当前数据点最近的点
数据点获取执行单元,用于将当前数据点的位置加上步长Δt构成新的数据点,并构造B样条曲线,在构造的B样条曲线上,获得与每一个数据点 最近的点
校验模块,用于设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线重复在所构造的B样条曲线上,获得与每一个数据点最近的点直至最短间距,其中最短间距在误差限内。
对本模块进行说明,校验模块,包括:
曲线重构单元,用于设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线
循环执行单元,用于重复牛顿迭代的方法直到第α次迭代后, 在误差限内。其中的误差限为1e-9。
实施例:
(1)根据测量而得的201个数据点Qi(i=0,1,...,200),假设这些数据点为 B样条曲线的控制点定义节点向量t0=...=t3=0,t201=...=t204=1, 其中,设τ0=0, 根据控制点与节点向量,构造出四阶B样条曲线
(2)令P0=Q0,P200=Q200,对于每一个数据点获得与步骤(1)中得到的B样条曲线上近的点,即满足也即向量 和的切线正交。在计算机中浮点数计算,并不存在完全等于0的情况,这里采用代替。在本步骤中,具体通过牛顿迭代的方法获得与步骤(1)中得到的B样条曲线上近的点。在第j次迭代中,假设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为 与曲率圆的交点为Mi,j,比较在r(ti,j)切线方向投影 与|r(ti,j)Mi,j|的大小;若则 若则 若则Δt=0,即获得与当前数据点最近的点
(3)根据步骤(2)得到的位置i=1,2,3,...,n-1,更新Pi (1),令 P0 (2)=Q0,Pn (2)=Qn作为新的控制点,构造曲线 重复步骤(2)直到第α次迭代后,在误差限1e-9内。
由图2可知,通过本发明实施例构造的B样条曲线与测量的数据点之间的距离误差在误差限内,因而本发明实施例的拟合精度高,很好地展示 了未知曲面的二维平面特征。
本发明实施例提供的基于B样条曲线的数据点的拟合方法及装置,将需要拟合的测量数据点作为控制点,并定义节点向量,产生初始的B样条曲线;通过牛顿迭代的方法,在初始的B样条曲线上寻找与已知数据点距离最近的点;使用最近点与测量数据点的向量更新控制点,产生新的曲线,重复进行该过程直到测量数据点与曲线的最短距离满足误差限,从而实现了数据点的精确拟合,满足了拟合需求。
本发明实施例在通过牛顿迭代的方法在初始的B样条曲线上寻找与已知数据点距离最近的点的过程中,选择合适的迭代步长,可以加快寻找曲线上距离测量数据点最近的点的速度,实现数据点的快速拟合。本发明实施例能够实现在满足误差限的前提下,实现测量数据点拟合的快速收敛,并且适用于CAD应用系统,便于推广。
最后所应说明的是,以上具体实施方式仅用以说明本发明的技术方案而非限制,尽管参照实例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或者等同替换,而不脱离本发明技术方案的精神和范围,其均应涵盖在本发明的权利要求范围当中。
Claims (10)
1.一种基于B样条曲线的数据点的拟合方法,其特征在于,包括:
将未知曲面的测量数据点Qi(i=0,1,...,n)作为B样条曲线的控制点
定义节点向量t0=…=tk-1=0,tr-k+1=…=tr=1,
根据所述控制点和所述节点向量构造B样条曲线其中,k为曲线的阶数,r=n+k;
在所构造的B样条曲线上,获得与每一个数据点最近的点
设 更新Pi (1)为Pi (2)作为新的控制点,构造曲线重复所述在所构造的B样条曲线上,获得与每一个数据点最近的点直至最短间距,其中所述最短间距在误差限内。
2.如权利要求1所述的基于B样条曲线的数据点的拟合方法,其特征在于,所述在所构造的B样条曲线上,获得与每一个数据点最近的点包括:通过牛顿迭代的方法在所述构造的B样条曲线上,获得与每一个数据点最近的点
3.如权利要求2所述的基于B样条曲线的数据点的拟合方法,其特征在于,还包括:在第j次迭代中,设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为与曲率圆的交点为Mi,j;比较在r(ti,j)切线方向投影与|r(ti,j)Mi,j|的大小;
若 则
若 则
若 则Δt=0,即获得与当前数据点最近的点
4.如权利要求3所述的基于B样条曲线的数据点的拟合方法,其特征在于,所述重复所述在所构造的B样条曲线上,获得与每一个数据点最近的点直至最短间距,其中所述最短间距在误差限内,包括:重复所述牛顿迭代的方法直到第α次迭代后, 在误差限内。
5.如权利要求1-4中任一项所述的基于B样条曲线的数据点的拟合方法,其特征在于,所述误差限为1e-9。
6.一种基于B样条曲线的数据点的拟合装置,其特征在于,包括:
控制点设置模块,用于将未知曲面的测量数据点Qi(i=0,1,...,n)作为B样条曲线的控制点
节点向量定义模块,用于定义节点向量t0=…=tk-1=0,tr-k+1=…=tr=1, 其中,设τ0=0,
B样条曲线构造模块,用于根据所述控制点和所述节点向量构造B样条曲线其中,k为曲线的阶数,r=n+k;
数据点获取模块,用于在所构造的B样条曲线上,获得与每一个数据点最近的点
校验模块,用于设 P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线重复所述在所构造的B样条曲线上,获得与每一个数据点最近的点直至最短间距,其中所述最短间距在误差限内。
7.如权利要求6所述的基于B样条曲线的数据点的拟合装置,其特征在于,所述数据点获取模块,具体用于通过牛顿迭代的方法在所述构造的B样条曲线上,获得与每一个数据点最近的点
8.如权利要求7所述的基于B样条曲线的数据点的拟合装置,其特征在于,所述数据点获取模块,包括:
比较单元,用于在第j次迭代中,设当前点位置为ti,j,迭代步长为Δt,当前位置处的曲率圆为与曲率圆的交点为Mi,j;比较在r(ti,j)切线方向投影与|r(ti,j)Mi,j|的大小;
若 则
若 则
若 则Δt=0,即获得与当前数据点最近的点
数据点获取执行单元,用于将当前数据点的位置加上步长Δt构成新的数据点,并构造B样条曲线,在所述构造的B样条曲线上,获得与每一个数据点 最近的点
9.如权利要求8所述的基于B样条曲线的数据点的拟合装置,其特征在于,所述校验模块,包括:
曲线重构单元,用于设P0 (2)=Q0,Pn (2)=Qn,更新Pi (1)为Pi (2)作为新的控制点,构造曲线
循环执行单元,用于重复所述牛顿迭代的方法直到第α次迭代后, 在误差限内。
10.如权利要求6-9中任一项所述的基于B样条曲线的数据点的拟合装置,其特征在于,所述误差限为1e-9。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410722418.3A CN104517032A (zh) | 2014-12-02 | 2014-12-02 | 一种基于b样条曲线的数据点的拟合方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201410722418.3A CN104517032A (zh) | 2014-12-02 | 2014-12-02 | 一种基于b样条曲线的数据点的拟合方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN104517032A true CN104517032A (zh) | 2015-04-15 |
Family
ID=52792322
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201410722418.3A Pending CN104517032A (zh) | 2014-12-02 | 2014-12-02 | 一种基于b样条曲线的数据点的拟合方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN104517032A (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105425725A (zh) * | 2015-12-09 | 2016-03-23 | 华中科技大学 | 一种离散刀具轨迹的曲线拟合方法 |
CN108733973A (zh) * | 2018-05-11 | 2018-11-02 | 深圳晶泰科技有限公司 | 一种自动高效dftb排斥势拟合方法 |
CN109446480A (zh) * | 2018-09-03 | 2019-03-08 | 北京航空航天大学 | 一种基于b样条的阻尼振荡频谱数据预处理方法 |
CN113343328A (zh) * | 2021-06-08 | 2021-09-03 | 中国空气动力研究与发展中心计算空气动力研究所 | 一种基于改进牛顿迭代的高效最近点投影方法 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103488825A (zh) * | 2013-09-10 | 2014-01-01 | 太原理工大学 | 一种用于齿轮齿廓曲线重构的数据拟合方法 |
CN103592665A (zh) * | 2013-11-15 | 2014-02-19 | 厦门雅迅网络股份有限公司 | 基于b样条曲线的车载终端定位轨迹拟合方法 |
-
2014
- 2014-12-02 CN CN201410722418.3A patent/CN104517032A/zh active Pending
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103488825A (zh) * | 2013-09-10 | 2014-01-01 | 太原理工大学 | 一种用于齿轮齿廓曲线重构的数据拟合方法 |
CN103592665A (zh) * | 2013-11-15 | 2014-02-19 | 厦门雅迅网络股份有限公司 | 基于b样条曲线的车载终端定位轨迹拟合方法 |
Non-Patent Citations (6)
Title |
---|
HUAIPING YANG ET AL.: "Control point adjustment for B-spline curve approximation", 《COMPUTER-AIDED DESIGN》 * |
HYUNGJUN PARK ET AL.: "B-spline curve fitting based on adaptive curve refinement using dominant points", 《COMPUTER-AIDED DESIGN》 * |
周红梅等: "基于最小控制点的非均匀有理B样条曲线拟合", 《西安交通大学学报》 * |
张春莹: "平面点云的曲线拟合与匹配算法", 《中国优秀硕士学位论文全文数据库信息科技辑》 * |
肖轶军等: "基于迭代最近点的B样条曲线拟合方法研究", 《中国图像图形学报》 * |
赵世田等: "测量数据点的高精度B样条曲线拟合算法", 《计算机集成制造系统》 * |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN105425725A (zh) * | 2015-12-09 | 2016-03-23 | 华中科技大学 | 一种离散刀具轨迹的曲线拟合方法 |
CN105425725B (zh) * | 2015-12-09 | 2017-10-31 | 华中科技大学 | 一种离散刀具轨迹的曲线拟合方法 |
CN108733973A (zh) * | 2018-05-11 | 2018-11-02 | 深圳晶泰科技有限公司 | 一种自动高效dftb排斥势拟合方法 |
CN108733973B (zh) * | 2018-05-11 | 2021-06-04 | 深圳晶泰科技有限公司 | 一种自动高效dftb排斥势拟合方法 |
CN109446480A (zh) * | 2018-09-03 | 2019-03-08 | 北京航空航天大学 | 一种基于b样条的阻尼振荡频谱数据预处理方法 |
CN113343328A (zh) * | 2021-06-08 | 2021-09-03 | 中国空气动力研究与发展中心计算空气动力研究所 | 一种基于改进牛顿迭代的高效最近点投影方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN104517032A (zh) | 一种基于b样条曲线的数据点的拟合方法及装置 | |
CN104392047B (zh) | 一种基于平稳滑翔弹道解析解的快速弹道规划方法 | |
CN106599427B (zh) | 一种基于贝叶斯理论和气垫船姿态信息的海浪信息预测方法 | |
CN103344260B (zh) | 基于rbckf的捷联惯导系统大方位失准角初始对准方法 | |
CN103940420B (zh) | 等航程大圆航线设计方法 | |
CN104077496A (zh) | 基于差分进化算法的智能管道布局优化方法和系统 | |
CN103777518B (zh) | 基于改进的最小二乘法的卫星导航授时系统及方法 | |
CN102606564B (zh) | 超声速流道的实现方法和装置 | |
WO2017106728A3 (en) | Repeat protein architectures | |
CN104536442A (zh) | 一种基于动态规划的水下航行器路径规划方法 | |
CN105509750A (zh) | 一种天文测速与地面无线电组合的火星捕获段导航方法 | |
CN103297162A (zh) | Gssk调制通信系统中基于压缩感知的信号检测方法 | |
CN105093926A (zh) | 一种迭代学习控制参考轨迹的优化匹配组合方法 | |
Butusov et al. | Simulation of dynamical systems based on parallel numerical integration methods | |
CN104640201A (zh) | 基于wifi指纹技术的定位方法和装置 | |
CN105807093A (zh) | 一种基于粒子图像测速技术的加速度测量方法及装置 | |
CN103152825A (zh) | 一种适用于无线传感器网络的分布式非测距定位方法 | |
Chen et al. | An ibeacon assisted indoor localization and tracking system | |
CN103674022B (zh) | 一种快速脉冲星导航整周模糊度解算方法 | |
CN105741345A (zh) | 点云法向量调整方法及系统 | |
Brezillon et al. | Aerodynamic inverse design framework using discrete adjoint method | |
CN106990423A (zh) | 一种卫星导航定位整周模糊度有效性检验方法 | |
CN103761744B (zh) | 通用型二维点云分组方法 | |
CN103017766A (zh) | 一种大航向快速粗对准方法 | |
CN107273572B (zh) | 一种基于等力密度法的曲面两点间测地线索段找形方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20150415 |