システムトレード研究所 〜FXで完全自動売買〜

このサイトでは、FXで完全自動売買を行うために必要な情報を書いていこうと思っています。システムを自分で作りたい方、システムトレードをやってみたい方は御覧になっていって下さい。
OrderSelectについて
こんばんはDCです。



今回は「OrderSelectについて」という内容で記事を書かせて頂きます。


 OrderSelect関数は、ポジションのデータを取得する関数ですが、使い方が複数あり、実際に使いこなすとなれば難しいので、今回は詳しく説明させて頂きます。

 まずは、OrderSelect関数の引数について説明します。



OrderSelect( int index, int select, int pool)


日本語にすると下記のようになります。

オーダーセレクト(番号、番号の種類、取得中か決済後か)

最初の番号(int index)はポジション番号かチケットナンバーを入力します。どちらを入力するかは次の番号の種類の引数で選びます。

ポジション番号は、現在取得しているポジションに対して0から割り振られたナンバーです。例えば、ポジションが3つあれば、先に取得した順に0、1、2とナンバーが付けられます。



for(cnt=0;cnt<OrdersTotal();cnt++)
 {
  OrderSelect(cnt,SELECT_BY_POS);


いつも使っている上記のようなコードの場合は、このポジション番号を取得しています。
OrdersTotal()は現在の取得中のポジション数を調べる関数です。

この番号はポジション数の増減により、番号も変化します。例えば、0番のポジションが決済された場合は、1番が0番に、2番が1番に変更されます。


次にチケットナンバーですが、これはそのポジションに割り振られた固定のナンバーで変わることはありません。ポジションを保有していても、決済していもこのナンバーはずっと同じ番号になります。


チケットナンバーの調べ方は、一度ポジション番号でオーダーセレクトをしてから、OrderTicket()で取得出来ます。


次に番号の種類(int select)ですが、SELECT_BY_POS でポジション番号、SELECT_BY_TICKET でチケットナンバーを選択出来ます。


最後に取得中か決済後か (int pool)ですが、これは現在取得中のポジションか、すでに決済されているポジションかの選択です。

MODE_TRADESで取得中のポジション、MODE_HISTORY で決済されているポジションになります。ただし、番号の種類がチケットナンバーの時はここは必要ありません。チケットナンバーは取得中でも決済後でもナンバーが変わらないためです。

また、ここに何も書かない場合は、自動的にMODE_TRADESになります。


決済したポジション数を調べる関数はOrdersHistoryTotal()です。この関数で取得した数値−1が最後に決済、もしくは取り消されたポジションになります。


実際の使用例です。


OrderSelect(0,SELECT_BY_POS,MODE_TRADES);


現在取得中のポジション番号0番のデータを取得してます。



OrderSelect(1,SELECT_BY_TICKET);


チケットナンバー1番のデータを取得してます。



OrderSelect(5,SELECT_BY_POS,MODE_HISTORY);


決済したポジションの番号5番のデータを取得してます。



for(cnt=OrdersHistoryTotal()-1;cnt>=0;cnt--)
 {
  OrderSelect(cnt,SELECT_BY_POS,MODE_HISTORY);


上記の処理で過去に決済したポジションを調べることが出来ます。最新の決済されたポジションから順にループするごとに過去に決済されたポジションになります。


過去に決済したポジションは数が多くなります。その分処理も重くなりますので、必要なデータを見つけたら、そこでループを止める処理をしておいたほうがいいと思います。


今回はこれで終了です。



システムトレード研究所〜FXで完全自動売買〜INDEXへ
自動売買システム制作のオーダーシステム|FXでオリジナルのシステムトレード

---------------------------------------注意---------------------------------------

 内容には注意を払っていますが、保障は出来ません。
 実際に運用する場合は、自己責任でお願いします。

JUGEMテーマ:ビジネス
| zikund01 | MetaTrader4 プログラム中級編 | 11:23 | comments(2) | - |
リミットとストップロスを計算で設定する
こんばんはDCです。


今回は「リミットとストップロスを計算で設定する」についてお話したいと思います。

 よくあるシステムはリミットとストップロスを最初に設定しておけば、ポジションを取得した後に毎回同じリミットとストップロスを設定してくれます。今回は、そのリミットとストップロスを毎回違う値で設定するような方法を紹介します。
毎回同じリミットとストップロスにするのではなく、違った値で設定することが可能になります。



サンプルプログラムはこちらです。

http://jidoubaibai.com/Samples/Sample%20TPSL2.mq4

サンプルプログラムの使い方は、こちらで説明しています。

http://jidoubaibai.com/burogu11.html






 今回はレートとボリンジャーバンドの中央線のクロスでポジションを取得し、TPSLはボリンジャーバンドの±2σの位置に設定してみます。
ボリンジャーバンドの中央線は移動平均線なので、ソース内の関数ではMAとのクロスで処理していますので注意してください。






 では、MetaEditorを起動して下さい。
 NameはTPSL2などにして下さい。
 では、まとめてコードを書きますので、同じようにコードを半角英数で書いていってください。




int start()
{
 //変数の宣言
 int cnt, CurrentPosition;
 int Ticket;

 double BuyTP,BuySL;
 double SellTP,SellSL;


 // オーダーチェック(ポジションなどのデータ)
 CurrentPosition=-1;
 for(cnt=0;cnt < OrdersTotal();cnt++)
 {
  OrderSelect(cnt,SELECT_BY_POS);

  if(OrderSymbol() == Symbol())
  {
   CurrentPosition=cnt;
  }
 }




 // ポジションチェック ポジション無し
 if(CurrentPosition == -1)
 {
  //もし終値がMAを上に抜けたら
  if( CrossMA(20) == 1 )
  {
   //買いポジションを取る
   Ticket = OrderSend(Symbol(), OP_BUY, 1, Ask, 3, 0, 0, "Buy", 0, 0, Red);
  }

  //もし終値がMAを下に抜けたら
  if( CrossMA(20) == 2)
  {
   //売りポジションを取る
   Ticket = OrderSend(Symbol(), OP_SELL, 1, Bid, 3, 0, 0, "Sell", 0, 0, Blue);
  }



 }
 // ポジション有り
 else
 {

  //ポジションの選択
  OrderSelect(CurrentPosition,SELECT_BY_POS);

  //通貨ペアの確認
  if(Symbol() == OrderSymbol())
  {
   //もし買いポジションだったら
   if(OrderType()==OP_BUY)
   {
    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)
    {

     //TPSLの値を算出
     BuyTP = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_UPPER,0),Digits);
     BuySL = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_LOWER,0),Digits);

     //ストップロス更新
     OrderModify(OrderTicket(), OrderOpenPrice(), BuySL,BuyTP, 0, MediumSeaGreen);

    }
   }
   //もし売りポジションだったら
   else if(OrderType()==OP_SELL)
   {
    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)
    {

     //TPSLの値を算出
     SellTP = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_LOWER,0),Digits);
     SellSL = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_UPPER,0),Digits);

     //ストップロス更新
     OrderModify(OrderTicket(), OrderOpenPrice(), SellSL,SellTP, 0, MediumSeaGreen);

    }
   }
  }
 }
 return(0);
}



/*------------------------------------------------------
関数名 CrossMA
内容  MAとレートのクロスを判断する関数

引数  int Kikan MAの期間設定

戻り値 0:何も出来ていない 1:上抜け
     2:下抜け
-------------------------------------------------------*/
int CrossMA(int Kikan)
{
 double kakoa,gennzaia;
 double kakob,gennzaib;


 //一つ前の終値
 kakoa = iClose(NULL,0,1);
 //一つ前のMAの値
 kakob = iMA(NULL,0,Kikan,0,0,PRICE_CLOSE,1);

 //現在の終値
 gennzaia = iClose(NULL,0,0);
 //現在のMAの値
 gennzaib = iMA(NULL,0,Kikan,0,0,PRICE_CLOSE,0);



 //もし終値がMAを上に抜けたら
 if( kakoa < kakob && gennzaia >= gennzaib)
 {
  return(1);
 }

 //もし終値がMAを下に抜けたら
 if( kakoa > kakob && gennzaia <= gennzaib)
 {
  return(2);
 }


 return(0);
}



 書けましたか?

 今回は以前こちら
で説明したオリジナル関数を使い、レートの終値とMAのゴールデンクロスとデッドクロスでポジションをとり、
その後にポジションを持っていて、リミットとストップロスが設定されていない場合に、
ボリンジャーバンドの位置を算出してリミットとストップロスを入れるプログラムになっています。

先ず下記のポジションを取るプログラムの説明です。

 // ポジションチェック ポジション無し
 if(CurrentPosition == -1)
 {
  //もし終値がMAを上に抜けたら
  if( CrossMA(20) == 1 )
  {
   //買いポジションを取る
   Ticket = OrderSend(Symbol(), OP_BUY, 1, Ask, 3, 0, 0, "Buy", 0, 0, Red);
  }

  //もし終値がMAを下に抜けたら
  if( CrossMA(20) == 2)
  {
   //売りポジションを取る
   Ticket = OrderSend(Symbol(), OP_SELL, 1, Bid, 3, 0, 0, "Sell", 0, 0, Blue);
  }



 ここでは、ポジションを持っていないとき、関数内で計算された内容で終値とMAがゴールデンクロス、
またはデッドクロスと判定された時にポジションを取るようになっています。

今回もポジション取得時にリミットとストップロスを入れていると注文がキャンセルされる仕様のブローカーに合わせて、
リミットとストップロスは0でポジションを取得しています。

次に、取得しているポジションのリミットとストップロスが0の場合にボリンジャーバンドの±2σを算出し、
その位置にリミットとストップロスを新たに設定する為のプログラムです。




 // ポジション有り
 else
 {

  //ポジションの選択
  OrderSelect(CurrentPosition,SELECT_BY_POS);

  //通貨ペアの確認
  if(Symbol() == OrderSymbol())
  {
   //もし買いポジションだったら
   if(OrderType()==OP_BUY)
   {
    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)
    {

     //TPSLの値を算出
     BuyTP = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_UPPER,0),Digits);
     BuySL = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_LOWER,0),Digits);

     //ストップロス更新
     OrderModify(OrderTicket(), OrderOpenPrice(), BuySL,BuyTP, 0, MediumSeaGreen);

    }
   }
   //もし売りポジションだったら
   else if(OrderType()==OP_SELL)
   {
    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)
    {

     //TPSLの値を算出
     SellTP = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_LOWER,0),Digits);
     SellSL = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_UPPER,0),Digits);

     //ストップロス更新
     OrderModify(OrderTicket(), OrderOpenPrice(), SellSL,SellTP, 0, MediumSeaGreen);

    }
   }
  }
 }
 return(0);
}




 今回ここで初めて登場するのはiBands関数
NormalizeDouble関数です。

iBands関数(通貨ペア,タイムフレーム(時間足),期間,偏差,バンドのシフト,値を取る時間(始値、終値など),モード,シフト)

ボリンジャーバンドの数値を出す関数です。他のインディケーターで使われる関数に似ている部分が多いので簡単に説明していきます。

 通貨ペア

 どの通過ペアなのかを表すシンボルです。
 基本的に選択された通過ペアで行うNULLを入れておけば問題ありません。

 タイムフレーム(時間足)

 時間足等のタイムフレームです。
 基本的に0を入れておけば問題ないです。
 選択されたタイムフレームで行ってくれます。

 期間

 ボリンジャーバンドの期間です。
 20期間のボリンジャーバンドにしたい場合は20と入力します。

 偏差

 ボリンジャーバンドの偏差です。
 2σのボリンジャーバンドにしたい場合は2と入力します。

 バンドのシフト

 ボリンジャーバンドをシフトする値を入れます
 ここに入力した数字の数だけ右側にシフトします。
 よく分からない場合は0と入力しておけば問題ないです。

  値を取る時間(始値、終値など)

 始値、高値、安値、終値など、どのデータを使用してボリンジャーバンドを作るかです。
 PRICE_CLOSE
 PRICE_OPEN
 PRICE_HIGH
 PRICE_LOW
 PRICE_MEDIAN
 PRICE_TYPICAL
 PRICE_WEIGHTEDの7種類あります。

 モード

 ボリンジャーバンドの上下のラインのうちどれを使うかの設定です。
 MODE_UPPER
 MODE_LOWERの2種類があります。
 MODE_UPPERが上のライン、MODE_LOWERが下のラインになります。

  シフト

 ボリンジャーバンドの時間をシフトする数値です。
 0なら現在のボリンジャーバンド、1なら一つ前の足のボリンジャーバンドのデータが入ります。
 1時間足なら、一時間前の移動平均のデータが入ります。


NormalizeDouble関数(値,位)

この関数は数字の小数点以下を第何位までにするかを制御する関数です。
この関数でボリンジャーバンドの値を通貨ペアで使用されている小数点の位に合わせています。

 

 ここに入力された値を処理します。
 今回はここでボリンジャーバンドの値を処理しています。

 

 ここに入力された数字分、小数点以下を使用します。
 2と入力すると、小数第二位までという形になります。
 今回はチャートの位と合わせるので、Digitsと入力しています。
 これにより自動的にチャートの位に合います



 プログラムの内容は、ポジションを持っている時で尚且つストップロスかリミットに0が入っていた場合、
ボリンジャーバンドの±2σの値を算出してその値にストップロスとリミットの値を変更するという内容です。
基本的な動き方は以前にこちらで説明したとおりです。




//TPSLの値を算出
BuyTP = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_UPPER,0),Digits);
BuySL = NormalizeDouble(iBands(NULL,0,20,2,0,PRICE_CLOSE,MODE_LOWER,0),Digits);

//ストップロス更新
OrderModify(OrderTicket(), OrderOpenPrice(), BuySL,BuyTP, 0, MediumSeaGreen);



こちらが今回追加、または修正された内容です。

NormalizeDoubleの場所にiBands関数
が入っています。つまり、iBands関数で算出した値をチャートの小数点にあわせている形になります。それを変数に入れています

後は、OrderModify関数で、リミットとストップロスの値を先ほど算出した値で設定しています。




/*------------------------------------------------------
関数名 CrossMA
内容  MAとレートのクロスを判断する関数

引数  int Kikan MAの期間設定

戻り値 0:何も出来ていない 1:上抜け
     2:下抜け
-------------------------------------------------------*/
int CrossMA(int Kikan)
{
 double kakoa,gennzaia;
 double kakob,gennzaib;


 //一つ前の終値
 kakoa = iClose(NULL,0,1);
 //一つ前のMAの値
 kakob = iMA(NULL,0,Kikan,0,0,PRICE_CLOSE,1);

 //現在の終値
 gennzaia = iClose(NULL,0,0);
 //現在のMAの値
 gennzaib = iMA(NULL,0,Kikan,0,0,PRICE_CLOSE,0);



 //もし終値がMAを上に抜けたら
 if( kakoa < kakob && gennzaia >= gennzaib)
 {
  return(1);
 }

 //もし終値がMAを下に抜けたら
 if( kakoa > kakob && gennzaia <= gennzaib)
 {
  return(2);
 }


 return(0);
}



 上記の内容はMAのオリジナル関数です。
ここでレートの終値とMAのクロスの判定を行っています。
詳しくは、オリジナル関数の作り方で説明しています。

 今回はこれで終了ですが、一点だけ注意点があります。
TPSLを計算により算出した時、稀に現在のレートに近すぎるため指値を入れることが出来ない場合がありますので注意してください。

今回のような方法で、リミットとストップロスを毎回違う値で設定することが可能になります。
いろいろと応用が出来る方法ですので、ぜひマスターしてください。



システムトレード研究所〜FXで完全自動売買〜INDEXへ
自動売買システム制作のオーダーシステム|FXでオリジナルのシステムトレード

---------------------------注意------------------------------

 内容には注意を払っていますが、保障は出来ません。 実際に運用する場合は、自己責任でお願いします。


| zikund01 | MetaTrader4 プログラム中級編 | 16:07 | comments(2) | - |
色々な決済の仕方
こんばんは、DCです。今回は「色々な決済の仕方」についてお話したいと思います。



 皆さんは決済をどのようにお考えでしょうか。FXで勝つためにはエントリー位置も重要ですがそれと同様に決済の仕方が重要だと私は考えています。今回は決済について一つの方法をご紹介します。





 買いポジションを取得した後、レートが逆行してしまい含み損を抱えてしまった場合、おとなしく損切りをするかレートが持ち直すのを待つのかという選択を迫られる場合があります。
そんな時、ナンピンをしてみるという選択肢があります。


 今回は説明のため、スプレッド抜きで説明させて頂きますが、例えば90.00で買いポジションを立て、レートが逆行して89.50になった場合。この位置で更に買いポジションを立てます。
そうすれば、90.00で立てた買いポジションと89.50で立てた買いポジションの損益の合計が0になるのは89.75となります。ナンピンをしなかった場合、レートが90.00まで戻らなければ
損失を出すはずだったポジションが、89.75までレートが戻れば±0で切り抜けることができるということになります。




 分かりやすく書くと下記の通りになります。


 (説明のため、スプレッドは考慮していません。)

 ポジションA=90.00で取得したポジション。

 ポジションB=89.50で取得したポジション。



 レートが89.75の位置の場合のポジションAの損益=-0.25

 レートが89.75の位置の場合のポジションBの損益=0.25



 合計損益=0



 更にレートが下がった場合、ナンピンを重ねることも可能なので、どんどん相殺レートは下がっていきます。



 デメリットとしては、レートが反転せずに下降し続けた場合、ナンピンした数だけ損益が大きくなるという危険な一面もあります。



 この方法は、ナンピンポジションのlot数を減らしたり増やしたり、ナンピンする幅を広げたり狭めたりとバランスのとり方も色々考えることができます。
その為デメリットもあるものの、バランスの比較的とり易い方法といえます。リスク管理がしっかりしているのであれば、有効な方法かもしれません。



他にもやり方としては、以下のような方法もあります。



 (説明のため、スプレッドは考慮していません。)

 ポジションA=90.00で取得したポジション、ロット数は1。

 ポジションB=89.50で取得したポジション。ロット数は2



 レートが89.75の位置でポジションAの1ロットとポジションBの半分にあたる1ロットを決済して相殺。
残りのポジションBの1ロットを引き続き保有して利益を狙うといった方法もあります。



 実際にはスプレッドの影響などがありますので上記の説明ほど単純には行きませんが、考え方は上記の通りになります。


 今回はこれで終了です。決済方法はすごく奥の深い要素を持っているので、皆さんもぜひ研究してみてください。





----------------------------注意----------------------------


 内容には注意を払っていますが、保障は出来ません。
 実際に運用する場合は、自己責任でお願いします。


| zikund01 | システムトレード実践編 | 17:17 | comments(6) | - |
MetaTrader4 Proactiveへの対応
こんにちは、DCです。今回は「MetaTrader4 Proactiveへの対応」について説明します。



 MetaTrader4 Proactiveが発表され、暫く時間がたちました。従来のMetaTrader4からMetaTrader4 Proactive対応の証券会社に変えたことで、「今までのEAが突然動かなくなった。」などのお便りが多数寄せられています。どうしたらEAが動くのかというご質問に、今回は答えさせて頂こうと思います。





 サンプルプログラムはこちらです。


 http://jidoubaibai.com/Sample%20TPSL.mq4


 サンプルプログラムの使い方は、こちらで説明しています。 


 http://jidoubaibai.com/burogu11.html







 なぜ突然EAが動かなくなったのでしょうか。それはMetaTrader4 Proactiveの仕様に原因があります。決してMetaTrader4 Proactiveの性能の問題ではなく、「ポジション取得時にリミットとストップを設定できない。」という仕様に引っかかっていたのです。




 MetaTrader4 Proactiveでは、ポジションを取得すると同時にリミットとストップを設定していると、エラーが発生し、注文がキャンセルされる仕様となっています。以前のEAでは、ポジション取得と同時にリミットとストップの設定がされているものがほとんどです。その為にEAが突如ポジションを取得しなくなる現象が起っています。つまりポジションを取得する時には、ストップとリミットを設定していてはいけません。




 動かなくなったほとんどのEAはリミットとストップロスを無くせば、また動くようになるでしょう。ストップとリミットを設定する場合は、ポジションを取得した後に設定することになります。




 今回はMACDのゴールデンクロスで買い、デッドクロスで売るシステムのリミットとストップを後からつけるプログラムを紹介します。決済はリミットとストップのみで行い、MACDの判定は以前こちらで紹介したオリジナル関数を使ってみましょう。


 では、MetaEditorを起動して下さい。

 NameはTPSLなどにして下さい。

 では、まとめてコードを書きますので、同じようにコードを半角英数で書いていってください。





int start()

{

 //変数の宣言

 int cnt, CurrentPosition;

 int Ticket;





  // オーダーチェック(ポジションなどのデータ)

 CurrentPosition=-1;

 for(cnt=0;cnt < OrdersTotal();cnt++){

 OrderSelect(cnt,SELECT_BY_POS);

 if(OrderSymbol() == Symbol()) CurrentPosition=cnt;

 }





 // ポジションチェック ポジション無し

 if(CurrentPosition == -1)

 {

  //もしメインがシグナルを下から上にクロスしたら

  if( CrossMACD(12,26,9) == 1 )

  {

   //買いポジションを取る

   Ticket = OrderSend(Symbol(), OP_BUY, 1, Ask, 3, 0, 0, "Buy", 0, 0, Red);

  }



  //もしメインがシグナルを上から下にクロスしたら

  if( CrossMACD(12,26,9) == 2)

  {

   //売りポジションを取る

   Ticket = OrderSend(Symbol(), OP_SELL, 1, Bid, 3, 0, 0, "Sell", 0, 0, Blue);

  }



 }

 // ポジション有り

 else

 {



  //ポジションの選択

  OrderSelect(CurrentPosition,SELECT_BY_POS);



  //通貨ペアの確認

  if(Symbol() == OrderSymbol())

  {

   //もし買いポジションだったら

   if(OrderType()==OP_BUY)

   {

    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)

    {

     //ストップロス更新

     OrderModify(OrderTicket(), OrderOpenPrice(), OrderOpenPrice()-(200*Point),OrderOpenPrice()+(200*Point), 0, MediumSeaGreen);

    }

   }

   //もし売りポジションだったら

   else if(OrderType()==OP_SELL)

   {

    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)

    {

     //ストップロス更新

     OrderModify(OrderTicket(), OrderOpenPrice(), OrderOpenPrice()+(200*Point),OrderOpenPrice()-(200*Point), 0, MediumSeaGreen);

    }

   }

  }

 }

 return(0);

}



/*------------------------------------------------------

関数名 CrossMACD

内容  MACDのゴールデンクロスとデッドクロスを判断する関数

引数 int fast  短期EMA

    int slow  長期EMA

    int signal シグナル

戻り値  0:何も出来ていない  1:ゴールデンクロス

      2:デッドクロス

-------------------------------------------------------*/

int CrossMACD(int fast,int slow,int signal)

{

 double kakoa,gennzaia;

 double kakob,gennzaib;



 //一つ前のMACDのメイン

 kakoa = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_MAIN,1);

 //一つ前のMACDのシグナル

 kakob = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_SIGNAL,1);



 //現在のMACDのメイン

 gennzaia = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_MAIN,0);

 //現在のMACDのシグナル

 gennzaib = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_SIGNAL,0);



 //もしメインがシグナルを下から上にクロスしたら

 if( kakoa < kakob && gennzaia >= gennzaib)

 {

  return(1);

 }



 //もしメインがシグナルを上から下にクロスしたら

 if( kakoa > kakob && gennzaia <= gennzaib)

 {

  return(2);

 }

return(0);

}





 書けましたか?




 今回は以前こちらで説明したオリジナル関数を使い、MACDのゴールデンクロスとデッドクロスでポジションをとり、その後にポジションを持っていて、リミットとストップロスが設定されていない場合に、リミットとストップロスを入れるプログラムになっています。




先ず下記のポジションを取るプログラムの説明です。


 // ポジションチェック ポジション無し

 if(CurrentPosition == -1)

 {

  //もしメインがシグナルを下から上にクロスしたら

  if( CrossMACD(12,26,9) == 1 )

  {

   //買いポジションを取る

   Ticket = OrderSend(Symbol(), OP_BUY, 1, Ask, 3, 0, 0, "Buy", 0, 0, Red);

  }



  //もしメインがシグナルを上から下にクロスしたら

  if( CrossMACD(12,26,9) == 2)

  {

   //売りポジションを取る

   Ticket = OrderSend(Symbol(), OP_SELL, 1, Bid, 3, 0, 0, "Sell", 0, 0, Blue);

  }





 ここでは、ポジションを持っていないとき、関数内で計算された内容でMACDがゴールデンクロス、またはデッドクロスと判定された時にポジションを取るようになっています。普段と違うのは、ストップロスとリミットが0になっていることです。


 次に、ポジションを持っている場合にリミットとストップロスが0の場合に新たに設定する為のプログラムです。





 // ポジション有り

 else

 {



  //ポジションの選択

  OrderSelect(CurrentPosition,SELECT_BY_POS);



  //通貨ペアの確認

  if(Symbol() == OrderSymbol())

  {

   //もし買いポジションだったら

   if(OrderType()==OP_BUY)

   {

    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)

    {

     //ストップロス更新

     OrderModify(OrderTicket(), OrderOpenPrice(), OrderOpenPrice()-(200*Point),OrderOpenPrice()+(200*Point), 0, MediumSeaGreen);

    }

   }

   //もし売りポジションだったら

   else if(OrderType()==OP_SELL)

   {

    if(OrderStopLoss() == NULL || OrderTakeProfit() == NULL)

    {

     //ストップロス更新

     OrderModify(OrderTicket(), OrderOpenPrice(), OrderOpenPrice()+(200*Point),OrderOpenPrice()-(200*Point), 0, MediumSeaGreen);

    }

   }

  }

 }

 return(0);

}






 今回初めて登場するのはOrderModify関数
OrderOpenPrice関数OrderStopLoss関数
OrderTakeProfit関数OrderTicket関数です。


 プログラムの内容は、ポジションを持っている時で尚且つストップロスかリミットに0が入っていた場合、ストップロスとリミットの値を変更するという内容です。


OrderOpenPrice関数は、ポジションのオープンレートを調べる関数です。

OrderStopLoss関数は、ポジションのストップロス値を調べる関数です。

OrderTakeProfit関数は、ポジションのリミット値を調べる関数です。

OrderTicket関数は、ポジションのチケット番号を調べる関数です。






 OrderModify(OrderTicket(), OrderOpenPrice(), OrderOpenPrice()-(200*Point),OrderOpenPrice()+(200*Point), 0, MediumSeaGreen);





 上記がOrderModify関数です。注文の内容を変更するのに使われる関数となっています。サイズの関係上2行に分けて表記しましたが、皆さんは1行で書いても大丈夫です。


OrderModify関数(チケット番号, 指値, ストップロス値,リミット値, 有効期限, 表示される色)


個別に説明していきます。

チケット番号は変更する注文のチケット番号を選択します。

指値は指値を変更するときなどに使います。今回はオープンレートが入っています

ストップロス値はここに入力された数値をストップロスにします。

リミット値はここに入力された数値をリミットにします。

有効期限は指値などの未約定の注文の有効期限を指定します。

表示される色は色の設定です。


 今回はストップロスとリミットを変更しています。

 買いの場合、ストップロスに「OrderOpenPrice()-(200*Point)」、リミットに「OrderOpenPrice()+(200*Point)」を入力していますので、ストップロスはオープンレートから200pips下で、リミットはオープンレートから200pips上になるようにしています。



/*------------------------------------------------------

関数名 CrossMACD

内容  MACDのゴールデンクロスとデッドクロスを判断する関数



引数 int fast  短期EMA

    int slow  長期EMA

    int signal シグナル



戻り値  0:何も出来ていない  1:ゴールデンクロス

      2:デッドクロス

-------------------------------------------------------*/

int CrossMACD(int fast,int slow,int signal)

{

 double kakoa,gennzaia;

 double kakob,gennzaib;



 //一つ前のMACDのメイン

 kakoa = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_MAIN,1);

 //一つ前のMACDのシグナル

 kakob = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_SIGNAL,1);



 //現在のMACDのメイン

 gennzaia = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_MAIN,0);

 //現在のMACDのシグナル

 gennzaib = iMACD(NULL,0,fast,slow,signal,PRICE_CLOSE,MODE_SIGNAL,0);



 //もしメインがシグナルを下から上にクロスしたら

 if( kakoa < kakob && gennzaia >= gennzaib)

 {

  return(1);

 }



 //もしメインがシグナルを上から下にクロスしたら

 if( kakoa > kakob && gennzaia <= gennzaib)

 {

  return(2);

 }

return(0);

}





 上記の内容はMACDのオリジナル関数です。ここでMACDのクロスの判定を行っています。詳しくは、オリジナル関数の作り方で説明しています。


 余談ですが、MetaTrader4 Proactiveがリリースされた後にオーダーシステムでご注文頂いたシステムには、全て上記の対処がされていますので、正常に稼動します。

 今回はこれで終了です。OrderModify関数は出来ることがたくさんありますので、是非マスターしてください。
 





システムトレード研究所〜FXで完全自動売買〜INDEXへ

自動売買システム制作のオーダーシステム|FXでオリジナルのシステムトレード



----------------------------------注意--------------------------------


 内容には注意を払っていますが、保障は出来ません。
 実際に運用する場合は、自己責任でお願いします。


| zikund01 | MetaTrader4 プログラム中級編 | 18:34 | comments(0) | - |
新しい特典について

 こんばんは、DCです。今回はこのホームページの姉妹サイト「オーダーシステム」で新しい特典を製作しましたので、その紹介をさせて頂こうと思います。



 今回新たに「Dealings_Line」というインディケーターを特典として制作しました。

Dealings_Line」は、今までに取引されたデータをチャート上に表示させるインディケーターです。




 具体的にはチャート上の売買した位置に買い矢印、売りの矢印、決済の矢印などを表示し、その時の損益がチャートに数字で表示され、どのポジションがどこで決済されたかを色のついたラインで結んで表示するため、チャートを見ただけで大体の取引内容が把握できるようになっています。






Dealings_Line





 上の図の赤い矢印は売りのポジションです。

そこから伸びる赤いラインと繋がっている黄色い四角マークが売りポジションの決済ポイントで、
更にバーの下にある数字は損益です。

青い矢印は買いポジションの表示です。




 このインディケーターは直接売買に影響を及ぼすものではなく、売買結果をチャートに表示させるだけの地味なインディケーターですが、
売買がどの様な結果になったのかをチャート上に表示することによって後々の検証などが実にやり易くなります。




 他のインディケーターやシステムと併用して利用することが出来るので、売買結果がチャートに表示されない自動売買システムなどと併用すれば、チャートに結果を表示することができます。





Dealings_Line





 上の図はポジションを取ってすぐの画像です。

決済をすると下の図の様になります。





Dealings_Line





 少し見づらいですが、黄色の四角いマークが表示され、バーの下に損益が表示されました。






 この各シンボル(買い矢印、売り矢印、決済マーク、損益の表示)の色はパラメーターで自分好みに変更することができます。

また、売買の矢印や損益の表示はサイズの変更もできますので、見やすいサイズにすることが可能です。




 もちろん過去の取引も、口座に履歴が残っていれば表示させることが可能ですので、検証に余分な時間を取られることが少なくなります。





 先程上のほうでも書きましたが、このインディケーターを使えば、例えチャートに売買の矢印の表示されないシステムを使用していても、
このインディケーターが変わりに矢印などを描画するのでとても見やすくなります。




 デモトレードやリアルトレードでポジションが表示されないと、検証や確認作業に大きな時間を費やしてしまいます。

この特典がそういった無駄な時間を省略する手助けになればと思います。



 今回はこれで終了です。



 今回の特典について詳しく御覧になりたい方は、こちらを御覧下さい。



 また何か新しい特典などが出来たらまた紹介させていただこうと思います。







システムトレード研究所〜FXで完全自動売買〜INDEXへ


自動売買システム制作のオーダーシステム|FXでオリジナルのシステムトレード





-----------------------------------注意-----------------------------------


 内容には注意を払っていますが、保障は出来ません。
 実際に運用する場合は、自己責任でお願いします。

| zikund01 | システムトレード | 17:19 | comments(1) | - |
  12345
6789101112
13141516171819
20212223242526
27282930   
<< November 2011 >>

このページの先頭へ