Source code for spinn_front_end_common.interface.splitter_selectors.splitter_selector
# 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.
import logging
from spinn_utilities.log import FormatAdapter
from pacman.data import PacmanDataView
from pacman.model.partitioner_splitters import (
SplitterOneAppOneMachine, SplitterFixedLegacy)
from pacman.model.graphs.application.abstract import (
AbstractOneAppOneMachineVertex)
from spinn_front_end_common.utility_models import ReverseIpTagMultiCastSource
logger = FormatAdapter(logging.getLogger(__name__))
[docs]def splitter_selector():
"""
Basic selector which puts the legacy splitter object on
everything without a splitter object.
"""
for app_vertex in PacmanDataView.iterate_vertices():
if app_vertex.splitter is None:
vertex_selector(app_vertex)
[docs]def vertex_selector(app_vertex):
"""
Main point for selecting a splitter object for a given app vertex.
Will assume the SplitterFixedLegacy if no heuristic is known for the
app vertex.
:param ~pacman.model.graphs.application.ApplicationVertex app_vertex:
app vertex to give a splitter object to
"""
if isinstance(app_vertex, AbstractOneAppOneMachineVertex):
app_vertex.splitter = SplitterOneAppOneMachine()
elif isinstance(app_vertex, ReverseIpTagMultiCastSource):
app_vertex.splitter = SplitterFixedLegacy()
else:
logger.warning(
f"The SplitterSelector has not seen the {app_vertex} vertex "
f"before. Therefore there is no known splitter to allocate to "
f"this app vertex and so will use the SplitterFixedLegacy.")
app_vertex.splitter = SplitterFixedLegacy()