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

📄 knt2mlt.m

📁 演示matlab曲线拟和与插直的基本方法
💻 M
字号:
function [m,t] = knt2mlt(t)
%KNT2MLT Knot multiplicities.
%
%   KNT2MLT(T) returns the vector M of knot multiplicities. Precisely,
%
%   M(i) = # { j<i : T(j) = T(i) },  i=1:length(T),
%
%   with T here first sorted if the input is not.
%
%   [M,T] = KNT2MLT(T) also returns the sorted knot sequence.
%
%   For example, [m,t] = knt2mlt([ 1 2 3 3 1 3]) returns 
%   [0 1 0 0 1 2] for m and [1 1 2 3 3 3] for t.
%
%   See also KNT2BRK, BRK2KNT.

%   cb 16aug96; 31jan97 (change name, from MLTKNT to KNT2MLT)
%   cb 06may98 (standardize the help)
%   Copyright 1987-2003 C. de Boor and The MathWorks, Inc. 
%   $Revision: 1.14 $

[r,c] = size(t);
if r*c<2 m=0; return, end

difft = diff(t); if any(difft<0) t = sort(t); difft = diff(t); end

index = zeros([r,c]); index(2:end) = difft==0;
m = cumsum(index);
zz = find(diff(index)<0);
if isempty(zz) return, end

z = zeros([r,c]);
pt = m(zz);
pt(2:end) = diff(pt);
z(zz+1) = pt;
m = m - cumsum(z);

⌨️ 快捷键说明

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