非均匀B样条拟合MATLAB程序
直接上代码,多的不再说了。
1、写一个Base函数
function result = Bbase(i,k,u,t)
%第i段k次B样条基,Deboor递推递归算法
%t为变量,u(i)<=t<u(i+),k=0时result=;
if(k==)
if(u(i)<=t && t<u(i+))%注意1=u(i)<=t<u(i+)=1时的情况,这里要用t<=u(i+);
result=;
return;
else
result=;
return;
end
else
if(u(i+k)-u(i)==)
alpha=;
else
alpha=(t-u(i))/(u(i+k)-u(i));
end
if(u(i+k+)-u(i+)==)
beta=;
else
beta=(u(i+k+)-t)/(u(i+k+)-u(i+));
end
end
result=alpha*Bbase(i,k-,u,t)+beta*Bbase(i+,k-,u,t);
2、B样条程序
%------------------非均匀B样条拟合MATLAB程序-----------------
clear
k=;
x=load('data.txt');
[n,m]=size(x);
%-----------弦长参数化--------------------------------------
u(k+n)=;
for i=:n-
u(k+i+)=u(k+i)+sqrt((x(i+,)-x(i,))^+(x(i+,)-x(i,))^);
end;
L=u(n+k);
for i=:n
u(k+i)=u(k+i)/L;
end;
for i=:
u(k+i+n)=;
end
%控制多边线
plot(x(:,),x(:,),'o');
hold on
%------------反求n+2个控制点--------------------
%首位重节点v1=v2
%首位与控制多边形相切
A=zeros(n+);
A(,)=;A(,)=-;
A(,)=;
A(n+,n+)=-;A(n+,n+)=;
A(n+,n+)=;
for i=:n
for j=:
A(i,i+j-)=Base(i+j-,k,u,u(i+));
end
end
%e:方程右边.
e=;
for i=:m
e(n+,i)=;
end
for i=:n
e(i+,:)=x(i,:);
end
%求出控制点d
d=inv(A)*e;
plot(d(:,),d(:,),'g'); hold on
%------------插值并作出样条曲线-----------------
x=;y=;down=;
for j=:(n-)
uu=(u(j+)):0.0005:u(j+);
for kk=:length(uu)
down=down+;
x(down)=d(j,)*Base(j,,u,uu(kk))+d(j+,)*Base(j+,,u,uu(kk))+d(j+,)*Base(j+,,u,uu(kk))+d(j+,)*Base(j+,,u,uu(kk));
y(down)=d(j,)*Base(j,,u,uu(kk))+d(j+,)*Base(j+,,u,uu(kk))+d(j+,)*Base(j+,,u,uu(kk))+d(j+,)*Base(j+,,u,uu(kk));
end
end
axis('equal'); plot(x,y,'red'); xlabel('x');ylabel('y');
grid on
参考文章
非均匀B样条拟合MATLAB程序的更多相关文章
- 蚁群算法 matlab程序(已执行)
下面是解放军信息project大学一个老师编的matlab程序,请尊重原作者劳动,引用时请注明出处. 我经过改动添加了凝视,已经执行过,无误, function [R_best,L_best,L_av ...
- MATLAB程序:用FCM分割脑图像
MATLAB程序:用FCM分割脑图像 作者:凯鲁嘎吉 - 博客园http://www.cnblogs.com/kailugaji/ 脑图像基础知识请看:脑图像:FCM算法介绍请看:聚类——FCM:数据 ...
- mean shift聚类算法的MATLAB程序
mean shift聚类算法的MATLAB程序 凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 1. mean shift 简介 mean shift, 写的 ...
- OpenFOAM——设置非均匀边界方法总结
在使用OpenFOAM求解的时候我们经常需要设置非均匀的边界,比如我们在计算层流的时候,很多时候需要入口为充分发展的入口边界,下面我们就以入口处为充分发展的层流速度分布为总结OpenFOAM当中设定不 ...
- 【转】小波与小波包、小波包分解与信号重构、小波包能量特征提取 暨 小波包分解后实现按频率大小分布重新排列(Matlab 程序详解)
转:https://blog.csdn.net/cqfdcw/article/details/84995904 小波与小波包.小波包分解与信号重构.小波包能量特征提取 (Matlab 程序详解) ...
- WPF:指定的命名连接在配置中找不到、非计划用于 EntityClient 提供程序或者无效的解决方法
文/嶽永鹏 WPF 数据绑定中绑定到ENTITY,如果把数据文件做成一个类库,在UI文件中去应用它,可能遇到下面这种情况. 指定的命名连接在配置中找不到.非计划用于 EntityClient 提供程序 ...
- [zz]求一维序列的信息熵(香浓熵)的matlab程序实例
对于一个二维信号,比如灰度图像,灰度值的范围是0-255,因此只要根据像素灰度值(0-255)出现的概率,就可以计算出信息熵. 但是,对于一个一维信号,比如说心电信号,数据值的范围并不是确定的, ...
- 条件随机场matlab程序下载
19:44:23 1 http://www.cs.ubc.ca/~murphyk/Software/CRF/crf.html matlab程序包: 该条件随机场程序(CRF)是针对语句进行标注,mat ...
- 【matlab】MATLAB程序调试方法和过程
3.8 MATLAB程序的调试和优化 在MATLAB的程序调试过程中,不仅要求程序能够满足设计者的设计需求,而且还要求程序调试能够优化程序的性能,这样使得程序调试有时比程序设计更为复杂.MATLAB ...
随机推荐
- jq 7种实例化
$(html) ->$(array) $(html,{}||$(...)) $(#id) $(expr,$(...)) $(expr,context) $(dom) $(function(){} ...
- CoInitialize()、CoInitializeEx()和AfxOleInit()区别联系
CoInitialize()和AfxOleInit() 都是初始化COM库,不同之处在与: OLE是建立在COM之上的技术,层次比COM要高.AfxOleInit()调用的是OleInitialize ...
- jq获取元素到底部的距离
// var wh = $(window).height(),//是文档窗口高度 // ot = $("#icoimg").offset().top,//是标签距离顶部高度 // ...
- jQuery列表拖动排列-jquery list dragsort插件参数和使用方法
在编写网页的时候,有时可能需要对ul的li进行排序,今天就给大家推荐使用jquery插件jquery list dragsort实现列表拖动排序效果. 效果如图: jquery list dragso ...
- 算法导论_ch2
Ch2算法基础 whowhoha@outlook.com 2.1 插入排序 输入:n个数的一个序列〈a1,a2,…,an〉. 输出:输入序列的一个排列〈a′1,a′2,…,a′n〉,满足a′1≤a′2 ...
- SpringMVC ResponseBody返回中文乱码解决方案
@RequestMapping(value = "/getForm") @ResponseBody public List<String> getForm(String ...
- android 设置gridView item的高度
public View getView(int position, View convertView, ViewGroup parent) { convertView = LayoutInflater ...
- java CMS gc解析
转载: http://www.blogjava.net/killme2008/archive/2009/09/22/295931.html CMS,全称Concurrent Low Pause ...
- java main()静态方法
java main()方法是静态的.意味着不需要new(),就在内存中存在.而且是属于类的,但是对象还是可以调用的. 若干个包含这个静态属性和方法的对象引用都可以指向这个内存区域.这个内存区域发生改变 ...
- 如何理解IoC/DI
IoC:Inversion of Control,控制反转DI:Dependency Injection,依赖注入 要理解上面两个概念,就必须搞清楚如下的问题: 参与者都有谁?依赖:谁依赖于谁?为什么 ...