【问题标题】:How can I work around overflow error in matplotlib?如何解决 matplotlib 中的溢出错误?
【发布时间】:2018-07-22 18:14:28
【问题描述】:

我正在使用 scipy.integrate 中的 odeint 包求解一组耦合微分方程。

对于我的整合时间:

 t=numpy.linspace(0,8e+9,5e+06)

其中 5e+06 是时间步长。

然后我绘制出这样的方程式:

plt.xscale('symlog') #x axis logarithmic scale
plt.yscale('log',basey=2) #Y axis logarithmic scale
plt.gca().set_ylim(8, 100000) #Changing y axis ticks
ax = plt.gca()
ax.yaxis.set_major_formatter(matplotlib.ticker.ScalarFormatter())
ax.xaxis.set_major_formatter(matplotlib.ticker.ScalarFormatter())
plt.title("Example graph")
plt.xlabel("time (yr)")
plt.ylabel("quantity a")
plt.plot(t,a,"r-", label = 'Example graph')
plt.legend(loc='best')

其中 a 是时间相关变量。 (这只是众多图表中的一张。)

但是,图表看起来有点锯齿状,而不是振荡,我收到此错误:

OverflowError: Exceeded cell block limit (set 'agg.path.chunksize' rcparam)

我不太确定这个错误意味着什么,我查看了其他答案,但不知道如何实现“agg.path.chunksize”。

此外,集成 + 绘图大约需要 7 个小时,而且还有一些 CPU 处理技巧,所以我真的不想实现任何会增加时间的东西。

我该如何克服这个错误?

我试图减少时间步长,但是我得到了这个错误:

Excess work done on this call (perhaps wrong Dfun type).
Run with full_output = 1 to get quantitative information.

【问题讨论】:

  • 那个溢出错误看起来像是来自matplotlib的agg后端,所以它可能与odeint无关。你能通过绘制与 odeint 的输出大小相同的随机数据来重现错误吗?
  • 好的,所以我使用了大约 12 个微分方程,其中 6 个是非常振荡的。如果我注释掉高度振荡的方程并保持时间步长和积分时间相同,我不会得到错误。

标签: python numpy matplotlib physics differential-equations


【解决方案1】:

如错误消息所示,您可以set the chunksize to a larger value

plt.rcParams['agg.path.chunksize'] = 1000

但是,您也可以首先批判性地反映为什么会发生此错误。仅当您尝试在图表上绘制大量数据时才会发生这种情况。这意味着,如果您尝试绘制 200000000 个点,渲染器可能无法将它们全部保存在内存中。但或许有人应该问自己,为什么要绘制这么多点?一个屏幕可能横向显示大约 2000 个点,一张打印纸可能显示 6000 个。使用更多点通常没有意义。

现在,如果您的微分方程的解需要较大的点密度,这并不意味着您需要将它们全部绘制出来。

例如可以每 100 个点绘制一次,

plt.plot(x[::100], y[::100])

很可能甚至不会影响视觉情节的外观。

【讨论】:

  • 哦,这太神奇了,它确实需要非常大的点密度,但我什至没有想到在实际绘图中不包括它们。谢谢。
猜你喜欢
  • 2017-01-10
  • 2020-01-11
  • 1970-01-01
  • 2017-11-07
  • 2015-04-03
  • 1970-01-01
  • 2022-01-05
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多