Skip to content
Snippets Groups Projects
Commit 3f32dcde authored by Hugo Winbladh's avatar Hugo Winbladh Committed by Oscar Gustafsson
Browse files

Add a sink operation to avoid dangling nodes

parent ce58bd0e
No related branches found
No related tags found
1 merge request!425Add a sink operation to avoid dangling nodes
Pipeline #102906 passed
...@@ -73,7 +73,6 @@ class Constant(AbstractOperation): ...@@ -73,7 +73,6 @@ class Constant(AbstractOperation):
def __str__(self) -> str: def __str__(self) -> str:
return f"{self.value}" return f"{self.value}"
class Addition(AbstractOperation): class Addition(AbstractOperation):
""" """
Binary addition operation. Binary addition operation.
...@@ -1263,3 +1262,45 @@ class Shift(AbstractOperation): ...@@ -1263,3 +1262,45 @@ class Shift(AbstractOperation):
if not isinstance(value, int): if not isinstance(value, int):
raise TypeError("value must be an int") raise TypeError("value must be an int")
self.set_param("value", value) self.set_param("value", value)
class Sink(AbstractOperation):
r"""
Sink operation.
Used for ignoring the output from another operation to avoid dangling output nodes.
Parameters
==========
name : Name, optional
Operation name.
"""
_execution_time = 0
is_linear = True
def __init__(self, name: Name = ""):
"""Construct a Sink operation."""
super().__init__(
input_count=1,
output_count=0,
name=name,
latency_offsets={"in0": 0},
)
@classmethod
def type_name(cls) -> TypeName:
return TypeName("sink")
def evaluate(self):
raise NotImplementedError
@property
def latency(self) -> int:
return self.latency_offsets["in0"]
def __repr__(self) -> str:
return "Sink()"
def __str__(self) -> str:
return "sink"
...@@ -20,6 +20,8 @@ from b_asic import ( ...@@ -20,6 +20,8 @@ from b_asic import (
SquareRoot, SquareRoot,
Subtraction, Subtraction,
SymmetricTwoportAdaptor, SymmetricTwoportAdaptor,
Sink,
SFG,
) )
...@@ -404,3 +406,16 @@ class TestDepends: ...@@ -404,3 +406,16 @@ class TestDepends:
bfly1 = Butterfly() bfly1 = Butterfly()
assert set(bfly1.inputs_required_for_output(0)) == {0, 1} assert set(bfly1.inputs_required_for_output(0)) == {0, 1}
assert set(bfly1.inputs_required_for_output(1)) == {0, 1} assert set(bfly1.inputs_required_for_output(1)) == {0, 1}
class TestSink:
def test_create_sfg_with_sink(self):
bfly = Butterfly()
sfg = bfly.to_sfg()
s = Sink()
sfg1 = sfg.replace_operation(s, "out0")
sfg2 = SFG(sfg1.input_operations, sfg1.output_operations[1:])
assert sfg2.output_count == 1
assert sfg2.input_count == 2
assert sfg.evaluate_output(1, [0,1]) == sfg2.evaluate_output(0, [0,1])
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment