import numpy as np import matplotlib.pyplot as plt x=np.array([60,80,100,120,140,160]) y=np.array([70,90,130,150,175,180]) def model(a,b,x): return a*x+b def cost_function(a,b,x,y): n=6 return 0.5/n*(np.square(y-a*x-b)).sum() def optimize(a,b,x,y): n=6 step=0.0001 y_hat =model(a,b,x) da=(1.0/n)*((y_hat-y)*x).sum() db=(1.0/n)*((y_hat-y).sum) a=a-step*da b=b-step*db return a,b def iterate(a,b,x,y,times): for i in range(times): a,b=optimize(a,b,x,y) y_hat=model(a,b,x) cost=cost_function(a,b,x,y) print(a,b,cost) plt.scatter(x,y) plt.plot(x,y_hat) return a,b a=1 b=1 a,b=iterate(a,b,x,y,400000) 出现错误Traceback (most recent call last): File "D:\人工智能\4-1.py", line 31, in <module> a,b=iterate(a,b,x,y,400000) File "D:\人工智能\4-1.py", line 22, in iterate a,b=optimize(a,b,x,y) File "D:\人工智能\4-1.py", line 16, in optimize db=(1.0/n)*((y_hat-y).sum) TypeError: unsupported operand type(s) for *: 'float' and 'builtin_function_or_method' Process finished with exit code 1