У меня есть график, логарифмический по обеим осям. Для этого у меня есть функция loglog
pyplot. Это также дает мне логарифмическую шкалу по обеим осям.
Теперь, используя numpy, я подгоняю прямую линию к набору точек, которые у меня есть. Однако, когда я наношу эту линию на график, я не могу получить прямую линию. У меня получается изогнутая линия.
Синяя линия — это якобы «прямая линия». Это не получает заговор прямо. Я хочу, чтобы эта прямая линия соответствовала кривой, нанесенной красными точками.
Вот код, который я использую для построения точек:
import numpy
from matplotlib import pyplot as plt
import math
fp=open("word-rank.txt","r")
a=[]
b=[]
for line in fp:
string=line.strip().split()
a.append(float(string[0]))
b.append(float(string[1]))
coefficients=numpy.polyfit(b,a,1)
polynomial=numpy.poly1d(coefficients)
ys=polynomial(b)
print polynomial
plt.loglog(b,a,'ro')
plt.plot(b,ys)
plt.xlabel("Log (Rank of frequency)")
plt.ylabel("Log (Frequency)")
plt.title("Frequency vs frequency rank for words")
plt.show()