我有一个图,它在两个轴上都是对数的。我有 pyplot 的loglog
功能来做到这一点。它还为我提供了两个轴上的对数刻度。
现在,使用 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()