如果x和y标度是线性的,我使用谷歌找到了这个解决方案
import numpy as npimport matplotlib.pyplot as plgolden_mean = (np.sqrt(5)-1.0)/2.0dy=pl.gca().get_ylim()[1]-pl.gca().get_ylim()[0]dx=pl.gca().get_xlim()[1]-pl.gca().get_xlim()[0]pl.gca().set_aspect((dx/dy)*golden_mean,adjustable='Box')
如果是对数日志图,我想出了这个解决方案
dy=np.abs(np.log10(pl.gca().get_ylim()[1])-np.log10(pl.gca().get_ylim()[0]))dx=np.abs(np.log10(pl.gca().get_xlim()[1])-np.log10(pl.gca().get_xlim()[0]))pl.gca().set_aspect((dx/dy)*golden_mean,adjustable='Box')
但是,对于半对数图,当我调用set_aspect时,我得到了
UserWarning: aspect is not supported for Axes with xscale=log,yscale=linear
任何人都可以想到解决这个问题吗?
解决方法 最简单的解决方案是记录您的数据,然后使用lin-lin的方法.然后,您可以标记轴,使其看起来像正常的对数图.
ticks = np.arange(min_logx,max_logx,1)ticklabels = [r"^{}$".format(tick) for tick in ticks]pl.yticks(ticks,ticklabels)
如果您的值高于10e9,则需要三对括号,两对用于LaTeX括号,一对用于.format()
ticklabels = [r"^{{{}}}$".format(tick) for tick in ticks]
编辑:
如果你还需要0.1ex … 0.9ex的刻度,你也想要使用次刻度:
它们需要位于log10(1),log10(2),log10(3)……,log10(10),log10(20)……
你可以创建和设置它们:
minor_ticks = []for i in range(min_exponent,max_exponent): for j in range(2,10): minor_ticks.append(i+np.log10(j))plt.gca().set_yticks(minor_labels,minor=True)总结
以上是内存溢出为你收集整理的python – 使用Matplotlib的半对数图中的宽高比全部内容,希望文章能够帮你解决python – 使用Matplotlib的半对数图中的宽高比所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)