我创建了一个名为errors的类,我正在尝试进行一些错误分析。我一直收到错误代码:
TypeError: unbound method just_print() must be called with errors instance as first argument (got ndarray instance instead)
我正在尝试使用just_print方法,只是使用它将结果打印到解释器模块,方法是将两个数组x,y作为年份和临时值传递给它。
感谢您的帮助:D
我的原始代码如下:
#imports
from pylab import *
#defining error class
class errors(object):
#creates class object
def __init__(self):
pass
#error method
def just_print(x,y): # defining error method
#error analysis
n = len(x) #length of the x data
D = sum(x**2) - 1./n * sum(x)**2 # d is the sum of the squares minus the sum squared over n
x_bar = mean(x) # average all x values
p_coeff, residuals, _, _, _ = polyfit(x, y, 1, full=True) #using only the first 2 results from the poly fit returned values
dm_squared = 1./(n-2)*residuals/D # error squared using standard forula
dc_squared = 1./(n-2)*(D/n + x_bar**2)*residuals/D #error squared using standard forula
dm = sqrt(dm_squared) # rooted squared error
dc = sqrt(dc_squared) # rooted squared error
#printing results
print("The value for gradient is")
print("%.3g" % p_coeff[0] , "error:" , "%.3g" % dm)
print("The value for intercept is")
print("%.3g" % p_coeff[1] , "error:" , "%.3g" % dc)
return;
#reading in data from data file called wales_temp.txt
f = open("wales_temp.txt")
temps = loadtxt(f, skiprows=8)#skips thw first 8 rows as they are information aboutthe data
f.close()
years = linspace(1911,2012,(2012 - 1911 + 1), dtype=int)#set the years array of euqal length such that each corrosponds to the temp
print("The max temprature for the lest 100 years was " , "%.3g" % max(temps) , " Celcius in " , years[argmax(temps)] )
print("The min temprature for the lest 100 years was " , "%.3g" % min(temps) , " Celcius in " , years[argmin(temps)] )
print("The standard deviation of the tempratures over the past 100 years is : " , "%.3g" % std(temps))
years1990 = linspace(1990,2012,(2012 - 1990 + 1), dtype=int)
temps1990 = temps[-len(years1990):]
temps1990_9degs = temps1990[9<temps1990]
percent = (float(len(temps1990_9degs))) / (float(len(temps[9<temps])))
print("The percantage of years with tempratures above 9 degrees after 1990 compared to all the years is : " , (100*percent) , "%")
hist(temps, bins=len(years))
hist(temps1990 , bins = len(years))
figure("avg temps")
plot(years, temps, "bx")
best_fit = poly1d(polyfit(years,temps,1))
plot(years,best_fit(years))
test = errors
test.just_print(years, temps)
答案 0 :(得分:2)
您想要访问其中test.just_print(years, temps)
不是类实例的test
,请创建对象。
您必须将just_print
方法声明为staticmethod
或将其签名更改为def just_print(self, x,y):
并使用实例进行调用。
test = errors()
test.just_print(years, temps)