gpt4 book ai didi

python - 在 matplotlib 中用两个 Y 轴(两个单位)绘制单个数据

转载 作者:太空狗 更新时间:2023-10-29 18:30:24 25 4
gpt4 key购买 nike

我正在尝试绘制单个时间序列,但想在左右轴上以两个单位表示它。这是我到目前为止所做的。

fig, ax1 = plt.subplots()
t = np.arange(1,50,1)
s1 = np.sin(t)*20000+40000 #synthetic ts, but closer to my data
ax1.plot(t, s1, 'b-')

ax1.set_xlabel('time')
ax1.set_ylim(20000,70000)
ax1.set_ylabel('km3/year')

km3yearToSv=31.6887646*(1/1e6)

ax2 = ax1.twinx()
s2 = s1*km3yearToSv
ax2.plot(t, s2, 'b-')
ax2.set_ylim(20000*km3yearToSv,70000*km3yearToSv)
ax2.set_ylabel('Sv')

enter image description here

通过调整 ylim(),我可以让它看起来像一条线,但可以看到一些锯齿。如果我不必两次绘制数据,我会更愿意。

有什么建议吗?

更新:谢谢,askewchan,完美的解决方案!

最佳答案

不需要绘制两次,这么多应该会给你你想要的结果:

ax2 = ax1.twinx()
ax2.set_ylim(20000*km3yearToSv, 70000*km3yearToSv)
ax2.set_ylabel('Sv')

一个更稳健的方法是首先提取绘图的限制(如果您更改它们,它们不再是 2000070000,或者您希望绘图能够自动调整限制:

ax2 = ax1.twinx()
mn, mx = ax1.get_ylim()
ax2.set_ylim(mn*km3yearToSv, mx*km3yearToSv)
ax2.set_ylabel('Sv')

one plot

总而言之,还有一些其他的小调整:

import numpy as np
import matplotlib.pyplot as plt

mean, amp = 40000, 20000
t = np.arange(50)
s1 = np.sin(t)*amp + mean #synthetic ts, but closer to my data

fig, ax1 = plt.subplots()
ax1.plot(t, s1, 'b-')

ax1.set_xlabel('time')
mn, mx = ax1.set_ylim(mean-amp, mean+amp)
ax1.set_ylabel('km$^3$/year')

km3yearToSv = 31.6887646e-6

ax2 = ax1.twinx()
ax2.set_ylim(mn*km3yearToSv, mx*km3yearToSv)
ax2.set_ylabel('Sv')

关于python - 在 matplotlib 中用两个 Y 轴(两个单位)绘制单个数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32662642/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com