Sequential delay analysis by placement engines
First Claim
1. A method of designing an integrated circuit (IC), the IC design expressed as a graph comprising a plurality of edges and a plurality of nodes representing a plurality of IC components, each edge connecting two nodes without encompassing a third node, the method comprising:
- defining a cost function that has a component for each edge that is based on (i) a spatial relationship comprising a difference in horizontal and vertical coordinates of the two nodes of the edge and (ii) a temporal relationship comprising a difference between event times of the two nodes of the edge;
optimizing, by a computer, the IC design by changing at least one of an event time and a coordinate of a node and modifying the IC design to satisfy a set of constraints on each component of the cost function such that, for each edge, a difference between the event times of the nodes connected by the edge is not less than a signal propagation delay caused by the spatial relationship between the two nodes connected by the edge; and
placing the IC components based on the optimized IC design.
3 Assignments
0 Petitions
Accused Products
Abstract
Some embodiments provide a method of designing an integrated circuit (IC). The design is expressed as a graph that includes several nodes that represent several IC components. The nodes include a first set of nodes that represent a set of clocked elements. The method creates a second set of nodes by removing all nodes in the first set from the nodes that represent the IC components. The method identifies a set of edges that connect two nodes in the second set without encompassing a third node in the second set. The method assigns an event time to each node in the second set. The method assigns a cost function based on the event times of the nodes connected by each edge and the number of nodes in the first set encompassed by each edge. The method optimizes the cost function and places the components based on the cost function optimization.
-
Citations
28 Claims
-
1. A method of designing an integrated circuit (IC), the IC design expressed as a graph comprising a plurality of edges and a plurality of nodes representing a plurality of IC components, each edge connecting two nodes without encompassing a third node, the method comprising:
-
defining a cost function that has a component for each edge that is based on (i) a spatial relationship comprising a difference in horizontal and vertical coordinates of the two nodes of the edge and (ii) a temporal relationship comprising a difference between event times of the two nodes of the edge; optimizing, by a computer, the IC design by changing at least one of an event time and a coordinate of a node and modifying the IC design to satisfy a set of constraints on each component of the cost function such that, for each edge, a difference between the event times of the nodes connected by the edge is not less than a signal propagation delay caused by the spatial relationship between the two nodes connected by the edge; and placing the IC components based on the optimized IC design. - View Dependent Claims (2, 3, 4)
-
-
5. A method of designing an integrated circuit (IC), wherein the IC design is expressed as a graph comprising a plurality of edges and a plurality of nodes representing a plurality of IC components, each edge connecting two nodes without encompassing a third node, the method comprising:
-
assigning an event time to each node in the graph, each event time associated with availability of a signal at a corresponding node; defining a cost function that has a cost expression for each edge that is based on the event times of the nodes connected by the edge and a spatial distance between the nodes connected by the edge, wherein the spatial distance is based on horizontal and vertical coordinates of the two nodes of the edge; identifying, by a computer, a placement solution for the IC components by changing at least one of an event time and a coordinate of a node in the cost function and modifying the IC design to satisfy a set of constraints on each component of the cost function such that, for each edge, a difference between the event times of the nodes connected by the edge is not less than a signal propagation delay caused by the spatial relationship between the two nodes connected by the edge; and placing the IC components based on the identified placement solution. - View Dependent Claims (6, 7, 8)
-
-
9. A method of designing an integrated circuit (IC), wherein the IC design is expressed as a graph comprising a plurality of nodes representing a plurality of IC components, the plurality of nodes comprising a first set of nodes representing a set of clocked elements, the method comprising:
-
identifying a second set of nodes that comprises nodes in the plurality of nodes that are not in the first set of nodes, the second set of nodes not comprising any node from the first set of nodes; identifying a set of edges, each identified edge connecting two nodes in the second set of nodes while encompassing at least one node from the first set of nodes; assigning an event time to each node in the second set of nodes; defining a cost function that has a component for each edge that is based on (i) the event times of the two nodes connected by the edge, (ii) a spatial distance based on a difference in horizontal and vertical coordinates of the two nodes connected by the edge, and (iii) a number of nodes in the first set encompassed by the edge; optimizing, by a computer, the IC design; and placing the IC components based on the optimized IC design by modifying the IC design to satisfy a set of constraints on each component of the cost function such that, for each edge, a difference between the event times of the nodes connected by the edge is not less than a signal propagation delay caused by the spatial relationship between the two nodes connected by the edge. - View Dependent Claims (10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20)
-
-
21. A non-transitory computer readable medium storing a computer program for designing an integrated circuit (IC), the IC design expressed as a graph comprising a plurality of edges and a plurality of nodes representing a plurality of IC components, each edge connecting two nodes without encompassing a third node, the computer program for execution by at least one processor, the computer program comprising sets of instructions for:
-
defining a cost function that has a cost expression for each edge that is based on (i) a spatial relationship comprising a difference in horizontal and vertical coordinates of the two nodes of the edge and (ii) a temporal relationship comprising a difference between event times of the two nodes of the edge; optimizing the IC design based by changing at least one of an event time and a coordinate of a node and modifying the IC design to satisfy a set of constraints on each component of the cost function such that, for each edge, a difference between the event times of the nodes connected by the edge is not less than a signal propagation delay caused by the spatial relationship between the two nodes connected by the edge; and placing the IC components based on the optimized IC design. - View Dependent Claims (22, 23, 24)
-
-
25. A method of designing an integrated circuit (“
- IC”
), wherein the IC design is expressed as a graph comprising a plurality of edges and a plurality of nodes representing a plurality of IC components, each edge connecting two nodes without encompassing a third node, the method comprising;defining a cost function that has a component for each edge that is based on (i) signal temporal values for the two nodes of the edge, and (ii) a spatial relationship comprising a difference between coordinates of the two nodes of the edge; by a computer, iteratively examining different placement solutions by changing at least one of a signal temporal value and a coordinate of a node and modifying the IC design to satisfy a set of constraints on each component of the cost function such that, for each edge, a difference between the temporal values of the nodes connected by the edge is not less than a signal propagation delay caused by the spatial relationship between the two nodes connected by the edge; and placing the IC components based on an optimal placement solution according to the cost function. - View Dependent Claims (26, 27, 28)
- IC”
Specification