
সবাইকে নমস্কার, আমি সম্প্রতি বন্ধুদের কাছ থেকে কর্মপ্রবাহ ব্যবহার সম্পর্কে প্রচুর প্রতিক্রিয়া পেয়েছি, এবং সবচেয়ে বেশি জিজ্ঞাসিত প্রশ্ন হল…ক্রেডিট শতাংশএবংস্টপ লসসেটআপ সংক্রান্ত সমস্যা সম্পর্কে, অনেকেই জিজ্ঞাসা করেন: “আমি জানি আমার ঝুঁকি নিয়ন্ত্রণ করতে হবে, কিন্তু অ্যাকাউন্ট তহবিলের উপর ভিত্তি করে অর্ডারের পরিমাণ ঠিক কীভাবে গণনা করব? এছাড়াও, পজিশন খোলার পরে আমি কীভাবে স্বয়ংক্রিয়ভাবে স্টপ-লস এবং টেক-প্রফিট অর্ডার সেট করব যাতে সিস্টেম আমাদের জন্য ঝুঁকি পরিচালনা করতে পারে?”
আজ, আমরা এই ব্যবহারিক চাহিদাগুলি সমাধান করব এবং, ইনভেন্টরস কোয়ান্টিফিকেশন প্ল্যাটফর্মের প্রকৃত কোড ব্যবহার করে, এই দুটি মূল ফাংশন কীভাবে বাস্তবায়ন করতে হয় তা বিস্তারিতভাবে ব্যাখ্যা করব।

ক্রেডিট শতাংশএর মানে হল অর্ডারের সংখ্যা নির্দিষ্ট নয়, বরং অ্যাকাউন্টে মোট তহবিলের একটি নির্দিষ্ট শতাংশের ভিত্তিতে গণনা করা হয়।
উদাহরণস্বরূপ:
মূল সুবিধা:
// 1. 获取账户信息
const accountInfo = exchange.GetAccount();
if (!accountInfo) {
return [{
json: {
success: false,
error: "获取账户信息失败"
}
}];
}
const availBalance = accountInfo.Balance; // 可用余额
Log("账户可用余额:", availBalance);
গুরুত্বপূর্ণ বিষয়সমূহ:Balanceক্ষেত্রটি উপলব্ধ ব্যালেন্সকে প্রতিনিধিত্ব করে, যা গণনার ভিত্তি।
// 2. 获取市场信息
const symbol = $vars.coin + '_USDT.swap' || 'ETH_USDT.swap';
const allMarkets = exchange.GetMarkets();
const marketsInfo = allMarkets[symbol];
if (!marketsInfo) {
return [{
json: {
success: false,
error: `未找到交易对信息: ${symbol}`
}
}];
}
মূল প্যারামিটারের বর্ণনা:
CtValচুক্তির অভিহিত মূল্য (যেমন, একটি ETH চিরস্থায়ী চুক্তির অভিহিত মূল্য 0.01 ETH)MinQtyসর্বনিম্ন অর্ডার পরিমাণMaxQtyসর্বোচ্চ অর্ডার পরিমাণAmountPrecisionপরিমাণ নির্ভুলতাPricePrecisionদামের নির্ভুলতাবিশেষ মনোযোগআপনি যে মুদ্রাটি লেনদেন করতে চান তা এক্সচেঞ্জে বিদ্যমান কিনা তা নিশ্চিত করে দেখুন।
// 3. 获取当前价格
const ticker = exchange.GetTicker(symbol);
if (!ticker) {
return [{
json: {
success: false,
error: "获取价格信息失败"
}
}];
}
const currentPrice = ticker.Last; // 最新成交价
Log("当前价格:", currentPrice);
// 4. 计算合约张数
const riskRatio = $vars.riskRatio || 0.05; // 默认 5% 风险比例
// 步骤 1:计算风险金额
const riskAmount = availBalance * riskRatio;
// 步骤 2:计算币种数量
let coinQuantity = riskAmount / currentPrice;
// 步骤 3:转换为合约张数(因为期货交易用的是合约张数)
let contractQuantity = coinQuantity / marketsInfo.CtVal;
// 步骤 4:精度处理(确保下单数量符合交易所要求)
contractQuantity = _N(contractQuantity, marketsInfo.AmountPrecision);
Log("计算步骤:");
Log("- 风险金额:", riskAmount);
Log("- 币种数量:", coinQuantity);
Log("- 合约面值:", marketsInfo.CtVal);
Log("- 原始合约张数:", coinQuantity / marketsInfo.CtVal);
Log("- 精度处理后:", contractQuantity);
গণনার সূত্রের সারাংশ:
合约张数 = (账户余额 × 风险比例 ÷ 当前价格) ÷ 合约面值
// 5. 检查限制
if (contractQuantity < marketsInfo.MinQty) {
return [{
json: {
success: false,
error: `计算数量${contractQuantity}小于最小要求${marketsInfo.MinQty}`,
calculatedQuantity: contractQuantity,
minQty: marketsInfo.MinQty
}
}];
}
if (contractQuantity > marketsInfo.MaxQty) {
Log("数量超过最大限制,使用最大值:", marketsInfo.MaxQty);
contractQuantity = marketsInfo.MaxQty;
}
Log("最终下单数量:", contractQuantity);
নতুনদের দ্বারা করা সাধারণ ভুলগুলি:
উপরের সেটিংস ভুল থাকলে, অর্ডার ব্যর্থতার একটি বিজ্ঞপ্তি প্রদর্শিত হবে। এটি এমন একটি বিষয় যা নতুনদের বিশেষভাবে মনোযোগ দেওয়া উচিত।

লাভ-গ্রহণ এবং ক্ষতি-প্রতিরোধের দিকনির্দেশনা নিয়ে অনেকেই বিভ্রান্ত। আসুন এটি স্পষ্ট করি:
| হোল্ডিংয়ের ধরণ | মুনাফা অর্জনের কার্যক্রম | স্টপ লস অপারেশন |
|---|---|---|
| একাধিক অর্ডার | দাম বাড়লে পজিশন বন্ধ করার জন্য বিক্রি করুন | দাম কমে গেলে পজিশন বন্ধ করার জন্য বিক্রি করুন। |
| সংক্ষিপ্ত পদ | দাম কমে গেলে পজিশন বন্ধ করার জন্য কিনুন | দাম বাড়লে পজিশন বন্ধ করার জন্য কিনুন |
গুরুত্বপূর্ণ বিষয়সমূহলাভ-গ্রহণ এবং স্টপ-লস উভয়ইবন্ধের কাজদিকটি অবস্থানের দিকের বিপরীত হওয়া উচিত।
উদ্ভাবক প্ল্যাটফর্মে, ব্যবহার করুনCreateConditionOrderস্টপ-লস এবং টেক-প্রফিট লেভেল নির্ধারণের ফাংশন:
বর্তমানে, FMZ প্ল্যাটফর্ম লাইভ ট্রেডিংয়ে CreateConditionOrder শর্তসাপেক্ষ অর্ডার সমর্থন করে, কিন্তু ব্যাকটেস্টিং এখনও তাদের সমর্থন করে না।
exchange.CreateConditionOrder(
symbol, // 交易对
closeDirection, // 平仓方向:closebuy 或 closesell
positionSize, // 平仓数量
{
"ConditionType": ORDER_CONDITION_TYPE_SL, // 止损类型
"SlTriggerPrice": stopLossPrice, // 触发价格
"SlOrderPrice": executionPrice // 执行价格
},
"止损单" // 订单备注
);
প্যারামিটার বর্ণনা:
অপারেশনের ধরণ(closeDirection):
closebuyclosesellConditionType:
ORDER_CONDITION_TYPE_SLস্টপ লসORDER_CONDITION_TYPE_TPলাভ নিনট্রিগারপ্রাইসএই দামে পৌঁছে গেলে অর্ডারটি সক্রিয় করুন।
অর্ডার মূল্য (কার্যকর মূল্য)সক্রিয়করণের পর এই মূল্যে লেনদেন সম্পন্ন হবে।
বিজ্ঞপ্তি:বর্তমানে, শর্তসাপেক্ষ অর্ডারগুলি শুধুমাত্র লাইভ ট্রেডিংয়ে সমর্থিত, এবং কাস্টোডিয়ান আপডেট করা প্রয়োজন।
কোডে, আমরা খোলার দিকের উপর ভিত্তি করে গতিশীলভাবে গণনা করি:
const stopLossPercent = 0.02; // 2% 止损
const takeProfitPercent = 0.04; // 4% 止盈
if (openSide == 'openShort') {
// 空仓:止损价格上涨,止盈价格下跌
stopLossPrice = _N(entryPrice * (1 + stopLossPercent), pricePrecision);
takeProfitPrice = _N(entryPrice * (1 - takeProfitPercent), pricePrecision);
} else {
// 多仓:止损价格下跌,止盈价格上涨
stopLossPrice = _N(entryPrice * (1 - stopLossPercent), pricePrecision);
takeProfitPrice = _N(entryPrice * (1 + takeProfitPercent), pricePrecision);
}
Log("入场价格:", entryPrice);
Log("止损价格:", stopLossPrice);
Log("止盈价格:", takeProfitPrice);
শর্তসাপেক্ষ শীটগুলি সেট আপ করার পরে, আমাদের সেগুলি পরিচালনা এবং পর্যবেক্ষণ করতে হবে:
// 查询条件单状态
const slOrder = exchange.GetConditionOrder(stopLossOrderId);
const tpOrder = exchange.GetConditionOrder(takeProfitOrderId);
Log("止损单状态:", slOrder.Status);
Log("止盈单状态:", tpOrder.Status);
Log("状态说明: 0=活跃, 1=已触发, -1=不存在");
স্টেট হ্যান্ডলিং লজিক:
if (slStatus == 1 && tpStatus == 0) {
// 止损被触发,取消止盈单
Log("🛑 止损单已触发,取消止盈单");
exchange.CancelConditionOrder(takeProfitOrderId);
_G('status', 'finished');
} else if (tpStatus == 1 && slStatus == 0) {
// 止盈被触发,取消止损单
Log("🎯 止盈单已触发,取消止损单");
exchange.CancelConditionOrder(stopLossOrderId);
_G('status', 'finished');
} else if (slStatus == 0 && tpStatus == 0) {
// 两个单都还活跃,继续监控
Log("⏳ 止盈止损单都活跃,继续监控");
}
মূল বৈশিষ্ট্য:
GetConditionOrderএই ফাংশনটি আপনাকে সমস্ত শর্তসাপেক্ষ অর্ডারের বর্তমান অবস্থা দেখতে দেয়।CancelConditionOrderফাংশনটির জন্য শুধুমাত্র অর্ডার নম্বর ইনপুট হিসেবে প্রয়োজন।সতর্কতা:
ডেমোনস্ট্রেশন ওয়ার্কফ্লোতে, আমরা সম্পূর্ণ লেনদেন চক্র পরিচালনা করার জন্য একটি স্টেট মেশিন ব্যবহার করি:
const savestatus = _G('status');
// 初始化状态
if (!savestatus) {
_G('status', 'unfinished');
}
তিনটি রাজ্য:
স্টপ-লস এবং টেক-প্রফিট অর্ডারের সাথে ইকুইটি শতাংশ অর্ডার একীভূত করার মাধ্যমে, আমাদের একটি সম্পূর্ণ ট্রেডিং কর্মপ্রবাহ রয়েছে:
প্রবাহ তালিকা:
计算下单数量 → 执行开仓 → 设置止盈止损 → 监控持仓 → 交易完成
কোড বাস্তবায়ন:
// 状态1: 执行开仓
if (positionData.status == 'unfinished') {
// 1. 开仓下单
const openOrder = exchange.CreateOrder(symbol, dir, -1, positionSize);
// 2. 等待订单成交
Sleep(3000);
const openOrderInfo = exchange.GetOrder(openOrder);
// 3. 订单成交后设置止盈止损
if (openOrderInfo.Status == ORDER_STATE_CLOSED) {
const stopLossOrderId = exchange.CreateConditionOrder(...);
const takeProfitOrderId = exchange.CreateConditionOrder(...);
// 4. 保存订单ID并切换到监控状态
_G('stopLossOrderId', stopLossOrderId);
_G('takeProfitOrderId', takeProfitOrderId);
_G('status', 'monitor');
}
}
// 状态2: 监控止盈止损
if (positionData.status == 'monitor') {
// 检查条件单状态,处理触发情况
// ...
}
// 状态3: 交易完成
if (positionData.status == 'finished') {
_G('status', 'unfinished'); // 重置状态,准备下次交易
}
পুরো প্রক্রিয়ার সুবিধা:
ঝুঁকি অনুপাত:
লাভ-গ্রহণ এবং স্টপ-লস অনুপাত:
সম্পূর্ণ পরীক্ষার চেকলিস্ট:
পরীক্ষা প্রক্রিয়া:
মনে রাখবেন: পুঙ্খানুপুঙ্খ পরীক্ষার পরই এটিকে লাইভ ট্রেডিংয়ে রাখা উচিত; এটি পরিমাণগত ট্রেডিংয়ের একটি মৌলিক নীতি।
ঠিক আছে, আজকের আলোচনাটি ইকুইটি শতাংশ অর্ডার প্লেসমেন্ট এবং স্টপ-লস/টেক-প্রফিট সেটিংস নিয়ে শেষ হচ্ছে। এই কর্মপ্রবাহটি ঝুঁকি নিয়ন্ত্রণকে স্বয়ংক্রিয় সম্পাদনের সাথে একত্রিত করে, যা আমাদের ট্রেডিংকে আরও মানসম্মত করে তোলে। তবে, প্রত্যেকের ট্রেডিং স্টাইল এবং ঝুঁকি সহনশীলতা আলাদা, তাই আপনার নিজস্ব পরিস্থিতি অনুসারে প্যারামিটারগুলি সামঞ্জস্য করতে ভুলবেন না। ব্যবহারের সময় যদি আপনার কোনও সমস্যার সম্মুখীন হন, অথবা পরিমাণগত ট্রেডিং সম্পর্কে অন্য কোনও প্রশ্ন থাকে, তাহলে পরামর্শ এবং আলোচনার জন্য দয়া করে আমাদের সাথে যোগাযোগ করতে দ্বিধা করবেন না। আসুন একসাথে অন্বেষণ করি এবং উন্নতি করি।
সোর্স কোড রেফারেন্স: https://www.fmz.com/strategy/516459