Node

The node statement creates an artificial electrical attachment point.

The node statement is only valid from within a pcb-module context.

Signature


  ; Single Node Instance
  node <NAME>:<TYPE>
  ; Array Node Instance
  node <NAME>:<TYPE>[<ARRAY:Int|Tuple>]

  • &lt;NAME> - Symbol name for the node in this context. This name must be unique in the current context.
  • &lt;TYPE> - The type of port to construct. This can be the keyword pin for a single pin type or any declared pcb-bundle type.
  • &lt;ARRAY:Int|Tuple> - Optional array initializer argument. This value can be:
    • Int - PortArray type constructed with length ARRAY. This array is constructed as a contiguous zero-index array of nodes.
    • Tuple - PortArray constructed with an explicit set of indices. This array is not guaranteed to be contiguous.

Watch Out! - There is no space between &lt;TYPE> and the [ opening bracket of the array initializer.

Usage

The node is often a tool for creating intermediate connection points in a circuit. You will see this functionality used for:

  1. Fanout - Given a port on a component instance, a node array can fanout that signal to multiple connection points.
  2. Return Values - When writing generators using the inside pcb-module: syntax, it is often useful to be able to return a port-like object.

The utility of a node statement is often abstract and doesn't have a physical component associated with it.

Example - Reverse Differential Pair

defn reverse-pair (p:JITXObject) :
  inside pcb-module:
    node temp:diff-pair
    topo-net(p.P, temp.N)
    topo-net(p.N, temp.P)
    temp

This function assumes that the argument p is a diff-pair port. This generator function constructs a node and then swaps the P and N ports of the input diff-pair before assignment.

Notice that this function is using topo-net but that isn't a requirement. A simple net statement would also work if signal integrity constraints aren't required.