Commit 65cf9f34 by sakundu

Merge branch 'main' of github.com:TILOS-AI-Institute/MacroPlacement into flow_scripts

parents c462529e 8cd04019
...@@ -25,6 +25,18 @@ python -m Plc_client.plc_client_os_test --netlist ./Plc_client/test/ariane/netli ...@@ -25,6 +25,18 @@ python -m Plc_client.plc_client_os_test --netlist ./Plc_client/test/ariane/netli
--smooth 2 --smooth 2
``` ```
You may uncomment any available tests and even run your own test dataset. We do not handle all corner cases since during RL placement, they are unlikely to occur. Our aim here is to reproduce Google's code as much as possible and be able to plug into Circuit Training Flow.
## How to run our code in Circuit Training?
Once you have downloaded Google's Circuit Training code, replace the environment.py with environment_ct.py (**you do need to change the name of the file**). Then, copy `plc_client_os.py` under the same directory (**you should not replace it with `plc_client.py` and should not change the name of the file**).
Since Force Directed Placer for the soft macros is not implemented yet, our code is essentially running Google's `plc_client.py` in parallel with our `plc_client_os.py` but extracting input from our code only except for soft macro positions. The memory usage will double and the runtime tends to be longer. However, with this "more open sourced" version of Circuit Training, we do see comparable training quality as using Google's API.
If you wish to find any discrepancies between these outputs, toggle `DEBUG` to `True` [here](https://github.com/TILOS-AI-Institute/MacroPlacement/blob/e634766f6aa53510c3fe8062896a6020f7ff18d1/CodeElements/Plc_client/environment_ct.py#L42) at the beginning of `environment_ct.py`. This will save all discrepancies into the corresponding folders.
## Implementation Details
For complete information on how the proxy cost is computed in our code, please refer to [Proxy Cost Documentation](https://tilos-ai-institute.github.io/MacroPlacement/Docs/ProxyCost/). Below is a quick overview of the formulation.
## HPWL Computation ## HPWL Computation
Given a net $i$, its wirelength can be computed as the following: Given a net $i$, its wirelength can be computed as the following:
...@@ -85,11 +97,8 @@ $$ ...@@ -85,11 +97,8 @@ $$
Notice a smoothing range can be set for congestion. This is only applied to congestion due to net routing which by counting adjacent cells and adding the averaged congestion to these adjacent cells. More details are provided in the document above. Notice a smoothing range can be set for congestion. This is only applied to congestion due to net routing which by counting adjacent cells and adding the averaged congestion to these adjacent cells. More details are provided in the document above.
## Placement Util ## DISCLAIMER
**Disclaimer: We DO NOT own the content of placement_util_os.py. All rights belong to Google Authors. This is a modified version of placement_util.py and we are including in the repo for the sake of testing. Original Code can be viewed [here](https://github.com/google-research/circuit_training/blob/main/circuit_training/environment/placement_util.py)**. **We DO NOT own the original content of placement_util_os.py, observation_extractor_os.py, environment_os.py, environment_ct.py, coordinate_descent_placer.py. All rights belong to Google Authors. These are modified version of the original code and we are including in the repo for the sake of testing. Original Code can be viewed [here](https://github.com/google-research/circuit_training/blob/main/circuit_training/environment/placement_util.py)**.
## Observation Extractor
**Disclaimer: We DO NOT own the content of observation_extractor_os.py. All rights belong to Google Authors. This is a modified version of observation_extractor.py and we are including in the repo for the sake of testing. Original Code can be viewed [here](https://github.com/google-research/circuit_training/blob/main/circuit_training/environment/observation_extractor.py)**.
...@@ -203,15 +203,12 @@ class ObservationExtractor(object): ...@@ -203,15 +203,12 @@ class ObservationExtractor(object):
def _get_clustered_port_locations( def _get_clustered_port_locations(
self, grid_cell_index: int) -> Tuple[float, float]: self, grid_cell_index: int) -> Tuple[float, float]:
"""Returns clustered port locations. """Returns clustered port locations.
This function returns an approximation location of the ports in a grid This function returns an approximation location of the ports in a grid
cell. Depending on the cell location in the canvas, the approximation cell. Depending on the cell location in the canvas, the approximation
differs. differs.
Args: Args:
grid_cell_index: The index of the grid cell where the cluster port is grid_cell_index: The index of the grid cell where the cluster port is
located. located.
Returns: Returns:
A tuple of float: Approximate x, y location of the port cluster in the A tuple of float: Approximate x, y location of the port cluster in the
grid cell in the same unit as canvas width and height (micron). grid cell in the same unit as canvas width and height (micron).
......
...@@ -13,7 +13,6 @@ ...@@ -13,7 +13,6 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
"""A collection of non-prod utility functions for placement. """A collection of non-prod utility functions for placement.
All the dependencies in this files should be non-prod. All the dependencies in this files should be non-prod.
""" """
...@@ -80,11 +79,9 @@ def restore_macro_orientations(plc: plc_client.PlacementCost, ...@@ -80,11 +79,9 @@ def restore_macro_orientations(plc: plc_client.PlacementCost,
def extract_attribute_from_comments(attribute: str, def extract_attribute_from_comments(attribute: str,
filenames: List[str]) -> Optional[str]: filenames: List[str]) -> Optional[str]:
"""Parses the files' comments section, tries to extract the attribute. """Parses the files' comments section, tries to extract the attribute.
Args: Args:
attribute: attribute to look for (case sensetive). attribute: attribute to look for (case sensetive).
filenames: List of protobuf file or a plc file. filenames: List of protobuf file or a plc file.
Returns: Returns:
Attribute name string, or None if not found. Attribute name string, or None if not found.
""" """
...@@ -134,10 +131,8 @@ def get_blockages_from_comments( ...@@ -134,10 +131,8 @@ def get_blockages_from_comments(
def extract_sizes_from_comments( def extract_sizes_from_comments(
filenames: List[str]) -> Optional[Tuple[float, float, int, int]]: filenames: List[str]) -> Optional[Tuple[float, float, int, int]]:
"""Parses the file's comments section, tries to extract canvas/grid sizes. """Parses the file's comments section, tries to extract canvas/grid sizes.
Args: Args:
filenames: A list of netlist (.pb.txt) or placement (.plc) files. filenames: A list of netlist (.pb.txt) or placement (.plc) files.
Returns: Returns:
Tuple of canvas_width, canvas_height, grid_cols, grid_rows Tuple of canvas_width, canvas_height, grid_cols, grid_rows
""" """
...@@ -174,7 +169,6 @@ def extract_sizes_from_comments( ...@@ -174,7 +169,6 @@ def extract_sizes_from_comments(
# done # done
def fix_port_coordinates(plc: plc_client.PlacementCost) -> None: def fix_port_coordinates(plc: plc_client.PlacementCost) -> None:
"""Find all ports and fix their coordinates. """Find all ports and fix their coordinates.
Args: Args:
plc: the placement cost object. plc: the placement cost object.
""" """
...@@ -204,7 +198,6 @@ def create_placement_cost( ...@@ -204,7 +198,6 @@ def create_placement_cost(
macro_vertical_routing_allocation: float = 51.79, macro_vertical_routing_allocation: float = 51.79,
) -> plc_client.PlacementCost: ) -> plc_client.PlacementCost:
"""Creates a placement_cost object. """Creates a placement_cost object.
Args: Args:
netlist_file: Path to the netlist proto text file. netlist_file: Path to the netlist proto text file.
init_placement: Path to the inital placement .plc file. init_placement: Path to the inital placement .plc file.
...@@ -218,7 +211,6 @@ def create_placement_cost( ...@@ -218,7 +211,6 @@ def create_placement_cost(
vertical_routes_per_micron: Vertical route capacity per micros. vertical_routes_per_micron: Vertical route capacity per micros.
macro_horizontal_routing_allocation: Macro horizontal routing allocation. macro_horizontal_routing_allocation: Macro horizontal routing allocation.
macro_vertical_routing_allocation: Macro vertical routing allocation. macro_vertical_routing_allocation: Macro vertical routing allocation.
Returns: Returns:
A PlacementCost object. A PlacementCost object.
""" """
...@@ -272,10 +264,8 @@ def create_placement_cost( ...@@ -272,10 +264,8 @@ def create_placement_cost(
def get_node_type_counts(plc: plc_client.PlacementCost) -> Dict[str, int]: def get_node_type_counts(plc: plc_client.PlacementCost) -> Dict[str, int]:
"""Returns number of each type of nodes in the netlist. """Returns number of each type of nodes in the netlist.
Args: Args:
plc: the placement cost object. plc: the placement cost object.
Returns: Returns:
Number of each type of node in a dict. Number of each type of node in a dict.
""" """
...@@ -391,7 +381,6 @@ def fd_placement_schedule(plc: plc_client.PlacementCost, ...@@ -391,7 +381,6 @@ def fd_placement_schedule(plc: plc_client.PlacementCost,
use_current_loc: bool = False, use_current_loc: bool = False,
move_macros: bool = False) -> None: move_macros: bool = False) -> None:
"""A placement schedule that uses force directed method. """A placement schedule that uses force directed method.
Args: Args:
plc: The plc object. plc: The plc object.
num_steps: Number of steps of the force-directed algorithm during each call. num_steps: Number of steps of the force-directed algorithm during each call.
...@@ -425,12 +414,10 @@ def get_ordered_node_indices(mode: str, ...@@ -425,12 +414,10 @@ def get_ordered_node_indices(mode: str,
plc: plc_client.PlacementCost, plc: plc_client.PlacementCost,
exclude_fixed_nodes: bool = True) -> List[int]: exclude_fixed_nodes: bool = True) -> List[int]:
"""Returns an ordering of node indices according to the specified mode. """Returns an ordering of node indices according to the specified mode.
Args: Args:
mode: node ordering mode mode: node ordering mode
plc: placement cost object plc: placement cost object
exclude_fixed_nodes: Whether fixed nodes should be excluded. exclude_fixed_nodes: Whether fixed nodes should be excluded.
Returns: Returns:
Node indices sorted according to the mode. Node indices sorted according to the mode.
""" """
...@@ -465,10 +452,8 @@ def get_ordered_node_indices(mode: str, ...@@ -465,10 +452,8 @@ def get_ordered_node_indices(mode: str,
def extract_parameters_from_comments( def extract_parameters_from_comments(
filename: str) -> Tuple[float, float, int, int]: filename: str) -> Tuple[float, float, int, int]:
"""Parses the file's comments section, tries to extract canvas/grid sizes. """Parses the file's comments section, tries to extract canvas/grid sizes.
Args: Args:
filename: protobuf file or a plc file. filename: protobuf file or a plc file.
Returns: Returns:
Tuple of canvas_width, canvas_height, grid_cols, grid_rows Tuple of canvas_width, canvas_height, grid_cols, grid_rows
""" """
...@@ -503,9 +488,7 @@ def extract_parameters_from_comments( ...@@ -503,9 +488,7 @@ def extract_parameters_from_comments(
# done # done
def get_routing_resources() -> Dict[str, float]: def get_routing_resources() -> Dict[str, float]:
"""Currently we only use default parameter settings. """Currently we only use default parameter settings.
In the future, for specific project, the resources may need to be tuned. In the future, for specific project, the resources may need to be tuned.
Returns: Returns:
Routing resources. Routing resources.
""" """
...@@ -703,7 +686,6 @@ def save_placement_with_info(plc: plc_client.PlacementCost, ...@@ -703,7 +686,6 @@ def save_placement_with_info(plc: plc_client.PlacementCost,
Routes used by macros, hor : {hor_macro_alloc:.3f} ver : {ver_macro_alloc:.3f} Routes used by macros, hor : {hor_macro_alloc:.3f} ver : {ver_macro_alloc:.3f}
Smoothing factor : {smooth} Smoothing factor : {smooth}
Use incremental cost : {incr_cost} Use incremental cost : {incr_cost}
To view this file (most options are default): To view this file (most options are default):
viewer_binary\ viewer_binary\
--netlist_file {src_filename}\ --netlist_file {src_filename}\
...@@ -907,12 +889,10 @@ def grid_locations_near(plc: plc_client.PlacementCost, ...@@ -907,12 +889,10 @@ def grid_locations_near(plc: plc_client.PlacementCost,
def place_near(plc: plc_client.PlacementCost, node_index: int, def place_near(plc: plc_client.PlacementCost, node_index: int,
location: int) -> bool: location: int) -> bool:
"""Places a node (legally) closest to the given location. """Places a node (legally) closest to the given location.
Args: Args:
plc: placement_cost object. plc: placement_cost object.
node_index: index of a node. node_index: index of a node.
location: target grid cell location. (row * num_cols + num_cols) location: target grid cell location. (row * num_cols + num_cols)
Returns: Returns:
True on success, False if this node was not placed on any grid legally. True on success, False if this node was not placed on any grid legally.
""" """
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment