Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
macroplacement
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
macroplacement
Commits
5c5e93f5
Commit
5c5e93f5
authored
Aug 23, 2022
by
Dinple
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
congestion update
parent
a279985c
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
98 additions
and
49 deletions
+98
-49
CodeElements/Plc_client/plc_client_os.py
+60
-17
CodeElements/Plc_client/plc_client_os_test.py
+38
-32
No files found.
CodeElements/Plc_client/plc_client_os.py
View file @
5c5e93f5
...
...
@@ -513,28 +513,29 @@ class PlacementCost(object):
return
float
(
sum_cong
/
cong_cnt
)
def
get_congestion_cost
(
self
):
return
max
(
self
.
get_H_congestion_cost
(),
self
.
get_V_congestion_cost
())
# temp_cong = [sum(x) for x in zip(self.V_routing_cong, self.H_routing_cong)]
#
return max(self.get_H_congestion_cost(), self.get_V_congestion_cost())
temp_cong
=
self
.
V_routing_cong
+
self
.
H_routing_cong
#
occupied_cells = sorted([gc for gc in temp_cong if gc != 0.0], reverse=True)
#
cong_cost = 0.0
occupied_cells
=
sorted
([
gc
for
gc
in
temp_cong
if
gc
!=
0.0
],
reverse
=
True
)
cong_cost
=
0.0
# # take top 10%
# cong_cnt = math.floor(len(temp_cong) * 0.1)
# take top 5%
cong_cnt
=
math
.
floor
(
len
(
temp_cong
)
*
0.05
)
if
cong_cnt
==
0
:
cong_cnt
=
1
#
# if grid cell smaller than 10
, take the average over occupied cells
# if len(temp_cong) < 10
:
#
cong_cost = float(sum(occupied_cells) / len(occupied_cells))
#
return cong_cost
#
if grid cell smaller than 5
, take the average over occupied cells
if
len
(
temp_cong
)
<
5
:
cong_cost
=
float
(
sum
(
occupied_cells
)
/
len
(
occupied_cells
))
return
cong_cost
#
idx = 0
#
sum_cong = 0
#
#
take top 10%
#
while idx < cong_cnt and idx < len(occupied_cells):
#
sum_cong += occupied_cells[idx]
#
idx += 1
idx
=
0
sum_cong
=
0
# take top 10%
while
idx
<
cong_cnt
and
idx
<
len
(
occupied_cells
):
sum_cong
+=
occupied_cells
[
idx
]
idx
+=
1
#
return float(sum_cong / cong_cnt)
return
float
(
sum_cong
/
cong_cnt
)
def
__get_grid_cell_location
(
self
,
x_pos
,
y_pos
):
"""
...
...
@@ -802,12 +803,18 @@ class PlacementCost(object):
for
col_idx
in
range
(
col_min
,
col_max
,
1
):
col
=
col_idx
row
=
source_gcell
[
0
]
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
H_routing_cong
):
continue
self
.
H_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing
for
row_idx
in
range
(
row_min
,
row_max
,
1
):
row
=
row_idx
col
=
sink_gcell
[
1
]
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
def
__three_pin_net_routing
(
self
,
node_gcells
,
weight
):
...
...
@@ -824,24 +831,36 @@ class PlacementCost(object):
for
col_idx
in
range
(
temp_gcell_first_col
,
temp_gcell_second_col
,
1
):
col
=
col_idx
row
=
temp_gcell_first_row
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
H_routing_cong
):
continue
self
.
H_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# H routing (x2, y2) to (x3-1, y2)
for
col_idx
in
range
(
temp_gcell_second_col
,
temp_gcell_third_col
,
1
):
col
=
col_idx
row
=
temp_gcell_second_row
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
H_routing_cong
):
continue
self
.
H_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing (x2,min(y1,y2)) to (x2, max(y1,y2)-1)
for
row_idx
in
range
(
min
(
temp_gcell_first_row
,
temp_gcell_second_row
),
max
(
temp_gcell_first_row
,
temp_gcell_second_row
),
1
):
row
=
row_idx
col
=
temp_gcell_second_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing (x3,min(y2,y3)) to (x3, max(y2,y3)-1)
for
row_idx
in
range
(
min
(
temp_gcell_second_row
,
temp_gcell_third_row
),
max
(
temp_gcell_second_row
,
temp_gcell_third_row
),
1
):
row
=
row_idx
col
=
temp_gcell_third_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
elif
temp_gcell_first_row
==
temp_gcell_third_row
:
...
...
@@ -849,12 +868,18 @@ class PlacementCost(object):
for
col_idx
in
range
(
temp_gcell_first_col
,
temp_gcell_third_col
,
1
):
col
=
col_idx
row
=
temp_gcell_first_row
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
H_routing_cong
):
continue
self
.
H_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing from (x2, min(y1,y2)) to (x2, max(y1,y2)-1)
for
row_idx
in
range
(
min
(
temp_gcell_first_row
,
temp_gcell_second_row
),
max
(
temp_gcell_first_row
,
temp_gcell_second_row
),
1
):
row
=
row_idx
col
=
temp_gcell_second_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
elif
temp_gcell_first_row
>
temp_gcell_third_row
and
temp_gcell_third_row
>
temp_gcell_second_row
:
...
...
@@ -862,18 +887,27 @@ class PlacementCost(object):
for
col_idx
in
range
(
temp_gcell_first_col
,
temp_gcell_third_col
,
1
):
col
=
col_idx
row
=
temp_gcell_third_row
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
H_routing_cong
):
continue
self
.
H_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing from (x1,y3) to (x1,y1-1)
for
row_idx
in
range
(
temp_gcell_third_row
,
temp_gcell_first_row
,
1
):
row
=
row_idx
col
=
temp_gcell_first_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing from (x2, min(y2,y3)) to (x2, max(y2,y3)-1)
for
row_idx
in
range
(
min
(
temp_gcell_second_row
,
temp_gcell_third_row
),
max
(
temp_gcell_second_row
,
temp_gcell_third_row
),
1
):
row
=
row_idx
col
=
temp_gcell_second_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
elif
temp_gcell_third_row
>
temp_gcell_first_row
and
temp_gcell_first_row
>
temp_gcell_second_row
:
...
...
@@ -881,18 +915,27 @@ class PlacementCost(object):
for
col_idx
in
range
(
temp_gcell_first_row
,
temp_gcell_third_col
,
1
):
col
=
col_idx
row
=
temp_gcell_third_row
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
H_routing_cong
):
continue
self
.
H_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing from (x1,y3) to (x1,y1-1)
for
row_idx
in
range
(
temp_gcell_third_col
,
temp_gcell_first_col
,
1
):
row
=
row_idx
col
=
temp_gcell_first_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
# V routing from (x2, min(y2,y3)) to (x2, max(y2,y3)-1)
for
row_idx
in
range
(
min
(
temp_gcell_second_row
,
temp_gcell_third_row
),
max
(
temp_gcell_second_row
,
temp_gcell_third_row
),
1
):
row
=
row_idx
col
=
temp_gcell_second_col
# ignore OOB
if
row
*
self
.
grid_col
+
col
>
len
(
self
.
V_routing_cong
):
continue
self
.
V_routing_cong
[
row
*
self
.
grid_col
+
col
]
+=
weight
def
__macro_route_over_grid_cell
(
self
,
mod_x
,
mod_y
,
mod_w
,
mod_h
):
...
...
CodeElements/Plc_client/plc_client_os_test.py
View file @
5c5e93f5
...
...
@@ -11,44 +11,47 @@ FLAGS = flags.FLAGS
class
CircuitDataBaseTest
():
# NETLIST_PATH = "./Plc_client/test/sample_clustered_uniform_two_soft/netlist.pb.txt"
NETLIST_PATH
=
"./Plc_client/test/ariane_hard2soft/netlist.pb.txt"
#
NETLIST_PATH = "./Plc_client/test/ariane_hard2soft/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/ariane_soft2hard/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/ariane_port2soft/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/sample_clustered_nomacro/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/sample_clustered_macroxy/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/ariane/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/ariane133/netlist.pb.txt"
#
NETLIST_PATH = "./Plc_client/test/testcases/TC1_MP1_0_0_P2_0_1.pb.txt"
NETLIST_PATH
=
"./Plc_client/test/testcases/TC1_MP1_0_0_P2_0_1.pb.txt"
# NETLIST_PATH = "./Plc_client/test/testcases/TC24_MP1_0_0_MP2_4_4.pb.txt"
# NETLIST_PATH = "./Plc_client/test/0P1M1m/netlist.pb.txt"
NETLIST_PATH
=
"./Plc_client/test/0P2M0m/netlist.pb.txt"
#
NETLIST_PATH = "./Plc_client/test/0P2M0m/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/0P3M0m/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/0P4M0m/netlist.pb.txt"
# NETLIST_PATH = "./Plc_client/test/testcases_xm/TC_MP1_4_1_MP2_2_2_MP3_3_4_MP4_0_0.pb.txt"
# Google's Ariane
#
CANVAS_WIDTH = 356.592
#
CANVAS_HEIGHT = 356.640
#
GRID_COL = 35
#
GRID_ROW = 33
CANVAS_WIDTH
=
356.592
CANVAS_HEIGHT
=
356.640
GRID_COL
=
35
GRID_ROW
=
33
# Ariane133
# CANVAS_WIDTH = 1
430.723
# CANVAS_HEIGHT = 1
430.723
# CANVAS_WIDTH = 1
599.99
# CANVAS_HEIGHT = 1
600.06
# GRID_COL = 24
# GRID_ROW = 21
# Sample clustered
CANVAS_WIDTH
=
400
CANVAS_HEIGHT
=
400
GRID_COL
=
4
GRID_ROW
=
4
#
CANVAS_WIDTH = 400
#
CANVAS_HEIGHT = 400
#
GRID_COL = 4
#
GRID_ROW = 4
# PMm
# CANVAS_WIDTH = 100
# CANVAS_HEIGHT = 100
# GRID_COL = 5
# GRID_ROW = 5
CANVAS_WIDTH
=
100
CANVAS_HEIGHT
=
100
GRID_COL
=
3
GRID_ROW
=
3
def
__init__
(
self
,
NETLIST_PATH
)
->
None
:
self
.
NETLIST_PATH
=
NETLIST_PATH
def
test_proxy_congestion
(
self
):
# Google's Binary Executable
...
...
@@ -62,24 +65,26 @@ class CircuitDataBaseTest():
self
.
plc
.
set_macro_routing_allocation
(
10
,
10
)
self
.
plc_os
.
set_macro_routing_allocation
(
10
,
10
)
self
.
plc
.
set_congestion_smooth_range
(
1
.0
)
self
.
plc_os
.
set_congestion_smooth_range
(
1
.0
)
self
.
plc
.
set_congestion_smooth_range
(
2
.0
)
self
.
plc_os
.
set_congestion_smooth_range
(
2
.0
)
self
.
plc
.
set_canvas_size
(
self
.
CANVAS_WIDTH
,
self
.
CANVAS_HEIGHT
)
self
.
plc
.
set_placement_grid
(
self
.
GRID_COL
,
self
.
GRID_ROW
)
self
.
plc_os
.
set_canvas_size
(
self
.
CANVAS_WIDTH
,
self
.
CANVAS_HEIGHT
)
self
.
plc_os
.
set_placement_grid
(
self
.
GRID_COL
,
self
.
GRID_ROW
)
print
(
"Name: "
,
self
.
plc
.
get_source_filename
()
.
rsplit
(
"/"
,
1
)[
1
])
self
.
plc_os
.
display_canvas
()
start
=
time
.
time
()
#
start = time.time()
temp_gl_h
=
self
.
plc
.
get_horizontal_routing_congestion
()
temp_os_h
=
self
.
plc_os
.
get_horizontal_routing_congestion
()
# print(np.array(temp_gl_h).reshape(self.GRID_COL, self.GRID_ROW))
# print(np.array(temp_os_h).reshape(self.GRID_COL, self.GRID_ROW))
#
print("GL H Congestion: ", temp_gl_h)
#
print("OS H Congestion: ", temp_os_h)
print
(
"GL H Congestion: "
,
temp_gl_h
)
print
(
"OS H Congestion: "
,
temp_os_h
)
temp_gl_v
=
self
.
plc
.
get_vertical_routing_congestion
()
temp_os_v
=
self
.
plc_os
.
get_vertical_routing_congestion
()
...
...
@@ -87,17 +92,17 @@ class CircuitDataBaseTest():
# print(np.array(temp_gl_v).reshape(self.GRID_COL, self.GRID_ROW))
# print(np.array(temp_os_v).reshape(self.GRID_COL, self.GRID_ROW))
# print("GL V Congestion: ", self.plc.get_vertical_routing_congestion())
# print("OS V Congestion: ", self.plc_os.get_vertical_routing_congestion())
# print("Congestion: ", self.plc.get_congestion_cost())
end
=
time
.
time
()
print
(
"time elapsed:"
,
end
-
start
)
print
(
"GL V Congestion: "
,
self
.
plc
.
get_vertical_routing_congestion
())
print
(
"OS V Congestion: "
,
self
.
plc_os
.
get_vertical_routing_congestion
())
# end = time.time()
# print("time elapsed:", end - start)
for
idx
in
range
(
len
(
temp_gl_h
)):
print
(
"gl, os:"
,
temp_gl_h
[
idx
],
temp_os_h
[
idx
],
temp_gl_v
[
idx
],
temp_os_v
[
idx
])
#
for idx in range(len(temp_gl_h)):
#
print("gl, os:", temp_gl_h[idx], temp_os_h[idx], temp_gl_v[idx], temp_os_v[idx])
print
(
"congestion summation gl os"
,
sum
(
temp_gl_h
),
sum
(
temp_os_h
),
sum
(
temp_gl_v
),
sum
(
temp_os_v
))
print
(
"congestion gl, os"
,
self
.
plc
.
get_congestion_cost
(),
self
.
plc_os
.
get_congestion_cost
())
# print("congestion summation gl os", sum(temp_gl_h), sum(temp_os_h), sum(temp_gl_v), sum(temp_os_v))
print
(
"congestion GL: "
,
self
.
plc
.
get_congestion_cost
())
print
(
"congestion OS: "
,
self
.
plc_os
.
get_congestion_cost
())
def
test_proxy_cost
(
self
):
# Google's Binary Executable
...
...
@@ -215,7 +220,8 @@ class CircuitDataBaseTest():
def
main
(
argv
):
temp
=
CircuitDataBaseTest
()
args
=
sys
.
argv
[
1
:]
temp
=
CircuitDataBaseTest
(
args
[
0
])
temp
.
test_proxy_congestion
()
# temp.test_proxy_cost()
# temp.test_metadata()
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment