Introduzione all'analisi di portafoglio in Python
Charlotte Werger
Data Scientist

$$
$$

# Definisci tasso privo di rischio e rendimento obiettivo 0
rfr = 0
target_return = 0
# Calcola i rendimenti giornalieri dai prezzi
apple_returns=pd.DataFrame(apple_price.pct_change())
# Seleziona solo i rendimenti negativi
negative_returns = apple_returns.loc[apple_returns['AAPL'] < target]
# Calcola rendimento atteso e deviazione std dei rendimenti al ribasso
expected_return = apple_returns['AAPL'].mean()
down_stdev = negative_returns.std()
# Calcola il Sortino ratio
sortino_ratio = (expected_return - rfr)/down_stdev
print(sortino_ratio)
0.07887683763760528

# Calcola il valore massimo dei prezzi con rolling().max() roll_max = apple_price.rolling(min_periods=1,window=250).max()# Calcola il drawdown giornaliero dal massimo mobile daily_drawdown = apple_price/roll_max - 1.0# Calcola il drawdown giornaliero massimo max_daily_drawdown = daily_drawdown.rolling(min_periods=1,window=250).min()# Grafica i risultati daily_drawdown.plot() max_daily_drawdown.plot() plt.show()

Introduzione all'analisi di portafoglio in Python