Recognizer.mesa
Last Edited by: Gbier, July 11, 1985 10:17:42 am PDT
Last Edited by: Gbier, July 26, 1985 1:30:18 pm PDT
DIRECTORY
CD,
CornerStitching;
Recognizer: CEDAR DEFINITIONS =
BEGIN
RegionList: TYPE = LIST OF REF CornerStitching.Region;
InstAndForbidLayerRec: TYPE = RECORD [
instance: CD.Instance,
forbidLayerList: LIST OF CD.Layer ← NIL --List of layers that cannot overlap the instance
];
InstAndForbidLayerList: TYPE = LIST OF REF InstAndForbidLayerRec;
PossibleInstanceProc: TYPE = PROC [active1, active2: CD.Layer, coveredList: RegionList,
possibleInstListPtr: REF InstAndForbidLayerList]; --Contains registered procedures that will guess possible instances
RecognizeObjects: PROC [design: CD.Design, cellOb: CD.Object];
--Recognizes instances inside cellOb only
RegisterPossibleInstanceProc: PROC [technology: CD.Technology, rectCount: INT, instProc: PossibleInstanceProc];
RegisterLayerList: PROC [technology: CD.Technology, active1, active2: CD.Layer, layerList: LIST OF CD.Layer];
-- layerlist should include 1) all forbidden layers 2) other layers generated by abstract
-- diffusion layers ie pwell or nwell 3) layers needed by an object that will be guessed, for
-- example: butting contacts are found by overlapping metal and cut and will also need planes
-- of metal, poly, diffusion, and well.
END.