|
import math, json |
|
|
|
|
|
def scale_nutrition(nutrition_per_serving, user_serving_size): |
|
scaling_factor = user_serving_size / nutrition_per_serving['servingSize'] |
|
return { |
|
'energy': round(nutrition_per_serving['energy'] * scaling_factor, 2), |
|
'protein': round(nutrition_per_serving['protein'] * scaling_factor, 2), |
|
'carbohydrates': round(nutrition_per_serving['carbohydrates'] * scaling_factor, 2), |
|
'addedSugars': round(nutrition_per_serving['addedSugars'] * scaling_factor, 2), |
|
'dietaryFiber': round(nutrition_per_serving['dietaryFiber'] * scaling_factor, 2), |
|
'totalFat': round(nutrition_per_serving['totalFat'] * scaling_factor, 2), |
|
'saturatedFat': round(nutrition_per_serving['saturatedFat'] * scaling_factor, 2), |
|
'monounsaturatedFat': round(nutrition_per_serving['monounsaturatedFat'] * scaling_factor, 2), |
|
'polyunsaturatedFat': round(nutrition_per_serving['polyunsaturatedFat'] * scaling_factor, 2), |
|
'transFat': round(nutrition_per_serving['transFat'] * scaling_factor, 2), |
|
'sodium': round(nutrition_per_serving['sodium'] * scaling_factor, 2) |
|
} |
|
|
|
|
|
def calculate_percentage(nutrient_value, daily_value): |
|
print(f"DEBUG : nutrient_value : {nutrient_value} daily_value : {daily_value}") |
|
if daily_value == 0 or math.isnan(nutrient_value): |
|
return 'N/A' |
|
return f"{round((nutrient_value / daily_value) * 100, 2)}%" |
|
|
|
|
|
def process_nutrition_data(nutrition_per_serving, user_serving_size): |
|
|
|
daily_values = { |
|
'energy': 2230, |
|
'protein': 55, |
|
'carbohydrates': 330, |
|
'addedSugars': 30, |
|
'dietaryFiber': 30, |
|
'totalFat': 74, |
|
'saturatedFat': 22, |
|
'sodium': 2000, |
|
'monounsaturatedFat': 25, |
|
'polyunsaturatedFat': 25, |
|
'transFat': 2 |
|
} |
|
|
|
scaled_nutrition = scale_nutrition(nutrition_per_serving, user_serving_size) |
|
|
|
|
|
|
|
percentage_daily_values = { |
|
'energy': calculate_percentage(scaled_nutrition['energy'], daily_values['energy']), |
|
'protein': calculate_percentage(scaled_nutrition['protein'], daily_values['protein']), |
|
'carbohydrates': calculate_percentage(scaled_nutrition['carbohydrates'], daily_values['carbohydrates']), |
|
'addedSugars': calculate_percentage(scaled_nutrition['addedSugars'], daily_values['addedSugars']), |
|
'dietaryFiber': calculate_percentage(scaled_nutrition['dietaryFiber'], daily_values['dietaryFiber']), |
|
'totalFat': calculate_percentage(scaled_nutrition['totalFat'], daily_values['totalFat']), |
|
'saturatedFat': calculate_percentage(scaled_nutrition['saturatedFat'], daily_values['saturatedFat']), |
|
'sodium': calculate_percentage(scaled_nutrition['sodium'], daily_values['sodium']), |
|
} |
|
return scaled_nutrition, percentage_daily_values |
|
|
|
def find_nutrition(data): |
|
|
|
try: |
|
nutrition_per_serving = data['nutritionPerServing'] |
|
user_serving_size = float(data['userServingSize']) |
|
|
|
if not nutrition_per_serving or user_serving_size <= 0: |
|
return {"error": "Invalid nutrition data or serving size"} |
|
|
|
|
|
scaled_nutrition, percentage_daily_values = process_nutrition_data(nutrition_per_serving, user_serving_size) |
|
print(f"DEBUG : percentage_daily_values : {percentage_daily_values}") |
|
|
|
rda_analysis_str = f"Nutrition per serving as percentage of Recommended Dietary Allowance (RDA) is {json.dumps(percentage_daily_values)}" |
|
print(f"DEBUG : rda_analysis_str : {rda_analysis_str}") |
|
return rda_analysis_str |
|
|
|
except Exception as e: |
|
return {"error": "Invalid JSON or input"} |