⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rpmak.m

📁 演示matlab曲线拟和与插直的基本方法
💻 M
字号:
function rp = rpmak(breaks,coefs,d)
%RPMAK Put together a rational spline in rpform.
%
%   RPMAK(BREAKS,COEFS), RPMAK(BREAKS,COEFS,D) and RPMAK(BREAKS,COEFS,SIZEC)
%   all return the rpform of the rational spline specified by the input, with 
%   COEFS interpreted according to whether or not the third input argument is 
%   present. 
%
%   This is exactly the output of 
%   RPMAK(BREAKS,COEFS), RPMAK(BREAKS,COEFS,D+1) and RPMAK(BREAKS,COEFS,SIZEC)
%   except that it is tagged to be the rpform of a rational spline, namely the
%   rational spline whose denominator is provided by the last component of the 
%   spline, while its remaining components describe the numerator.
%
%   In particular, the input coefficients must be (d+1)-vector valued for some
%   d>0 and cannot be ND-valued.
%
%   For example, since ppmak([-5 5],[1 -10 26]) provides the ppform
%   of the polynomial  t |-> t^2+1  on the interval [-5 .. 5], while 
%   ppmak([-5 5], [0 0 1]) provides the ppform of the quadratic polynomial
%   t |-> 1  there, the command
%
%      runge = rpmak([-5 5],[0 0 1; 1 -10 26],1);
%
%   provides the rpform on the interval [-5 .. 5] for the rational function 
%   t |-> 1/(t^2+1)  famous from Runge's example concerning polynomial inter-
%   polation at equally spaced sites.
%
%   See also RPBRK, RSMAK, PPMAK, SPMAK, FNBRK.

%   Copyright 1987-2003 C. de Boor and The MathWorks, Inc.
%   $Revision: 1.12 $  $Date: 2003/04/25 21:12:06 $

if nargin>2
   if length(d)==1, d = d+1; end
   rp = ppmak(breaks,coefs,d);
else
   rp = ppmak(breaks,coefs);
end

dp1 = fnbrk(rp,'dim');
if length(dp1)>1
   error('SPLINES:RPMAK:onlyvec','A rational spline cannot be ND-valued.')
end
if dp1==1
   error('SPLINES:RPMAK:needmorecomps', ...
         'A rational spline must have more than one component.')
end
rp.dim = dp1-1; rp.form = 'rp';

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -