【FX完全自動売買シリーズ】MT4 EA無料ダウンロード&ロジック完全公開 ポンドドル1時間足 191502_GBPUSD_H1_ONB_S



EA無料ダウンロード

永遠に放置できるわけではありません

裁量トレードほどには儲かりませんが、使い方によっては完全放置で利益が出ます

ですが、定期的なメンテナンス(パラメータ調整)はどうしても必要です。

「完全放置じゃないじゃん(゚Д゚)!」と言うツッコミありがとうございます。

【期間限定で完全放置】と言うことで勘弁してください。

投資は自己責任で

ご利用前に必ずご自身でデバッグ&バックテストしてください

公開しておいてなんですが、ロジックを参考にする程度に留めておくと幸せになれます。
免責や著作権について 免責:著作権は放棄していませんので商用利用不可。改造しての販売・再配布も不可。個人口座でのみ利用可。

また、ご利用されたことによるいかなる事態・結果についても責任は負いかねます。全て自己責任でお願いします。
ご注意:EAや自動売買に過度な期待をされている方、FXの世界に聖杯があると信じている方はこちらの記事も併せてご覧ください。

FXで完全機械化は可能か?

結論から言うと可能です。そんなことは20世紀からやっていることで、いまさら議論することでもないのですが・・・

コピペしてお持ち帰りください

※スパゲティなのは仕様です。ローカルにコピペでもしてご覧ください。


#define EA_MAGIC_NO		191502
#define D_NONE	0
#define D_BUY	1
#define D_SELL	2
#define D_OFF	0
#define D_ON	1
/*****************************************
 * グロバル変数
 *****************************************/
//extern int	EA_temp = 1;
int	EA_stop_min = 130;
int	EA_open_end = 19;
int	EA_over_night = 13;
int	EA_kairi = 70;
int	EA_ma_period_l = 408;
int	EA_range_period = 11;
int	EA_open_start = 1;
int	EA_least_cnt = 6;

int g_TDM=0;
bool tradeFlg=D_OFF;
bool OpenRangeInit=D_OFF;
double openRangeHigh;
double openRangeLow;
int	slippage=3;
double g_stop_loss=0;

double	EA_Lots = 0.01;
double	G_Point = 0;

int init()
{
	if(Point==0.00001) G_Point=10*Point;//業者によって異なるため、注意
	else
	if(Point==0.0001)  G_Point=1*Point;//業者によって異なるため、注意
	else return;

	slippage=slippage*G_Point;
}
//+------------------------------------------------------------------+
//| Check for open order conditions                                  |
//+------------------------------------------------------------------+
void CheckForOpen()
{
	int		ticket=0;
	double	ma_l_1=0;

	if((Ask-Bid)>6*G_Point) return;//スプレッドが極端に広いときはやらない

	ma_l_1=iMA(NULL,0,EA_ma_period_l,0,MODE_EMA,PRICE_TYPICAL,1);

	if((Bid-ma_l_1)>EA_kairi*Bid*G_Point && Open[0]>openRangeLow && Bid<openRangeLow)
	{
		g_stop_loss = iHigh(NULL,PERIOD_D1,iHighest(NULL,PERIOD_D1,MODE_HIGH,1,0)) + 10*G_Point;

		if((g_stop_loss-Bid)<EA_stop_min*Bid*G_Point)
		{
			g_stop_loss = Ask+EA_stop_min*Bid*G_Point;
		}

		ticket=OrderSend(
			Symbol(),OP_SELL,
			EA_Lots,
			Bid,slippage,0,0,"191502",EA_MAGIC_NO,0,Red);

		if(ticket<0)
		{
			Print("OrderSendError ",GetLastError());
		}
		//オーダーに成功したらフラグを立て、カウントをアップする
		else
		{
			tradeFlg=D_ON;
		}
	}
}

void CheckForClose()
{
	int		ii=0,jj=0;				//カウンタ
	int		total=0;			//オーダートータル
	int		order_flag=D_NONE;
	int		bar_count=0;
	double	volatility=0,stop_loss_new=0;

	total=OrdersTotal();
	if(total<=0) return;

	total=OrdersTotal();
	for(ii=(total-1);ii>=0;ii--)	//注文がある
	{
		order_flag=D_NONE;

		if(OrderSelect(ii,SELECT_BY_POS,MODE_TRADES)!=TRUE)
		{
			Print("OrderSelect ERROR",GetLastError( ));
			return;
		}

		if(OrderSymbol()!=Symbol()) continue;
		if(OrderMagicNumber()!=EA_MAGIC_NO) continue;

		bar_count=iBarShift(NULL,0,OrderOpenTime(),false);

		if(OrderStopLoss()==0 && g_stop_loss!=0)
		{
			if(OrderModify(OrderTicket(),OrderOpenPrice(),g_stop_loss,0,0,White)!=TRUE)
			{
				Print("OrderModify ERROR stop ",GetLastError( ));
			}
		}

		if(!(bar_count>1)) continue;

		if(order_flag==D_NONE && OrderProfit()>0 && Hour()==EA_over_night && bar_count>EA_least_cnt)
		{
			order_flag=D_SELL;
		}
/*
		if(order_flag==D_NONE && (OrderOpenPrice()-Bid)>EA_shoot_val*Bid*G_Point)
		{
			order_flag=D_SELL;
		}
*/
/*
		if(order_flag==D_NONE)
		{
			volatility=High[iHighest(NULL,0,MODE_HIGH,EA_vola_cnt,1)]-Low[iLowest(NULL,0,MODE_LOW,EA_vola_cnt,1)];

			stop_loss_new=Bid+volatility*EA_trail_rate;

			if((OrderOpenPrice()-Bid)>EA_start_trail*Bid*G_Point && OrderStopLoss()>(stop_loss_new+20*G_Point))
			{
				if(OrderModify(OrderTicket(),OrderOpenPrice(),stop_loss_new,0,0,White)!=TRUE)
				{
					Print("OrderModify ERROR trail ",GetLastError( ));
				}
			}
		}
*/
		if(order_flag==D_SELL)
		{
			if(OrderClose(OrderTicket(),OrderLots(),Ask,10,Red)!=TRUE)
			{
				Print("OrderClose ERROR",GetLastError( ));
			}
		}
	}
}

int start()
{
	int		total=0,ii=0;
	bool	posi_flag=D_OFF;

	//---- check for history and trading
	if(Bars<EA_ma_period_l || IsTradeAllowed()==false) return;

	total=OrdersTotal();
	for(ii=(total-1);ii>=0;ii--)	//注文がある
	{
		if(OrderSelect(ii,SELECT_BY_POS,MODE_TRADES)!=TRUE)
		{
			Print("OrderSelect ERROR A",GetLastError( ));
			return;
		}
		if(OrderSymbol()!=Symbol()) continue;
		if(OrderMagicNumber()!=EA_MAGIC_NO) continue;

		posi_flag=D_ON;
	}

	if(OpenRangeInit==D_ON)
	{
		if(Hour()>=(EA_over_night+EA_open_start) && Hour()<EA_open_end)
		{
//			if(posi_flag==D_OFF)
			if(tradeFlg==D_OFF)
			{
//				if(Month()==EA_temp)
//				if(Month()!=8 && Month()!=9 && Month()!=5)
				{
//					if(g_TDM==EA_temp)
					if(g_TDM!=8 && g_TDM!=9 && g_TDM!=10 && g_TDM!=11)
					{
//						if(DayOfWeek()==EA_temp)
						if(DayOfWeek()!=1)
						{
							CheckForOpen();
						}
					}
				}
			}
		}
		else
		if(Hour()>=EA_open_end)
		{
			OpenRangeInit=D_OFF;
		}
	}
	else
	//オーバーナイト終了時、オーバーナイトのある一定期間の値幅を記録&各種変数初期化
	if(Hour()==EA_over_night && OpenRangeInit==D_OFF)
	{
		openRangeLow = Low[iLowest(NULL,0,MODE_LOW,EA_range_period,0)];
		OpenRangeInit=D_ON;
		tradeFlg=D_OFF;

		for(ii=0;ii<=Day();ii++)
		{
			//iTimeはbarの開始時刻を返すので、先月のbarになった時点でループから抜ける
			if(TimeMonth(iTime(NULL,PERIOD_D1,ii))==Month())
			{
			}
			else
			{
				break;
			}
		}
		g_TDM = ii;
	}

	if(posi_flag==D_ON)
	{
		CheckForClose();
	}
}
//+------------------------------------------------------------------+