particleupdatefullyrandom.java

来自「這是最近蒐集資料找到的Java PSO Swarm 大家可以下載回去參考使用 」· Java 代码 · 共 38 行

JAVA
38
字号
package net.sourceforge.jswarm_pso;/** * Particle update: Fully random approach * Note that rlocal and rother are randomly choosen for each particle and for each dimention *  * @author Pablo Cingolani <pcingola@sinectis.com> */public class ParticleUpdateFullyRandom extends ParticleUpdate {	/**	 * Constructor 	 * @param particle : Sample of particles that will be updated later	 */	public ParticleUpdateFullyRandom(Particle particle) {		super(particle);	}		/** Update particle's velocity and position */	public void update(Swarm swarm, Particle particle) {		double position[] = particle.getPosition();		double velocity[] = particle.getVelocity();		double globalBestPosition[] = swarm.getBestPosition();		double particleBestPosition[] = particle.getBestPosition();		// Update velocity and position		for( int i = 0; i < position.length; i++ ) {			// Update position			position[i] = position[i] + velocity[i];			// Update velocity			velocity[i] = swarm.getInertia() * velocity[i] // Inertia					+ Math.random() * swarm.getParticleIncrement() * (particleBestPosition[i] - position[i]) // Local best					+ Math.random() * swarm.getGlobalIncrement() * (globalBestPosition[i] - position[i]); // Global best		}	}}

⌨️ 快捷键说明

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