测树学weibull拟合matlab程序,难者不会,会者不难

function [N,k,x,dbh,n_fit parmhat, parmci]=WblDbh(n,a,W)
% 根据整化的径阶,进行weibull拟合
% n : 径阶株数
% dbh : 各株的胸径大小
% N 株数
% k 径阶数
% x 径阶胸径
% n_fit 各径阶拟合值
% parmhat, parmci weibull拟合结果

%W = 1; %径阶距
%a = 6; %起测胸径
dbh = [];
for i = 1:length(n)
  
    %tmp = GetDbhFrom(i,a,W)*ones(n(i),1);
    tmp = GetDbhFrom(i,0,W)*ones(n(i),1);
    dbh = [dbh;tmp];
end
N = length(dbh);
k = length(n);
%dbh = dbh - a;  % 起测胸径平移
[parmhat parmci]= wblfit(dbh);
A=parmhat(1)
B=parmhat(2)
%figure();
f=k-3-1; %自由度
%x = W/2: W : k*W; %径阶中值
x = GetDbhFrom([1:k],0,W);
%x = GetDbhFrom([1:k],a,W);
%各径阶理论株数;
n_fit=round( N*W*B/A*power(x/A,B-1).*exp(-1*power(x/A,B)));
%n_fit = round( N*W * wblpdf(x, A,B));
figure;
plot(x +a,n,'*',x+a ,n_fit,'-o');
%chi-test
end

 

function dbh = GetDbhFrom(i,a,W)
%W = 1; %径阶距
%a = 6; %起测胸径
%dbh 第i径阶的胸径

dbh = W/2 + a + (i-1)*W;
end

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值