route_taper

photonforge.parametric.route_taper(*, terminal1=None, terminal2=None, layer=None, offset_distance=None, use_box=None, technology=None, name=None)[source]

Create a taper connecting 2 terminals.

Parameters:
  • terminal1 (Annotated[Terminal | tuple[Reference, str] | tuple[Reference, str, int], _Metadata(type=Terminal, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – First terminal to be connected. The terminal can be specified as a photonforge.Terminal or as a tuple including a photonforge.Reference, the terminal name, and the repetition index (optional, only for array references).

  • terminal2 (Annotated[Terminal | tuple[Reference, str] | tuple[Reference, str, int], _Metadata(type=Terminal, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – Second terminal to be connected.

  • layer (Annotated[str | tuple[int, int], _Metadata(type=Layer, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – Layer used for the connection. If None, the routing layer of the first terminal is used.

  • offset_distance (Annotated[Annotated[float, _Metadata(type=None, title=None, description=None, units=μm, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | Annotated[Sequence[Annotated[float, _Metadata(type=None, title=None, description=None, units=μm, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)]], _Metadata(type=None, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=2, max_items=2)], _Metadata(type=None, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – Offset applied to the terminal structure before creating the envelope taper. If None, defaults to 0.

  • use_box (Annotated[bool, _Metadata(type=None, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – Flag indicating whether to use the bounding box of the terminal structures or the structures themselves. If None, defaults to True.

  • technology (Annotated[Technology, _Metadata(type=None, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – Component technology. If None, the default technology is used.

  • name (Annotated[str, _Metadata(type=None, title=None, description=None, units=None, required=False, minimum=None, maximum=None, exclusive_minimum=None, exclusive_maximum=None, min_items=None, max_items=None)] | None) – Component name.

Returns:

Component with the route.

terminal1 = pf.Terminal("METAL", pf.Rectangle((50, 50)))
terminal2 = pf.Terminal("METAL", pf.Rectangle(center=(100, -20), size=(15, 15)))
component = route_taper(terminal1=terminal1, terminal2=terminal2)
route_taper