Проблема в том, что вы подгоняете свои данные в обычном масштабе, но позже вы переводите оси в логарифмический масштаб.Таким образом, линейное соответствие больше не будет линейным в логарифмическом масштабе.
Вместо этого вам нужно преобразовать данные в логарифмический масштаб (основание 10) и затем выполнить линейную регрессию.Ваши данные в настоящее время список.Было бы легко преобразовать ваши данные в масштабирование журнала, если вы преобразуете свой список в массив NumPy, потому что тогда вы можете использовать векторизованную операцию.
Внимание: одна из ваших x-записей - 0
, для которых журналне определено.Там вы увидите предупреждение.
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np
some_x=np.array([0,1,2,3,4,5,6,7])
some_y=np.array([3,5,4,7,7,9,9,10])
ax = sns.regplot(x=np.log10(some_x), y=np.log10(some_y), order=1)
Решение с использованием полифита NumPy , где вы исключаете точку данных x = 0 из фитинга
import matplotlib.pyplot as plt
import numpy as np
some_x=np.log10(np.array([0,1,2,3,4,5,6,7]))
some_y=np.log10(np.array([3,5,4,7,7,9,9,10]))
fit = np.poly1d(np.polyfit(some_x[1:], some_y[1:], 1))
plt.plot(some_x, some_y, 'ko')
plt.plot(some_x, fit(some_x), '-k')