Beispiel #1
0
 def test_createAlleleRange(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     self.assertEqual(_allelerange.beginEnd, [(10, 20)])
     self.assertEqual(_allelerange.minimum, 10)
     self.assertEqual(_allelerange.maximum, 20)
     _allelerange = GAllele.GAlleleRange(1.0, 2.0, real=True)
     self.assertEqual(_allelerange.real, True)
Beispiel #2
0
 def test_createAlleles_default(self):
     _alleles = GAllele.GAlleles(allele_list=None)
     self.assertTrue(hasattr(_alleles, 'allele_list'), True)
     self.assertTrue(hasattr(_alleles, 'homogeneous'), True)
     self.assertEqual(_alleles.allele_list, [])
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3])
     self.assertEqual(_alleles.allele_list, [1, 2, 3])
     _alleles = GAllele.GAlleles(homogeneous=True)
     self.assertEqual(_alleles.homogeneous, True)
Beispiel #3
0
 def test_AlleleRange_add(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     _allelerange.add(30, 40)
     self.assertEqual(_allelerange.beginEnd, [(10, 20), (30, 40)])
     self.assertEqual(_allelerange.minimum, 10)
     self.assertEqual(_allelerange.maximum, 40)
     with self.assertRaises(ValueError):
         _allelerange.add(40, 30)
Beispiel #4
0
 def test_AlleleRange_slicing(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     _allelerange.add(30, 40)
     self.assertEqual(_allelerange[0], (10, 20))
     _allelerange[1] = (50, 60)
     self.assertEqual(_allelerange[1], (50, 60))
     with self.assertRaises(ValueError):
         _allelerange[1] = (60, 50)
Beispiel #5
0
 def test_Alleles_slicing(self):
     # includes slice operation, getitem and setitem
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3])
     self.assertEqual(_alleles[1], 2)
     with self.assertRaises(Exception):
         _ = _alleles[4]
     _alleles[1] = 5
     self.assertEqual(_alleles[1], 5)
     self.assertEqual(_alleles[0:2], [1, 5])
Beispiel #6
0
 def test_AlleleRange_getRandomAllele(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     random_allele = _allelerange.getRandomAllele()
     self.assertTrue(
         random_allele,
         any([x[0] <= random_allele <= x[1]
              for x in _allelerange.beginEnd]))
     _allelerange.add(30, 40)
     random_allele = _allelerange.getRandomAllele()
     self.assertTrue(
         random_allele,
         any([x[0] <= random_allele <= x[1]
              for x in _allelerange.beginEnd]))
     _allelerange = GAllele.GAlleleRange(1.0, 2.0, real=True)
     random_allele = _allelerange.getRandomAllele()
     self.assertTrue(
         random_allele,
         any([x[0] <= random_allele <= x[1]
              for x in _allelerange.beginEnd]))
def run_main():
    # Genome instance
    setOfAlleles = GAllele.GAlleles()

    # From 0 to 10 we can have only some
    # defined ranges of integers
    for i in range(11):
        a = GAllele.GAlleleRange(0, i)
        setOfAlleles.add(a)

    # From 11 to 19 we can have a set
    # of elements
    for i in range(11, 20):
        # You can even add objects instead of strings or
        # primitive values
        a = GAllele.GAlleleList(['a', 'b', 'xxx', 666, 0])
        setOfAlleles.add(a)

    genome = G1DList.G1DList(20)
    genome.setParams(allele=setOfAlleles)

    # The evaluator function (objective function)
    genome.evaluator.set(eval_func)

    # This mutator and initializator will take care of
    # initializing valid individuals based on the allele set
    # that we have defined before
    genome.mutator.set(G1DListMutatorAllele)
    genome.initializator.set(G1DListInitializatorAllele)

    # Genetic Algorithm Instance
    ga = GSimpleGA.GSimpleGA(genome)
    ga.setGenerations(40)

    # Do the evolution, with stats dump
    # frequency of 10 generations
    ga.evolve(freq_stats=5)

    # Best individual
    print(ga.bestIndividual())
Beispiel #8
0
 def test_Alleles_repr(self):
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3])
     self.assertIsInstance(repr(_alleles), str)
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3], homogeneous=True)
     self.assertIsInstance(repr(_alleles), str)
Beispiel #9
0
 def test_Alleles_iter(self):
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3])
     self.assertIsInstance(iter(_alleles), Iterable)
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3], homogeneous=True)
     self.assertIsInstance(iter(_alleles), Iterable)
Beispiel #10
0
 def test_Alleles_len(self):
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3])
     self.assertEqual(len(_alleles), 3)
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3], homogeneous=True)
     self.assertEqual(len(_alleles), 1)
Beispiel #11
0
 def test_AlleleList_remove(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     _allelelist.remove(2)
     self.assertEqual(_allelelist.options, [1, 3])
Beispiel #12
0
 def test_Alleles_slicing_homogeneous(self):
     _alleles = GAllele.GAlleles(allele_list=[1, 2, 3], homogeneous=True)
     self.assertEqual(_alleles[2], 1)
     _alleles[1] = 5
     self.assertEqual(_alleles[0], 5)
Beispiel #13
0
 def test_AlleleList_repr(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     self.assertIsInstance(repr(_allelelist), str)
Beispiel #14
0
 def test_Alleles_add(self):
     _alleles1 = GAllele.GAlleles(allele_list=[1, 2, 3])
     _alleles1.add(4)
     self.assertEqual(_alleles1.allele_list, [1, 2, 3, 4])
Beispiel #15
0
 def test_AlleleList_slicing(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     self.assertEqual(_allelelist[0:2], [1, 2])
     self.assertEqual(_allelelist[1], 2)
     _allelelist[1] = 4
     self.assertEqual(_allelelist[1], 4)
Beispiel #16
0
 def test_AlleleList_len(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     self.assertEqual(len(_allelelist), 3)
Beispiel #17
0
 def test_AlleleList_getRandomAllele(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     random_allele = _allelelist.getRandomAllele()
     self.assertIn(random_allele, _allelelist.options)
Beispiel #18
0
 def test_createAlleleList_default(self):
     _allelelist = GAllele.GAlleleList()
     self.assertEqual(_allelelist.options, [])
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     self.assertEqual(_allelelist.options, [1, 2, 3])
Beispiel #19
0
 def test_AlleleRange_clear(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     _allelerange.clear()
     self.assertEqual(_allelerange.beginEnd, [])
Beispiel #20
0
 def test_AlleleRange_getMinimum(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     self.assertEqual(_allelerange.getMaximum(), 20)
Beispiel #21
0
 def test_AlleleRange_iter(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     self.assertIsInstance(iter(_allelerange), Iterable)
Beispiel #22
0
 def test_AlleleList_clear(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     _allelelist.clear()
     self.assertEqual(_allelelist.options, [])
Beispiel #23
0
 def test_AlleleRange_real(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     self.assertEqual(_allelerange.getReal(), False)
     _allelerange.setReal(flag=True)
     self.assertEqual(_allelerange.getReal(), True)
Beispiel #24
0
 def test_AlleleList_add(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     _allelelist.add(4)
     self.assertEqual(_allelelist.options, [1, 2, 3, 4])
Beispiel #25
0
 def test_AlleleRange_len(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     _allelerange.add(30, 40)
     self.assertEqual(len(_allelerange), 2)
Beispiel #26
0
 def test_AlleleRange_repr(self):
     _allelerange = GAllele.GAlleleRange(10, 20)
     self.assertIsInstance(repr(_allelerange), str)
Beispiel #27
0
 def test_AlleleList_iter(self):
     _allelelist = GAllele.GAlleleList(options=[1, 2, 3])
     self.assertIsInstance(iter(_allelelist), Iterable)