• カテゴリー別アーカイブ ダウンロード
  • MQL4/MQL5共通EAライブラリ(180128版)

    新メタトレ実践本用のMQL4/MQL5共通EAライブラリを更新しました。ライブラリファイルは、以下からダウンロードできます。

    基本的な使い方は変わっていません。以下の記事をご参考にしてください。

    ライブラリ関数の変更点、追加点は以下の通りです。

    1. LibMQL4.mqhの各テクニカル指標関数で、timeframeが0のときに、プログラム実行途中で時間枠を変更してもテクニカル指標の時間枠が変更されないという不具合を修正しました。
    2. LibMQL4.mqhにiBarShift()関数を追加しました。これはMQL4の組込み関数と同じ仕様ですが、あまり効率のよい実装ではないので、多用すると時間がかかります。
    3. LibOrder4.mqhとLibOrder5.mqhに次の二つの関数を追加しました。
      //前回までの連続損益(金額)の取得
      double MyOrderConsecutiveProfit(int pos_id=0)
      //前回までの連続勝敗数の取得
      int MyOrderConsecutiveWins(int pos_id=0)
      連勝した数や連勝によって積みあがった利益を取得します。連敗の場合はマイナスの値になります。

    以上です。



  • MQL4/MQL5共通EAライブラリ(171202版)

    新メタトレ実践本用のMQL4/MQL5共通EAライブラリを更新しました。ライブラリファイルは、以下からダウンロードできます。

    今回変更したのは、MQL5でMQL4と同じ形式でテクニカル指標関数を使えるようにする LibMQL4.mqh です。オーダー系のライブラリは修正していません。

    MQL4からMQL5への対応は、ちょっと無理やりなところがあるので、MQL5で動かす際に不具合が生じることがあります。そのため、各テクニカル指標関数でエラーが生じたときに、エラーメッセージを出力させるようにしました。

    今回のライブラリの改訂で、カスタム指標プログラムをMQL4とMQL5で共通化させることができました。ただし、テクニカル指標関数を使った簡単なものだけです。

    以下のプログラムは、ボリンジャーバンドの関数を使ったカスタム指標プログラムの一例です。一応、このソースファイルのまま拡張子をmq4とmq5にすることで、それぞれMT4、MT5でコンパイル・実行させることができます。

    kindle本の新MT4入門書で解説したカスタム指標プログラムと書き方が異なるところを説明しておきます。

    MQL4では、指標の種類の指定はラインの場合不要でしたが、MQL5では必須となるので追加してあります。MQL4の過去のアップデートでも、指標の種類の指定をしないと表示が不安定になることがあったので、入れておいた方がいいでしょう。

    LibMQL4.mqh はMQL5の場合のみ必要となります。MQL4でそのファイルがなくてもエラーが出ないように、MQL5の場合のみ LibMQL4.mqh をインクルードするようにしています。

    指標バッファ用の配列を時系列配列に設定する命令で、MQL5では必須です。MQL4の場合、デフォルトで時系列配列になっているので、この行は不要です。

    指標を表示する範囲のための変数で、チャートの書き始めの部分でBandsPeriodだけずらしてあります。こうしておかないと、MQL5では何も表示されないことがあります。MQL4では、この行はなくても構いません。

    MQL5では、指標ハンドルを作成するコードと、指標を配列にコピーするコードを別タイミングで行うことを想定しているようですが、本ライブラリでは同じタイミングで行っています。そのためか、プログラムをチャートに挿入した直後で指標値が計算されないことがあります。今回のライブラリの改訂で、指標値が計算されていない場合、EMPTY_VALUEという値を返すようにしました。このエラーを無視してしまうと、最新のバーにしか指標が表示されないことがあるので、指標値が計算できていない場合、指標を表示できていないということで、0を返すようにしています。MQL4では不要です。

    とりあえず、単純にテクニカル指標関数のみを使うカスタム指標プログラムは、以上の点に注意することで、MQL4/MQL5でコードを共通にすることができます。

    あと、よくある書き方として、表示用の指標バッファとは別に計算用の指標バッファを使うケースがあります。ただ、この場合、MQL4とMQL5でコードの書き方が決定的に違うので、今のところコード共通化の対応はできません。ご了承ください。


    *追記*(2017-12-04)
    48行目で、limitをlimitとrates_total-BandsPeriodの小さい方に設定し直す命令は、プログラムをチャートに挿入した直後(limit=rates_totalになっているとき)にチャートの開始位置をずらすためのものなので、次のように書いてもOKです。

    厳密には、チャートの最初からBandsPeriod-1だけずらせばよいので、

    あるいは、

    でもOKです。

     



  • MQL4/MQL5共通EAライブラリ(171116版)

    新メタトレ実践本用のMQL4/MQL5共通EAライブラリを更新しました。

    iCustom()を使ったEAのプログラムがMT4とMT5で共通化できるようになりました。ライブラリファイルは、以下からダウンロードできます。

    使い方ですが、例えば、MT4、MT5にそれぞれ「HLBand」というカスタム指標が入っているとします。一定期間の高値と安値を結んだよくある指標です。簡単のため、期間をパラメータとし、モードが0で高値ライン、モードが1で安値ラインを返すものとします。

    長期のHLバンドをブレイクしたときにエントリー、短期のHLバンドをブレイクしたときにエグジットという典型的なブレイクアウトシステムのEAプログラムは、このライブラリを使うと次のように書けます。

    ここでiCustom()は、MQL4標準の書式で呼び出しています。このソースファイルが修正なしにMT5でコンパイルでき、EAとして実行できるようになったというのが、今回のライブラリの更新点です。

    ただiCustom()は、MQL5にも同じ関数があり、それぞれ可変長の引数を取るので、そのままオーバーライドすることができませんでした。ライブラリを見てもらうとわかると思いますが、iCustom()をiMyCustom()に読み替えて、iMyCustom()をパラメータが0個から8個まで個別に作成しています。

    なので、これを使うためには、以下の制約があります。

    1. カスタム指標のパラメータの数が8個まで
    2. カスタム指標のパラメータがint,doubleの数値のみ

    その他の注意事項は、過去の記事をご参照ください。

     



  • メタトレ二刀流本のサンプルプログラムをMT5ヘッジ口座で動かす

    最近、MT5の利用者も増えてきたのでしょうか、MQL5プログラミングに関するご質問をいただくようになりました。

    多くは、拙著の「FXメタトレーダー4&5一挙両得プログラミング」(メタトレ二刀流本)の読者様からのものです。そのなかで、サンプルプログラムをMT5のヘッジ口座で利用したいというご要望がいくつかありました。

    しかし、残念ながらメタトレ二刀流本は初版のままで、改変のタイミングがありません。

    MT5のヘッジ口座用のライブラリで、当方が現在メンテしているのは、以下の記事で紹介した「新MT4対応ライブラリによるメタトレーダーEA実践プログラミング」(新メタトレ実践本)用のもののみです。

    MT4とMT5で同じソースプログラムを使ってEAが作れるということから、基本的にこのライブラリをお勧めしています。ただ、MT5のプログラミングに関する出版物がほとんどない状態なので、メタトレ二刀流本をご参考にされている方も少なからずいらっしゃいます。

    そこで本記事では、メタトレ二刀流本のサンプルプログラムを多少修正して、新メタトレ実践本のライブラリが利用できるようにする方法をご紹介します。

    対応するサンプルプログラムは以下の12個です。

    P.264 リスト3.6 MA2Cross1_EA.mq5
    P.271 リスト3.8 BBCross1_EA.mq5
    P.289 リスト3.10 MA2Cross1SL_EA.mq5
    P.299 リスト3.12 MA2Cross1TS_EA.mq5
    P.307 リスト3.14 MA3Cross1_EA.mq5
    P.320 リスト3.16 BBCross1ET_EA.mq5
    P.330 リスト3.18 BBCross1Trend_EA.mq5
    P.338 リスト3.20 BBCross1Time_EA.mq5
    P.345 リスト3.22 RIFD_EA.mq5
    P.352 リスト3.24 BBCross1Limit_EA.mq5
    P.362 リスト3.26 RIFD2_EA.mq5
    P.370 リスト3.28 MultiSystem_EA.mq5


    プログラムの修正ポイント

    1. ヘッダファイルの変更

    ライブラリはmqhという拡張子のヘッダファイルとして作成されています。MT5の場合、「LibEA.mqh」「LibOrder5.mqh」「LibMQL4.mqh」の3つのファイルを使います。これらのファイルをEAと同じフォルダに入れておきます。
    インクルードするヘッダファイルは「LibEA.mqh」のみです。次のように古いヘッダファイルの行はコメントアウトするか、削除して、新しいヘッダファイルに変更します。

    なお、ヘッダファイルをMT5のIncludeフォルダに入れて共通に使う場合、

    とします。

    2. 不要となる行(コメントアウト、あるいは削除)

    以下の行は不要となるので、コメントアウトするか、削除して結構です。

    マジックナンバーについては、EA中に記載しなくても、ライブラリで自動的に宣言されるので、それを変更してもいいです。EAで決まった値にしたければ、次のようにヘッダファイルをインクルードする前に、#defineで定義しておきます。

    Open[], Close[], High[], Low[]などの四本値の配列や、売値、買値のBid, Ask、ポジションの管理もライブラリで自動的に行われます。その代わり、OnTick()関数ではなく、Tick()関数(これもライブラリ中に定義してあります)を呼ぶように変更します。

    3. オーダー関数の変更

    オーダー関数のMyOrderSend()関数は、引数の数と順番が変更になっています。引数は、売買の種類、売買ロット数、売買価格、ポジション番号の順になっているので、次のように変更します。

    SLやTPの指定は、オーダー送信時ではなく、オーダー送信後にMyOrderModify()関数で行うようになりました。SLやTPを指定したい場合は、次のようにMyOrderSend()とMyOrderModify()に分けて記述します。

    各ライブラリ関数の詳しい仕様については、新メタトレ実践本を参照してください。

    以上の修正を施したサンプルプログラムとライブラリファイルは、以下からダウンロードできます。ただし、このサンプルプログラムを実行することにより発生した障害、損失などについて、当方は一切の責任を負いかねますので、あらかじめご了承ください。



  • 新メタトレ実践本用のMQL4/MQL5共通ライブラリ(β版)

    皆さん、こんにちは。

    「新MT4対応ライブラリによるメタトレーダーEA実践プログラミング」(新メタトレ実践本)は、タイトルの通りMT4用の本なのですが、実は、MT5用のライブラリも作っておりまして、ライブラリを差し替えることで、MT5でも動くEAが作れたりするのです。

    MT5がもうちょっと流行れば、またkndle本にまとめたいとは思いますが、とりあえず、新メタトレ実践本の読者の方のために、サンプルプログラムを若干修正することでMT5でも動作するEAのライブラリを公開します。ただし、MT4とMT5でソースプログラムを共通にするにはいくつか制限があり、今後、仕様が変更になる可能性もあるので、β版としておきます。各自の責任でご利用ください。

    では、使い方です。まず、以下のファイルをダウンロードして本書のサンプルプログラムの入っているフォルダに展開してください。

    サンプルプログラムと同じフォルダには、「LibEA4.mqh」というヘッダファイルが入っていると思いますが、ダウンロードしたファイルを、これの代わりに使います。

    「LibEA.mqh」が共通のヘッダファイルで、MQL4の場合、「LibOrder4.mqh」をインクルードし、MQL5の場合、「LibOrder5.mqh」と「LibMQL4.mqh」をインクルードします。

    例えば、次のようなサンプルプログラムがあるとします。

    このままだと、MT4でしか動きませんが、2行目と8行目を次のように修正します。

    つまり、「LibEA4.mqh」を「LibEA.mqh」に変えて、「OnTick()」を「Tick()」に変えるだけです。この修正はすべてのサンプルプログラムに共通です。

    このファイルは、MT4で同じように動きます。そして、このファイルの拡張子を「mq4」から「mq5」に変えるだけで、MT5でコンパイル、実行させることができます。

    ソースプログラムを共通にする仕組みや、制限事項については、別記事で解説します。