24小时热门版块排行榜    

Znn3bq.jpeg
查看: 351  |  回复: 1
【奖励】 本帖被评价1次,作者fspdlh增加金币 1
当前主题已经存档。

fspdlh

金虫 (正式写手)


[资源] 【原创】三点法或五点法数值求导程序

把以下代码拷到m文件里就可以了
function y=NumDiff(X,Y,x,method_fit,point_min_ins,method_diff)
% Get the differential coefficient of data base on X and Y
% y=NumDiff(X,Y)
% y=NumDiff(X,Y,x)
% y=NumDiff(X,Y,x,method_fit)
% y=NumDiff(X,Y,x,method_fit,point_min_ins)
% y=NumDiff(X,Y,x,method_fit,point_min_ins,method_diff)
%   X Y  must be vectors of the same length,raw data
%   x    points output
%   method_fit   the method of fit,'spline' or 'pchip'
%   point_min_ins   numbers of points input to the nearest step of X
%   method_diff   3 or 5, 3 points method or 5 points method

%--------------------------------------------------------------------------
%paraments initialization
if nargin<2
    error('Not enough paraments!');
end
if nargin<3
    x=X;
end
if nargin<4
    method_fit='pchip';
end
if nargin<5
    point_min_ins=5;
end
point_min_ins=point_min_ins+1;
if nargin<6
    method_diff=5;
elseif method_diff~=3 && method_diff~=5
    error('method error');
end
[m_X n_X]=size(X);
if m_X==1 && n_X>1
    X=X';
    temp=m_X;
    m_X=n_X;
    n_X=temp;
elseif m_X>1 && n_X>1
    error('X must be a vector');
end
[m_Y n_Y]=size(Y);
if m_Y~=m_X && n_Y==m_X
    Y=Y';
elseif m_Y~=m_X && n_Y~=m_X
    error('X and Y must have the same groups of data!');
end
%--------------------------------------------------------------------------
%step
N=ceil(   (    max(X)-min(X)    )/ ...
          ( min(abs(diff(X))/point_min_ins ) )  )+1;
h=(max(X)-min(X))./(N-1);
X1=[min(X):h:max(X)]';
Y1=interp1(X,Y,X1,method_fit);
%--------------------------------------------------------------------------
%coefficient
coef=zeros(N,N);
if method_diff==5
    coef(1:2,1:5)=[-25 48 -36 16 -3;-3 -10 18 -6 1];
    coef(3:N+1:N*(N-4))=1;
    coef(N+3:N+1:N*(N-3))=-8;
    coef(3*N+3:N+1:N*(N-1))=8;
    coef(4*N+3:N+1:N*N)=-1;
    coef(N-1:N,N-4:N)=[-1 6 -18 10 3;3 -16 36 -48 25 ];
    coef=coef./12;
elseif method_diff==3
    coef(1,1:3)=[-3 4 -1];
    coef(2:N+1:N*(N-2))=-1;
    coef(2*N+2:N+1:N*N)=1;
    coef(N,N-2:N)=[1 -4 3];
    coef=coef./2;
end
%--------------------------------------------------------------------------
%output
dif=coef*Y1./h;
y=interp1(X1,dif,x,method_fit);

[ Last edited by fspdlh on 2009-4-16 at 16:41 ]
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

sunxiao

荣誉版主 (著名写手)


★★★★★ 五星级,优秀推荐

谢谢提供
2楼2009-03-20 13:46:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 fspdlh 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 今年审到国自然15份,谈谈感受 +19 国自然国社科中 2026-05-17 20/1000 2026-05-20 14:14 by 仲夏夜的星星
[论文投稿] Sci. Bull. 悲剧经验 +4 jyang1999 2026-05-16 5/250 2026-05-20 13:49 by jyang1999
[基金申请] 国自然评分 +3 无名者登山 2026-05-20 4/200 2026-05-20 13:29 by vito刘
[基金申请] 面上本子正文33页,违规吗?会被低分嘛? +9 1234567wang 2026-05-17 11/550 2026-05-20 12:37 by zhuzg0628
[基金申请] 评审有感 +13 popular289 2026-05-18 22/1100 2026-05-20 11:28 by 水和泥不是水泥
[有机交流] 反应很差,大量原料没有反应 5+3 Mr.Zot 2026-05-19 6/300 2026-05-20 10:36 by xtlilibin
[基金申请] 河北省自然科学基金 +3 Peterchao 2026-05-18 3/150 2026-05-20 08:57 by 霸_霸
[教师之家] 上海大学实验技术岗位非升即走 +12 嘻嘻哈哈乐呵呵 2026-05-15 13/650 2026-05-20 08:34 by xli1984
[文学芳草园] 献血感触 +6 呀呀好傻 2026-05-19 11/550 2026-05-19 22:26 by 而立得乐
[考博] 云南大学材料与能源学院解琳课题组钙钛矿博士招生 +3 光伏爱好者 2026-05-17 5/250 2026-05-19 19:13 by 光伏爱好者
[考博] 找博士生导师 +6 小代想上岸 2026-05-15 7/350 2026-05-19 10:22 by free_fisher
[考博] 26/27申博自荐-锂/钠电池方向 5+3 狗头军师. 2026-05-15 4/200 2026-05-19 09:10 by moonboat
[基金申请] 别被青基扩招骗了!26年科研内卷才刚刚开始 +3 国自然国社科中 2026-05-14 4/200 2026-05-19 08:48 by archvillain
[考博] 2026博士还有哪些学校有名额 +7 小王求读研 2026-05-15 8/400 2026-05-19 08:27 by zhyzzh
[考博] 博士申请 +5 星…… 2026-05-18 6/300 2026-05-18 23:49 by 糊糊涂涂好
[基金申请] 国自然上会要求 +5 无名者登山 2026-05-18 9/450 2026-05-18 17:50 by BlakeReary
[硕博家园] 我在等一个没有答案的答案 +3 Love_MH 2026-05-17 3/150 2026-05-18 02:22 by 竹林孤影
[文学芳草园] 半夜喝咖啡 +3 myrtle 2026-05-15 5/250 2026-05-18 01:03 by 小沈2018
[有机交流] 求助2,4-二氯-5-嘧啶甲醛的合成方法 20+3 光吃不拉 2026-05-14 6/300 2026-05-16 19:46 by Equinoxhua
[考博] 材料类只有一篇综述能申博么 +4 乐逍遥谷 2026-05-13 4/200 2026-05-14 12:05 by zhyzzh
信息提示
请填处理意见