作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
对于使用下面的代码生成的图,我想获得通过 pandas 逻辑生成的信号。
当曲线比最后一个局部最小值高(或更多)+3 个点时,输出信号应从 -4 变为 -2。当曲线比最后一个局部最大值低(或更少)2 个点时,它应该从 -2 变回 -4。
图 1 显示了由以下代码生成的曲线。图 2 大致显示了输出信号的样子。
代码:
import matplotlib
matplotlib.use('QT5Agg')
import matplotlib.pyplot as plt
import numpy as np
a = np.arange(5)
b = np.arange(5, -4, -1)
c = np.arange(-4, 7, .5)
d = np.arange(7, 2, -1)
e = np.arange(2, 6, .2)
f = np.arange(6, -3, -1)
g = np.arange(-3, 2, .25)
r1 = np.append(a, b)
r2 = np.append(r1, c)
r3 = np.append(r2, d)
r4 = np.append(r3, e)
r5 = np.append(r4, f)
r6 = np.append(r5, g)
plt.rcParams['font.size'] = 6
fig, ax1 = plt.subplots()
ax1.plot(r6,'g-o',markersize=3)
plt.annotate('start upward', xy=(0,0), textcoords='data',)
plt.annotate('end upward', xy=(3,3), textcoords='data',)
plt.annotate('start downward', xy=(5,5), textcoords='data',)
plt.annotate('end downward', xy=(7,3), textcoords='data',)
plt.annotate('start upward', xy=(14,-4), textcoords='data',)
plt.annotate('end upward', xy=(20,-1), textcoords='data',)
plt.annotate('start downward', xy=(36,7), textcoords='data',)
plt.annotate('end downward', xy=(38,5), textcoords='data',)
plt.annotate('start upward', xy=(41,2), textcoords='data',)
plt.annotate('end upward', xy=(56,5), textcoords='data',)
plt.annotate('start downward', xy=(61,6), textcoords='data',)
plt.annotate('end downward', xy=(63,4), textcoords='data',)
plt.annotate('start upward', xy=(70,-3), textcoords='data',)
plt.annotate('end upward', xy=(82,0), textcoords='data',)
ax1.minorticks_on()
ax1.grid(b=True, which='major', color='g', linestyle='-')
ax1.grid(b=True, which='minor', color='y', linestyle='--')
plt.show()
最佳答案
我想你想要这个:
s = pd.Series(np.concatenate((a,b,c,d,e,f,g,)))
# is increasing
incr = s.diff().ge(0)
# shifted trend (local minima)
shifted = incr.ne(incr.shift())
# local max
local_max = shifted & (~incr)
# thresholding function
def thresh(x, threshold=3, step=2):
ret = pd.Series([0]*len(x), index=x.index)
t = x.min() + threshold
ret.loc[x.gt(t)] = step
return ret
signal = s.groupby(local_max.cumsum()).apply(thresh)
signal += s.min()
# draw
fig, ax = plt.subplots(figsize=(10,6))
s.plot(ax=ax)
signal.plot(drawstyle='steps', ax=ax)
plt.show()
输出:
关于python - 如何用 Pandas 检测上升和下降趋势?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56193600/
我是一名优秀的程序员,十分优秀!