-
Notifications
You must be signed in to change notification settings - Fork 23
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Refactor footprint changes #167
Changes from 6 commits
32864c4
7e1aafa
ea1bf88
bc1850b
5c52344
e6d1433
835407e
4662360
ae5dbb5
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,6 +5,7 @@ | |
from collections import defaultdict | ||
from collections import OrderedDict | ||
import difflib | ||
import logging | ||
|
||
import emission.storage.timeseries.abstract_timeseries as esta | ||
import emission.storage.timeseries.tcquery as esttc | ||
|
@@ -59,6 +60,7 @@ async def add_base_mode_footprint(trip_list): | |
labels = await emcu.read_json_resource("label-options.default.json") | ||
value_to_basemode = {mode["value"]: mode.get("base_mode", mode.get("baseMode", "UNKNOWN")) for mode in labels["MODE"]} | ||
|
||
counter_trip_error = 0 | ||
for trip in trip_list: | ||
#format so emffc can get id for metadata | ||
trip['data']['_id'] = trip['_id'] | ||
|
@@ -75,13 +77,14 @@ async def add_base_mode_footprint(trip_list): | |
trip['data']['replaced_base_mode'] = "UNKNOWN" | ||
trip['data']['replaced_mode_footprint'] = {} | ||
|
||
except: | ||
print("hit exception") | ||
except Exception as e: | ||
counter_trip_error = counter_trip_error + 1 | ||
logging.debug(f"The exception is : {e} for the trip - {trip['data']['_id']}") | ||
iantei marked this conversation as resolved.
Show resolved
Hide resolved
|
||
trip['data']['base_mode'] = "UNKNOWN" | ||
trip['data']['replaced_base_mode'] = "UNKNOWN" | ||
trip['data']['mode_confirm_footprint'] = {} | ||
trip['data']['replaced_mode_footprint'] = {} | ||
logging.debug(f"There are {counter_trip_error} trip errors") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Interesting. As a future cleanup, I think we should report these errors in some place other than logs @Abby-Wheelis @iantei so we don't have to scrape logs to figure out if there is something we need to fix. Maybe in the server stats, or even displayed in the generated chart if we can figure out a way to do so without confusing people too much. |
||
return trip_list | ||
|
||
async def load_all_confirmed_trips(tq, add_footprint): | ||
|
@@ -254,7 +257,7 @@ async def map_trip_data(expanded_trip_df, study_type, dynamic_labels): | |
|
||
return expanded_trip_df | ||
|
||
async def load_viz_notebook_inferred_data(year, month, program, study_type, dynamic_labels, include_test_users=False): | ||
async def load_viz_notebook_inferred_data(year, month, program, study_type, dynamic_labels, include_test_users=False, add_footprint=False): | ||
shankari marked this conversation as resolved.
Show resolved
Hide resolved
|
||
""" Inputs: | ||
year/month/program/study_type = parameters from the visualization notebook | ||
dic_* = label mappings; if dic_pur is included it will be used to recode trip purpose | ||
|
@@ -263,7 +266,7 @@ async def load_viz_notebook_inferred_data(year, month, program, study_type, dyna | |
""" | ||
# Access database | ||
tq = get_time_query(year, month) | ||
participant_ct_df = await load_all_participant_trips(program, tq, include_test_users) | ||
participant_ct_df = await load_all_participant_trips(program, tq, include_test_users, add_footprint) | ||
inferred_ct = filter_inferred_trips(participant_ct_df) | ||
expanded_it = expand_inferredlabels(inferred_ct) | ||
expanded_it = await map_trip_data(expanded_it, study_type, dynamic_labels) | ||
|
@@ -501,29 +504,21 @@ def unit_conversions(df): | |
df['distance_miles']= df["distance"]*0.00062 #meters to miles | ||
df['distance_kms'] = df["distance"] / 1000 #meters to kms | ||
|
||
def extract_kwh(footprint_dict): | ||
if 'kwh' in footprint_dict.keys(): | ||
return footprint_dict['kwh'] | ||
else: | ||
print("missing kwh", footprint_dict) | ||
return np.nan | ||
|
||
def extract_co2(footprint_dict): | ||
if 'kg_co2' in footprint_dict.keys(): | ||
return footprint_dict['kg_co2'] | ||
def extract_footprint(footprint_dict, footprint_key): | ||
if footprint_key in footprint_dict.keys(): | ||
return footprint_dict[footprint_key] | ||
shankari marked this conversation as resolved.
Show resolved
Hide resolved
|
||
else: | ||
print("missing co2", footprint_dict) | ||
return np.nan | ||
|
||
def unpack_energy_emissions(expanded_ct): | ||
expanded_ct['Mode_confirm_kg_CO2'] = expanded_ct['mode_confirm_footprint'].apply(extract_co2) | ||
expanded_ct['Mode_confirm_kg_CO2'] = expanded_ct['mode_confirm_footprint'].apply(extract_footprint, footprint_key='kg_co2') | ||
expanded_ct['Mode_confirm_lb_CO2'] = kg_to_lb(expanded_ct['Mode_confirm_kg_CO2']) | ||
expanded_ct['Replaced_mode_kg_CO2'] = expanded_ct['replaced_mode_footprint'].apply(extract_co2) | ||
expanded_ct['Replaced_mode_kg_CO2'] = expanded_ct['replaced_mode_footprint'].apply(extract_footprint, footprint_key='kg_co2') | ||
expanded_ct['Replaced_mode_lb_CO2'] = kg_to_lb(expanded_ct['Replaced_mode_kg_CO2']) | ||
CO2_impact(expanded_ct) | ||
|
||
expanded_ct['Replaced_mode_EI(kWH)'] = expanded_ct['replaced_mode_footprint'].apply(extract_kwh) | ||
expanded_ct['Mode_confirm_EI(kWH)'] = expanded_ct['mode_confirm_footprint'].apply(extract_kwh) | ||
expanded_ct['Replaced_mode_EI(kWH)'] = expanded_ct['replaced_mode_footprint'].apply(extract_footprint, footprint_key='kwh') | ||
expanded_ct['Mode_confirm_EI(kWH)'] = expanded_ct['mode_confirm_footprint'].apply(extract_footprint, footprint_key='kwh') | ||
energy_impact(expanded_ct) | ||
|
||
return expanded_ct | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good text change. More concise & clearer