graph.GraphModule
- class graph.GraphModule(input_nodes: SetList[GraphNode], output_nodes: SetList[GraphNode], name: str, computational_module: Any)[source]
 Bases:
GraphModuleBaseDescribe a module of computation in a graph
GraphModuleacts as a base class for all modules of computation that exist in a computational graph in Rockpool. It minimally holds a set of input nodesinput_nodesand output nodesoutput_nodesthat it is connected to, and which are then connected onward to otherGraphModules in the graph.You should subclass
GraphModuleto make graph modules that define some specific computation. e.g. a set of weights; a set of spiking neurons with some characteristics. Specific subclasses ofGraphModulecan be converted between each other as part of the device mapping process. e.g. a set of generic LIF neurons can be converted to a HW specific graph module that defines the configuration of some neurons on a device.Specific subclasses of
GraphModuleshould ideally be “units” of computation, as in the examples above. The exception isGraphHolder, which is deigned to encapsulate entire graphs or subgraphs.See also
For an overview of computational graphs in Rockpool, see Computational graphs in Rockpool.
Attributes overview
The input nodes attached to this module
The output nodes attached to this module
An arbitrary name attached to this specific
GraphModuleThe computational module that acts as the source for this graph module
Methods overview
__init__(input_nodes, output_nodes, name, ...)add_input(node)Add a
GraphNodeas an input source to this module, and connect itadd_output(node)Add a
GraphNodeas an output of this module, and connect itRemove all
GraphNodes as inputs of this moduleRemove all
GraphNodes as outputs of this moduleremove_input(node)Remove a
GraphNodeas an input of this module, and disconnect itremove_output(node)Remove a
GraphNodeas an output of this module, and disconnect it- __init__(input_nodes: SetList[GraphNode], output_nodes: SetList[GraphNode], name: str, computational_module: Any) None
 
- classmethod _convert_from(mod: GraphModuleBase) GraphModuleBase[source]
 Convert another
GraphModuleto aGraphModuleof this specific subclassYou should override this method in your subclass, to include conversion rules from other graph module classes to your specific subclass.
If you do not provide conversion rules to your specific subclass then it will not be possible to map other
GraphModulesubclasses to your subclass.- Parameters:
 mod (GraphModule) – A
GraphModuleorGraphModulesubclass object to convert to an object of the specific subclass.- Returns:
 A converted
GraphModulesubclass object, of the specific subclass on which this method was called.- Return type:
 
- classmethod _factory(size_in: int, size_out: int, name: str | None = None, computational_module: Any | None = None, *args, **kwargs) GraphModuleBase
 Build a new
GraphModuleorGraphModulesubclass, with new input and outputGraphNodes created automaticallyUse this factory method to construct a new
GraphModulefrom scratch, which needs new input and outputGraphNodes created automatically. This helper method will be inherited by newGraphModulesubclasses, and will act as factory methods also for your customGraphModulesubclass.- Parameters:
 size_in (int) – The number of input
GraphNodes to create and attachsize_out (int) – The number of output
GraphNodes to create and attachname (str, optional) – An arbitrary name to attach to this
GraphModule, defaults to Nonecomputational_module (Optional[Module], optional) – A rockpool computational module that forms the “generator” of this graph module, defaults to None
- Returns:
 The newly constructed
GraphModuleorGraphModulesubclass- Return type:
 
- add_input(node: GraphNode) None[source]
 Add a
GraphNodeas an input source to this module, and connect itThe new node will be appended after the last current input node. The node will be connected with this
GraphModuleas a sink.- Parameters:
 node (GraphNode) – The node to add as an input source
- add_output(node: GraphNode) None[source]
 Add a
GraphNodeas an output of this module, and connect itThe new node will be appended after the last current output node. The node will be connected with this
GraphModuleas a source.- Parameters:
 node (GraphNode) – The node to add as an output
- computational_module: Any
 The computational module that acts as the source for this graph module
- Type:
 
- name: str
 An arbitrary name attached to this specific
GraphModule- Type:
 str
- remove_input(node: GraphNode) None[source]
 Remove a
GraphNodeas an input of this module, and disconnect itThe node will be disconnected from this
GraphModuleas a sink, and will be removed from the module.- Parameters:
 node (GraphNode) – The node to remove. If this node exists as an input to the module, it will be removed.
- remove_output(node: GraphNode) None[source]
 Remove a
GraphNodeas an output of this module, and disconnect itThe node will be disconnected from this
GraphModuleas a source, and will be removed from the module.- Parameters:
 node (GraphNode) – The node to remove. If this node exists as an output to the module, it will be removed.