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()