반응형
2023.07.17 - [투자] - 기업의 미래를 예측하는 퀀트(Quant) 트레이딩 이란?
2023.07.18 - [배웁시다!!] - [Python]파이썬 기초 중의 기초(순서대로만 익혀준다면...)
기존의 두 글을 바탕으로 이번에는 간단한 백테스트 예제를 돌려보았다. 이 예제에서는 주식 종목 하나에 대한 일간 데이터를 사용하며, 20일 이동평균선과 50일 이동평균선의 교차점을 기반으로 매매 결정을 내리는 전략을 테스트한다. csv 파일을 구글링을 통해 얻은 것이므로 그냥 이렇게 돌아간다는 것만 확인하면 좋을 듯 싶다.
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import os
# 데이터 불러오기
file_path = os.path.dirname(os.path.abspath(__file__))
data = pd.read_csv(file_path +'/stock_data.csv', index_col='Date', parse_dates=True)
# 20일 이동평균선과 50일 이동평균선 계산
data['MA20'] = data['Close'].rolling(window=20).mean()
data['MA50'] = data['Close'].rolling(window=50).mean()
# 매매 신호 계산
data['Signal'] = np.where(data['MA20'] > data['MA50'], 1, 0)
data['Position'] = data['Signal'].diff()
# 수익률 계산
data['Market_Return'] = np.log(data['Close']/data['Close'].shift(1))
data['Strategy_Return'] = data['Market_Return'] * data['Position']
# 누적 수익률 계산
data['Market_Cum_Return'] = data['Market_Return'].cumsum().apply(np.exp)
data['Strategy_Cum_Return'] = data['Strategy_Return'].cumsum().apply(np.exp)
# 결과 출력
plt.plot(data[['Market_Cum_Return', 'Strategy_Cum_Return']])
plt.legend(['Market', 'Strategy'])
plt.show()
위와 같은 결과화면이 출력되었다면 정상적으로 프로그램이 돌아간 것이다.
프로그램 소스와 csv 파일은 아래 첨부해 놓겠다. 한번씩 돌려보면서 백테스트 소스에 대해 분석해 보길 바란다.
반응형
'투자' 카테고리의 다른 글
주택담보대출 디딤돌 대출 완벽분석 (0) | 2023.07.22 |
---|---|
흑해 곡물 협정 이란 무엇인가?(feat. 관련주) (0) | 2023.07.19 |
기업의 미래를 예측하는 퀀트(Quant) 트레이딩 이란? (0) | 2023.07.17 |
변동성 돌파 (Volatility Breakout): 주가 트렌드 추세를 탐지하는 전략 (0) | 2023.07.10 |
평균 편차 (Mean Deviation): 주가 변동성 분석과 리스크 측정에 활용되는 지표 (0) | 2023.07.10 |