Экстраполяция в логлоге сюжета в питоне

Я пытаюсь экстраполировать в сюжете журнала в Python. Я сделал линейную регрессию, чтобы данные соответствовали кривой наилучшего соответствия. Теперь я хочу расширить эту линию наилучшего соответствия, чтобы увидеть, как уклон идет с расширенным диапазоном.

Мои данные действительно большие, поэтому вот ссылка на мои данные: my_data

Мой код выглядит так:

import numpy as np
import scipy as sp
import matplotlib.pyplot as plt

from scipy.optimize import curve_fit
import matplotlib.pyplot as plt
import numpy as np
from scipy.interpolate import InterpolatedUnivariateSpline
from scipy.optimize import curve_fit
import scipy as sp
import scipy.stats

#########################################################
motl = 'motl.txt'
mx, my = np.loadtxt(motl, unpack=True)


print mx
print my

# now do general curve fit for all data

# Regression Function
def regress(x, y):
    #Return a tuple of predicted y values and parameters for linear regression
    p = sp.stats.linregress(x, y)
    b1, b0, r, p_val, stderr = p
    y_pred = sp.polyval([b1, b0], x)
    return y_pred, p

# plotting z
allx, ally = mx, my                              # data, non-transformed
y_pred, _ = regress(np.log(allx), np.log(ally))      # change here           # transformed input             

plt.loglog(allx, ally, marker='p',color ='g', markersize=3,linestyle='None')
plt.loglog(allx, np.exp(y_pred), "k:")  # transformed output


#################################################


# positions to inter/extrapolate
x = np.linspace(12, 14, 1000)
# spline order: 1linear, 2 quadratic, 3 cubic ... 
order = 1
# do inter/extrapolation
s = InterpolatedUnivariateSpline(np.log10(mx), np.log10(my), k=order)
y = s(x)

plt.loglog(10**x, 10**y, 'g:')
#######################################################
plt.show()

С регрессией сюжет выглядит следующим образом:

Но как мне экстраполировать, чтобы расширить строку с 10^12 до 10^14? Ваша помощь приветствуется.

1 ответ

Решение

Это, конечно, не минимальный, полный и проверяемый пример, он не является ни минимальным, ни проверяемым с помощью кода, который выдает сообщения об ошибках. Для вашей задачи вам просто нужно расширить ось х, используемую для расчета линии регрессии. Я предполагаю, что это

 x = np.linspace(12, 14, 1000)

Но так как ваш код выдает сообщение об ошибке в строке

s = InterpolatedUnivariateSpline(np.log10(mx), np.log10(my), k=order)

Я не могу это проверить. Вместо этого я просто покажу вам минимальный пример, который достигает желаемого результата:

import matplotlib.pyplot as plt
import numpy as np
import scipy.stats as stats

motl = 'motl.txt'
mx, my = np.loadtxt(motl, unpack=True)

#log-log plot of original data
plt.loglog(mx, my, marker = 'o', color = 'g', markersize = 3, linestyle = 'None')
#x values for predicted line
x_pred = np.linspace(13, 16, 1000)
#linear regression on log-log data using base 10 like for log-log graph
b1, b0, _r, _p_val, _stderr = stats.linregress(np.log10(mx), np.log10(my)) 
#corresponding y values using regression data
y_pred = b1 * x_pred + b0   
#log-log plot of linear regression curve
plt.loglog(10 ** x_pred, 10 ** y_pred, color = 'b', linestyle = "-")
plt.show()
Другие вопросы по тегам