gdsfactory.Component

gdsfactory.Component#

class gdsfactory.Component(name: str | None = None, kcl: KCLayout | None = None, kdb_cell: kdb.Cell | None = None, ports: kf.Ports | None = None)[source]#

Canvas where you add polygons, instances and ports.

  • stores settings that you use to build the component

  • stores info that you want to use

  • can return ports by type (optical, electrical …)

  • can return netlist for circuit simulation

  • can write to GDS, OASIS

  • can show in KLayout, matplotlib or 3D

Properties:

info: dictionary that includes derived properties, simulation_settings, settings (test_protocol, docs, …)

__init__(name: str | None = None, kcl: KCLayout | None = None, kdb_cell: Cell | None = None, ports: Ports | None = None) None[source]#

Initializes a Component.

Methods

__init__([name, kcl, kdb_cell, ports])

Initializes a Component.

absorb(reference)

Absorbs polygons from ComponentReference into Component.

add(instances)

add_array(component[, columns, rows, ...])

Creates a ComponentReference reference to a Component.

add_label([text, position, layer])

Adds Label to the Component.

add_polygon()

Adds a Polygon to the Component and returns a klayout Shape.

add_port([name, port, center, width, ...])

Adds a Port to the Component.

add_ports(ports[, prefix, suffix, keep_mirror])

Add a sequence of ports to the cell.

add_ref(component[, name, columns, rows, ...])

Adds a component instance reference to a Component.

add_route_info(cross_section, length[, ...])

Adds route information to a component.

area(layer)

Returns the area of the Component in um2.

auto_rename_ports([rename_func])

Rename the ports with the schema angle -> "NSWE" and sort by x and y.

bbox_np()

Returns the bounding box of the Component as a numpy array.

cell_index()

Gets the cell index.

circuit(l2n[, port_types])

Create the circuit of the KCell in the given netlist.

connectivity_check([port_types, layers, db, ...])

Create a ReportDatabase for port problems.

construct([_fields_set])

convert_to_static([recursive])

Convert the KCell to a static cell if it is pdk KCell.

copy()

Copy the full cell.

copy_child_info(component)

Copy and settings info from child component into parent.

copy_layers(layer_map[, recursive])

Remaps a list of layers and returns the same Component.

create_inst(cell[, trans, a, b, na, nb, ...])

Add an instance of another KCell.

create_port(**kwargs)

Proxy for [Ports.create_port][kfactory.kcell.Ports.create_port].

create_vinst(cell)

Insert the KCell as a VInstance into a VKCell or KCell.

delete()

Delete the cell.

dict(*[, include, exclude, by_alias, ...])

draw_ports()

Draw all the ports on their respective layer.

dup()

Copy the full cell.

each_inst()

Iterates over all child instances (which may actually be instance arrays).

each_overlapping_inst(b)

Gets the instances overlapping the given rectangle.

each_touching_inst(b)

Gets the instances overlapping the given rectangle.

evaluate_insts()

Check all KLayout instances and create kfactory Instances.

extract(layers[, recursive])

Extracts a list of layers and adds them to a new Component.

flatten([merge])

Flatten the cell.

from_kcell(kcell)

Returns a Component from a KCell.

from_orm(obj)

from_yaml(constructor, node[, verbose])

Internal function used by the placer to convert yaml to a KCell.

get_boxes(layer[, recursive])

Returns a list of boxes.

get_labels(layer[, recursive])

Returns a list of labels from the Component.

get_meta_data([meta_format])

Read metadata from the KLayout Layout object.

get_netlist([recursive])

Returns a place-aware netlist for circuit simulation.

get_paths(layer[, recursive])

Returns a list of paths.

get_polygons([merge, by, layers])

Returns a dict of Polygons per layer.

get_polygons_points([merge, scale, by, layers])

Returns a dict with list of points per layer.

get_ports_list(**kwargs)

Returns list of ports.

hash()

Provide a unique hash of the cell.

insert(inst[, property_id])

Inserts a cell instance given by another reference.

insert_vinsts([recursive])

Insert all virtual instances and create Instances of real KCells.

json(*[, include, exclude, by_alias, ...])

l2n([port_types])

Generate a LayoutToNetlist object from the port types.

layer(*args, **kwargs)

Get the layer info, convenience for klayout.db.Layout.layer.

model_construct([_fields_set])

Creates a new instance of the Model class with validated data.

model_copy(*[, update, deep])

Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#model_copy

model_dump(*[, mode, include, exclude, ...])

Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#modelmodel_dump

model_dump_json(*[, indent, include, ...])

Usage docs: https://docs.pydantic.dev/2.10/concepts/serialization/#modelmodel_dump_json

model_json_schema([by_alias, ref_template, ...])

Generates a JSON schema for a model class.

model_parametrized_name(params)

Compute the class name for parametrizations of generic classes.

model_post_init(context, /)

We need to both initialize private attributes and call the user-defined model_post_init method.

model_rebuild(*[, force, raise_errors, ...])

Try to rebuild the pydantic-core schema for the model.

model_validate(obj, *[, strict, ...])

Validate a pydantic model instance.

model_validate_json(json_data, *[, strict, ...])

Usage docs: https://docs.pydantic.dev/2.10/concepts/json/#json-parsing

model_validate_strings(obj, *[, strict, context])

Validate the given object with string data against the Pydantic model.

offset(layer, distance)

Offsets a Component layer by a distance in um.

over_under(layer[, distance])

Returns a Component over-under on a layer in the Component.

parse_file(path, *[, content_type, ...])

parse_obj(obj)

parse_raw(b, *[, content_type, encoding, ...])

plot([show_labels, show_ruler, return_fig])

Plots the Component using klayout.

plot_netlist([recursive, with_labels, ...])

Plots a netlist graph with networkx.

plot_netlist_graphviz([recursive, ...])

Plots a netlist graph with graphviz.

pprint_ports(**kwargs)

Pretty prints ports.

read(filename[, options, register_cells, ...])

Read a GDS file into the existing KCell.

rebuild()

Rebuild the instances of the KCell.

ref(*args, **kwargs)

Returns a Component Instance.

remap_layers(layer_map[, recursive])

Remaps a list of layers and returns the same Component.

remove_layers(layers[, recursive])

Removes a list of layers and returns the same Component.

schema([by_alias, ref_template])

schema_json(*[, by_alias, ref_template])

set_meta_data()

Set metadata of the Cell.

show([lyrdb, l2n, keep_position, ...])

Stream the gds to klive.

to_3d([layer_views, layer_stack, exclude_layers])

Return Component 3D trimesh Scene.

to_dict([with_ports])

Returns a dictionary representation of the Component.

to_graphviz([recursive])

Returns a netlist graph with graphviz.

to_yaml(representer, node)

Internal function to convert the cell to yaml.

transform(inst_or_trans[, trans, no_warn, ...])

Transforms the instance or cell with the transformation given.

trim(left, bottom, right, top[, flatten])

Trims the Component to a bounding box.

update_forward_refs(**localns)

validate(value)

write(filename[, save_options, ...])

Write a KCell to a GDS.

write_gds([gdspath, gdsdir, save_options, ...])

Write component to GDS and returns gdspath.

write_netlist(netlist[, filepath])

Returns netlist as YAML string.

Attributes

center

Returns the coordinate center of the bounding box.

dcenter

Coordinate of the port in um.

dx

X coordinate of the port in um.

dxmax

Returns the x-coordinate of the left edge of the bounding box.

dxmin

Returns the x-coordinate of the left edge of the bounding box.

dxsize

Returns the width of the bounding box.

dy

Y coordinate of the port in um.

dymax

Returns the x-coordinate of the left edge of the bounding box.

dymin

Returns the x-coordinate of the left edge of the bounding box.

dysize

Returns the height of the bounding box.

factory_name

Return the name under which the factory was registered.

ghost_cell

Returns a value indicating whether the cell is a "ghost cell".

layers

model_computed_fields

model_config

Configuration for the model, should be a dictionary conforming to [ConfigDict][pydantic.config.ConfigDict].

model_extra

Get extra fields set during validation.

model_fields

model_fields_set

Returns the set of fields that have been explicitly set on this model instance.

name

Name of the KCell.

named_references

Returns a dictionary of named references.

ports

Ports associated with the cell.

prop_id

Gets the properties ID associated with the cell.

references

Returns a list of references.

settings

Settings dictionary set by the [@vcell][kfactory.kcell.vcell] decorator.

settings_units

Dictionary containing the units of the settings.

x

Returns the x-coordinate of the center of the bounding box.

xmax

Returns the x-coordinate of the left edge of the bounding box.

xmin

Returns the x-coordinate of the left edge of the bounding box.

xsize

Returns the x-coordinate of the left edge of the bounding box.

y

Returns the y-coordinate of the center of the bounding box.

yaml_tag

ymax

Returns the x-coordinate of the left edge of the bounding box.

ymin

Returns the x-coordinate of the left edge of the bounding box.

ysize

Returns the x-coordinate of the left edge of the bounding box.

routes

boundary

insts

size_info

dsize_info

vinsts

info

kcl

function_name

basename