Невозможно уместить данные из-за ошибки «невозможно умножить последовательность на не-int типа numpy.float64» - PullRequest
1 голос
/ 18 апреля 2019

Я пытаюсь уместить простые данные в файл .txt с линейной функцией (a*x+b), используя matplotlib и scipy.Я столкнулся с ошибкой, связанной с тестовой функцией: "can't multiply sequence by non-int of type 'numpy.float64'"

Я попытался изменить имя переменной x, но у меня возникла та же проблема.Большая часть кода взята из рабочего кода, который без проблем подходит для данных и использует то же определение для тестовой функции.

import matplotlib.pyplot as plt
from scipy import optimize
import numpy as np
f=open("testData.txt","r")
x_data=[]
y_data=[]
trash=f.readline() #discards first line
for line in f: #reads x and y data from file
    x_read,y_read=line.split()
    x_data.append(float(x_read))
    y_data.append(float(y_read))

def test_func(x, a, b):
    return a*x+b

params, params_covariance = optimize.curve_fit(test_func, x_data, y_data, 
p0=[1, 1])
plt.figure(figsize=(6, 4))
plt.scatter(x_data, y_data)
plt.plot(x_data, test_func(x_data, params[0], params[1]), label='Fitted 
function')
plt.show()

Это ошибка:

Трассировка (последний вызов был последним):

Файл "C: /Users/Fra/Desktop/lab/ottica/2/reaqd.py", строка 19, в plt.plot (x_data, test_func (x_data,params [0], params [1]), label = 'Fitted function')

Файл "C: /Users/Fra/Desktop/lab/ottica/2/reaqd.py", строка 14, вtest_func возвращает a * x + b

TypeError: невозможно умножить последовательность на не-int типа 'numpy.float64'

Ответы [ 2 ]

0 голосов
/ 18 апреля 2019

Когда вы спрашиваете о том, как работает принятый ответ, может показаться, что используется способ "старой школы":

plt.plot(x_data, 
  [test_func(x, params[0], params[1]) for x in x_data],
  label='Fitted function')

x_data = [] - это список, а Python не является Matlab., number*x_data не является поэлементным умножением, но создает список, который повторяется x_data, number раз, для которого требуется целое число.

0 голосов
/ 18 апреля 2019

Возможно, вы пытаетесь умножить список Python на число с плавающей точкой, что не работает.Попробуйте a*np.array(x)+b

...