コード例 #1
0
 private void remove_extinct_species()
 {
     for (int i = species.size() - 1; i >= 0; i--)
     {
         if (species.get(i).size() <= 1)
         {
             species.get(i).goExtinct();
             species.remove(i);
         }
     }
 }
コード例 #2
0
        public virtual void kill(double percentage)
        {
            clients.Data.Sort((x, y) => x.CompareTo(y));

            double amount = percentage * this.clients.size();

            for (int i = 0; i < amount; i++)
            {
                Client client = clients.get(0);
                clients.get(0).Species = null;
                clients.remove(0);
            }
        }
コード例 #3
0
        public virtual void mutate_node()
        {
            ConnectionGene con = connections.random_element();

            if (con == null)
            {
                return;
            }

            NodeGene from = con.From;
            NodeGene to   = con.To;

            int      replaceIndex = neat.getReplaceIndex(from, to);
            NodeGene middle;

            if (replaceIndex == 0)
            {
                middle   = neat.Node;
                middle.X = (from.X + to.X) / 2;
                middle.Y = (from.Y + to.Y) / 2 + GlobalRandom.NextDouble * 0.1 - 0.05;
                neat.setReplaceIndex(from, to, middle.Innovation_number);
            }
            else
            {
                middle = neat.getNode(replaceIndex);
            }

            ConnectionGene con1 = neat.getConnection(from, middle);
            ConnectionGene con2 = neat.getConnection(middle, to);

            con1.Weight  = 1;
            con2.Weight  = con.Weight;
            con2.Enabled = con.Enabled;

            connections.remove(con);
            connections.add(con1);
            connections.add(con2);

            nodes.add(middle);
        }