mirror of https://github.com/KLayout/klayout.git
64 lines
1.8 KiB
Plaintext
64 lines
1.8 KiB
Plaintext
|
|
source $drc_test_source
|
|
target $drc_test_target
|
|
|
|
if $drc_test_deep
|
|
deep
|
|
threads(0) # easier to debug
|
|
end
|
|
|
|
l1 = input(1, 0)
|
|
l2 = input(2, 0)
|
|
l3 = input(3, 0)
|
|
|
|
l1.output(1, 0)
|
|
l2.output(2, 0)
|
|
l3.output(3, 0)
|
|
|
|
# predicates and logical operations
|
|
|
|
l1.drc(rectangles).output(100, 0)
|
|
l1.drc(primary.rectangles).output(101, 0)
|
|
l2.drc(secondary(l1).rectangles).output(102, 0)
|
|
l1.drc(squares).output(103, 0)
|
|
l1.drc(primary.squares).output(104, 0)
|
|
l2.drc(secondary(l1).squares).output(105, 0)
|
|
|
|
l1.drc(rectilinear).output(110, 0)
|
|
l1.drc(primary.rectilinear).output(111, 0)
|
|
l2.drc(secondary(l1).rectilinear).output(112, 0)
|
|
|
|
l1.drc(area > 3.0).output(120, 0)
|
|
l1.drc(area >= 3.0).output(121, 0)
|
|
l1.drc(3.0 <= area < 4.0).output(122, 0)
|
|
|
|
l1.drc(perimeter > 7.0).output(130, 0)
|
|
l1.drc(perimeter >= 7.0).output(131, 0)
|
|
l1.drc(7.0 <= perimeter < 8.0).output(132, 0)
|
|
|
|
l1.drc(! rectilinear).output(140, 0)
|
|
l1.drc(! rectangles).output(141, 0)
|
|
|
|
l1.drc(if_all(! rectangles, area < 8.0)).output(150, 0)
|
|
l1.drc(if_any(rectangles, area >= 8.0)).output(151, 0)
|
|
|
|
l1.drc(if_any(corners.count > 4)).output(160, 0)
|
|
l1.drc(if_any(corners.count == 4)).output(161, 0)
|
|
|
|
l1.drc(switch(! rectangles, primary.sized(100.nm))).output(170, 0)
|
|
l1.drc(switch(! rectangles, primary.sized(100.nm), primary.sized(200.nm))).output(171, 0)
|
|
|
|
error = ""
|
|
begin
|
|
l1.drc(switch(! rectangles, primary.sized(100.nm), squares, primary.sized(200.nm).edges))
|
|
rescue => ex
|
|
error = ex.to_s
|
|
end
|
|
if error != "'drc': All result arguments of 'switch' need to render the same type (got 'Region,Edges')"
|
|
raise "switch did not give the right error when having different types. Was:\n" + error
|
|
end
|
|
|
|
l1.drc(switch(! rectangles, primary.sized(100.nm), squares, primary.sized(200.nm))).output(172, 0)
|
|
l1.drc(switch(! rectangles, primary.sized(100.nm), squares, primary.sized(200.nm), primary)).output(173, 0)
|
|
|