亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? goaliepositioning.cpp

?? 2006年世界杯足球賽2D仿真組第16名的源代碼。在此代碼上隨便改改
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/* *  Copyright 2002-2005, Mersad Team, Allameh Helli High School (NODET). * *  This program is free software, you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *  GNU Library General Public License for more details. * *  This file is created by: Meisam Vosoughpour * *  Released on Monday 1 August 2005, 10 Mordad 1384 by Mersad RoboCup Team. *  For more information please read README file.*/#include <cmath>#include <Line.h>#include <Degree.h>#include <Vector.h>#include <Logger.h>#include <BasicTurn.h>#include <BasicDash.h>#include <Basics.h>#include <GoaliePositioning.h>using namespace std;GoaliePositioning::GoaliePositioning(const WorldModel *worldModel):		AdvancedAction(worldModel){}void GoaliePositioning::setGoalieParams(){    Point ballPoint;    float changeXDist = 1;    float changeYDistBadAngle = 1;    float minGoalieX = -48.5;    float virtualMinGoalieX;//  	float overLoadDistByNoTurn;// 		float overLoadDistByTurn;    float virtualGoalieX, virtualGoalieYIn52, 		virtualGoalieYIn44, virtualGoalieYInNow;    	Line midAngleLine, upWallLine, downWallLine, directWallLine;     //KOMAK		/*KOMAK*/ float goalieXHome = -47;	//KOMAK	if (worldModel->getPlayMode() == PM_PENALTY_SETUP ||		worldModel->getPlayMode() == PM_PENALTY_SETUP_OPP ||		worldModel->getPlayMode() == PM_PENALTY_READY_OPP ||		worldModel->getPlayMode() == PM_PENALTY_READY)	{		goalieXHome = -40;		changeXDist = 2;	}		else	{//	 LATEST TRICK		if (config["Agent"]["Public"]["LatestTrick"].asBool() && 		worldModel->getBall().getPos().getX() > -3)	{		if (worldModel->getBall().getPos().getX() > -34 &&			worldModel->getBall().getPos().getX() < -15)			goalieXHome = Basics::reRate(worldModel->getBall().getPos().getX(),					-25, -15, -47, -38);				if (worldModel->getBall().getPos().getX() > -15 &&			worldModel->getBall().getPos().getX() < 0)			goalieXHome = Basics::reRate(worldModel->getBall().getPos().getX(),					-15, 0, -38, -20);			if (worldModel->getBall().getPos().getX() >= 0)			goalieXHome = Basics::reRate(worldModel->getBall().getPos().getX(),					0, 54, -24, -15);		if (goalieXHome > -32)			goalieXHome = -32;	}//	LATEST TRICK 					}	    virtualGoalieX = goalieXHome;    virtualGoalieYIn52 = 6;    virtualGoalieYIn44 = 6;	ballPoint.x = worldModel->getBall().getPos().getX() + 					worldModel->getBall().getVel().getX();						ballPoint.y = worldModel->getBall().getPos().getY() + 					worldModel->getBall().getVel().getY();    if(ballPoint.x < -52.4)		ballPoint.x = -52.4;    virtualMinGoalieX = -52.5 + float((ballPoint.x - (-52.5)) / 2.8);           if(worldModel->getBall().getPos().getX() < -25 && 		worldModel->getBody().getPos().getX() < virtualGoalieX)    {		if (worldModel->getBody().getPos().getX() > virtualMinGoalieX)	   		virtualGoalieX = worldModel->getBody().getPos().getX(); 		else if (virtualMinGoalieX < virtualGoalieX) 			virtualGoalieX = virtualMinGoalieX;    }    if(virtualGoalieX < minGoalieX)		virtualGoalieX = minGoalieX;    if(fabs(virtualGoalieX - worldModel->getBody().getPos().getX()) 		< changeXDist)		virtualGoalieX = worldModel->getBody().getPos().getX();        virtualGoalieYInNow = virtualGoalieYIn44 + ((-44 - 							virtualGoalieX) * (virtualGoalieYIn52 - 							virtualGoalieYIn44)) / (-44 - (-52.5));	     Point tirUpPoint, tirDownPoint;    Vector tirUpVector, tirDownVector, midAngleVector;    float deltaAngle, betweenAngle;        tirUpPoint.x = tirDownPoint.x = -52.5;    tirUpPoint.y = 7;    tirDownPoint.y = -7;        tirUpVector.setByPoints(ballPoint, tirUpPoint);    tirDownVector.setByPoints(ballPoint, tirDownPoint);        deltaAngle = tirUpVector.getDirection() - tirDownVector.getDirection();    deltaAngle = Degree::normalizeAngle(deltaAngle);    deltaAngle = fabs(deltaAngle);    deltaAngle /= 2.00;        betweenAngle = tirUpVector.getDirection() + deltaAngle;    betweenAngle = Degree::normalizeAngle(betweenAngle);        midAngleVector.setAsPolar(1, betweenAngle);    midAngleLine.setBySourceDir(ballPoint, midAngleVector.getDirection());        upWallLine.setByPoints(Point(virtualGoalieX, virtualGoalieYInNow), 							Point(-52.5, virtualGoalieYIn52));						    downWallLine.setByPoints(Point(virtualGoalieX, -virtualGoalieYInNow), 							Point(-52.5, -virtualGoalieYIn52));							    directWallLine.setByPoints(Point(virtualGoalieX, -1), 								Point(virtualGoalieX, 1));	LOG << "directWallLine : a, b, c = " << directWallLine.getA() << "," << directWallLine.getB() << "," << directWallLine.getC() << endl;	LOG << "midAngleLine : a, b, c = " << midAngleLine.getA() << "," << midAngleLine.getB() << "," << midAngleLine.getC() << endl;	LOG << "midAngleLine : direction = " << midAngleLine.getDirection() << endl;	LOG << "virtualGoalieX = " << virtualGoalieX << endl;    midAngleLine.getLineIntersect(directWallLine, goalieHomePoint);    LOG << "goalieHomePoint 1 : " << goalieHomePoint << endl;        if(goalieHomePoint.y > virtualGoalieYInNow)    {		midAngleLine.getLineIntersect(upWallLine, goalieHomePoint);    	LOG << "goalieHomePoint 2 : " << goalieHomePoint << endl;    }    else if(goalieHomePoint.y < (-virtualGoalieYInNow))	{	    midAngleLine.getLineIntersect(downWallLine, goalieHomePoint);    	LOG << "goalieHomePoint 3 : " << goalieHomePoint << endl;	}    mainIdealBetweenAngle = midAngleVector.getDirection();         Vector goalieHomeVector;    goalieHomeVector.setByPoints(worldModel->getBody().getPos(), 								goalieHomePoint);        	float localDeltaAngle = goalieHomeVector.getDirection() - 							worldModel->getBody().getBodyDir();							    localDeltaAngle = Degree::normalizeAngle(localDeltaAngle);    localDeltaAngle = fabs(localDeltaAngle);    	if((localDeltaAngle >= 15 || localDeltaAngle >= 165) && 		fabs(goalieHomePoint.y - worldModel->getBody().getPos().getY()) <= 		changeYDistBadAngle)		goalieHomePoint.y = worldModel->getBody().getPos().getY();    LOG << "goalieHomePoint 4 : " << goalieHomePoint << endl;    float idealBodyAngle = mainIdealBetweenAngle - 90;    idealBodyAngle = Degree::normalizeAngle(idealBodyAngle);    Line idealAngleLine, ballToHomeLine;    Point bodyPoint;	    bodyPoint.x = worldModel->getBody().getPos().getX();    bodyPoint.y = worldModel->getBody().getPos().getY();    	idealAngleLine.setBySourceDir(bodyPoint, idealBodyAngle);    Line tirUpLine, tirDownLine;    tirUpLine.setByPoints(ballPoint, tirUpPoint);    tirDownLine.setByPoints(ballPoint, tirDownPoint);    LOG << "goalieHomePoint 5 : " << goalieHomePoint << endl;    float miniChangeDist = .3;	    if(worldModel->getBall().getBodyVec().getMagnitude() >= 10)		miniChangeDist += (worldModel->getBall().getBodyVec().getMagnitude() 							- 10) * .05;    	if(worldModel->getBall().getBodyVec().getMagnitude() >= 25)		miniChangeDist = 1.2;    	if (worldModel->getPlayMode() != PM_PLAY_ON)    	miniChangeDist = 5;        	if(mainIdealBetweenAngle > -122 && mainIdealBetweenAngle < 0)    {		goalieHomePoint = shootToTirSimulate(tirUpPoint, goalieHomePoint, 							idealBodyAngle, .00/*firstDashLength*/, 							6/*maxChangeDistance*/,miniChangeDist);							    	LOG << "goalieHomePoint 6 : " << goalieHomePoint << endl;    }	    if(mainIdealBetweenAngle < 122 && mainIdealBetweenAngle > 0)    {		goalieHomePoint = shootToTirSimulate(tirDownPoint, goalieHomePoint, 							idealBodyAngle, .00/*firstDashLength*/, 							6/*maxChangeDistance*/,miniChangeDist);							    	LOG << "goalieHomePoint 7 : " << goalieHomePoint << endl;    }        if(hypot(goalieHomePoint.x - worldModel->getBody().getPos().getX(), 		goalieHomePoint.y - worldModel->getBody().getPos().getY()) < 3)    {    	if(mainIdealBetweenAngle < -122 && mainIdealBetweenAngle > -160)     	{			Point tempSource;			idealAngleLine.getLineIntersect(tirUpLine, tempSource);			goalieHomePoint = shootToTirSimulate(tempSource, goalieHomePoint, 								idealBodyAngle, .00/*firstDashLength*/, 								7/*maxChangeDistance*/, .3);								 		   	LOG << "goalieHomePoint 8 : " << goalieHomePoint << endl;    	}			    if(mainIdealBetweenAngle > 124 && mainIdealBetweenAngle < 160) 	    {			Point tempSource;			idealAngleLine.getLineIntersect(tirDownLine, tempSource);			goalieHomePoint = shootToTirSimulate(tempSource, goalieHomePoint, 								idealBodyAngle, .00/*firstDashLength*/, 								7/*maxChangeDistance*/, .3);								  		  	LOG << "goalieHomePoint 9 : " << goalieHomePoint << endl;    	}    }    LOG << "goalieHomePoint 10 : " << goalieHomePoint << endl;        ballToHomeLine.setByPoints(goalieHomePoint, ballPoint);    float permitedDist = 1.2;    	if(hypot(goalieHomePoint.x - worldModel->getBody().getPos().getX(), 		goalieHomePoint.y - worldModel->getBody().getPos().getY()) < permitedDist)		idealAngleLine.getLineIntersect(ballToHomeLine, goalieHomePoint);   	LOG << "goalieHomePoint 11 : " << goalieHomePoint << endl;    if(goalieHomePoint.x < -50.5 )		goalieHomePoint.x = -50.5;   	LOG << "goalieHomePoint 12 : " << goalieHomePoint << endl;}void GoaliePositioning::setGoalieParamsLineMode(){    float goalieXHomeLineMode = -47;    float goalieXHomeEmg = -49.5;    float mainGoalieXHomeLM;	float minGoalieXLM = -50;	float virtualMinGoalieXLM;	if (worldModel->getPlayMode() == PM_PENALTY_SETUP ||		worldModel->getPlayMode() == PM_PENALTY_SETUP_OPP ||		worldModel->getPlayMode() == PM_PENALTY_READY_OPP ||		worldModel->getPlayMode() == PM_PENALTY_READY)	{	}	else	{///////////	LATEST TRICK	if (config["Agent"]["Public"]["LatestTrick"].asBool() &&		worldModel->getBall().getPos().getX() > -3)	{		if (worldModel->getBall().getPos().getX() > -34 &&			worldModel->getBall().getPos().getX() < -15)			goalieXHomeLineMode = Basics::reRate(worldModel->getBall().getPos().getX(),					-25, -15, -47, -38);				if (worldModel->getBall().getPos().getX() > -15 &&			worldModel->getBall().getPos().getX() < 0)			goalieXHomeLineMode = Basics::reRate(worldModel->getBall().getPos().getX(),					-15, 0, -38, -20);			if (worldModel->getBall().getPos().getX() >= 0)			goalieXHomeLineMode = Basics::reRate(worldModel->getBall().getPos().getX(),					0, 54, -24, -15);		if (goalieXHomeLineMode > -32)			goalieXHomeLineMode = -32;	}//	LATEST TRICK //////////		}	    Vector upTirToBall, downTirToBall, goalToBall;    Point ballPoint;        ballPoint.x = worldModel->getBall().getPos().getX() + 					worldModel->getBall().getVel().getX();					    ballPoint.y = worldModel->getBall().getPos().getY() + 					worldModel->getBall().getVel().getY();    mainGoalieXHomeLM = goalieXHomeLineMode;	virtualMinGoalieXLM = -52.5 + float((ballPoint.x - (-52.5)) / 2.8);   	minGoalieXLM = max(minGoalieXLM, virtualMinGoalieXLM);	if (worldModel->getBody().getPos().getX() < mainGoalieXHomeLM)	{		if (worldModel->getBody().getPos().getX() > minGoalieXLM)			mainGoalieXHomeLM = worldModel->getBody().getPos().getX();		}	    upTirToBall.setByPoints(Point(-52.5, 7), ballPoint);    downTirToBall.setByPoints(Point(-52.5, -7), ballPoint);    goalToBall.setByPoints(Point(-52.5, 0), ballPoint);	    float deltaAngleToUpTir = upTirToBall.getDirection() - 90;    float deltaAngleToDownTir = downTirToBall.getDirection() - (-90);    float deltaAngleToGoal;    	if (ballPoint.y > 0)    	deltaAngleToGoal = goalToBall.getDirection() - 90;	else    	deltaAngleToGoal = goalToBall.getDirection() - (-90);			    deltaAngleToUpTir = Degree::normalizeAngle(deltaAngleToUpTir);    deltaAngleToDownTir = Degree::normalizeAngle(deltaAngleToDownTir);    deltaAngleToGoal = Degree::normalizeAngle(deltaAngleToGoal);	    deltaAngleToUpTir = fabs(deltaAngleToUpTir);    deltaAngleToDownTir = fabs(deltaAngleToDownTir);    deltaAngleToGoal = fabs(deltaAngleToGoal);	LOG << "Goalie LOG 1 : " << mainGoalieXHomeLM << " " << goalieXHomeLineMode 		<< " " << goalieXHomeEmg << endl;    if(worldModel->getBall().getPos().getY() > 0 && 		deltaAngleToUpTir < 45 && upTirToBall.getMagnitude() < 15)		{			mainGoalieXHomeLM = goalieXHomeEmg;			LOG << "GOALIE Change Function 1" << endl;			setGoalieParams();			return;		}		LOG << "Goalie LOG 2 : " << mainGoalieXHomeLM << " " << goalieXHomeLineMode 		<< " " << goalieXHomeEmg << endl;		    if(worldModel->getBall().getPos().getY() < 0 && 		deltaAngleToDownTir < 45 && downTirToBall.getMagnitude() < 15)		{			mainGoalieXHomeLM = goalieXHomeEmg;			LOG << "GOALIE Change Function 2" << endl;			setGoalieParams();			return;		}	LOG << "Goalie LOG 3 : " << mainGoalieXHomeLM << " " << goalieXHomeLineMode 		<< " " << goalieXHomeEmg << endl;    LOG << "deltaAngleToGoal : " << deltaAngleToGoal << endl;    LOG << "goalToBall.Length : " << goalToBall.getMagnitude() << endl;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产不卡视频一区二区三区| 色婷婷精品久久二区二区蜜臀av| 亚洲国产精品久久人人爱| 亚洲欧美另类在线| 日韩一区二区在线看| 亚洲欧洲在线观看av| 日本欧美在线看| 一本一道综合狠狠老| 爽好多水快深点欧美视频| 午夜精品成人在线视频| 国产一区不卡在线| 97国产精品videossex| 欧美视频一区在线观看| 久久精品一区蜜桃臀影院| 亚洲综合网站在线观看| 国产精品一区二区久久不卡| 欧美伊人久久大香线蕉综合69 | www.av亚洲| 555夜色666亚洲国产免| 久久色在线视频| 久久综合色综合88| 亚洲午夜av在线| 不卡视频免费播放| 中文字幕巨乱亚洲| 国产馆精品极品| 欧美精品一区二区三区高清aⅴ| 午夜国产精品一区| 欧美人与性动xxxx| 天堂成人国产精品一区| 欧美欧美欧美欧美| 日韩国产欧美视频| 欧美一级淫片007| 麻豆成人在线观看| 精品国产一区二区三区不卡| 韩国中文字幕2020精品| 久久久久久综合| 国产不卡视频一区二区三区| 亚洲国产精华液网站w | 午夜视频在线观看一区二区三区| 在线观看日韩毛片| 天堂影院一区二区| 欧美不卡一区二区三区| 国产精品自拍一区| 国产精品传媒入口麻豆| 不卡一卡二卡三乱码免费网站| 日韩美女精品在线| 欧美午夜电影一区| 欧美a级一区二区| 久久久亚洲精品一区二区三区 | 视频一区视频二区中文| 欧美高清dvd| 国产一二三精品| 国产精品久久国产精麻豆99网站| fc2成人免费人成在线观看播放| 亚洲婷婷在线视频| 欧美日韩一区二区在线视频| 免费成人深夜小野草| 欧美v亚洲v综合ⅴ国产v| 国产精品一区二区久久不卡| 亚洲欧美日韩久久| 91精品国产欧美一区二区| 激情成人综合网| 亚洲视频在线观看三级| 欧美日韩国产综合视频在线观看| 美女任你摸久久| ㊣最新国产の精品bt伙计久久| 欧美嫩在线观看| 大美女一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在| 欧美色视频在线观看| 婷婷开心激情综合| 精彩视频一区二区| 中文字幕在线观看不卡| 欧美高清视频在线高清观看mv色露露十八 | 国产高清一区日本| 亚洲综合激情小说| 国产女主播在线一区二区| 日本高清免费不卡视频| 国产在线精品视频| 三级精品在线观看| 国产精品久久二区二区| 久久在线免费观看| 欧美日韩三级一区二区| 成人网在线免费视频| 欧美aⅴ一区二区三区视频| 亚洲青青青在线视频| 久久久久久影视| 欧美一级片在线观看| 91麻豆自制传媒国产之光| 国产精品资源站在线| 日韩中文字幕不卡| 一区av在线播放| 亚洲视频电影在线| 国产精品毛片久久久久久| 日韩精品一区二区三区视频播放| 91麻豆国产在线观看| 成人免费不卡视频| 国产在线视视频有精品| 日韩av一区二| 亚洲aⅴ怡春院| 亚洲一级二级三级在线免费观看| 国产精品不卡一区| 国产亚洲精品免费| 精品国产乱码久久久久久图片 | 国产精品免费看片| 国产亚洲成年网址在线观看| 欧美第一区第二区| 6080午夜不卡| 欧美日韩一区二区电影| 色婷婷香蕉在线一区二区| 91在线观看视频| 色综合天天综合在线视频| av综合在线播放| 91亚洲精华国产精华精华液| 成人丝袜高跟foot| 成人性生交大片免费看视频在线| 国产在线日韩欧美| 国产乱码字幕精品高清av| 国产成人小视频| 国产一区二区三区蝌蚪| 国产精品性做久久久久久| 国产精品综合一区二区| 国产成人精品免费在线| www.欧美.com| 欧美亚洲国产怡红院影院| 欧美色成人综合| 欧美一区二区三区四区久久| 欧美videofree性高清杂交| 久久一留热品黄| 国产精品久久久久久久裸模 | 26uuu亚洲综合色| 久久久99免费| 亚洲免费观看高清完整版在线观看熊| 国产精品传媒视频| 亚洲无线码一区二区三区| 美女视频黄频大全不卡视频在线播放| 精品系列免费在线观看| av在线这里只有精品| 欧美性感一区二区三区| 91精品视频网| 国产精品素人一区二区| 一区二区不卡在线播放| 久久99在线观看| 成人黄页毛片网站| 欧美日韩国产综合草草| 精品国产1区二区| 亚洲免费观看在线观看| 免费在线观看不卡| av电影一区二区| 欧美精品18+| 国产精品久久久久久久久晋中 | 日韩欧美国产综合在线一区二区三区 | 欧美一区三区二区| 国产丝袜在线精品| 亚洲午夜免费视频| 国产成人av电影在线播放| 欧美亚洲一区二区在线| 久久日一线二线三线suv| 一区二区三区四区在线播放| 另类欧美日韩国产在线| 91啦中文在线观看| 久久久久久9999| 亚洲高清一区二区三区| 国产传媒欧美日韩成人| 欧美一区二区免费视频| 成人欧美一区二区三区黑人麻豆| 日韩av二区在线播放| 99国产麻豆精品| 久久综合久久综合久久综合| 亚洲123区在线观看| 成人国产精品免费| 欧美变态tickling挠脚心| 一区二区视频免费在线观看| 成人免费av资源| 精品成人私密视频| 视频一区中文字幕| 色综合 综合色| 中文字幕在线一区| 国产一区二区三区黄视频| 在线成人av影院| 亚洲制服丝袜在线| 99久久伊人精品| 欧美国产丝袜视频| 国产精品 欧美精品| 91精品国产综合久久久蜜臀粉嫩| 亚洲图片欧美一区| 色视频成人在线观看免| 亚洲视频精选在线| www.在线欧美| 国产精品嫩草99a| 懂色av中文字幕一区二区三区| 精品美女在线播放| 日韩黄色免费电影| 欧美日韩aaa| 日韩国产成人精品| 欧美区视频在线观看| 午夜久久久久久久久| 777亚洲妇女| 开心九九激情九九欧美日韩精美视频电影 | 日韩精品亚洲一区|