নিবন্ধটি ডিজিটাল মুদ্রার উচ্চ-ফ্রিকোয়েন্সির লেনদেনের কৌশলগুলি নিয়ে আলোচনা করে, যার মধ্যে রয়েছে মুনাফা উত্স (প্রধানত বাজারের তীব্র উদ্বেগ এবং এক্সচেঞ্জের কমিশন ফেরত থেকে), একক অবস্থান এবং অবস্থান নিয়ন্ত্রণের সমস্যা, এবং প্যারেটো বন্টন ব্যবহার করে লেনদেনের মডেলিংয়ের পদ্ধতি। এছাড়াও, বিএনআইএন দ্বারা প্রদত্ত একক লেনদেন এবং সর্বোত্তম লেনদেনের ডেটা পুনরায় পরীক্ষা করার জন্য উল্লেখ করা হয়েছে এবং পরবর্তী নিবন্ধে উচ্চ-ফ্রিকোয়েন্সির লেনদেনের কৌশল সম্পর্কিত অন্যান্য বিষয়গুলি গভীরভাবে আলোচনা করার পরিকল্পনা করা হয়েছে।
এর আগে আমি ডিজিটাল মুদ্রার উচ্চ ফ্রিকোয়েন্সি ট্রেডিং সম্পর্কে দুটি নিবন্ধ লিখেছিলাম।ডিজিটাল মুদ্রার উচ্চ ফ্রিকোয়েন্সি কৌশল সম্পর্কে বিস্তারিত, ৫টি ক্যান্টন ৮০ গুণ শক্তিশালী, উচ্চ ফ্রিকোয়েন্সি কৌশল☞ তবে এটি কেবল অভিজ্ঞতা ভাগ করে নেওয়ার জন্য, সাধারণভাবে কথা বলার জন্য। এইবার আমি একটি সিরিজ নিবন্ধ লেখার পরিকল্পনা করছি, শুরু থেকে উচ্চ-ফ্রিকোয়েন্সি ট্রেডিংয়ের ধারণাটি পরিচয় করিয়ে দেওয়ার জন্য, আমি যতটা সম্ভব সংক্ষিপ্তভাবে স্পষ্ট করার চেষ্টা করছি, তবে আমার ব্যক্তিগত স্তরের সীমাবদ্ধতার কারণে, উচ্চ-ফ্রিকোয়েন্সি ট্রেডিংয়ের বোঝার গভীরতা নেই, এই নিবন্ধটি কেবল একটি কুইজ জুটি ফেলেছে, আশা করি দাদা ঠিক বলেছেন।
পূর্ববর্তী নিবন্ধে উল্লেখ করা হয়েছে যে, উচ্চ-ফ্রিকোয়েন্সি কৌশলগুলি বিশেষত বাজারে খুব তীব্রভাবে ওঠানামা করার জন্য উপযুক্ত। একটি ট্রেডিং জাতের স্বল্প সময়ের মধ্যে দামের পরিবর্তনগুলি পরীক্ষা করুন, যা সামগ্রিক প্রবণতা এবং উত্তেজনার সমন্বয়ে গঠিত। যদি আমরা সঠিকভাবে প্রবণতার পরিবর্তনগুলি পূর্বাভাস দিতে পারি তবে অবশ্যই অর্থ উপার্জন করতে পারি, তবে এটিও সবচেয়ে কঠিন। এই নিবন্ধটি মূলত উচ্চ-ফ্রিকোয়েন্সি ম্যাকার কৌশল সম্পর্কে আলোচনা করে, এই সমস্যাটি জড়িত হবে না। উত্তেজনার পরিস্থিতিতে, কৌশলগতভাবে অর্ডার দেওয়ার জন্য, যদি ট্রেডগুলি যথেষ্ট ঘন ঘন হয় এবং মুনাফার সুযোগ যথেষ্ট বড় হয় তবে ট্রেডগুলি প্রবণতার কারণে সম্ভাব্য ক্ষতিগুলি কভার করতে সক্ষম হয়, যাতে ভবিষ্যদ্বাণী করা যায় না।
1.策略同时挂买单和卖单,第一个问题就是在哪里挂单。挂的离盘口越近,成交的概率越高,但在剧烈波动的行情中,瞬间成交的价格可能离盘口较远,挂的那太近没有能吃到足够的利润。挂的太远的单子成交概率又低。这是一个需要优化的问题。
2.控制仓位。为了控制风险,策略就不能长时间累计过多的仓位。可以通过控制挂单距离、挂单量、总仓位限制等办法解决。
উপরের উদ্দেশ্যগুলি অর্জন করার জন্য, লেনদেনের সম্ভাব্যতা, লেনদেনের মুনাফা, বাজার অনুমান ইত্যাদির বিভিন্ন দিকের মডেলিং অনুমান করা প্রয়োজন। এই বিষয়ে অনেকগুলি নিবন্ধ এবং নিবন্ধ রয়েছে, উচ্চ-ফ্রিকোয়েন্সি ট্রেডিং, অর্ডারবুক ইত্যাদির মতো কীওয়ার্ডগুলিতে পাওয়া যায়। অনলাইনে অনেকগুলি প্রস্তাবনা রয়েছে, এখানে এটি চালু করা উচিত নয়। এছাড়াও একটি নির্ভরযোগ্য দ্রুত রিটার্নিং সিস্টেম স্থাপন করা ভাল। যদিও উচ্চ-ফ্রিকোয়েন্সি কৌশলগুলি বাস্তবতার মাধ্যমে কৌশলটির কার্যকারিতা যাচাই করা সহজ, তবে রিটার্নিং এখনও আরও পথ সরবরাহ করতে পারে এবং ভুল ধারণাটির ব্যয় হ্রাস করতে পারে।
বিএনএন পে-টু-পেড লেনদেন এবং সেরা আপলোড ডেটা সরবরাহ করে।ডাউনলোড, গভীরতার ডেটাটি হোয়াইটলিস্টে ডাউনলোড করা দরকার এবং এটি নিজেরাই সংগ্রহ করা যেতে পারে। পুনর্বিবেচনার জন্য অ্যাবস্ট্রাকশন ব্যবহার করে ট্রানজাকশন ডেটা সংগ্রহ করা যেতে পারে। এই নিবন্ধটি HOOKUSDT-aggTrades-2023-01-27 এর ডেটা দিয়ে উদাহরণ দেয়।
from datetime import date,datetime
import time
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
%matplotlib inline
এক টাকায় যেসব লেনদেন করা হয় তার মধ্যে রয়েছেঃ
আপনি দেখতে পাচ্ছেন যে 660,000 লেনদেনের ডেটা ছিল এবং লেনদেনগুলি সক্রিয় ছিল। csv টি মন্তব্য বিভাগে সংযুক্ত থাকবে।
trades = pd.read_csv('COMPUSDT-aggTrades-2023-07-02.csv')
trades
৬৬৪৪৭৫ সারি × ৭ কলাম
agg_trade_id | দাম | পরিমাণ | প্রথম_ট্রেড_আইডি | last_trade_id | লেনদেনের সময় | is_buyer_maker |
---|---|---|---|---|---|---|
120719552 | 52.42 | 22.087 | 207862988 | 207862990 | 1688256004603 | মিথ্যা |
120719553 | 52.41 | 29.314 | 207862991 | 207863002 | 1688256004623 | সত্য |
120719554 | 52.42 | 0.945 | 207863003 | 207863003 | 1688256004678 | মিথ্যা |
120719555 | 52.41 | 13.534 | 207863004 | 207863006 | 1688256004680 | সত্য |
… | … | … | … | … | … | … |
121384024 | 68.29 | 10.065 | 210364899 | 210364905 | 1688342399863 | মিথ্যা |
121384025 | 68.30 | 7.078 | 210364906 | 210364908 | 1688342399948 | মিথ্যা |
121384026 | 68.29 | 7.622 | 210364909 | 210364911 | 1688342399979 | সত্য |
প্রথমে ডাটা প্রক্রিয়াকরণ করা হয়, প্রাথমিক ট্রেডগুলিকে পেমেন্টের জন্য প্রারম্ভিক টার্গেট গ্রুপ এবং বিক্রয় আদেশের জন্য প্রারম্ভিক টার্গেট গ্রুপে বিভক্ত করা হয়। অন্যদিকে, প্রাথমিক সমষ্টিগত লেনদেনের ডেটা একই সময়ে একই দামে এবং একই দিকের একটি ডেটা। একটি প্রারম্ভিক লেনদেনের পরিমাণ 100 হতে পারে। যদি একাধিক লেনদেনের মধ্যে বিভক্ত করা হয় এবং দামগুলি ভিন্ন হয়, যেমন 60 এবং 40 টির জন্য বিভক্ত করা হয়, তবে দুটি ডেটা উত্পাদিত হবে, যা লেনদেনের পরিমাণের অনুমানকে প্রভাবিত করে। অতএব, লেনদেনের সময় অনুসারে একবার পুনরায় সমষ্টি করা প্রয়োজন। সমষ্টির পরে ডেটা পরিমাণ 140,000 টি হ্রাস পেয়েছে।
trades['date'] = pd.to_datetime(trades['transact_time'], unit='ms')
trades.index = trades['date']
buy_trades = trades[trades['is_buyer_maker']==False].copy()
sell_trades = trades[trades['is_buyer_maker']==True].copy()
buy_trades = buy_trades.groupby('transact_time').agg({
'agg_trade_id': 'last',
'price': 'last',
'quantity': 'sum',
'first_trade_id': 'first',
'last_trade_id': 'last',
'is_buyer_maker': 'last',
'date': 'last',
'transact_time':'last'
})
sell_trades = sell_trades.groupby('transact_time').agg({
'agg_trade_id': 'last',
'price': 'last',
'quantity': 'sum',
'first_trade_id': 'first',
'last_trade_id': 'last',
'is_buyer_maker': 'last',
'date': 'last',
'transact_time':'last'
})
buy_trades['interval']=buy_trades['transact_time'] - buy_trades['transact_time'].shift()
sell_trades['interval']=sell_trades['transact_time'] - sell_trades['transact_time'].shift()
print(trades.shape[0] - (buy_trades.shape[0]+sell_trades.shape[0]))
146181
উদাহরণস্বরূপ, পেমেন্টের জন্য, প্রথমে একটি স্ট্র্যাক গ্রাফ আঁকুন, আপনি দেখতে পাবেন যে দীর্ঘ-প্রবাহের প্রভাবটি খুব স্পষ্ট, বেশিরভাগ ডেটা বাম দিকে একদম কেন্দ্রীভূত, তবে ছোট পরিমাণে বড় লেনদেনগুলিও লেজের উপরে বিতরণ করা হয়েছে।
buy_trades['quantity'].plot.hist(bins=200,figsize=(10, 5));
为了观察方便,截掉尾部观察.可以看到成交量越大,出现频率越低,且减少的趋势更快。
buy_trades['quantity'][buy_trades['quantity']<200].plot.hist(bins=200,figsize=(10, 5));
লেনদেন-সন্তুষ্ট বন্টন নিয়ে অনেক গবেষণা করা হয়েছে। এটি পাওয়ার-লয় বন্টন নামেও পরিচিত। এটি পরিসংখ্যান পদার্থবিজ্ঞান এবং সামাজিক বিজ্ঞানে একটি সাধারণ সম্ভাব্যতা বন্টন। লেনদেন-সন্তুষ্ট বন্টনে, ঘটনার আকার (বা ফ্রিকোয়েন্সি) এর সম্ভাব্যতা ঘটনার আকারের একটি নেতিবাচক সূচকের সমান হয়। এই বন্টনের প্রধান বৈশিষ্ট্য হ'ল বড় ইভেন্টগুলির (অর্থাৎ, যেগুলি গড় থেকে দূরে) ঘটনার ফ্রিকোয়েন্সি অন্যান্য অনেক বন্টনে প্রত্যাশিতের চেয়ে বেশি। এটি হ'ল লেনদেনের বন্টনের বৈশিষ্ট্য। লেনদেনের বন্টনের ফর্মঃ Px = Cx^-α। এটি নীচে প্রমাণিত হবে।
নীচের চিত্রটি একটি মানের চেয়ে বড় একটি ট্রেডিংয়ের সম্ভাব্যতা দেখায়, নীল লাইনটি প্রকৃত সম্ভাব্যতা, বক্ররেখাটি অনুকরণীয় সম্ভাব্যতা। এখানে নির্দিষ্ট পরামিতিগুলিকে প্রথমে বিভ্রান্ত করবেন না, আপনি দেখতে পাবেন যে এটি সত্যিই প্যারেটো বিতরণকে সন্তুষ্ট করে। যেহেতু অর্ডার পরিমাণ 0 এর চেয়ে বড় হওয়ার সম্ভাবনা 1 এবং মানকীকরণের জন্য, এর বিতরণ সমীকরণের ফর্মটি নিম্নরূপ হওয়া উচিতঃ
যেখানে N হল মানসম্মত পরামিতি । এখানে গড় লেনদেনের পরিমাণ M নির্বাচন করুন, আলফা নির্বাচন করুন -২.০৬ । নির্দিষ্ট আলফার অনুমান D=N হলে P-ভ্যালু দ্বারা প্রতিফলিত হতে পারে । বিশেষতঃ আলফা = log ((P ((d>M)) /log ((2)) । বিভিন্ন পয়েন্ট নির্বাচন করে আলফা গ্রহণের মান সামান্য ভিন্ন হবে ।
depths = range(0, 250, 2)
probabilities = np.array([np.mean(buy_trades['quantity'] > depth) for depth in depths])
alpha = np.log(np.mean(buy_trades['quantity'] > mean_quantity))/np.log(2)
mean_quantity = buy_trades['quantity'].mean()
probabilities_s = np.array([(1+depth/mean_quantity)**alpha for depth in depths])
plt.figure(figsize=(10, 5))
plt.plot(depths, probabilities)
plt.plot(depths, probabilities_s)
plt.xlabel('Depth')
plt.ylabel('Probability of execution')
plt.title('Execution probability at different depths')
plt.grid(True)
plt.figure(figsize=(10, 5))
plt.grid(True)
plt.title('Diff')
plt.plot(depths, probabilities_s-probabilities);
কিন্তু এই অনুমানটি কেবল দেখতে এরকম, যে আমরা উপরের চিত্রটিতে অ্যালগরিদমের মান এবং প্রকৃত মানের মধ্যে পার্থক্য আঁকছি। যখন লেনদেনটি ছোট হয় তখন বিচ্যুতি খুব বড়, এমনকি 10% এর কাছাকাছিও হয়। প্যারামিটার অনুমানের সময় বিভিন্ন পয়েন্ট নির্বাচন করা যেতে পারে যাতে এই পয়েন্টটির সম্ভাবনা আরও সুনির্দিষ্ট হয়, তবে বিচ্যুতির সমস্যাও সমাধান করা যায় না। এটি একটি জার্লট বিতরণ এবং প্রকৃত বিতরণের পার্থক্য দ্বারা নির্ধারিত হয়, আরও সঠিক ফলাফল পেতে জার্লট বিতরণের সমীকরণের সংশোধন প্রয়োজন। নির্দিষ্ট প্রক্রিয়াটি বর্ণনা করা হয়নি, সংক্ষেপে, আলোর ঝলক পাওয়া গেছে, বাস্তবে এটি হওয়া উচিতঃ
এখানে r = q/M এর মাধ্যমে স্ট্যান্ডার্ডাইজড ট্রানজিশনের প্রতিনিধিত্ব করা হয়। প্যারামিটারগুলি উপরের মতোই অনুমান করা যেতে পারে। নীচের চিত্রটি দেখায় যে সংশোধনের পরে সর্বাধিক বিচ্যুতি 2% এর বেশি নয়। তাত্ত্বিকভাবে এটি সংশোধন করা যেতে পারে, তবে এই নির্ভুলতা যথেষ্ট।
depths = range(0, 250, 2)
probabilities = np.array([np.mean(buy_trades['quantity'] > depth) for depth in depths])
mean = buy_trades['quantity'].mean()
alpha = np.log(np.mean(buy_trades['quantity'] > mean))/np.log(2.05)
probabilities_s = np.array([(((1+20**(-depth/mean))*depth+mean)/mean)**alpha for depth in depths])
plt.figure(figsize=(10, 5))
plt.plot(depths, probabilities)
plt.plot(depths, probabilities_s)
plt.xlabel('Depth')
plt.ylabel('Probability of execution')
plt.title('Execution probability at different depths')
plt.grid(True)
plt.figure(figsize=(10, 5))
plt.grid(True)
plt.title('Diff')
plt.plot(depths, probabilities_s-probabilities);
লেনদেনের বন্টনের আনুমানিক সমীকরণের সাথে, সমীকরণের সম্ভাব্যতা সত্যিকারের সম্ভাব্যতা নয়, বরং একটি শর্তাধীন সম্ভাব্যতা। এই সময়ে এই প্রশ্নের উত্তর দেওয়া যেতে পারে যে, যদি পরবর্তী অর্ডার ঘটে তবে এই অর্ডারটি কোনও মানের চেয়ে বড় হওয়ার সম্ভাবনা কত? এটিও বলা যেতে পারে যে, বিভিন্ন গভীরতার অর্ডারগুলি সম্পন্ন হওয়ার সম্ভাবনা কত ((আদর্শ ক্ষেত্রে, কম কঠোর, তত্ত্বগত অর্ডার বুকটিতে নতুন অর্ডার এবং প্রত্যাহার রয়েছে এবং একই গভীরতার সারি রয়েছে) ।) ।
এখানে লেখাটা প্রায় শেষ হয়ে গেছে, কিন্তু অনেক প্রশ্নের উত্তর এখনও বাকি আছে, যেগুলোর উত্তর নিচের ধারাবাহিক লেখায় দেয়া হবে।
ওক পরিমাণ 🐂🍺
fmzeroগম্ভীর!
ঘাসসিএসভি খুব বড়, আমি নিজে ডাউনলোড করতে পারি।