diff options
author | sanine-a <sanine.not@pm.me> | 2023-08-01 17:03:28 -0500 |
---|---|---|
committer | sanine-a <sanine.not@pm.me> | 2023-08-01 17:03:28 -0500 |
commit | 6aae1f6fb4cf289ecf5ed318b34c0e7df62bbf83 (patch) | |
tree | 85fb52a6be571758d45f25137f08ecf04dbe91fe /src/genome/genome.test.js | |
parent | 1dec9525213de7b8c23bf3393b2b76a46e27f6c7 (diff) |
add mutation_type and mutate()
Diffstat (limited to 'src/genome/genome.test.js')
-rw-r--r-- | src/genome/genome.test.js | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/genome/genome.test.js b/src/genome/genome.test.js new file mode 100644 index 0000000..853d103 --- /dev/null +++ b/src/genome/genome.test.js @@ -0,0 +1,20 @@ +'use strict';
+
+import { mutation_type, mutate } from './genome';
+
+
+test('basic gene mutations', () => {
+ expect(mutate([0, 1, 2], mutation_type.none, 0)).toEqual([0, 1, 2]);
+
+ expect(mutate([0, 1, 2], mutation_type.source, 0.2)).toEqual([0, 1, 2]);
+ expect(mutate([1, 1, 2], mutation_type.source, 0.2)).toEqual([0, 1, 2]);
+ expect(mutate([0, 1, 2], mutation_type.source, 0.8)).toEqual([1, 1, 2]);
+
+ expect(mutate([0, 1, 2], mutation_type.sink, 0.2)).toEqual([0, 0, 2]);
+ expect(mutate([0, 1, 2], mutation_type.sink, 0.8)).toEqual([0, 2, 2]);
+ expect(mutate([0, 0, 2], mutation_type.sink, 0.2)).toEqual([0, 0, 2]);
+
+ expect(mutate([0, 1, 2], mutation_type.weight, 0.5)).toEqual([0, 1, 0]);
+ expect(mutate([0, 1, 2], mutation_type.weight, 0.0)).toEqual([0, 1, -4]);
+ expect(mutate([0, 1, 2], mutation_type.weight, 1.0)).toEqual([0, 1, 4]);
+});
|