২০২১ সালের সমাপ্তি এবং ভবিষ্যতের কৌশল.ipynb
২০২১ সাল শেষ হতে চলেছে, এবং ডিইএফআই থেকে গেমএফআই পর্যন্ত হট স্পটগুলি একের পর এক আবির্ভূত হচ্ছে, এবং সামগ্রিকভাবে বাজারটি এখনও একটি ষাঁড়ের বাজারে রয়েছে। এখন ফিরে তাকিয়ে, আপনি ২০২১ সালে কত উপার্জন করেছেন? কোন সুযোগটি মিস করেছেন? কোনও সফল বিনিয়োগ আছে কি? সম্প্রতি, আমি গত বছরের ইতিহাসের বাজার কোটগুলি টানলাম এবং একটি অপ্রত্যাশিতভাবে সহজ মুনাফা কৌশল পেয়েছি, তবে এটি একটি মাল্টি-মুদ্রা সূচক।
প্ল্যাটফর্মে তালিকাভুক্ত অনেকগুলি মুদ্রা প্রতীক রয়েছে এবং অনেকগুলি অজানা হওয়ার জন্য নির্ধারিত এবং এমনকি ট্রেডিং থেকে প্রত্যাহার করা যেতে পারে। এখানে আমরা মুদ্রা প্রতীকগুলি বেছে নিই যা বিন্যান্স চিরস্থায়ী স্যুপে তালিকাভুক্ত হয়েছে। এগুলি সাধারণত পরীক্ষা করা হয়েছে এবং মূলধারার মুদ্রা হিসাবে স্বীকৃত, যা তুলনামূলকভাবে নিরাপদ। একটি সাধারণ স্ক্রিনিংয়ের পরে, কিছু সূচক মুদ্রা সরানো হয়েছিল এবং 134 টি মুদ্রা অবশেষে বেঁচে ছিল।
[1] এঃ আমদানির অনুরোধ তারিখ-সময় থেকে আমদানি তারিখ, তারিখ-সময় আমদানি সময় পিডি হিসাবে পান্ডা আমদানি করুন এনপি হিসাবে আমদানি করুন plt হিসাবে matplotlib.pyplot আমদানি করুন % ম্যাটপ্লটলিব ইনলাইন
[১৪৪] এঃ
##বর্তমান ট্রেডিং জুটি
তথ্য = অনুরোধ.get(
[১৫৪] এঃ
চিহ্নf = list(set(filter(lambda x: x[-4:] ==
[১৫৫] এঃ print(len(symbols_f))
তারপর, আমরা গত বছরের তাদের দৈনিক বন্ধ মূল্য পেতে, এবং আমরা লক্ষ্য করি যে কিছু মুদ্রা প্রতীক শুধুমাত্র একটি স্বল্প সময়ের জন্য বাজারে ছিল, তাই তথ্য unitization প্রক্রিয়াকরণ প্রয়োজন। তথ্য unitizing দ্বারা, সূচক গণনা করা যেতে পারে।
চূড়ান্ত সূচক মুনাফা প্রায় 12 গুণ, অর্থাৎ, আপনি যদি 2021 সালের 1 জানুয়ারী গড়ে এই 134 টি মুদ্রা প্রতীক কিনে থাকেন তবে কিছুই না করার চূড়ান্ত মুনাফা 12 গুণ, এবং এটি অনুমান করা হয় যে 90% এরও বেশি লোক গড় সূচককে ছাড়িয়ে যায় না। তাদের মধ্যে, সর্বাধিক হ্রাস সহ মুদ্রা প্রতীকগুলিঃ আইসিপি 93%, ডোডো 85% হ্রাস পেয়েছে এবং লিনা 75% হ্রাস পেয়েছে। প্রায় একশো গুণ বৃদ্ধিঃ সোল, এফটিএম, লুনা, ম্যাটিক, স্যান্ড, এক্সএস। তাদের মধ্যে, এক্সএস 168 গুণ বৃদ্ধি পেয়েছে এবং বৃহত্তম কালো ঘোড়া। মাঝারি 3 গুণ বৃদ্ধি পেয়েছে। বলা যেতে পারে যে সূচকটি মূলত পাবলিক চেইন এবং গেমস দ্বারা চালিত হয়। এই সময়ের মধ্যে নতুন তালিকাভুক্ত মুদ্রা প্রতীকগুলি বাদ দিয়ে বেঁচে থাকার পক্ষপাত রোধ করার জন্য, এটি প্রায় 11 গুণ মুনাফা অর্জন করেছে। এটি কেবল বিটিসির হোল্ডিং।
এটি একটি হতাশাজনক মুনাফা অনুপাত। আমি কঠোর পরিশ্রম করেছি এবং সমস্ত ধরণের কৌশল চেষ্টা করেছি, এবং আমি কোনও অতিরিক্ত প্রচেষ্টা না করে এমন এক বছরের মতো বেশি মুনাফা অর্জন করতে পারি নি। তবে, এটি লক্ষ করা উচিত যে অনুপাতের বেশ কয়েকটি বৃদ্ধি খুব বিশাল, এবং স্পষ্টতই সূচক থেকে বিচ্যুত হয়। যদি এই মুদ্রা প্রতীকগুলি বছরের শুরুতে নির্বাচিত না হয় তবে মুনাফাটি মধ্যস্থের কাছাকাছি হবে, যা অনেক কম বিশিষ্ট।
[১৫৭] এঃ
#কোনও সময়ের মধ্যে K-লাইন পেতে ফাংশন
def GetKlines ((symbol=
df = pd.DataFrame(Klines,columns=['time','open','high','low','close','amount','end_time','volume','count','buy_amount','buy_volume','null']).astype('float')
df.index = pd.to_datetime(df.time,unit='ms')
profit df
[১৬৪] এঃ
df_all_s = pd.DataFrame ((index=pd.date_range ((start=
[১৬৫] এঃ df_all_s.tail() #ডাটা স্ট্রাকচার আউট[165]:
[১৭৪] এঃ
df_all = df_all_s.fillna ((method=
[১৭৫] এঃ # মধ্যম বৃদ্ধি df_norm.median ((axis=1).plot ((figsize=(12,4),grid=True); আউট[175]:
[১৬৮] এঃ #উঠা এবং পতন বাছাই print ((df_norm.iloc[-1].round ((2).sort_values().to_dict())
[317] এঃ গত বছরের সর্বোচ্চ মূল্যের তুলনায় বর্তমান মূল্যের সর্বোচ্চ প্রত্যাহার print (((1-df_norm.iloc[-1]/df_norm.max()) round ((2).sort_values().to_dict())
[১৭৭] এঃ
df_all_f = pd.DataFrame ((index=pd.date_range ((start=
[208] এঃ
# নতুন প্রতীক অন্তর্ভুক্ত না
df = df_all_s[df_all_s.columns[~df_all_f.iloc[0].isnull() ]
df = df.fillna ((পদ্ধতি=
[২১২] এঃ #বিটিসির তুলনায় (df.mean(axis=1)/df.BTCUSDT).plot(figsize=(12,4),grid=True); আউট[212]:
[২১৩] এঃ # পুরানো ব্যাকটেস্ট ইঞ্জিন ব্যবহার করুন ক্লাস এক্সচেঞ্জঃ
def __init__(self, trade_symbols, fee=0.0004, initial_balance=10000):
self.initial_balance = initial_balance #initial asset
self.fee = fee
self.trade_symbols = trade_symbols
self.account = {'USDT':{'realised_profit':0, 'unrealised_profit':0, 'total':initial_balance, 'fee':0}}
for symbol in trade_symbols:
self.account[symbol] = {'amount':0, 'hold_price':0, 'value':0, 'price':0, 'realised_profit':0,'unrealised_profit':0,'fee':0}
def Trade(self, symbol, direction, price, amount):
cover_amount = 0 if direction*self.account[symbol]['amount'] >=0 else min(abs(self.account[symbol]['amount']), amount)
open_amount = amount - cover_amount
self.account['USDT']['realised_profit'] -= price*amount*self.fee #deduct service fee
self.account['USDT']['fee'] += price*amount*self.fee
self.account[symbol]['fee'] += price*amount*self.fee
if cover_amount > 0: #close first
self.account['USDT']['realised_profit'] += -direction*(price - self.account[symbol]['hold_price'])*cover_amount #profit
self.account[symbol]['realised_profit'] += -direction*(price - self.account[symbol]['hold_price'])*cover_amount
self.account[symbol]['amount'] -= -direction*cover_amount
self.account[symbol]['hold_price'] = 0 if self.account[symbol]['amount'] == 0 else self.account[symbol]['hold_price']
if open_amount > 0:
total_cost = self.account[symbol]['hold_price']*direction*self.account[symbol]['amount'] + price*open_amount
total_amount = direction*self.account[symbol]['amount']+open_amount
self.account[symbol]['hold_price'] = total_cost/total_amount
self.account[symbol]['amount'] += direction*open_amount
def Buy(self, symbol, price, amount):
self.Trade(symbol, 1, price, amount)
def Sell(self, symbol, price, amount):
self.Trade(symbol, -1, price, amount)
def Update(self, close_price): #update asset
self.account['USDT']['unrealised_profit'] = 0
for symbol in self.trade_symbols:
self.account[symbol]['unrealised_profit'] = (close_price[symbol] - self.account[symbol]['hold_price'])*self.account[symbol]['amount']
self.account[symbol]['price'] = close_price[symbol]
self.account[symbol]['value'] = abs(self.account[symbol]['amount'])*close_price[symbol]
self.account['USDT']['unrealised_profit'] += self.account[symbol]['unrealised_profit']
self.account['USDT']['total'] = round(self.account['USDT']['realised_profit'] + self.initial_balance + self.account['USDT']['unrealised_profit'],6)
[418] এঃ
# আরো সঠিক ব্যাকটেস্টের জন্য, 1 ঘন্টা কে-লাইন ক্রল করুন
df_all_s = pd.DataFrame ((index=pd.date_range ((start=
[419]-এঃ
df = df_all_s[df_all_s.columns[~df_all_f.iloc[0].isnull() ]
df = df.fillna ((পদ্ধতি=
ব্যাকটেস্টটি 1 জানুয়ারী, 2021 তারিখে বাইনান্স চিরস্থায়ী চুক্তিতে তালিকাভুক্ত সমস্ত মুদ্রা প্রতীক নির্বাচন করেছে। কে-লাইন সময়কাল 1h, এবং পরামিতিটি হ'ল পজিশন পরিমাণ গড়ের 5% এর চেয়ে কম হলে কিনতে শুরু করুন এবং 5% এর বেশি হলে বিক্রি শুরু করুন। যখন ব্যাকটেস্টটি সমস্ত মুদ্রা প্রতীকগুলির হয়, চূড়ান্ত কৌশল লাভ 7.7 গুণ। 13 গুণের গড় লাভের তুলনায় উল্লেখযোগ্যভাবে খারাপ। এটিও আমার প্রত্যাশায়। সর্বোপরি, সেই মুদ্রা প্রতীকগুলি যা একশত গুণ বৃদ্ধি পেয়েছে সেগুলি খুব বিশেষ, এবং ভারসাম্যপূর্ণ কৌশল তাদের সমস্ত বিক্রি করবে।
যদি ব্যাকটেস্টটি সর্বোচ্চ বৃদ্ধির সাথে 10 টি মুদ্রা প্রতীক অপসারণের সিদ্ধান্ত নেয় এবং কেবলমাত্র তুলনামূলকভাবে মাঝারি মুদ্রা প্রতীকগুলি পরীক্ষা করে, চূড়ান্ত মুনাফা 4.8 গুণ, যা 3.4 গুণের গড় পারফরম্যান্সের চেয়ে অনেক বেশি।
যদি শুধুমাত্র সর্বোচ্চ বৃদ্ধি সহ 3 টি মুদ্রা প্রতীক ঘোরানো হয়, তাহলে চূড়ান্ত মুনাফা 373 গুণ, যা 160 গুণের গড় পারফরম্যান্সের তুলনায় অনেক বেশি। এটি দেখায় যে যদি নির্বাচিত ঘোরানো মুদ্রা প্রতীকটির প্রবণতা এবং বৃদ্ধি ধারাবাহিক হয়, তবে ঘোরানোর ফলাফলটি ঘোরানোর চেয়ে অনেক ভাল হবে।
[৪৯৪] এঃ
#backtest সব চিহ্ন
symbols = list ((df.iloc[-1].sort_values() [:].index)
e = এক্সচেঞ্জ ((সিম্বল, ফি=০.০০১, প্রাথমিক_বালান্স=১০০০০)
res_list = []
avg_pct = 1/len (প্রতীক)
df[symbols].iterrows ((() এর রঙের জন্যঃ
দাম = সারি [1]
মোট = ই.অ্যাকাউন্ট[
[৪৯৫] এঃ
e.account[
[৪৯৬] এঃ #backtest সব চিহ্ন কর্মক্ষমতা (res.total/10000).plot ((figsize=(12,4), গ্রিড = সত্য); df[symbols].mean ((axis=1).plot ((figsize=(12,4),grid=True); আউট[496]:
[৪৯৮] এঃ
# বড় বৃদ্ধি সঙ্গে প্রতীক হ্রাস
symbols = list ((df.iloc[-1].sort_values() [:-10].index)
e = এক্সচেঞ্জ ((সিম্বল, ফি=০.০০১, প্রাথমিক_বালান্স=১০০০০)
res_list = []
avg_pct = 1/len (প্রতীক)
df[symbols].iterrows ((() এর রঙের জন্যঃ
দাম = সারি [1]
মোট = ই.অ্যাকাউন্ট[
[৫০১] এঃ
e.account[
৪৯৯ সালেঃ (res.total/10000).plot ((figsize=(12,4), গ্রিড = সত্য); df[symbols].mean ((axis=1).plot ((figsize=(12,4),grid=True); আউট [499]:
[৫০৩] এঃ
#শুধুমাত্র সর্বোচ্চ বৃদ্ধি সঙ্গে চিহ্ন পরীক্ষা
symbols = list ((df.iloc[-1].sort_values() [-3:].index)
e = এক্সচেঞ্জ ((সিম্বল, ফি=০.০০১, প্রাথমিক_বালান্স=১০০০০)
res_list = []
avg_pct = 1/len (প্রতীক)
df[symbols].iterrows ((() এর রঙের জন্যঃ
দাম = সারি [1]
মোট = ই.অ্যাকাউন্ট[
[৫০৪] এঃ
e.account[
[৫০৫] এঃ (res.total/10000).plot ((figsize=(12,4), গ্রিড = সত্য); df[symbols].mean ((axis=1).plot ((figsize=(12,4),grid=True); আউট[505]:
সাধারণভাবে, ২০২১ সালটি অনুলিপি মুদ্রার জন্য একটি বড় ষাঁড়ের বাজার এবং বিটিসির জন্য একটি নির্জন বছর ছিল। বিটিসির বাজার মূল্য বছরের শুরুতে ৭০% থেকে এখন ৪০% এ নেমে গেছে, যা ইতিমধ্যে ইতিহাসের সর্বনিম্ন স্তরে রয়েছে। অতএব, গত বছরে অনুলিপি মুদ্রার প্রতীকগুলি কেনার এবং তাদের ধরে রাখার গড় মুনাফা বিটিসি রাখার তুলনায় অনেক বেশি ছিল। ২০২২ সালের দিকে এগিয়ে তাকিয়ে, যদি আপনি মনে করেন যে ভবিষ্যতে বর্তমান বাজারে এখনও কয়েকশ গুণ মুদ্রা জন্মগ্রহণ করবে, আপনি সাহসের সাথে আপনার রাখা মুদ্রার প্রতীকগুলি বৈচিত্র্যময় করতে পারেন এবং ধৈর্য সহকারে অপেক্ষা করতে পারেন। যদি আপনি কয়েকটি মুদ্রার প্রতীক বা গড় বাজারের বিষয়ে বিশেষভাবে আশাবাদী হন তবে আপনি চিন্তা না করে অতিরিক্ত মুনাফা অর্জনের জন্য ঘূর্ণন কৌশলটি ব্যবহার করতে পারেন। যদি আপনি সম্মত হন যে জিনিসগুলি যখন চরম হয়ে যায় তখন বিটিসি বিপরীত দিকে বিকশিত হবে, আপনি আরও ভাল মুনাফা এবং সুরক্ষার জন্য নীচে মাছ ধরতে পারেন।