Pandas和Numpy的一些金融相关的操作(一)

Pandas和Numpy的一些金融相关的操作

给定一个净值序列,求出最大回撤

# arr是一个净值的np.ndarray
i = np.argmax(
(np.maximum.acumulate(arr) - arr) / np.maximum.acculate(arr))

if i == 0:
 max_draw_dowm = 0
else:
 j = np.maximum(arr[:i])  # 开始位置
 max_draw_down = (arr[j] - arr[i]) / arr[j]

# i为回撤结束位置 j为回撤开始位置
# 可以用动态规划解决最小子列和的思路求出最大回撤 时间复杂度为O(n)

已知净值求日收益率

# net_value是一个净值的pd.Series 按照时间排序 较早的时间在前面
daily_return = net_value.pct_change()

已知日收益率求净值

# daily_return是一个日收益率的pd.Series 按照时间排序 较早的时间在前面
_net_value = (daily_return + 1).cumprod()  # 这时候第一个值还不是1
net_value = _net_value / _net_value.iloc[0]

已知净值求累计收益率

# net_value是一个净值的pd.Series 按照时间排序 较早的时间在前面
cum_return = net_value / net_value.iloc[0] - 1
posted @ 2020-04-01 22:06  Aokigahara  阅读(801)  评论(0编辑  收藏  举报