2019-02-23 15:20:48 +00:00
|
|
|
"""
|
|
|
|
Copyright 2019 Richard Feistenauer
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import abc
|
2019-02-23 16:37:18 +00:00
|
|
|
|
|
|
|
from . import neighborhood
|
2018-12-01 14:14:22 +00:00
|
|
|
|
|
|
|
|
2018-12-01 19:37:18 +00:00
|
|
|
class Rule:
|
2019-02-24 11:37:26 +00:00
|
|
|
""" Base class for evolution rules.
|
|
|
|
This class has to be inherited if the cellular automaton is supposed to have any effect.
|
|
|
|
"""
|
|
|
|
|
2019-02-23 16:37:18 +00:00
|
|
|
def __init__(self, neighborhood_: neighborhood.Neighborhood):
|
2019-02-23 15:20:48 +00:00
|
|
|
self._neighborhood = neighborhood_
|
2018-12-01 19:37:18 +00:00
|
|
|
|
2019-02-23 15:20:48 +00:00
|
|
|
def _get_neighbor_by_relative_coordinate(self, neighbours, rel_coordinate):
|
2019-02-24 11:37:26 +00:00
|
|
|
return neighbours[self._neighborhood.get_id_of_neighbor_from_relative_coordinate(rel_coordinate)]
|
2019-02-23 15:20:48 +00:00
|
|
|
|
|
|
|
@abc.abstractmethod
|
|
|
|
def evolve_cell(self, last_cell_state, neighbors_last_states):
|
2018-12-02 16:45:08 +00:00
|
|
|
""" Calculates and sets new state of 'cell'.
|
2019-02-24 11:37:26 +00:00
|
|
|
A cells evolution will only be called if it or at least one of its neighbors has changed last evolution_step.
|
|
|
|
:param last_cell_state: The cells state previous to the evolution step.
|
|
|
|
:param neighbors_last_states: The cells neighbors current states.
|
|
|
|
:return: New state. The state after this evolution step
|
2018-12-02 16:45:08 +00:00
|
|
|
"""
|
2019-02-17 10:11:27 +00:00
|
|
|
return last_cell_state
|
2019-02-23 15:20:48 +00:00
|
|
|
|
|
|
|
@abc.abstractmethod
|
|
|
|
def init_state(self, cell_coordinate):
|
2019-02-24 11:37:26 +00:00
|
|
|
""" Will be called to initialize a cells state.
|
2019-02-23 15:20:48 +00:00
|
|
|
:param cell_coordinate: Cells coordinate.
|
2019-02-24 11:37:26 +00:00
|
|
|
:return: Iterable that represents the initial cell state
|
|
|
|
Has to be compatible with 'multiprocessing.sharedctype.RawArray' when using multi processing.
|
2019-02-23 15:20:48 +00:00
|
|
|
"""
|
|
|
|
return [0]
|
|
|
|
|
|
|
|
@abc.abstractmethod
|
|
|
|
def get_state_draw_color(self, current_state):
|
2019-02-24 11:37:26 +00:00
|
|
|
""" Return the draw color for the current state """
|
2019-02-23 15:20:48 +00:00
|
|
|
return [0, 0, 0]
|