mirror of
				https://github.com/fjosw/pyerrors.git
				synced 2025-10-26 05:15:46 +01:00 
			
		
		
		
	
				commit
				
					
						e6aa679170
					
				
			
		
					 2 changed files with 23 additions and 17 deletions
				
			
		|  | @ -482,15 +482,15 @@ def _standard_fit(x, y, func, silent=False, **kwargs): | ||||||
|         chol_inv = np.linalg.inv(chol) |         chol_inv = np.linalg.inv(chol) | ||||||
|         chol_inv = np.dot(chol_inv, covdiag) |         chol_inv = np.dot(chol_inv, covdiag) | ||||||
| 
 | 
 | ||||||
|         def chisqfunc(p): |         def chisqfunc_corr(p): | ||||||
|             model = func(p, x) |             model = func(p, x) | ||||||
|             chisq = anp.sum(anp.dot(chol_inv, (y_f - model)) ** 2) |             chisq = anp.sum(anp.dot(chol_inv, (y_f - model)) ** 2) | ||||||
|             return chisq |             return chisq | ||||||
|     else: | 
 | ||||||
|         def chisqfunc(p): |     def chisqfunc(p): | ||||||
|             model = func(p, x) |         model = func(p, x) | ||||||
|             chisq = anp.sum(((y_f - model) / dy_f) ** 2) |         chisq = anp.sum(((y_f - model) / dy_f) ** 2) | ||||||
|             return chisq |         return chisq | ||||||
| 
 | 
 | ||||||
|     output.method = kwargs.get('method', 'Levenberg-Marquardt') |     output.method = kwargs.get('method', 'Levenberg-Marquardt') | ||||||
|     if not silent: |     if not silent: | ||||||
|  | @ -499,27 +499,32 @@ def _standard_fit(x, y, func, silent=False, **kwargs): | ||||||
|     if output.method != 'Levenberg-Marquardt': |     if output.method != 'Levenberg-Marquardt': | ||||||
|         if output.method == 'migrad': |         if output.method == 'migrad': | ||||||
|             fit_result = iminuit.minimize(chisqfunc, x0, tol=1e-4)  # Stopping criterion 0.002 * tol * errordef |             fit_result = iminuit.minimize(chisqfunc, x0, tol=1e-4)  # Stopping criterion 0.002 * tol * errordef | ||||||
|  |             if kwargs.get('correlated_fit') is True: | ||||||
|  |                 fit_result = iminuit.minimize(chisqfunc_corr, fit_result.x, tol=1e-4)  # Stopping criterion 0.002 * tol * errordef | ||||||
|             output.iterations = fit_result.nfev |             output.iterations = fit_result.nfev | ||||||
|         else: |         else: | ||||||
|             fit_result = scipy.optimize.minimize(chisqfunc, x0, method=kwargs.get('method'), tol=1e-12) |             fit_result = scipy.optimize.minimize(chisqfunc, x0, method=kwargs.get('method'), tol=1e-12) | ||||||
|  |             if kwargs.get('correlated_fit') is True: | ||||||
|  |                 fit_result = scipy.optimize.minimize(chisqfunc_corr, fit_result.x, method=kwargs.get('method'), tol=1e-12) | ||||||
|             output.iterations = fit_result.nit |             output.iterations = fit_result.nit | ||||||
| 
 | 
 | ||||||
|         chisquare = fit_result.fun |         chisquare = fit_result.fun | ||||||
| 
 | 
 | ||||||
|     else: |     else: | ||||||
|         if kwargs.get('correlated_fit') is True: |         if kwargs.get('correlated_fit') is True: | ||||||
|             def chisqfunc_residuals(p): |             def chisqfunc_residuals_corr(p): | ||||||
|                 model = func(p, x) |                 model = func(p, x) | ||||||
|                 chisq = anp.dot(chol_inv, (y_f - model)) |                 chisq = anp.dot(chol_inv, (y_f - model)) | ||||||
|                 return chisq |                 return chisq | ||||||
| 
 | 
 | ||||||
|         else: |         def chisqfunc_residuals(p): | ||||||
|             def chisqfunc_residuals(p): |             model = func(p, x) | ||||||
|                 model = func(p, x) |             chisq = ((y_f - model) / dy_f) | ||||||
|                 chisq = ((y_f - model) / dy_f) |             return chisq | ||||||
|                 return chisq |  | ||||||
| 
 | 
 | ||||||
|         fit_result = scipy.optimize.least_squares(chisqfunc_residuals, x0, method='lm', ftol=1e-15, gtol=1e-15, xtol=1e-15) |         fit_result = scipy.optimize.least_squares(chisqfunc_residuals, x0, method='lm', ftol=1e-15, gtol=1e-15, xtol=1e-15) | ||||||
|  |         if kwargs.get('correlated_fit') is True: | ||||||
|  |             fit_result = scipy.optimize.least_squares(chisqfunc_residuals_corr, fit_result.x, method='lm', ftol=1e-15, gtol=1e-15, xtol=1e-15) | ||||||
| 
 | 
 | ||||||
|         chisquare = np.sum(fit_result.fun ** 2) |         chisquare = np.sum(fit_result.fun ** 2) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -171,12 +171,13 @@ def test_fit_corr_independent(): | ||||||
|         y = a[0] * anp.exp(-a[1] * x) |         y = a[0] * anp.exp(-a[1] * x) | ||||||
|         return y |         return y | ||||||
| 
 | 
 | ||||||
|     out = pe.least_squares(x, oy, func) |     for method in ["Levenberg-Marquardt", "migrad", "Nelder-Mead"]: | ||||||
|     out_corr = pe.least_squares(x, oy, func, correlated_fit=True) |         out = pe.least_squares(x, oy, func, method=method) | ||||||
|  |         out_corr = pe.least_squares(x, oy, func, correlated_fit=True, method=method) | ||||||
| 
 | 
 | ||||||
|     assert np.isclose(out.chisquare, out_corr.chisquare) |         assert np.isclose(out.chisquare, out_corr.chisquare) | ||||||
|     assert (out[0] - out_corr[0]).is_zero(atol=1e-5) |         assert (out[0] - out_corr[0]).is_zero(atol=1e-5) | ||||||
|     assert (out[1] - out_corr[1]).is_zero(atol=1e-5) |         assert (out[1] - out_corr[1]).is_zero(atol=1e-5) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def test_total_least_squares(): | def test_total_least_squares(): | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue