पिछले लेख में)))https://www.fmz.com/digest-topic/4187),我们介绍了配对交易策略,并演示了如何利用数据和数学分析来创建和自动化交易策略。
बहु-अवकाश संतुलन हित रणनीति एक टोकरी ट्रेडिंग सूचकांक के लिए उपयुक्त जोड़े की ट्रेडिंग रणनीति का एक प्राकृतिक विस्तार है। यह विशेष रूप से विभिन्न प्रकार के और परस्पर जुड़े ट्रेडिंग बाजारों जैसे कि डिजिटल मुद्रा बाजार और वस्तु वायदा बाजार के लिए उपयुक्त है।
बहुआयामी संतुलन की रणनीति में एक बास्केट ट्रेड के लिए एक ही समय में बहुआयामी और खाली ट्रेड करना शामिल है। यह निर्धारित करता है कि कौन सा निवेशक सस्ता है और कौन सा निवेशक महंगा है। इसके विपरीत, बहुआयामी संतुलन की रणनीति में सभी निवेशकों को एक चयनित पूल में रखा जाता है ताकि यह निर्धारित किया जा सके कि कौन से निवेशक अपेक्षाकृत सस्ते या महंगे हैं। यह तब बहुआयामी अग्रिम n निवेशकों के लिए रैंकिंग के आधार पर होगा और समान राशि के लिए नीचें नीचें n निवेशकों के लिए खाली होगा।
क्या आपको याद है कि हमने पहले कहा था कि जोड़े का व्यापार एक बाजार-तटस्थ रणनीति है? बहु-अवकाश संतुलित हित-हित रणनीति भी ऐसा ही है, क्योंकि बहु-अवकाश और खाली पदों के बराबर की राशि सुनिश्चित करती है कि रणनीति बाजार-तटस्थ (बाजार में उतार-चढ़ाव से मुक्त) रहेगी। यह रणनीति सांख्यिकीय रूप से भी मजबूत है; निवेश के लिए रैंकिंग करके और कई पदों को पकड़कर, आप अपने रैंकिंग मॉडल पर कई बार जोखिम उठा सकते हैं, न कि केवल एक बार जोखिम उठा सकते हैं। आप केवल अपने रैंकिंग कार्यक्रम की गुणवत्ता पर ही दांव लगा रहे हैं।
रैंकिंग स्कीम एक ऐसा मॉडल है जिसमें प्रत्येक निवेशक को अपेक्षित प्रदर्शन के आधार पर प्राथमिकता दी जा सकती है; इसमें कारक मूल्य कारक, तकनीकी संकेतकों, मूल्य निर्धारण मॉडल या उपरोक्त सभी के संयोजन हो सकते हैं। उदाहरण के लिए, आप गतिशीलता संकेतकों का उपयोग करके रुझानों को ट्रैक करने वाले निवेशकों की एक श्रृंखला को रैंक करने के लिए कर सकते हैंः उच्चतम गतिशीलता वाले निवेशकों को बेहतर प्रदर्शन करना जारी रखने और उच्चतम रैंकिंग प्राप्त करने की उम्मीद है; सबसे कम गतिशीलता वाले निवेशों का सबसे खराब प्रदर्शन और सबसे कम रिटर्न है।
इस रणनीति की सफलता लगभग पूरी तरह से आपके द्वारा उपयोग किए जाने वाले रैंकिंग स्कीम पर निर्भर करती है, यानी आपका रैंकिंग स्कीम उच्च प्रदर्शन वाले निवेशकों को निम्न प्रदर्शन वाले निवेशकों से अलग कर सकता है, ताकि बहु-अवकाश वाले निवेशकों की रणनीतियों के लिए बेहतर रिटर्न प्राप्त हो सके। इसलिए, रैंकिंग स्कीम बनाना महत्वपूर्ण है।
एक बार जब हम रैंकिंग योजना का निर्धारण करते हैं, तो हम स्पष्ट रूप से इससे लाभान्वित होने की उम्मीद करते हैं। हम ऐसा एक ही राशि का निवेश करके करते हैं, जो कि कई रैंकिंग वाले निवेशकों के लिए सबसे ऊपर है और नीचे के निवेशकों के लिए खाली है। यह सुनिश्चित करता है कि रणनीति केवल रैंकिंग की गुणवत्ता के अनुसार आनुपातिक रूप से पैसा कमाएगी और यह बाजार में एक ही स्थान पर होगी।
मान लीजिए कि आप सभी निवेशकों के लिए m पर रैंकिंग कर रहे हैं, $n का निवेश कर रहे हैं, और कुल 2p (जिसमें m> 2p) की स्थिति रखना चाहते हैं। यदि रैंकिंग 1 वाले निवेशकों का प्रदर्शन सबसे खराब होने का अनुमान है, तो रैंकिंग m वाले निवेशकों का प्रदर्शन सबसे अच्छा होगाः
आप निवेश के संकेतकों को क्रमबद्ध करते हैं जैसे कि 1,..., p, और 2 / 2p डॉलर के संकेतों को खाली करते हैं।
आप निवेश चिह्नों को क्रमबद्ध करते हैं जैसे कि m-p,..., m, और अधिक n / 2p डॉलर के निवेश चिह्न बनाते हैं।
ध्यान देंःचूंकि कीमत में वृद्धि के कारण निवेशकों के लिए कीमतें हमेशा n/2p में समान रूप से विभाजित नहीं होती हैं, और कुछ निवेशकों को पूर्णांक में खरीदा जाना चाहिए, इसलिए कुछ अशुद्ध एल्गोरिदम होंगे जो इस संख्या के जितना संभव हो उतना करीब होना चाहिए।
n/2p =100000⁄1000 = 100
यह 100 से अधिक मूल्य स्कोर के लिए एक बड़ी समस्या है (जैसे कि कमोडिटी वायदा बाजार) क्योंकि आप स्कोर मूल्य के साथ स्थिति नहीं खोल सकते हैं (ऐसा कोई समस्या नहीं है डिजिटल मुद्रा बाजार) । हम स्कोर मूल्य व्यापार को कम करके या पूंजी में वृद्धि करके इस स्थिति को कम करते हैं।
सबसे पहले, काम को सुचारू रूप से करने के लिए, हमें अपने अनुसंधान वातावरण को बनाने की आवश्यकता है, जिसे हम आविष्कारक क्वांटिफिकेशन प्लेटफॉर्म (FMZ.COM) का उपयोग करके अनुसंधान वातावरण बनाने के लिए करते हैं, मुख्य रूप से एक सुविधाजनक और तेज़ एपीआई इंटरफेस और एक अच्छी तरह से पैक किए गए डॉकर सिस्टम के लिए जो बाद में इस मंच का उपयोग कर सकते हैं।
आविष्कारकों के लिए क्वांटिफाइड प्लेटफॉर्म के आधिकारिक नाम में, इस डॉकर सिस्टम को होस्टिंग सिस्टम कहा जाता है।
यह एक बहुत ही दिलचस्प और उपयोगी लेख है, लेकिन यह एक बहुत ही दिलचस्प लेख है, और यह एक बहुत ही उपयोगी लेख है।https://www.fmz.com/bbs-topic/4140
जो लोग अपने स्वयं के क्लाउड सर्वर परिनियोजन प्रबंधक खरीदना चाहते हैं, वे इस लेख को देख सकते हैंःhttps://www.fmz.com/bbs-topic/2848
एक बार जब हम एक अच्छी क्लाउड सेवा और व्यवस्थापक प्रणाली को सफलतापूर्वक तैनात कर लेते हैं, तो अब हम पायथन के सबसे बड़े मंदिर को स्थापित करते हैं: एनाकोंडा।
सभी संबंधित प्रोग्रामिंग वातावरणों (निर्भरता पुस्तकालय, संस्करण प्रबंधन, आदि) को लागू करने के लिए सबसे आसान तरीका Anaconda का उपयोग करना है; यह एक पैक किया गया पायथन डेटा विज्ञान पारिस्थितिकी तंत्र और निर्भरता पुस्तकालय प्रबंधक है।
Anaconda को स्थापित करने के तरीके के लिए, कृपया Anaconda के आधिकारिक गाइड देखेंःhttps://www.anaconda.com/distribution/
本文还将用到numpy和pandas这两个目前在Python科学计算方面十分流行且重要的库.
इन मूलभूत कार्यों का संदर्भ मेरे पिछले लेख से लिया जा सकता है, जिसमें मैं Anaconda वातावरण और दो पुस्तकालयों, numpy और pandas को स्थापित करने के बारे में बताया गया था।https://www.fmz.com/digest-topic/4169
हम एक यादृच्छिक निवेश सूचकांक और एक यादृच्छिक कारक उत्पन्न करते हैं और उन्हें क्रमबद्ध करते हैं. चलो मान लें कि हमारे भविष्य के रिटर्न वास्तव में इन कारक मानों पर निर्भर करते हैं.
import numpy as np
import statsmodels.api as sm
import scipy.stats as stats
import scipy
import matplotlib.pyplot as plt
import seaborn as sns
import pandas as pd
## PROBLEM SETUP ##
# Generate stocks and a random factor value for them
stock_names = ['stock ' + str(x) for x in range(10000)]
current_factor_values = np.random.normal(0, 1, 10000)
# Generate future returns for these are dependent on our factor values
future_returns = current_factor_values + np.random.normal(0, 1, 10000)
# Put both the factor values and returns into one dataframe
data = pd.DataFrame(index = stock_names, columns=['Factor Value','Returns'])
data['Factor Value'] = current_factor_values
data['Returns'] = future_returns
# Take a look
data.head(10)
अब जब हमारे पास कारक मूल्य और लाभ है, तो हम देख सकते हैं कि क्या होता है यदि हम निवेशकों को कारक मूल्य के आधार पर रैंक करते हैं, तो ओवरहेड और रिक्त पदों को खोलें।
# Rank stocks
ranked_data = data.sort_values('Factor Value')
# Compute the returns of each basket with a basket size 500, so total (10000/500) baskets
number_of_baskets = int(10000/500)
basket_returns = np.zeros(number_of_baskets)
for i in range(number_of_baskets):
start = i * 500
end = i * 500 + 500
basket_returns[i] = ranked_data[start:end]['Returns'].mean()
# Plot the returns of each basket
plt.figure(figsize=(15,7))
plt.bar(range(number_of_baskets), basket_returns)
plt.ylabel('Returns')
plt.xlabel('Basket')
plt.legend(['Returns of Each Basket'])
plt.show()
हमारी रणनीति एक टोकरी के निवेश के पूल में शीर्ष स्थान पर अधिक करना है; 10 वें स्थान पर शून्य करना है। इस रणनीति का प्रतिफल हैः
basket_returns[number_of_baskets-1] - basket_returns[0]
इसका परिणाम है: 4.172
हमारे रैंकिंग मॉडल पर पैसा डालें ताकि यह कम प्रदर्शन करने वाले निवेशकों से उच्च प्रदर्शन करने वाले निवेशकों को अलग कर सके।
इस लेख के बाद में, हम रैंकिंग योजनाओं का मूल्यांकन करने के तरीके पर चर्चा करेंगे। रैंकिंग पर आधारित लाभ-निर्धारण का लाभ यह है कि यह बाजार की अराजकता से प्रभावित नहीं है, बल्कि इसका उपयोग किया जा सकता है।
हमने स्टैंडर्ड 500 में विभिन्न उद्योगों के 32 शेयरों के लिए डेटा लोड किया और उन्हें रैंक करने का प्रयास किया।
from backtester.dataSource.yahoo_data_source import YahooStockDataSource
from datetime import datetime
startDateStr = '2010/01/01'
endDateStr = '2017/12/31'
cachedFolderName = '/Users/chandinijain/Auquan/yahooData/'
dataSetId = 'testLongShortTrading'
instrumentIds = ['ABT','AKS','AMGN','AMD','AXP','BK','BSX',
'CMCSA','CVS','DIS','EA','EOG','GLW','HAL',
'HD','LOW','KO','LLY','MCD','MET','NEM',
'PEP','PG','M','SWN','T','TGT',
'TWX','TXN','USB','VZ','WFC']
ds = YahooStockDataSource(cachedFolderName=cachedFolderName,
dataSetId=dataSetId,
instrumentIds=instrumentIds,
startDateStr=startDateStr,
endDateStr=endDateStr,
event='history')
price = 'adjClose'
चलिए एक महीने के समय चक्र के लिए एक मानक गतिशीलता सूचकांक के आधार पर रैंकिंग करते हैं।
## Define normalized momentum
def momentum(dataDf, period):
return dataDf.sub(dataDf.shift(period), fill_value=0) / dataDf.iloc[-1]
## Load relevant prices in a dataframe
data = ds.getBookDataByFeature()[‘Adj Close’]
#Let's load momentum score and returns into separate dataframes
index = data.index
mscores = pd.DataFrame(index=index,columns=assetList)
mscores = momentum(data, 30)
returns = pd.DataFrame(index=index,columns=assetList)
day = 30
अब हम अपने शेयरों के व्यवहार का विश्लेषण करेंगे और देखेंगे कि हमारे शेयर बाजार में हमारे चुने हुए रैंकिंग कारकों में कैसे काम करते हैं।
शेयरों का व्यवहार
हम देखते हैं कि हमारे द्वारा चुने गए बास्केट स्टॉक हमारे रैंकिंग मॉडल में कैसे प्रदर्शन करते हैं. इसके लिए, हम सभी स्टॉक के एक सप्ताह के दीर्घकालिक रिटर्न की गणना करते हैं. और फिर हम प्रत्येक स्टॉक के 1 सप्ताह पहले रिटर्न के साथ पिछले 30 दिनों की गतिशीलता के संबंध को देख सकते हैं. सकारात्मक संबंधित स्टॉक ट्रेंड का पालन करते हैं, नकारात्मक संबंधित स्टॉक औसत रिटर्न करते हैं.
# Calculate Forward returns
forward_return_day = 5
returns = data.shift(-forward_return_day)/data -1
returns.dropna(inplace = True)
# Calculate correlations between momentum and returns
correlations = pd.DataFrame(index = returns.columns, columns = [‘Scores’, ‘pvalues’])
mscores = mscores[mscores.index.isin(returns.index)]
for i in correlations.index:
score, pvalue = stats.spearmanr(mscores[i], returns[i])
correlations[‘pvalues’].loc[i] = pvalue
correlations[‘Scores’].loc[i] = score
correlations.dropna(inplace = True)
correlations.sort_values(‘Scores’, inplace=True)
l = correlations.index.size
plt.figure(figsize=(15,7))
plt.bar(range(1,1+l),correlations[‘Scores’])
plt.xlabel(‘Stocks’)
plt.xlim((1, l+1))
plt.xticks(range(1,1+l), correlations.index)
plt.legend([‘Correlation over All Data’])
plt.ylabel(‘Correlation between %s day Momentum Scores and %s-day forward returns by Stock’%(day,forward_return_day));
plt.show()
हमारे सभी शेयरों का कुछ हद तक एक समान रिटर्न होता है! (जाहिर है कि हमारे द्वारा चुने गए ब्रह्मांड का काम करना इस तरह है) यह हमें बताता है कि यदि स्टॉक गतिशीलता विश्लेषण में उच्च रैंक प्राप्त करता है, तो हमें अगले सप्ताह इसके खराब प्रदर्शन की उम्मीद करनी चाहिए।
अगला, हमें हमारे रैंकिंग स्कोर और समग्र बाजार के आगे की वापसी के बीच संबंध को देखना होगा, यानी क्या अपेक्षित रिटर्न का अनुमान हमारे रैंकिंग कारकों के संबंध में है, क्या उच्च प्रासंगिकता स्तर खराब सापेक्ष रिटर्न का अनुमान लगाते हैं, या इसके विपरीत?
इसके लिए, हमने सभी शेयरों के 30 दिनों के गतिशीलता और एक सप्ताह के दूरस्थ रिटर्न के बीच दैनिक संबंध की गणना की।
correl_scores = pd.DataFrame(index = returns.index.intersection(mscores.index), columns = [‘Scores’, ‘pvalues’])
for i in correl_scores.index:
score, pvalue = stats.spearmanr(mscores.loc[i], returns.loc[i])
correl_scores[‘pvalues’].loc[i] = pvalue
correl_scores[‘Scores’].loc[i] = score
correl_scores.dropna(inplace = True)
l = correl_scores.index.size
plt.figure(figsize=(15,7))
plt.bar(range(1,1+l),correl_scores[‘Scores’])
plt.hlines(np.mean(correl_scores[‘Scores’]), 1,l+1, colors=’r’, linestyles=’dashed’)
plt.xlabel(‘Day’)
plt.xlim((1, l+1))
plt.legend([‘Mean Correlation over All Data’, ‘Daily Rank Correlation’])
plt.ylabel(‘Rank correlation between %s day Momentum Scores and %s-day forward returns’%(day,forward_return_day));
plt.show()
दैनिक प्रासंगिकता का प्रदर्शन बहुत शोर है, लेकिन बहुत मामूली है (यह अपेक्षित है, क्योंकि हमने कहा कि सभी शेयरों में समान रिटर्न होगा) । हम एक महीने पहले औसत मासिक रिटर्न के लिए प्रासंगिकता को भी देखते हैं ।
monthly_mean_correl =correl_scores['Scores'].astype(float).resample('M').mean()
plt.figure(figsize=(15,7))
plt.bar(range(1,len(monthly_mean_correl)+1), monthly_mean_correl)
plt.hlines(np.mean(monthly_mean_correl), 1,len(monthly_mean_correl)+1, colors='r', linestyles='dashed')
plt.xlabel('Month')
plt.xlim((1, len(monthly_mean_correl)+1))
plt.legend(['Mean Correlation over All Data', 'Monthly Rank Correlation'])
plt.ylabel('Rank correlation between %s day Momentum Scores and %s-day forward returns'%(day,forward_return_day));
plt.show()
हम देख सकते हैं कि औसत प्रासंगिकता फिर से थोड़ा नकारात्मक है, लेकिन हर महीने बहुत बदलती है।
हमने अपने रैंकिंग से निकाले गए एक बास्केट स्टॉक के रिटर्न की गणना की है. यदि हम सभी शेयरों को रैंकिंग करते हैं और उन्हें एनएन समूहों में विभाजित करते हैं, तो प्रत्येक समूह का औसत रिटर्न क्या है?
पहला कदम एक फ़ंक्शन बनाना है जो हर महीने दिए गए प्रत्येक टोकरी के लिए औसत रिटर्न और रैंकिंग कारक देगा।
def compute_basket_returns(factor, forward_returns, number_of_baskets, index):
data = pd.concat([factor.loc[index],forward_returns.loc[index]], axis=1)
# Rank the equities on the factor values
data.columns = ['Factor Value', 'Forward Returns']
data.sort_values('Factor Value', inplace=True)
# How many equities per basket
equities_per_basket = np.floor(len(data.index) / number_of_baskets)
basket_returns = np.zeros(number_of_baskets)
# Compute the returns of each basket
for i in range(number_of_baskets):
start = i * equities_per_basket
if i == number_of_baskets - 1:
# Handle having a few extra in the last basket when our number of equities doesn't divide well
end = len(data.index) - 1
else:
end = i * equities_per_basket + equities_per_basket
# Actually compute the mean returns for each basket
#s = data.index.iloc[start]
#e = data.index.iloc[end]
basket_returns[i] = data.iloc[int(start):int(end)]['Forward Returns'].mean()
return basket_returns
जब हम इस स्कोर के आधार पर स्टॉक को रैंक करते हैं, तो हम प्रत्येक टोकरी के औसत रिटर्न की गणना करते हैं। यह हमें लंबे समय तक उनके संबंधों को समझने में मदद करेगा।
number_of_baskets = 8
mean_basket_returns = np.zeros(number_of_baskets)
resampled_scores = mscores.astype(float).resample('2D').last()
resampled_prices = data.astype(float).resample('2D').last()
resampled_scores.dropna(inplace=True)
resampled_prices.dropna(inplace=True)
forward_returns = resampled_prices.shift(-1)/resampled_prices -1
forward_returns.dropna(inplace = True)
for m in forward_returns.index.intersection(resampled_scores.index):
basket_returns = compute_basket_returns(resampled_scores, forward_returns, number_of_baskets, m)
mean_basket_returns += basket_returns
mean_basket_returns /= l
print(mean_basket_returns)
# Plot the returns of each basket
plt.figure(figsize=(15,7))
plt.bar(range(number_of_baskets), mean_basket_returns)
plt.ylabel('Returns')
plt.xlabel('Basket')
plt.legend(['Returns of Each Basket'])
plt.show()
ऐसा लगता है कि हम उच्च प्रदर्शन करने वालों और निम्न प्रदर्शन करने वालों को अलग कर सकते हैं।
बेशक, ये केवल औसत संबंध हैं. यह समझने के लिए कि यह संबंध कितना सुसंगत है, और क्या हम व्यापार करने के इच्छुक हैं, हमें समय के साथ इसे देखने के तरीके और दृष्टिकोण को बदलना चाहिए. इसके बाद, हम उनके पहले दो वर्षों के मासिक ब्याज दरों (कीफीन) को देखेंगे. हम अधिक परिवर्तन देख सकते हैं और आगे का विश्लेषण कर सकते हैं कि क्या यह गतिशीलता कारक व्यापार करने योग्य है।
total_months = mscores.resample('M').last().index
months_to_plot = 24
monthly_index = total_months[:months_to_plot+1]
mean_basket_returns = np.zeros(number_of_baskets)
strategy_returns = pd.Series(index = monthly_index)
f, axarr = plt.subplots(1+int(monthly_index.size/6), 6,figsize=(18, 15))
for month in range(1, monthly_index.size):
temp_returns = forward_returns.loc[monthly_index[month-1]:monthly_index[month]]
temp_scores = resampled_scores.loc[monthly_index[month-1]:monthly_index[month]]
for m in temp_returns.index.intersection(temp_scores.index):
basket_returns = compute_basket_returns(temp_scores, temp_returns, number_of_baskets, m)
mean_basket_returns += basket_returns
strategy_returns[monthly_index[month-1]] = mean_basket_returns[ number_of_baskets-1] - mean_basket_returns[0]
mean_basket_returns /= temp_returns.index.intersection(temp_scores.index).size
r = int(np.floor((month-1) / 6))
c = (month-1) % 6
axarr[r, c].bar(range(number_of_baskets), mean_basket_returns)
axarr[r, c].xaxis.set_visible(False)
axarr[r, c].set_title('Month ' + str(month))
plt.show()
plt.figure(figsize=(15,7))
plt.plot(strategy_returns)
plt.ylabel(‘Returns’)
plt.xlabel(‘Month’)
plt.plot(strategy_returns.cumsum())
plt.legend([‘Monthly Strategy Returns’,’Cumulative Strategy Returns’])
plt.show()
अंत में, अगर हम अंतिम टोकरी को जोड़ते हैं और हर महीने पहली टोकरी को खाली करते हैं, तो आइए रिटर्न देखें (यह मान लें कि प्रत्येक प्रति के लिए पूंजी का वितरण समान है)
total_return = strategy_returns.sum()
ann_return = 100*((1 + total_return)**(12.0 /float(strategy_returns.index.size))-1)
print('Annual Returns: %.2f%%'%ann_return)
वार्षिक रिटर्नः 5.03%
हम देखते हैं कि हमारे पास एक बहुत ही कमजोर रैंकिंग स्कीम है जो केवल उच्च प्रदर्शन वाले शेयरों और निम्न प्रदर्शन वाले शेयरों के बीच मामूली अंतर करती है। इसके अलावा, रैंकिंग स्कीम असंगत है और महीने-दर-महीने बहुत बदलती है।
बहुभुज संतुलन नीति को लागू करने के लिए, आपको वास्तव में केवल रैंकिंग योजना निर्धारित करने की आवश्यकता है. इसके बाद सब कुछ यांत्रिक है. एक बार जब आपके पास एक बहुभुज संतुलन नीति है, तो आप विभिन्न रैंकिंग कारकों को बदल सकते हैं, बाकी के लिए बहुत अधिक बदलाव नहीं करते हैं. यह एक बहुत ही सुविधाजनक तरीका है कि आप अपने विचारों को जल्दी से बदल सकते हैं, बिना हर बार सभी कोड को समायोजित करने की चिंता किए बिना।
रैंकिंग स्कीम भी लगभग किसी भी मॉडल से आ सकती है। यह जरूरी नहीं कि मूल्य-आधारित कारक मॉडल हो, यह एक मशीन सीखने की तकनीक हो सकती है जो एक महीने पहले रिटर्न का अनुमान लगा सकती है और उस रैंकिंग के आधार पर रैंक कर सकती है।
रैंकिंग एक बहुआयामी संतुलित हितों की रणनीति का लाभ और सबसे महत्वपूर्ण घटक है। एक अच्छा रैंकिंग चुनना एक प्रणालीगत कार्य है, और कोई सरल उत्तर नहीं है।
एक अच्छा प्रारंभिक बिंदु यह है कि मौजूदा ज्ञात प्रौद्योगिकियों का चयन करें और देखें कि क्या आप उन्हें थोड़ा संशोधित कर सकते हैं ताकि उच्च रिटर्न प्राप्त हो सके। हम यहां कुछ प्रारंभिक बिंदुओं पर चर्चा करेंगेः
क्लोन और समायोजन: अक्सर चर्चा की जाने वाली सामग्री चुनें और देखें कि क्या इसे थोड़ा सा संशोधित किया जा सकता है ताकि लाभ प्राप्त हो सके। आमतौर पर, खुले कारकों में कोई ट्रेडिंग सिग्नल नहीं होगा क्योंकि वे पूरी तरह से बाजार से बाहर हो गए हैं। लेकिन कभी-कभी वे आपको सही दिशा में ले जाते हैं।
मूल्य निर्धारण मॉडल: कोई भी मॉडल जो भविष्य के रिटर्न का अनुमान लगाता है वह एक कारक हो सकता है और आपके एक टोकरी के व्यापार संकेतकों के लिए रैंकिंग के लिए संभावित रूप से उपयोग किया जा सकता है। आप किसी भी जटिल मूल्य निर्धारण मॉडल को ले सकते हैं और इसे रैंकिंग योजना में बदल सकते हैं।
मूल्य आधारित कारक (तकनीकी संकेतक): मूल्य आधारित कारक, जैसे कि हम आज चर्चा कर रहे हैं, प्रत्येक हित के ऐतिहासिक मूल्य के बारे में जानकारी प्राप्त करते हैं और इसका उपयोग कारक मूल्य उत्पन्न करने के लिए करते हैं। उदाहरण चलती औसत, गतिशीलता या अस्थिरता सूचकांक हो सकते हैं।
वापसी और गतिशीलतायह ध्यान देने योग्य है कि कुछ कारक मानते हैं कि कीमतें एक बार एक दिशा में चलती हैं और ऐसा करना जारी रखती हैं; कुछ कारक बिल्कुल विपरीत हैं; दोनों अलग-अलग समय सीमाओं और परिसंपत्तियों के बारे में प्रभावी मॉडल हैं, और यह महत्वपूर्ण है कि मौलिक व्यवहार को गति या प्रतिगमन पर आधारित किया जाए।
मूलभूत कारक (मूल्य आधारित): यह मूल मूल्य के संयोजन का उपयोग करता है, जैसे कि पीई, लाभांश आदि. मूल मूल्य में कंपनी के वास्तविक दुनिया के तथ्यों से संबंधित जानकारी होती है और इसलिए कई मायनों में कीमत से अधिक शक्तिशाली हो सकती है.
अंत में, विकास के पूर्वानुमान कारक एक हथियारों की दौड़ है, और आप एक कदम आगे रहने की कोशिश कर रहे हैं। कारक बाजार से बाहर हो जाते हैं और जीवनकाल के साथ आते हैं, इसलिए आपको यह निर्धारित करने के लिए लगातार काम करना होगा कि आपके कारक ने कितना गिरावट देखी है और कौन से नए कारक उन्हें बदलने के लिए उपयोग किए जा सकते हैं।
प्रत्येक रैंकिंग सिस्टम थोड़ा अलग समय सीमा पर रिटर्न का अनुमान लगाता है; मूल्य-आधारित औसत मूल्य प्रतिफल कुछ दिनों में अनुमानित हो सकता है, जबकि मूल्य-आधारित कारक मॉडल कुछ महीनों में अनुमानित हो सकते हैं; यह निर्धारित करना महत्वपूर्ण है कि मॉडल को किस समय सीमा पर भविष्यवाणी करनी चाहिए, और रणनीति निष्पादित करने से पहले सांख्यिकीय सत्यापन करना। आप निश्चित रूप से पुनः संतुलन की आवृत्ति को अनुकूलित करने का प्रयास करके अत्यधिक फिट नहीं होना चाहते हैं, और आप अनिवार्य रूप से अन्य आवृत्तियों पर एक बेतरतीब विकल्प पाएंगे। एक बार रैंकिंग कार्यक्रम के भविष्यवाणियों का समय सीमा निर्धारित हो जाने के बाद, अपने मॉडल का अधिकतम लाभ उठाने के लिए लगभग उस आवृत्ति पर पुनः संतुलन करने का प्रयास करें।
प्रत्येक रणनीति में न्यूनतम और अधिकतम पूंजी मात्रा होती है, और न्यूनतम सीमा आमतौर पर लेनदेन लागत द्वारा निर्धारित की जाती है।
बहुत अधिक शेयरों का लेन-देन करने से उच्च लेन-देन की लागत होती है। मान लीजिए कि आप 1000 शेयर खरीदना चाहते हैं, तो प्रत्येक पुनर्वित्त के लिए कुछ हज़ार डॉलर की लागत होगी। आपका पूंजीगत आधार इतना ऊंचा होना चाहिए कि लेन-देन की लागत आपकी रणनीति द्वारा उत्पन्न रिटर्न का एक छोटा सा हिस्सा हो। उदाहरण के लिए, यदि आपकी पूंजी $100,000 है और आपकी रणनीति प्रति माह 1% कमा रही है ((1000 डॉलर), तो ये सभी रिटर्न लेन-देन की लागत में शामिल होंगे। आपको लाखों डॉलर की पूंजी के साथ उस रणनीति को चलाने की आवश्यकता है जो 1000 से अधिक शेयरों का लाभ उठाती है।
सबसे कम परिसंपत्ति सीमा, जो मुख्य रूप से कारोबार किए जाने वाले शेयरों की संख्या पर निर्भर करती है। हालांकि, अधिकतम क्षमता भी बहुत अधिक है, और बहु-अवकाश संतुलन हित रणनीति सौ करोड़ डॉलर का व्यापार करने में सक्षम है और बिना नुकसान के लाभ खो देती है। यह सच है, क्योंकि यह रणनीति अपेक्षाकृत बार-बार rebalance करती है। कुल परिसंपत्ति की संख्या, व्यापार किए जाने वाले शेयरों की संख्या के अलावा, प्रति शेयर का डॉलर मूल्य बहुत कम होगा, और आपको चिंता करने की ज़रूरत नहीं है कि आपकी ट्रेडिंग मात्रा बाजार को प्रभावित करेगी। मान लीजिए कि आप 1000 शेयरों का व्यापार करते हैं, जो कि $ 100,000,000 है। यदि आप प्रति माह पूरे पोर्टफोलियो को rebalance करते हैं, तो प्रति शेयर प्रति माह केवल $ 100,000 होगा, जो अधिकांश ट्रेडों के लिए महत्वपूर्ण बाजार हिस्सेदारी के लिए पर्याप्त नहीं है।