私は2つのデータフレームを持っています
df1=
x y1
0 0 0
1 1 1
2 2 2
3 4 3
df2=
x y2
0 0.0 0
1 0.5 1
2 1.5 2
3 3.0 3
4 4.0 4
y2-y1 (同じ x 値に対して) を計算する必要があります (2 つのグラフの違いを確認するため)
ご覧のとおり、いくつかの値はそれらの間で共通しています...いくつかはそうではありません
データを再サンプリングする必要があると思います...しかし、方法がわかりません! 2 つのデータフレームで同じ「x」列を使用するには、データを整列する必要があります。
2 点間で線形補間を実行して、指定された x での y 値を取得する必要があります。
この場合、x_step=0.5 でデータをリサンプリングするとよいでしょう。
これは私がしました...
import pandas as pd
import matplotlib.pylab as plt
df1 = pd.DataFrame([[0.0,0.0],[1.0,1.0],[2.0,2.0],[4.0,3.0]],columns=['x','y1'])
df2 = pd.DataFrame([[0.0,0.0],[0.5,1.9],[1.5,2.0],[3.0,3.0],[4.0,4.0]],columns=['x','y2'])
print(df1)
print("="*10)
print(df1['x'])
print("="*10)
print(df1['y1'])
print("="*10)
fig = plt.figure()
fig.subplots_adjust(bottom=0.1)
ax = fig.add_subplot(111)
plt.title("{y} = f({x})".format(x='x', y='y'))
p1, = plt.plot(df1['x'], df1['y1'], color='b', marker='.')
p2, = plt.plot(df2['x'], df2['y2'], color='r', marker='.')
plt.legend([p1, p2], ["y1", "y2"])
plt.show()