From b78b042f3c9b3fc2799163d843b54670461e1bf0 Mon Sep 17 00:00:00 2001 From: Sijia Wang Date: Thu, 15 Apr 2021 12:44:33 -0400 Subject: [PATCH] update project.py when only node changes are made #123 --- lasso/project.py | 78 ++++++++++++++++++++++++++---------------------- 1 file changed, 43 insertions(+), 35 deletions(-) diff --git a/lasso/project.py b/lasso/project.py index 40c8f46..36aa0f3 100644 --- a/lasso/project.py +++ b/lasso/project.py @@ -809,11 +809,48 @@ def _consolidate_actions(log, base, key_list): log_df["OPERATION_final"] = log_df.apply(lambda x: _final_op(x), axis=1) return log_df[changeable_col + ["OPERATION_final"]] + delete_link_dict = None + add_link_dict = None + change_link_dict_list = [] + if len(link_changes_df) != 0: link_changes_df = _consolidate_actions( link_changes_df, self.base_roadway_network.links_df, ["A", "B"] ) + # process deletions + delete_link_dict = _process_deletions(link_changes_df) + + # process additions + add_link_dict = _process_link_additions( + link_changes_df, limit_variables_to_existing_network + ) + + # process changes + WranglerLogger.debug("Processing changes") + WranglerLogger.debug(link_changes_df) + changeable_col = list( + ( + set(link_changes_df.columns) + & set(self.base_roadway_network.links_df.columns) + ) + - set(Project.STATIC_VALUES) + ) + + cols_in_changes_not_in_net = list( + set(link_changes_df.columns) + - set(self.base_roadway_network.links_df.columns) + ) + + if cols_in_changes_not_in_net: + WranglerLogger.warning( + "The following attributes are specified in the changes but do not exist in the base network: {}".format( + cols_in_changes_not_in_net + ) + ) + + change_link_dict_list = _process_link_changes(link_changes_df, changeable_col) + if len(node_changes_df) != 0: node_changes_df = _consolidate_actions( node_changes_df, self.base_roadway_network.nodes_df, ["model_node_id"] @@ -828,43 +865,14 @@ def _consolidate_actions(log, base, key_list): WranglerLogger.error(msg) raise ValueError(msg) node_add_df = node_changes_df[node_changes_df.OPERATION_final == "A"] - else: - node_add_df = pd.DataFrame() - - # process deletions - delete_link_dict = _process_deletions(link_changes_df) - - # process additions - add_link_dict = _process_link_additions( - link_changes_df, limit_variables_to_existing_network - ) - if len(_process_node_additions(node_add_df)): - add_link_dict["nodes"] = _process_node_additions(node_add_df) - - # process changes - WranglerLogger.debug("Processing changes") - WranglerLogger.debug(link_changes_df) - changeable_col = list( - ( - set(link_changes_df.columns) - & set(self.base_roadway_network.links_df.columns) - ) - - set(Project.STATIC_VALUES) - ) - cols_in_changes_not_in_net = list( - set(link_changes_df.columns) - - set(self.base_roadway_network.links_df.columns) - ) - - if cols_in_changes_not_in_net: - WranglerLogger.warning( - "The following attributes are specified in the changes but do not exist in the base network: {}".format( - cols_in_changes_not_in_net - ) - ) + if add_link_dict: + add_link_dict["nodes"] = _process_node_additions(node_add_df) + else: + add_link_dict = {"category": "Add New Roadway", "nodes": _process_node_additions(node_add_df)} - change_link_dict_list = _process_link_changes(link_changes_df, changeable_col) + else: + None # combine together