Пример #1
0
 def test_order(self):
     chain0 = Chain({(1,): {2: 1}, (2,): {1: 1}})
     chain1 = Chain({(1, 2): {2: 1}, (2, 3): {3: 1}, (3, 1): {1: 1}})
     chain2 = Chain({(1, 2, 1): {2: 1}, (2, 1, 2): {1: 1}})
     self.assertEqual(chain0.order, 1)
     self.assertEqual(chain1.order, 2)
     self.assertEqual(chain2.order, 3)
Пример #2
0
 def test_walk_deterministic1(self):
     chain = Chain({(1,): {2: 1}, (2,): {3: 1}, (3,): {None: 1}})
     chain.make_deterministic_map()
     test = list(chain.walk_deterministic_until((1,), 3))
     check = (1, 2, 3)
     for t, c in zip(test, check):
         self.assertEqual(t, c)
Пример #3
0
 def test_walk_deterministic2(self):
     chain = Chain({(1,): {2: 1}, (2,): {3: 1}, (3,): {None: 1}})
     chain.make_deterministic_map()
     test1 = list(chain.walk_deterministic_until((1,), 2))
     test2 = list(chain.walk_deterministic_until((3,), 2))
     check1 = (1, 2)
     check2 = (3, None)
     for t, c in zip(test1, check1):
         self.assertEqual(t, c)
     for t, c in zip(test2, check2):
         self.assertEqual(t, c)
Пример #4
0
    def _distribute_states_on_duration(
        start_state: State,
        states: typing.Iterable[State],
        markov_chain: yamm.Chain,
        lookup: Lookup,
        duration: numbers.Number,
    ) -> typing.Tuple[typing.Tuple[float]]:
        generator = markov_chain.walk_deterministic((start_state, ))

        state_names = tuple(state.name for state in states)

        summed_duration = 0
        last_state = None

        active_states = []
        while summed_duration < duration:
            next_state_name = next(generator)
            actual_state = lookup(next_state_name)
            current_state = states[state_names.index(actual_state)]
            print(round(summed_duration, 3), current_state.name)
            sustain = current_state.duration_maker()
            if last_state is None:
                relative_attack = None
            else:
                relative_attack = (
                    last_state.transition_duration_maker() +
                    current_state.transition_duration_maker()) * 0.5

            sustain_start = (summed_duration + relative_attack
                             if relative_attack else summed_duration)
            sustain = (sustain_start, sustain_start + sustain)
            attack = summed_duration if relative_attack else None

            new_summed_duration = sustain[-1]
            if new_summed_duration > duration:
                active_states[0][1] = summed_duration
                active_states[-1][3] = duration
                break

            if last_state is not None:
                active_states[-1][3] = sustain_start
            active_states.append([current_state.name, attack, sustain, None])
            summed_duration = new_summed_duration
            last_state = current_state

        return tuple(tuple(state) for state in active_states)
Пример #5
0
 def test_distribute2(self):
     dic = {1: 9, 2: 6, 3: 3}
     gen = Chain.distribute(dic)
     test = [next(gen) for i in range(18)]
     check = [1, 2, 1, 3, 2, 1, 1, 2, 1, 3, 2, 1, 1, 2, 3, 1, 2, 1]
     self.assertEqual(test, check)
Пример #6
0
 def test_distribute1(self):
     dic = {1: 3, 2: 3, 3: 3}
     gen = Chain.distribute(dic)
     test = [next(gen) for i in range(9)]
     check = [1, 2, 3, 1, 2, 3, 1, 2, 3]
     self.assertEqual(test, check)
Пример #7
0
 def test_walk_until(self):
     chain = Chain({(1,): {1: 1, 2: 1}, (2,): {1: 1}})
     test = len(chain.walk_until((1,), 8))
     check = 8
     self.assertEqual(test, check)
Пример #8
0
 def test_walk(self):
     chain = Chain({(1,): {2: 1}, (2,): {3: 1}, (3,): {None: 1}})
     test = chain.walk((1,))
     check = (1, 2, 3)
     for t, c in zip(test, check):
         self.assertEqual(t, c)
Пример #9
0
 def test_step(self):
     chain = Chain({(1,): {1: 1, 2: 1}, (2,): {1: 1}})
     test = chain.step((2,))
     check = 1
     self.assertEqual(test, check)
Пример #10
0
 def test_merge(self):
     chain0 = Chain({(1,): {2: 1}, (2,): {1: 1}})
     chain1 = Chain({(1,): {2: 1}, (3,): {1: 1}})
     test = chain0.merge(chain1)
     check = Chain({(1,): {2: 2}, (2,): {1: 1}, (3,): {1: 1}})
     self.assertEqual(test, check)
Пример #11
0
 def test_from_data2(self):
     test = Chain.from_data([1, 2, 1, 1], 2)
     check = Chain({(1, 2): {1: 1}, (2, 1): {1: 1}, (1, 1): {None: 1}})
     self.assertEqual(test, check)
Пример #12
0
 def test_from_data1(self):
     test = Chain.from_data([1, 2, 1, 1])
     check = Chain({(1,): {1: 1, 2: 1, None: 1}, (2,): {1: 1}})
     self.assertEqual(test, check)
Пример #13
0
 def test_vary_delete(self):
     test = Chain({(1,): {1: 1}})
     test.vary_weight((1,), 1, -1)
     check = Chain({})
     self.assertEqual(test, check)
Пример #14
0
 def test_vary3(self):
     test = Chain({(1,): {1: 1}})
     test.vary_weight((1,), 2)
     check = Chain({(1,): {1: 1, 2: 1}})
     self.assertEqual(test, check)
Пример #15
0
 def test_equal(self):
     test = Chain({(1,): {1: 1, 2: 1}, (2,): {1: 1}})
     check = Chain({(2,): {1: 1}, (1,): {2: 1, 1: 1}})
     self.assertEqual(test, check)