• 「新MT4対応ライブラリによるメタトレーダーEA実践プログラミング」更新しました

    皆さん、こんにちは。

    『新MT4対応 FXメタトレーダープログラミング入門』に引き続き、『新MT4対応ライブラリによるメタトレーダーEA実践プログラミング』も更新を行いました。

    一応、MT4 Build 1090対応ということで更新を行いましたが、本書の場合、初版で対象にしていたMT4のビルドから画面回りはあまり変わっていないことと、EAのプログラムで修正の必要な部分はなかったことより、内容的にはほとんど変わっていません。何カ所か言い回しを変えた程度です。

    ただ、Build 1090と関係なく追加した部分が、2カ所あります。

    一つは本書ライブラリに連続勝敗数と損益を取得するMyOrderConsecutiveWins()、MyOrderConsecutiveProfit()という関数を追加した点です。

    もう一つは、別途ライブラリの差し替えと数行のコードの変更で本書サンプルプログラムがMT5で動作可能であるという記述を追加した点です。ただし、具体的な変更方法は本書には記載せず、あくまで本ブログで紹介した以下の記事へのリンクのみです。

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

    本日以降、新規に購入された方には更新版が配信されています。既に購入済みの方で、更新版が必要な方は、お手数ですが以下の記事をご参考にしてアマゾンまでご連絡ください。

    Kindle電子書籍の改訂版を入手してみた」(青木宣明のブログ)

    なお、更新版では、最初の免責事項のページと最後の著者紹介のページに、MT4 Build 1090対応と記載されています。ご確認ください。



  • 「新MT4対応 FXメタトレーダープログラミング入門」更新しました

    皆さん、こんにちは。

    2年前に出版したKindle本『新MT4対応 FXメタトレーダープログラミング入門』ですが、MT4のアップデートに伴い、内容が古くなってきたので、更新を行いました。

    修正箇所をすべて書き出すことはできませんが、基本的に、MT4 Build 1090に合わせてメニュー項目などの修正と一部画像の差し替えを行いました。若干言い回しを変えた文章もありますが、内容的に変更はありません。

    ただ「第3章 カスタム指標のプログラミング」のところで、サンプルプログラムのコードの変更を行っています。

    これは、既に本ブログの以下の記事で解説していますが、カスタム指標プログラムで指標が表示されないというケースに対応するためです。

    MT4 Build1090でカスタム指標プログラムを作るときの注意点

    MT4の仕様が変わったのか、単に不具合なのかよくわからないのですが、一応、「#property indicator_type1 DRAW_LINE」を追加すればOKなので、それに合わせて説明の追加とコードの追加を行っています。

    本日以降、新規に購入された方には更新版が配信されています。既に購入済みの方については、アマゾンの「コンテンツと端末の管理」の設定で「本の自動更新」がONになっていても、自動的に更新版が配信されることはありません。

    更新版が必要な方はお手数ですが、以下の記事をご参考にしてアマゾンまでご連絡ください。

    Kindle電子書籍の改訂版を入手してみた」(青木宣明のブログ)

    なお、更新版では、最初の免責事項のページと最後の著者紹介のページに、MT4 Build 1090対応と記載されています。ご確認ください。



  • 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の数値のみ

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