⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 v_winnertakeall_va.java

📁 利用JAVA编写的群体机器人局部通讯完成一定得队形控制
💻 JAVA
字号:
/* * v_WinnerTakeAll_va.java */package EDU.gatech.cc.is.clay;import java.lang.*;import EDU.gatech.cc.is.util.Vec2;import EDU.gatech.cc.is.util.Units;/** * Combine an array of embedded schemas using * a winner-take-all policy.  * Configuration is done by setting the values of the embedded[] * weights[] arrays. * <P> * For detailed information on how to configure behaviors, see the * <A HREF="../clay/docs/index.html">Clay page</A>. * <P> * <A HREF="../COPYRIGHT.html">Copyright</A> * (c)1997, 1998 Tucker Balch * * @author Tucker Balch * @version $Revision: 1.1 $ */public class v_WinnerTakeAll_va extends NodeVec2	{	/**	 * Turn debug printing on or off.	 */	public static final boolean DEBUG = /*true;*/Node.DEBUG;		/**	 * Maximum number of components of an v_WinnerTakeAll_va node.	 */	public static final int MAX_COMPONENTS = 20;	/**	 * The embedded nodes to multiply by the weights and sum.	 */	public NodeVec2[]	embedded = new NodeVec2[MAX_COMPONENTS];	/**	 * The weights to multiply the nodes by.	 */	public double[]		weights  = new double[MAX_COMPONENTS];	/**	 * Instantiate a v_WinnerTakeAll_va node.	 */	public v_WinnerTakeAll_va()		{		}	Vec2	last_val = new Vec2();	long	lasttime = 0;	/**	 * Return a Vec2 representing the greatest of the embedded	 * nodes.	 * @param timestamp long, only get new information 	 *        if timestamp > than last call	 *        or timestamp == -1.	 * @return the vector weighted sum.	 */	public Vec2 Value(long timestamp)		{                if (DEBUG) System.out.println("v_WinnerTakeAll_va: Value()");                 if ((timestamp > lasttime)||(timestamp == -1))                        {                        /*--- reset the timestamp ---*/                        if (timestamp > 0) lasttime = timestamp;                         /*--- add in the weighted value of each schema ---*/                        last_val.setr(0);			Vec2 temp;			int i = 0;			while(embedded[i]!=null)				{                		if (DEBUG) System.out.println(i+" weight "+					weights[i]);				temp = embedded[i].Value(timestamp);				temp.setr(temp.r*weights[i]);				if (temp.r > last_val.r)					last_val = temp;				i++;				}			}		return (new Vec2(last_val.x, last_val.y));		}        }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -