{
  "title": "MicrowaveSMatrixData",
  "public_path": "flex_rf.tidy3d.MicrowaveSMatrixData",
  "lookup_path": "tidy3d.rf.MicrowaveSMatrixData",
  "slug": "flex_rf/tidy3d/MicrowaveSMatrixData",
  "public_url": "/rf/latest/autogenerated/flex_rf/tidy3d/microwavesmatrixdata/",
  "object_kind": "class",
  "introduction": "Stores the computed S-matrix and reference impedances for the terminal ports.",
  "notes": "",
  "examples": "",
  "references": "",
  "signature": "class MicrowaveSMatrixData(MicrowaveBaseModel)",
  "source": {
    "path": "flex/public/tidy3d/tidy3d/plugins/smatrix/data/terminal.py",
    "url": "",
    "lineno": 44,
    "endlineno": 64
  },
  "bases": [
    "MicrowaveBaseModel"
  ],
  "parameter_rows": [
    {
      "name": "port_reference_impedances",
      "annotation": "TerminalPortDataArray | None",
      "default": "None",
      "description": "Reference impedance matrix for each port used in the S-parameter calculation. Has dimensions (f, port_out, port_in) to support coupled impedances from TerminalWavePort. For WavePort and LumpedPort, the impedance matrix is diagonal.",
      "origin": "declared"
    },
    {
      "name": "data",
      "annotation": "TerminalPortDataArray",
      "default": "",
      "description": "An array containing the computed S-matrix of the device. The data is organized by terminal ports, representing the scattering parameters between them.",
      "origin": "declared"
    },
    {
      "name": "s_param_def",
      "annotation": "SParamDef",
      "default": "'pseudo'",
      "description": "Wave definition: 'pseudo', 'power', or 'symmetric_pseudo'.",
      "origin": "declared"
    },
    {
      "name": "attrs",
      "annotation": "dict",
      "default": "factory: dict",
      "description": "Dictionary storing arbitrary metadata for a Tidy3D object. This dictionary can be freely used by the user for storing data without affecting the operation of Tidy3D as it is not used internally. Note that, unlike regular Tidy3D fields, `attrs` are mutable. For example, the following is allowed for setting an `attr` `obj.attrs['foo'] = bar`. Also note that Tidy3D will raise a `TypeError` if `attrs` contain objects that can not be serialized. One can check if `attrs` are serializable by calling `obj.model_dump_json()`.",
      "origin": "inherited"
    }
  ],
  "members": [],
  "group": "flex_rf.tidy3d"
}
