⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vddgndm3.java

📁 The ElectricTM VLSI Design System is an open-source Electronic Design Automation (EDA) system that c
💻 JAVA
字号:
package com.sun.electric.tool.generator.flag.designs.Infinity2;import java.awt.geom.Rectangle2D;import java.util.Set;import java.util.TreeSet;import com.sun.electric.database.hierarchy.Cell;import com.sun.electric.database.hierarchy.Library;import com.sun.electric.database.text.CellName;import com.sun.electric.database.topology.PortInst;import com.sun.electric.tool.generator.layout.LayoutLib;import com.sun.electric.tool.generator.layout.TechType;public class VddGndM3 {	private final double DEF_SIZE = LayoutLib.DEF_SIZE;	private final double vddGndWidth = 23;		Set<Integer> xCoords = new TreeSet<Integer>();	VddGndM3() {		// lets do one side.		for (int i=0; i<28; i++) {			xCoords.add((i*144)+72);		}		for (int i=0; i<6; i++) {			// avoid m3 obstacles			// These first two coincide with scan busses			if (i==0) continue;			if (i==1) continue;			// These two might be an accidental collisions			if (i==2) continue;			if (i==3) continue;			xCoords.add((-i*144)-72);		}	}	public Cell makeVddGndM3Cell(Cell layCell, TechType tech) {		Library layLib = layCell.getLibrary();		CellName nm = layCell.getCellName();		String m3Nm = nm.getName()+"_m3{lay}";		Cell m3Cell = Cell.newInstance(layLib, m3Nm);		Rectangle2D bounds = layCell.findEssentialBounds();		double minX = bounds.getMinX();		double minY = bounds.getMinY();		double maxX = bounds.getMaxX();		double maxY = bounds.getMaxY();		LayoutLib.newNodeInst(tech.essentialBounds(), minX, minY, 				              DEF_SIZE, DEF_SIZE, 0, m3Cell);		LayoutLib.newNodeInst(tech.essentialBounds(), maxX, maxY, 				              DEF_SIZE, DEF_SIZE, 180, m3Cell);		for (Integer x : xCoords) {			PortInst p1 = LayoutLib.newNodeInst(tech.m3pin(), x, minY, 					DEF_SIZE, DEF_SIZE, 180, m3Cell).getOnlyPortInst();			PortInst p2 = LayoutLib.newNodeInst(tech.m3pin(), x, maxY, 					DEF_SIZE, DEF_SIZE, 180, m3Cell).getOnlyPortInst();			LayoutLib.newArcInst(tech.m3(), vddGndWidth, p1, p2);		}						return m3Cell;	}	}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -