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

📄 polygonconstructor.java

📁 JGAP是一种遗传算法和遗传规划的组成部分提供了一个Java框架。它提供了基本的遗传机制
💻 JAVA
字号:
/*
 * This file is part of JGAP.
 *
 * JGAP offers a dual license model containing the LGPL as well as the MPL.
 *
 * For licensing information please see the file license.txt included with JGAP
 * or have a look at the top of class org.jgap.Chromosome which representatively
 * includes the JGAP license policy applicable for any file delivered with JGAP.
 */
package examples.gp.monalisa.core.commands;

import java.awt.*;
import org.jgap.*;
import org.jgap.gp.*;
import org.jgap.gp.impl.*;
import org.jgap.util.*;

/**
 * A polygon consists of a series of points.
 *
 * @author Yann N. Dauphin
 */
public class PolygonConstructor
    extends CommandGene implements IMutateable, ICloneable {
  /** String containing the CVS revision. Read out via reflection!*/
  private final static String CVS_REVISION = "$Revision: 1.3 $";

  private boolean m_mutateable;

  private int m_points = 5;

  private int m_minPoints;

  private int m_maxPoints;

  public PolygonConstructor(GPConfiguration a_conf, int a_points)
      throws InvalidConfigurationException {
    this(a_conf, a_points, false);
  }

  public PolygonConstructor(GPConfiguration a_conf, int a_points,
                            int a_minPoints,
                            int a_maxPoints)
      throws InvalidConfigurationException {
    this(a_conf, a_points, true);
    m_minPoints = a_minPoints;
    m_maxPoints = a_maxPoints;
  }

  public PolygonConstructor(GPConfiguration a_conf, int a_points,
                            boolean a_mutateable)
      throws InvalidConfigurationException {
    super(a_conf, a_points, Polygon.class);
    m_points = a_points;
    m_mutateable = a_mutateable;
  }

  @Override
  public Object execute_object(ProgramChromosome a_chrom, int a_n,
                               Object[] a_args) {
    Polygon polygon = new Polygon();
    for (int i = 0; i < m_points; i++) {
      Point p = (Point) a_chrom.execute_object(a_n, i, a_args);
      polygon.addPoint(p.x, p.y);
    }
    return polygon;
  }

  @Override
  public Class getChildType(IGPProgram a_ind, int a_chromNum) {
    return Point.class;
  }

  @Override
  public String toString() {
    String s = "new Polygon(";
    for (int i = 0; i < m_points; i++) {
      if (i > 0) {
        s += ", ";
      }
      s += "&" + (i + 1);
    }
    s += ")";
    return s;
  }

  public CommandGene applyMutation(int index, double a_percentage)
      throws InvalidConfigurationException {
    if (!m_mutateable) {
      return this;
    }
    RandomGenerator randomGen = getGPConfiguration().getRandomGenerator();
    double random = randomGen.nextDouble();
    if (random < a_percentage) {
      return applyMutation();
    }
    return this;
  }

  public CommandGene applyMutation()
      throws InvalidConfigurationException {
    int points;
    if (m_minPoints < 1) {
      points = getGPConfiguration().getRandomGenerator().nextInt(7) +
          3;
    }
    else {
      points = getGPConfiguration().getRandomGenerator().nextInt(m_maxPoints +
          1 - m_minPoints) + m_minPoints;
    }
    PolygonConstructor result = new PolygonConstructor(getGPConfiguration(),
        points, m_mutateable);
    return result;
  }

  /**
   * Clones the object. Simple and straight forward implementation here.
   *
   * @return cloned instance of this object
   *
   * @author Klaus Meffert
   * @since 3.4.1
   */
  public Object clone() {
    try {
      PolygonConstructor result = new PolygonConstructor(getGPConfiguration(),
          m_points, m_mutateable);
      return result;
    } catch (Throwable t) {
      throw new CloneException(t);
    }
  }
}

⌨️ 快捷键说明

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