Source code for tidy3d.components.tcad.data.monitor_data.heat
"""Monitor level data, store the DataArrays associated with a single heat-charge monitor."""
from __future__ import annotations
from typing import Optional, Union
from pydantic import Field
from tidy3d.components.data.data_array import (
ScalarFieldTimeDataArray,
SpatialDataArray,
)
from tidy3d.components.data.utils import TetrahedralGridDataset, TriangularGridDataset
from tidy3d.components.tcad.data.monitor_data.abstract import HeatChargeMonitorData
from tidy3d.components.tcad.monitors.heat import TemperatureMonitor
from tidy3d.components.types.base import discriminated_union
from tidy3d.constants import KELVIN
FieldDataset = Union[
discriminated_union(Union[TriangularGridDataset, TetrahedralGridDataset]),
SpatialDataArray,
ScalarFieldTimeDataArray,
SpatialDataArray,
]
UnstructuredFieldType = Union[TriangularGridDataset, TetrahedralGridDataset]
[docs]
class TemperatureData(HeatChargeMonitorData):
"""Data associated with a :class:`TemperatureMonitor`: spatial temperature field.
Example
-------
>>> from tidy3d import TemperatureMonitor, SpatialDataArray
>>> import numpy as np
>>> temp_data = SpatialDataArray(
... np.ones((2, 3, 4)), coords={"x": [0, 1], "y": [0, 1, 2], "z": [0, 1, 2, 3]}
... )
>>> temp_mnt = TemperatureMonitor(size=(1, 2, 3), name="temperature", unstructured=True)
>>> temp_mnt_data = TemperatureData(
... monitor=temp_mnt, temperature=temp_data, symmetry=(0, 1, 0), symmetry_center=(0, 0, 0)
... )
>>> temp_mnt_data_expanded = temp_mnt_data.symmetry_expanded_copy
"""
monitor: TemperatureMonitor = Field(
title="Monitor",
description="Temperature monitor associated with the data.",
)
temperature: Optional[FieldDataset] = Field(
None,
title="Temperature",
description="Spatial temperature field.",
json_schema_extra={"units": KELVIN},
)
@property
def field_components(self) -> dict[str, Optional[FieldDataset]]:
"""Maps the field components to their associated data."""
return {"temperature": self.temperature}