我希望在此图中使用填充之间或任何必要的颜色而不是绘制点。基本上用连续的颜色带代替点。我怎么能实现这个目标?
相关代码如下(这些点可以被认为是三组实验数据,它们或多或少都是)
import matplotlib.pyplot as plt
from matplotlib.ticker import MaxNLocator
from pylab import figure, show
plt.rc('text', usetex=True)
plt.rc('font', family='serif')
fig = figure()
ax = fig.add_subplot(111)
p1, = ax.plot(x_124,y_124,'o')
p2, = ax.plot(x_125,y_125,'o')
p3, = ax.plot(x_126,y_126,'o')
xmax=max(x_124+x_125+x_126)
xmin=min(x_124+x_125+x_126)
ymax=max(y_124+y_125+y_126)
ymin=min(y_124+y_125+y_126)
plt.title('Escenario $m_{h}^{\mathrm{max}}$')
plt.ticklabel_format(style='sci',scilimits=(0,0),axis='both')
ax.xaxis.set_major_locator(MaxNLocator(12))
ax.yaxis.set_major_locator(MaxNLocator(12))
plt.xlim(0.96*xmin,1.04*xmax)
plt.ylim(0.96*ymin,1.04*ymax)
plt.legend(['$m_h$ = 124 GeV','$m_h$ = 125 GeV','$m_h$ = 126 GeV'],numpoints=1,loc=0)
plt.xlabel('M3SQ / GeV')
plt.ylabel('M3SU / GeV')
ax.grid()
show()
答案 0 :(得分:2)
我知道这是一个不完整的答案,应该有一个更优雅的方式来做到这一点。但它应该是一种快速而肮脏的方法,至少在图的右上角。
对于每个m_h,
当然,通过这种方式,你必须决定如何连接不同的连续颜色和#34;例如右上角的红色和绿色。
使用给定数量的"点"在你的情节中,这种方法不适用于中间的一组点(在你的图中大致从y = 1.6到x = 1.6)。这是因为你不能用一系列一维点构造一个乐队。你需要更多的样品。