KimIVの便利な機能 - ページ 24 1...171819202122232425262728293031...128 新しいコメント Igor Kim 2008.05.29 03:30 #231 NumberOfLossPosToday()関数を使用します。 この関数は、今日決済された負けポジションの数を返します。考慮すべき位置の選定は、外部パラメータを用いて行う。 sy- 市場商品の名前。このパラメータを設定すると、この機能はこの楽器の位置のみを考慮します。初期値「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルト値-1 は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 19.02.2008 | //| Описание : Возвращает количество убыточных позиций, закрытых сегодня. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ int NumberOfLossPosToday(string sy="", int op=-1, int mn=-1) { datetime t; int i, k=OrdersHistoryTotal(), kp=0; if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_HISTORY)) { if (OrderSymbol()==sy || sy=="") { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (op<0 || OrderType()==op) { if (mn<0 || OrderMagicNumber()==mn) { t=OrderCloseTime(); if (Year()==TimeYear(t) && DayOfYear()==TimeDayOfYear(t)) { if (OrderProfit()<0) kp++; } } } } } } } return(kp); } 追伸:NumberOfLossPosToday()関数をテストするスクリプトを添付します。 ファイル: test_numberoflosspostoday.mq4 4 kb Igor Kim 2008.06.01 06:41 #232 PriceCloseLastPos()関数です。 この関数は、最後に決済されたポジションの終値を返します。考慮すべき位置の選択は、外部パラメータで指定する。 sy- 市場商品の名前。このパラメータを設定すると、この機能はこの楽器の位置のみを考慮します。初期値「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルト値-1 は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 19.02.2008 | //| Описание : Возвращает цену закрытия последней закрытой позиций. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ double PriceCloseLastPos(string sy="", int op=-1, int mn=-1) { datetime t; double r=0; int i, k=OrdersHistoryTotal(); if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_HISTORY)) { if (OrderSymbol()==sy || sy=="") { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (op<0 || OrderType()==op) { if (mn<0 || OrderMagicNumber()==mn) { if (t<OrderCloseTime()) { t=OrderCloseTime(); r=OrderClosePrice(); } } } } } } } return(r); } ZZY.PriceCloseLastPos()関数をテストするスクリプトを添付しています。 ファイル: test_pricecloselastpos.mq4 4 kb khorosh 2008.06.01 17:27 #233 拝啓 キムアイビー スレッドの最後に、すべての関数のライブラリを掲載していただけるとうれしいです。 Rid 2008.06.02 05:52 #234 私も賛成です。こんなやり方もあるんですね。図書館全体ではありません。しかし、いくつかのライブラリが、しかも最後にではなく、特定のトピックについてfiライブラリが蓄積されていくように。 例えば、オープニングとクローズでライブラリを分ける(オープニングのf-iだけ+マーケットウォッチで オープニング、クローズで クローズ)。 次のライブラリ - これらの属性によって位置の存在を返すf.i.を持つ。 といった具合に。 ただ、ここでは、図書館の完全なセットに関する現在の人々の提案を集めることが必要である。 Igor Kim 2008.06.02 16:06 #235 PriceOpenLastPos()関数を使用します。 この関数は、直近のオープンポジションの始値を返します。考慮すべき位置の選択は、外部パラメータで指定する。 sy- 市場商品の名前。このパラメータが設定されている場合、この関数は指定された楽器の位置のみを考慮します。デフォルト値である「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルト値-1 は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 19.02.2008 | //| Описание : Возвращает цену открытия последней открытой позиций. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ double PriceOpenLastPos(string sy="", int op=-1, int mn=-1) { datetime t; double r=0; int i, k=OrdersTotal(); if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if (OrderSymbol()==sy || sy=="") { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (op<0 || OrderType()==op) { if (mn<0 || OrderMagicNumber()==mn) { if (t<OrderOpenTime()) { t=OrderOpenTime(); r=OrderOpenPrice(); } } } } } } } return(r); } ZS. PriceOpenLastPos()関数をテストするためのスクリプトを添付します。 ファイル: test_priceopenlastpos.mq4 4 kb Igor Kim 2008.06.03 02:54 #236 PriceOpenLastClosePos()関数を使用します。 この関数は、最後に決済されたポジションの始値を返します。考慮すべき位置の選択は、外部パラメータで指定する。 sy- 市場商品の名前。このパラメータを設定すると、この機能はこの楽器の位置のみを考慮します。デフォルト値である「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルト値-1 は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 03.06.2008 | //| Описание : Возвращает цену открытия последней закрытой позиций. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ double PriceOpenLastClosePos(string sy="", int op=-1, int mn=-1) { datetime t; double r=0; int i, k=OrdersHistoryTotal(); if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_HISTORY)) { if (OrderSymbol()==sy || sy=="") { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (op<0 || OrderType()==op) { if (mn<0 || OrderMagicNumber()==mn) { if (t<OrderCloseTime()) { t=OrderCloseTime(); r=OrderOpenPrice(); } } } } } } } return(r); } HH. PriceOpenLastClosePos()関数をテストするためのスクリプトを添付します。 ファイル: test_priceopenlastclosepos.mq4 4 kb 削除済み 2008.06.03 07:56 #237 rid: 私も賛成です。こんなやり方もあるんですね。図書館全体ではありません。しかし、いくつかのライブラリが、しかも最後にではなく、特定のトピックについてfiライブラリが蓄積されていくように。 例えば、オープニングとクローズでライブラリを分ける(オープニングのf-iだけ+マーケットウォッチで オープニング、クローズで クローズ)。 次のライブラリ - これらの属性によって位置の存在を返すf.i.を持つ。 といった具合に。 図書館の買収について、いくつか提案したいことがあります。 こんにちは。 KimIVさんへ。 初心者の専門家ライターにとって、とても有益なことをされていますね。 前の申立人に合流します。 難しいことでなければ、主な機能を1つの「専門家テンプレート」にまとめることも可能です。 -予備検査 -開幕 -注文を入れる -ポジションを閉じる -注文を削除する -オーダーやポジションのエスコート(変更)。 そして、誰もが自分でこれらの関数を呼び出すブロックを書くことになる。 自分で一からEAを書くのは無理です。 だから、他人のコードを変えることから始めたんです。 ブロック単位で機能を追加していくのですが、これがなかなか難しいんです。 数日間の修正と追加を経て、試用版のExpert Advisorは動作しましたが、非常に貧弱なものでした。 そこで、簡単なExpert Advisorのテンプレートを作ってほしいという要望を出したのです。 Rocheのテンプレートは、私にはやや難解で、最初のうちは冗長です -MetaEditorの 記事:Building on the power of templatesより。 Igor Kim 2008.06.04 04:18 #238 PriceOpenNearPos()関数を使用します。 この関数は、最も近いポジションの始値を返します。ポジションの開始価格と現在の市場価格との間の最小距離(pips)が、ポジションの「接近」の基準として機能します。考慮する位置の選択は、外部パラメータで設定します。 sy- 市場商品の名前。このパラメータが設定されている場合、この関数は指定された楽器の位置のみを考慮します。初期値「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルトの値である- 1は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 04.06.2008 | //| Описание : Возвращает цену открытия ближайшей позиции. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ double PriceOpenNearPos(string sy="", int op=-1, int mn=-1) { double mi, oop=0, p; int i, k=OrdersTotal(), pp=0; if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if ((OrderSymbol()==sy || sy=="") && (op<0 || OrderType()==op)) { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (mn<0 || OrderMagicNumber()==mn) { if (OrderType()==OP_BUY) mi=MarketInfo(OrderSymbol(), MODE_ASK); if (OrderType()==OP_SELL) mi=MarketInfo(OrderSymbol(), MODE_BID); p=MarketInfo(OrderSymbol(), MODE_POINT); if (p==0) if (StringFind(sy, "JPY")<0) p=0.0001; else p=0.01; if (pp==0 || pp>MathAbs(OrderOpenPrice()-mi)/p) { pp=MathAbs(OrderOpenPrice()-mi)/p; oop=OrderOpenPrice(); } } } } } } return(oop); } SZY. PriceOpenNearPos()関数をテストするスクリプトが添付されています。 興味のある方は、DistMarketAndPos()とPriceOpenNearPos()をご自身で比較してみてください。その違いにご注目ください。 ファイル: test_priceopennearpos.mq4 4 kb Igor Kim 2008.06.05 03:34 #239 TicketNearPos()関数です。 この関数は、マーケットに最も近いポジションのチケットを返します。ポジションの「近さ」の基準として、始値と現在の市場価格との間の最小距離(ポイント)が使用されます。考慮すべきポジションの選定は、外部パラメータによって設定される。 sy- 市場商品の名前。このパラメータが設定されている場合、この関数は指定された楽器の位置のみを考慮します。初期値「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルト値-1 は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 05.06.2008 | //| Описание : Возвращает тикет ближайшей к рынку позиции по цене открытия. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ int TicketNearPos(string sy="", int op=-1, int mn=-1) { double mi, p; int i, k=OrdersTotal(), pp=0, ti=0; if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if ((OrderSymbol()==sy || sy=="") && (op<0 || OrderType()==op)) { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (mn<0 || OrderMagicNumber()==mn) { if (OrderType()==OP_BUY) mi=MarketInfo(OrderSymbol(), MODE_ASK); if (OrderType()==OP_SELL) mi=MarketInfo(OrderSymbol(), MODE_BID); p=MarketInfo(OrderSymbol(), MODE_POINT); if (p==0) if (StringFind(sy, "JPY")<0) p=0.0001; else p=0.01; if (pp==0 || pp>MathAbs(OrderOpenPrice()-mi)/p) { pp=MathAbs(OrderOpenPrice()-mi)/p; ti=OrderTicket(); } } } } } } return(ti); } ZS. TicketNearPos()関数をテストするスクリプトを添付しています。 ファイル: test_ticketnearpos.mq4 4 kb Igor Kim 2008.06.07 04:12 #240 TypeNearPos()関数。 この関数は、始値で最も市場に近いポジションの種類(0-買い、1-売り)を返すか、-1 します。ポジションの開始価格と現在の市場価格との間の最小距離(pips)が、ポジションの「接近」の基準として機能します。考慮する位置の選択は、外部パラメータで設定します。 sy- 市場商品の名前。このパラメータが設定されている場合、この関数は指定された楽器の位置のみを考慮します。初期値「」は、あらゆる市場商品を意味する。NULL 値は、現在の測定器を意味する。 op- 貿易業務、ポジションタイプ。有効な値:OP_BUY、OP_SELL、または-1。初期値-1 は任意の位置を意味する。 mn- 位置の識別子,MagicNumber.デフォルト値-1 は、任意の識別子を意味する。 //+----------------------------------------------------------------------------+ //| Автор : Ким Игорь В. aka KimIV, http://www.kimiv.ru | //+----------------------------------------------------------------------------+ //| Версия : 07.06.2008 | //| Описание : Возвращает тип ближайшей к рынку позиции или -1. | //+----------------------------------------------------------------------------+ //| Параметры: | //| sy - наименование инструмента ("" - любой символ, | //| NULL - текущий символ) | //| op - операция (-1 - любая позиция) | //| mn - MagicNumber (-1 - любой магик) | //+----------------------------------------------------------------------------+ int TypeNearPos(string sy="", int op=-1, int mn=-1) { double mi, p; int i, k=OrdersTotal(), pp=0, ty=-1; if (sy=="0") sy=Symbol(); for (i=0; i<k; i++) { if (OrderSelect(i, SELECT_BY_POS, MODE_TRADES)) { if ((OrderSymbol()==sy || sy=="") && (op<0 || OrderType()==op)) { if (OrderType()==OP_BUY || OrderType()==OP_SELL) { if (mn<0 || OrderMagicNumber()==mn) { if (OrderType()==OP_BUY) mi=MarketInfo(OrderSymbol(), MODE_ASK); if (OrderType()==OP_SELL) mi=MarketInfo(OrderSymbol(), MODE_BID); p=MarketInfo(OrderSymbol(), MODE_POINT); if (p==0) if (StringFind(sy, "JPY")<0) p=0.0001; else p=0.01; if (pp==0 || pp>MathAbs(OrderOpenPrice()-mi)/p) { pp=MathAbs(OrderOpenPrice()-mi)/p; ty=OrderType(); } } } } } } return(ty); } TypeNearPos()関数をテストするスクリプトを添付します。 ファイル: test_typenearpos.mq4 5 kb 1...171819202122232425262728293031...128 新しいコメント 取引の機会を逃しています。 無料取引アプリ 8千を超えるシグナルをコピー 金融ニュースで金融マーケットを探索 新規登録 ログイン スペースを含まないラテン文字 このメールにパスワードが送信されます エラーが発生しました Googleでログイン WebサイトポリシーおよびMQL5.COM利用規約に同意します。 新規登録 MQL5.com WebサイトへのログインにCookieの使用を許可します。 ログインするには、ブラウザで必要な設定を有効にしてください。 ログイン/パスワードをお忘れですか? Googleでログイン
NumberOfLossPosToday()関数を使用します。
この関数は、今日決済された負けポジションの数を返します。考慮すべき位置の選定は、外部パラメータを用いて行う。
PriceCloseLastPos()関数です。
この関数は、最後に決済されたポジションの終値を返します。考慮すべき位置の選択は、外部パラメータで指定する。
私も賛成です。こんなやり方もあるんですね。図書館全体ではありません。しかし、いくつかのライブラリが、しかも最後にではなく、特定のトピックについてfiライブラリが蓄積されていくように。
例えば、オープニングとクローズでライブラリを分ける(オープニングのf-iだけ+マーケットウォッチで オープニング、クローズで クローズ)。
次のライブラリ - これらの属性によって位置の存在を返すf.i.を持つ。
といった具合に。
ただ、ここでは、図書館の完全なセットに関する現在の人々の提案を集めることが必要である。
PriceOpenLastPos()関数を使用します。
この関数は、直近のオープンポジションの始値を返します。考慮すべき位置の選択は、外部パラメータで指定する。
PriceOpenLastClosePos()関数を使用します。
この関数は、最後に決済されたポジションの始値を返します。考慮すべき位置の選択は、外部パラメータで指定する。
私も賛成です。こんなやり方もあるんですね。図書館全体ではありません。しかし、いくつかのライブラリが、しかも最後にではなく、特定のトピックについてfiライブラリが蓄積されていくように。
例えば、オープニングとクローズでライブラリを分ける(オープニングのf-iだけ+マーケットウォッチで オープニング、クローズで クローズ)。
次のライブラリ - これらの属性によって位置の存在を返すf.i.を持つ。
といった具合に。
図書館の買収について、いくつか提案したいことがあります。
こんにちは。
KimIVさんへ。
初心者の専門家ライターにとって、とても有益なことをされていますね。
前の申立人に合流します。
難しいことでなければ、主な機能を1つの「専門家テンプレート」にまとめることも可能です。
-予備検査
-開幕
-注文を入れる
-ポジションを閉じる
-注文を削除する
-オーダーやポジションのエスコート(変更)。
そして、誰もが自分でこれらの関数を呼び出すブロックを書くことになる。
自分で一からEAを書くのは無理です。
だから、他人のコードを変えることから始めたんです。
ブロック単位で機能を追加していくのですが、これがなかなか難しいんです。
数日間の修正と追加を経て、試用版のExpert Advisorは動作しましたが、非常に貧弱なものでした。
そこで、簡単なExpert Advisorのテンプレートを作ってほしいという要望を出したのです。
Rocheのテンプレートは、私にはやや難解で、最初のうちは冗長です -MetaEditorの 記事:Building on the power of templatesより。
PriceOpenNearPos()関数を使用します。
この関数は、最も近いポジションの始値を返します。ポジションの開始価格と現在の市場価格との間の最小距離(pips)が、ポジションの「接近」の基準として機能します。考慮する位置の選択は、外部パラメータで設定します。
SZY. PriceOpenNearPos()関数をテストするスクリプトが添付されています。
興味のある方は、DistMarketAndPos()とPriceOpenNearPos()をご自身で比較してみてください。その違いにご注目ください。
TicketNearPos()関数です。
この関数は、マーケットに最も近いポジションのチケットを返します。ポジションの「近さ」の基準として、始値と現在の市場価格との間の最小距離(ポイント)が使用されます。考慮すべきポジションの選定は、外部パラメータによって設定される。
TypeNearPos()関数。
この関数は、始値で最も市場に近いポジションの種類(0-買い、1-売り)を返すか、-1 します。ポジションの開始価格と現在の市場価格との間の最小距離(pips)が、ポジションの「接近」の基準として機能します。考慮する位置の選択は、外部パラメータで設定します。