Coverage for klayout_pex/rcx25/c/geometry_restorer.py: 92%
13 statements
« prev ^ index » next coverage.py v7.8.0, created at 2025-03-31 19:36 +0000
« prev ^ index » next coverage.py v7.8.0, created at 2025-03-31 19:36 +0000
1#! /usr/bin/env python3
2#
3# --------------------------------------------------------------------------------
4# SPDX-FileCopyrightText: 2024 Martin Jan Köhler and Harald Pretl
5# Johannes Kepler University, Institute for Integrated Circuits.
6#
7# This file is part of KPEX
8# (see https://github.com/martinjankoehler/klayout-pex).
9#
10# This program is free software: you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation, either version 3 of the License, or
13# (at your option) any later version.
14#
15# This program is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the GNU General Public License
21# along with this program. If not, see <http://www.gnu.org/licenses/>.
22# SPDX-License-Identifier: GPL-3.0-or-later
23# --------------------------------------------------------------------------------
24#
26import klayout.db as kdb
28from klayout_pex.rcx25.types import EdgeInterval
31class GeometryRestorer:
32 def __init__(self, transformation: kdb.IMatrix3d):
33 self.transformation = transformation
35 def restore_edge_interval(self, edge_interval: EdgeInterval) -> kdb.Edge:
36 return self.transformation * kdb.Edge(kdb.Point(edge_interval[0], 0),
37 kdb.Point(edge_interval[1], 0))
39 def restore_edge(self, edge: kdb.Edge) -> kdb.Edge:
40 return self.transformation * edge
42 def restore_polygon(self, polygon: kdb.Polygon) -> kdb.Polygon:
43 return self.transformation * polygon
45 def restore_region(self, region: kdb.Region) -> kdb.Region:
46 return region.transformed(self.transformation)