fitnlm either runs perfectly or crashes with nearly identical data

조회 수: 7 (최근 30일)
I am using fitnlm to do a simple curve fit. Most of the time it runs perfectly, but every now and then nearly identical data will cause it to crash, and I am not sure why. Here is an example that runs perfectly:
Here is an example where it doesn't work. Both example codes are attached, along with the function "weibull.m" which defines the fit.
Thank you very much for your help with this. It really has be baffled.
  댓글 수: 1
Clay Swackhamer
Clay Swackhamer 2020년 10월 7일
Pasting the full error message here:
Error using internal.stats.getscheffeparam>ValidateParameters (line 182)
If non-empty, JW must be a numeric, real matrix.
Error in internal.stats.getscheffeparam (line 110)
[J,VF,VP,JW,Intopt,TolSVD,TolE,VQ,usingJ] = ValidateParameters(J,VF,VP,JW,Intopt,TolSVD,TolE,VQ,allowedIntopt);
Error in nlinfit (line 441)
sch = internal.stats.getscheffeparam('WeightedJacobian',J(~nans,:),'Intopt','observation','VQ',VQ);
Error in NonLinearModel/fitter (line 1127)
nlinfit(X,y,F,b0,opts,wtargs{:},errormodelargs{:});
Error in classreg.regr.FitObject/doFit (line 94)
model = fitter(model);
Error in NonLinearModel.fit (line 1434)
model = doFit(model);
Error in fitnlm (line 99)
model = NonLinearModel.fit(X,varargin{:});
Error in fitnlm_broken (line 20)
mdl = fitnlm(x,y,@weibull,betaNot) %crashes here

댓글을 달려면 로그인하십시오.

채택된 답변

Gaurav Garg
Gaurav Garg 2020년 10월 13일
Hi Clay,
The roots returned in the latter case (fitnlm_broken.m) are imaginary, hence, you receive the error "JW must be scalar or real matrix". To know this, you can put a breakpoint on the 23rd line (x50 = ...) and replace fitnlm by nlinfit, and check the variable mdl (returns the model parameters) which are not real in your case.
Since the parameters are not full rank matrix, the model can not fit the x- and y- parameters.
A solution to this could be that you can try making your data full rank using PCA.
  댓글 수: 3
Gaurav Garg
Gaurav Garg 2020년 10월 14일
Hey Clay,
There are many ways to put constraints on rank, and PCA is one of them; and SVD being another.
You can take the eigen values which are more relevant and compress your data with the help of SVD and PCA taking help from their documentations.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Dimensionality Reduction and Feature Extraction에 대해 자세히 알아보기

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by