2010-06-16 5 views
9

J'effectue une régression des moindres carrés comme ci-dessous (univarié). Je voudrais exprimer la signification du résultat en termes de R^2. Numpy renvoie une valeur de résidu non scalaire, ce qui serait une manière sensée de normaliser cela.Conversion de la valeur résiduelle de Numpy Lstsq en R^2

field_clean,back_clean = rid_zeros(backscatter,field_data) 
num_vals = len(field_clean) 
x = field_clean[:,row:row+1] 
y = 10*log10(back_clean) 

A = hstack([x, ones((num_vals,1))]) 
soln = lstsq(A, y) 
m, c = soln [0] 
residues = soln [1] 

print residues 

Répondre

17

Voir http://en.wikipedia.org/wiki/Coefficient_of_determination

Votre R2 = valeur

1 - residual/sum((y - y.mean())**2) 

qui équivaut à

1 - residual/(n * y.var()) 

À titre d'exemple:

import numpy as np 

# Make some data... 
n = 10 
x = np.arange(n) 
y = 3 * x + 5 + np.random.random(n) 

# Note that polyfit is an easier way to do this... 
# It would just be "model, resid = np.polyfit(x,y,1,full=True)[:2]" 
A = np.vstack((x, np.ones(n))).T 
model, resid = np.linalg.lstsq(A, y)[:2] 

r2 = 1 - resid/(y.size * y.var()) 
print r2 
+0

pouvons-nous effectuer cette opération dans le cas de 'scipy.linalg.lstsq'!? – diffracteD

+0

et comment cet exemple 'numpy' que vous avez donné va pour les données 3D! ne pas être en mesure de l'obtenir .. – diffracteD

Questions connexes