Source code for spynnaker.pyNN.extra_algorithms.splitter_components.splitter_poisson_delegate

# Copyright (c) 2020 The University of Manchester
#
# 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
#
#     https://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.
from typing import List, Sequence, Tuple
from spinn_utilities.overrides import overrides
from pacman.model.graphs.machine import MachineVertex
from pacman.model.graphs.common import Slice
from pacman.model.resources import AbstractSDRAM
from pacman.model.partitioner_splitters import AbstractSplitterCommon
from pacman.exceptions import PacmanConfigurationException
from pacman.model.partitioner_splitters import SplitterFixedLegacy
from pacman.utilities.utility_objs import ChipCounter
from spynnaker.pyNN.models.spike_source import SpikeSourcePoissonVertex
from .abstract_supports_one_to_one_sdram_input import (
    AbstractSupportsOneToOneSDRAMInput)


class SplitterPoissonDelegate(SplitterFixedLegacy[SpikeSourcePoissonVertex]):
    """
    A splitter for Poisson sources that will ignore sources that are
    one-to-one connected to a single Population.
    """

    @property
    def send_over_sdram(self) -> bool:
        """
        Whether this vertex is to be sent using SDRAM.

        :rtype: bool
        """
        # If there is only one outgoing projection, and it is one-to-one
        # connected to the target, and the target knows what to do, leave
        # it to the target
        if len(self.governed_app_vertex.outgoing_projections) != 1:
            return False
        proj = self.governed_app_vertex.outgoing_projections[0]
        # pylint: disable=protected-access
        post_vertex = proj._projection_edge.post_vertex
        if not isinstance(post_vertex.splitter,
                          AbstractSupportsOneToOneSDRAMInput):
            return False
        return post_vertex.splitter.handles_source_vertex(proj)

[docs] @overrides(SplitterFixedLegacy.set_governed_app_vertex) def set_governed_app_vertex(self, app_vertex: SpikeSourcePoissonVertex): if not isinstance(app_vertex, SpikeSourcePoissonVertex): raise PacmanConfigurationException( f"The vertex {app_vertex} cannot be supported by the " "SplitterPoissonDelegate as the only vertex supported by this " "splitter is a SpikeSourcePoissonVertex. Please use the " "correct splitter for your vertex and try again.") super().set_governed_app_vertex(app_vertex)
[docs] @overrides(SplitterFixedLegacy.create_machine_vertices) def create_machine_vertices(self, chip_counter: ChipCounter): # If sending over SDRAM, let the target handle this if self.send_over_sdram: return # If we passed this part, use the super class super().create_machine_vertices(chip_counter)
[docs] @overrides(AbstractSplitterCommon.get_in_coming_slices) def get_in_coming_slices(self) -> List[Slice]: if self.send_over_sdram: proj = self.governed_app_vertex.outgoing_projections[0] # pylint: disable=protected-access post_vertex = proj._projection_edge.post_vertex return list(post_vertex.splitter.get_in_coming_slices()) return super().get_in_coming_slices()
[docs] @overrides(AbstractSplitterCommon.get_out_going_slices) def get_out_going_slices(self) -> List[Slice]: if self.send_over_sdram: proj = self.governed_app_vertex.outgoing_projections[0] # pylint: disable=protected-access post_vertex = proj._projection_edge.post_vertex return list(post_vertex.splitter.get_out_going_slices()) return super().get_out_going_slices()
[docs] @overrides(AbstractSplitterCommon.get_out_going_vertices) def get_out_going_vertices(self, partition_id: str) -> List[MachineVertex]: if self.send_over_sdram: return [] return super().get_out_going_vertices(partition_id)
[docs] @overrides(AbstractSplitterCommon.get_same_chip_groups) def get_same_chip_groups(self) -> Sequence[ Tuple[Sequence[MachineVertex], AbstractSDRAM]]: if self.send_over_sdram: return [] return super().get_same_chip_groups()