예제 #1
0
파일: genome.go 프로젝트: gitter-badger/lxy
func (m GAInvertMutator) Mutate(a ga.GAGenome) ga.GAGenome {
	n := a.Copy()
	p1 := rand.Intn(a.Len())
	p2 := rand.Intn(a.Len())
	if p1 > p2 {
		p1, p2 = p2, p1
	}

	n.Invert(p1, p2)

	return n
}
예제 #2
0
파일: genome.go 프로젝트: gitter-badger/lxy
func (m GAInvertMutator) Mutate(a ga.GAGenome) ga.GAGenome {
	n := a.Copy()
	p1 := rand.Intn(a.Len())
	p2 := rand.Intn(a.Len())
	if p1 > p2 {
		p1, p2 = p2, p1
	}

	n.Invert(p1, p2)

	/*
		// Until you reach the center
		for {
			if p1 >= p2{
				break
			}
			n.Switch(p1, p2)
			p1 += 1
			p2 -= 1
		}*/

	return n
}