[TOC]
এফএমজেড একটি পরিমাণগত ট্রেডিং প্ল্যাটফর্ম, যা মূলত প্রোগ্রামযুক্ত ব্যবসায়ীদের পরিষেবা দেওয়ার জন্য। তবে এটি একটি মৌলিক ট্রেডিং টার্মিনালও সরবরাহ করে, যদিও বৈশিষ্ট্যগুলি সহজ, তবে কখনও কখনও এটি খুব দরকারীও হতে পারে, যেমন এক্সচেঞ্জগুলি ব্যস্ত থাকে এবং খোলা যায় না, তবে এপিআইগুলি কাজ করতে পারে, যখন টার্মিনালটি দিয়ে টাকা তোলা, অর্ডার করা, ব্যাংক অ্যাকাউন্টগুলি দেখা যায় ইত্যাদি। ট্রেডিং টার্মিনালের অভিজ্ঞতা উন্নত করার জন্য, এখন প্লাগইন বৈশিষ্ট্য যুক্ত করা হয়েছে। কখনও কখনও আমাদের একটি ছোট বৈশিষ্ট্য প্রয়োজন যা ট্রেডিংকে সহায়তা করতে পারে, যেমন সিঁড়ি ঝুলানো, হিমশৈল ভাড়া, এক-কনক হোল্ডিং, এক-কনক স্থিতিশীলতা ইত্যাদি।
প্লাগ-ইন দুটি মোডে চলতে পারে, তাত্ক্ষণিকভাবে চলতে এবং ব্যাকগ্রাউন্ডে চলতে পারে। ব্যাকগ্রাউন্ডে চলতে রোবট তৈরির সমান ((স্বাভাবিক চার্জ) । তাত্ক্ষণিকভাবে চলার নীতি এবং ডিবাগিং সরঞ্জামগুলি একইঃ একটি কোড পাঠানোর হোস্টের দ্বারা সম্পাদিত হয় যা একটি লেনদেনের টার্মিনাল পৃষ্ঠায় পাঠায় এবং ফিরে আসা চার্ট এবং টেবিলগুলি সমর্থন করে (ডিবাগিং সরঞ্জামগুলি বর্তমানে আপগ্রেড সমর্থিত), একইভাবে কেবল 5 মিনিটের মধ্যে চালিত হয়, কোনও ফি বা কোনও ভাষার সীমাবদ্ধতা নেই। খুব কম সময় চলার প্লাগইনগুলি তাত্ক্ষণিকভাবে চলতে পারে, জটিল, দীর্ঘ চলমান কৌশলগুলি বা রোবট চালানোর প্রয়োজন হয়।
নীতির টাইপটি প্লাগইন হিসেবে নির্বাচন করা প্রয়োজন।প্লাগইন এর main ফাংশন return এর ফলাফলটি চালানোর পর টার্মিনালে পপ আপ হয়, যা স্ট্রিং, গ্রাফ এবং টেবিলকে সমর্থন করে। প্লাগইন এক্সিকিউশন লগ দেখতে না পারায়, প্লাগইন এর এক্সিকিউশন ফলাফল return ফিরিয়ে দিতে পারে।
আপনি যদি সরাসরি অনুসন্ধান বাক্সে অনুসন্ধান করেন, তাহলে আপনি দেখতে পাবেন যে এটি একটি খুব সহজ কাজ।মনে রাখবেন যে শুধুমাত্র লেনদেন প্লাগইন টাইপ নীতিগুলি চালানো যাবে, এবং তারপর Add ক্লিক করুন. Open Plugin টি Strategy Square এ পাওয়া যাবেঃhttps://www.fmz.com/square/21/1
ক্লিক করা নীতিটি প্যারামিটার সেটিং ইন্টারফেসে প্রবেশ করে, যদি কোনও প্যারামিটার না থাকে তবে এটি সরাসরি চালিত হয়, লেনদেন টার্মিনালের নির্বাচিত হোস্ট, লেনদেনের জোড়া, K লাইন চক্র হ'ল ডিফল্টরূপে সংশ্লিষ্ট প্যারামিটার। ক্লিক করা কার্যকর নীতিটি কার্যকর করা শুরু করে, প্যারামিটার মোডটি তাত্ক্ষণিকভাবে চালিত হয় যখন প্যারামিটারটি নির্বাচন করা হয় ((ডিফল্ট অপারেশনটি মনে রাখবেন) । প্লাগইনটি লগ প্রদর্শন করবে না।
প্রদর্শিত অবস্থানের উপর ক্লিক করলে প্লাগইনটি বন্ধ হয়ে যাবে, কারণ সমস্ত প্লাগইন একটি ডিবাগিং সরঞ্জাম প্রক্রিয়ার মধ্যে সম্পাদিত হয়।
প্লাগইন একটি নির্দিষ্ট সময়ের জন্য কোড সম্পাদন করতে পারে, কিছু সহজ ক্রিয়াকলাপ সম্পাদন করতে পারে, অনেক সময় ম্যানুয়াল অপারেশন পুনরাবৃত্তি করা প্রয়োজন এমন ক্রিয়াকলাপগুলি প্লাগইন দিয়ে বাস্তবায়ন করা যেতে পারে, সহজ লেনদেন; নীচে নির্দিষ্ট উদাহরণ দিয়ে পরিচয় করিয়ে দেওয়া হবে, সরবরাহিত উত্স কোডটি আপনার কৌশলটি কাস্টমাইজ করার জন্য রেফারেন্স হিসাবে ব্যবহার করা যেতে পারে।
ফিউচার ক্রস-টার্ম হেজিং একটি খুব সাধারণ কৌশল, যেহেতু ফ্রিকোয়েন্সি খুব বেশি নয়, তাই অনেক লোক ম্যানুয়ালি কাজ করবে, একটি চুক্তি আরও বেশি করার প্রয়োজন, একটি চুক্তি খালি করার প্রয়োজন, এবং পার্থক্যের গতিবিধি বিশ্লেষণ করা। ট্রেডিং টার্মিনালে প্লাগইন ব্যবহার করে আপনার শক্তি সাশ্রয় করবে।
প্রথমত, একটি পেইন্টিং ক্রস-টার্ম ডিফারেনশিয়াল প্লাগইনঃ
var chart = {
__isStock: true,
title : { text : '差价分析图'},
xAxis: { type: 'datetime'},
yAxis : {
title: {text: '差价'},
opposite: false,
},
series : [
{name : "diff", data : []},
]
}
function main() {
exchange.SetContractType('quarter')
var recordsA = exchange.GetRecords(PERIOD_M5) //周期可以自行定制
exchange.SetContractType('this_week')
var recordsB = exchange.GetRecords(PERIOD_M5)
for(var i=0;i<Math.min(recordsA.length,recordsB.length);i++){
var diff = recordsA[recordsA.length-Math.min(recordsA.length,recordsB.length)+i].Close - recordsB[recordsB.length-Math.min(recordsA.length,recordsB.length)+i].Close
chart.series[0].data.push([recordsA[recordsA.length-Math.min(recordsA.length,recordsB.length)+i].Time, diff])
}
return chart
}
এই প্লাগইনটির মূল কোড কপি করার জন্য, ক্লিক করুন এবং সাম্প্রতিক ক্রস-টার্ম পার্থক্যগুলি দেখুনঃhttps://www.fmz.com/strategy/187755
পার্থক্য বিশ্লেষণের সাথে, পার্থক্যটি ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে ঘনিষ্ঠভাবে।https://www.fmz.com/strategy/191348
function main(){
exchange.SetContractType(Reverse ? Contract_B : Contract_A)
var ticker_A = exchange.GetTicker()
if(!ticker_A){return 'Unable to get quotes'}
exchange.SetDirection('buy')
var id_A = exchange.Buy(ticker_A.Sell+Slip, Amount)
exchange.SetContractType(Reverse ? Contract_B : Contract_A)
var ticker_B = exchange.GetTicker()
if(!ticker_B){return 'Unable to get quotes'}
exchange.SetDirection('sell')
var id_B = exchange.Sell(ticker_B.Buy-Slip, Amount)
if(id_A){
exchange.SetContractType(Reverse ? Contract_B : Contract_A)
exchange.CancelOrder(id_A)
}
if(id_B){
exchange.SetContractType(Reverse ? Contract_B : Contract_A)
exchange.CancelOrder(id_B)
}
return 'Position: ' + JSON.stringify(exchange.GetPosition())
}
দামের ঘনিষ্ঠতার জন্য অপেক্ষা করুন, সমতলকরণের প্রয়োজন, একটি বোতাম সমতলকরণ প্লাগইন চালাতে পারেন, দ্রুততম গতি সমতলকরণ।
function main(){
while(ture){
var pos = exchange.GetPosition()
var ticker = exchange.GetTicekr()
if(!ticker){return '无法获取ticker'}
if(!pos || pos.length == 0 ){return '已无持仓'}
for(var i=0;i<pos.length;i++){
if(pos[i].Type == PD_LONG){
exchange.SetContractType(pos[i].ContractType)
exchange.SetDirection('closebuy')
exchange.Sell(ticker.Buy, pos[i].Amount - pos[i].FrozenAmount)
}
if(pos[i].Type == PD_SHORT){
exchange.SetContractType(pos[i].ContractType)
exchange.SetDirection('closesell')
exchange.Buy(ticker.Sell, pos[i].Amount - pos[i].FrozenAmount)
}
}
var orders = exchange.Getorders()
Sleep(500)
for(var j=0;j<orders.length;j++){
if(orders[i].Status == ORDER_STATE_PENDING){
exchange.CancelOrder(orders[i].Id)
}
}
}
}
সর্বাধিক সাধারণ হ'ল হিমশৈল কমিশন, বড় ফাইলগুলিকে ছোট বাক্সে বিভক্ত করা, যদিও এটি রোবট হিসাবে চালিত হতে পারে তবে 5 মিনিটের প্লাগইনটি আসলে যথেষ্ট। হিমশৈল কমিশন দুটি ধরণের রয়েছে, একটি হ'ল একক খাওয়ার, অন্যটি হ্যান্ডলিং, যদি কোনও পদ্ধতির ফি ছাড় থাকে তবে আপনি হ্যান্ডলিং বাছাই করতে পারেন, অর্থাৎ আরও বেশি সময় সম্পাদন করতে হবে।
নীচের কোডটি হ'ল হিমশৈলকে প্লাগইনটির উত্স কোড কেনার জন্য অর্ডার করাঃhttps://www.fmz.com/strategy/191771❖ সোর্স কোড বিক্রিঃhttps://www.fmz.com/strategy/191772
function main(){
var initAccount = _C(exchange.GetAccount)
while(true){
var account = _C(exchange.GetAccount)
var dealAmount = account.Stocks - initAccount.Stocks
var ticker = _C(exchange.GetTicker)
if(BUYAMOUNT - dealAmount >= BUYSIZE){
var id = exchange.Buy(ticker.Sell, BUYSIZE)
Sleep(INTERVAL*1000)
if(id){
exchange.CancelOrder(id) // May cause error log when the order is completed, which is all right.
}else{
throw 'buy error'
}
}else{
account = _C(exchange.GetAccount)
var avgCost = (initAccount.Balance - account.Balance)/(account.Stocks - initAccount.Stocks)
return 'Iceberg order to buy is done, avg cost is '+avgCost
}
}
}
একের পর এক কেনা বা বিক্রি করাও একটি ধীরগতির শিপিংয়ের উপায়, যা বাজারে কম প্রভাব ফেলে। এই কৌশলটিতে কিছু উন্নতি রয়েছে, যেখানে আপনি ম্যানুয়ালি সর্বনিম্ন পরিমাণ বা নির্ভুলতা পরিবর্তন করতে পারেন। ক্রয়ঃhttps://www.fmz.com/strategy/191582বিক্রয়ঃhttps://www.fmz.com/strategy/191730
function GetPrecision(){
var precision = {price:0, amount:0}
var depth = exchange.GetDepth()
for(var i=0;i<exchange.GetDepth().Asks.length;i++){
var amountPrecision = exchange.GetDepth().Asks[i].Amount.toString().indexOf('.') > -1 ? exchange.GetDepth().Asks[i].Amount.toString().split('.')[1].length : 0
precision.amount = Math.max(precision.amount,amountPrecision)
var pricePrecision = exchange.GetDepth().Asks[i].Price.toString().indexOf('.') > -1 ? exchange.GetDepth().Asks[i].Price.toString().split('.')[1].length : 0
precision.price = Math.max(precision.price,pricePrecision)
}
return precision
}
function main(){
var initAccount = exchange.GetAccount()
if(!initAccount){return '无法获取账户信息'}
var precision = GetPrecision()
var buyPrice = 0
var lastId = 0
var done = false
while(true){
var account = _C(exchange.GetAccount)
var dealAmount = account.Stocks - initAccount.Stocks
var ticker = _C(exchange.GetTicker)
if(BuyAmount - dealAmount > 1/Math.pow(10,precision.amount) && ticker.Buy > buyPrice){
if(lastId){exchange.CancelOrder(lastId)}
var id = exchange.Buy(ticker.Buy, _N(BuyAmount - dealAmount,precision.amount))
if(id){
lastId = id
}else{
done = true
}
}
if(BuyAmount - dealAmount <= 1/Math.pow(10,precision.amount)){done = true}
if(done){
var avgCost = (initAccount.Balance - account.Balance)/dealAmount
return 'order is done, avg cost is ' + avgCost // including fee cost
}
Sleep(Intervel*1000)
}
}
কখনও কখনও একটি ভাল শিপিং মূল্য বিক্রি করতে বা একটি ফাঁস হওয়ার অপেক্ষায় থাকা অর্ডারের জন্য, নির্দিষ্ট ব্যবধানে একাধিক অর্ডার ঝুলানো যেতে পারে। এই প্লাগইনটি ফিউচার ঝুলানো অর্ডারের জন্যও ব্যবহার করা যেতে পারে। উৎস কপি ঠিকানাঃhttps://www.fmz.com/strategy/190017
function main() {
var ticker = exchange.GetTicker()
if(!ticker){
return 'Unable to get price'
}
for(var i=0;i<N;i++){
if(Type == 0){
if(exchange.GetName().startsWith('Futures')){
exchange.SetDirection('buy')
}
exchange.Buy(Start_Price-i*Spread,Amount+i*Amount_Step)
}else if(Type == 1){
if(exchange.GetName().startsWith('Futures')){
exchange.SetDirection('sell')
}
exchange.Sell(Start_Price+i*Spread,Amount+i*Amount_Step)
}else if(Type == 2){
exchange.SetDirection('closesell')
exchange.Buy(Start_Price-i*Spread,Amount+i*Amount_Step)
}
else if(Type == 3){
exchange.SetDirection('closebuy')
exchange.Sell(Start_Price+i*Spread,Amount+i*Amount_Step)
}
Sleep(500)
}
return 'order complete'
}
সাধারণভাবে ব্যবহৃত ফিউচার ট্রেডিং সফটওয়্যার প্রায়শই অনেকগুলি উন্নত লিঙ্কডন বৈশিষ্ট্য রয়েছে, যেমন লিঙ্কডন স্টপ লস লিঙ্ক, লিঙ্কডন শর্তাদি ইত্যাদি, যা প্লাগইন হিসাবে লিখতে সুবিধাজনক। এখানে একটি লিঙ্কডন ট্রেড করার পরে তাত্ক্ষণিকভাবে লিঙ্কডন স্থির করার প্লাগইনটি ভাগ করুন। কপি ঠিকানাঃhttps://www.fmz.com/strategy/187736
var buy = false
var trade_amount = 0
function main(){
while(true){
if(exchange.IO("status")){
exchange.SetContractType(Contract)
if(!buy){
buy = true
if(Direction == 0){
exchange.SetDirection('buy')
exchange.Buy(Open_Price, Amount)
}else{
exchange.SetDirection('sell')
exchange.Sell(Open_Price, Amount)
}
}
var pos = exchange.GetPosition()
if(pos && pos.length > 0){
for(var i=0;i<pos.length;i++){
if(pos[i].ContractType == Contract && pos[i].Type == Direction && pos[i].Amount-pos[i].FrozenAmount>0){
var cover_amount = math.min(Amount-trade_amount, pos[i].Amount-pos[i].FrozenAmount)
if(cover_amount >= 1){
trade_amount += cover_amount
if(Direction == 0){
exchange.SetDirection('closebuy_today')
exchange.Sell(Close_Price, cover_amount)
}else{
exchange.SetDirection('closesell_today')
exchange.Buy(Close_Price, cover_amount)
}
}
}
}
}
} else {
LogStatus(_D(), "未连接CTP !")
Sleep(10000)
}
if(trade_amount >= Amount){
Log('任务完成')
return
}
Sleep(1000)
}
}
এই ছোট্ট বৈশিষ্ট্যগুলি দেখে, আপনারও নিজের ধারণা থাকা উচিত, কেন আপনি নিজের ম্যানুয়াল লেনদেনের জন্য একটি প্লাগইন লিখবেন না?
শায়মজানভুল রিপোর্টের কারণ কী? Error: Futures_OP 0: 400: {"error_message":"Open orders exist","code":35017,"error_code":"35017","message":"Open orders exist"} Buy ((5000, 0.1): 400: {"error_message":"order_size error","result":"true","error_code":"35063","order_id":"-1"}
ঘাসএক্সচেঞ্জ ডকুমেন্টেশন চেক করুন অথবা এক্সচেঞ্জ গ্রাহক সেবা দেখুন