Added graph store and read functionality

This commit is contained in:
Bugra Onal 2022-08-30 09:15:35 -07:00
parent d3753556c1
commit 05ab45f39b
4 changed files with 46 additions and 0 deletions

View File

@ -1,6 +1,7 @@
import copy
from collections import defaultdict
import debug
import json
class timing_graph():
@ -139,6 +140,35 @@ class timing_graph():
return [self.edge_mods[(path[i], path[i+1])] for i in range(len(path)-1)]
def write(self, filename):
"""
Export graph to a JSON file
"""
# TODO: Find a proper way to store edge_mods values
with open(filename, 'w') as f:
f.write(
json.dumps(
{
'graph':
{key: list(val) for key, val in self.graph.items()},
'edge_mods':
{
', '.join(key): str(value)
for key, value in self.edge_mods.items()
}
}
)
)
def read(self, filename):
"""
Read graph from JSON file
"""
with open(filename, 'r') as f:
d = json.loads(f.read())
self.graph = {key: set(value) for key, value in d['graph'].items()}
self.edge_mods = {tuple(key.split(', ')): value for key, value in d['edge_mods'].items()}
def __str__(self):
""" override print function output """

View File

@ -56,6 +56,9 @@ s.setup_multiport_constants()
OPTS.netlist_only = True
OPTS.check_lvsdrc = False
# TODO: remove this after adding trimmed netlist gen to sram run
OPTS.trim_netlist = False
# Characterize the design
start_time = datetime.datetime.now()
from characterizer import lib

View File

@ -9,6 +9,7 @@ import datetime
import os
import debug
from characterizer import functional
from base import timing_graph
from globals import OPTS, print_time
import shutil
@ -187,3 +188,13 @@ class sram():
debug.print_raw("Extended Config: Writing to {0}".format(oname))
self.extended_config_write(oname)
print_time("Extended Config", datetime.datetime.now(), start_time)
# Write the graph if specified
if OPTS.write_graph:
start_time = datetime.datetime.now()
oname = OPTS.output_path + OPTS.output_name + "_graph.json"
debug.print_raw("Graph: Writing to {0}".format(oname))
graph = timing_graph()
self.s.build_graph(graph, self.name, self.s.pins)
graph.write(oname)
print_time("Graph", datetime.datetime.now(), start_time)

View File

@ -119,6 +119,8 @@ class options(optparse.Values):
# Determines which analytical model to use.
# Available Models: elmore, linear_regression
model_name = "elmore"
# Write graph to a file
write_graph = False
###################
# Tool options