Функция разрешения целлюлозы дает одинаковый выход - PullRequest
1 голос
/ 26 апреля 2019

Я написал следующий код для генерации еды для разных дней, но я получаю одну и ту же еду каждый день. Я хочу, чтобы "мясные" и "вегетарианские" группы еды в разные дни.

my dataframe is as follows:

id      name               energy   sugar   Food_Groups
1       4-Grain Flakes      140     58.8    Breakfast
2       Beef Mince, Fried   1443    8.0     Meat
3       Pork                1000    3.0     Meat
4       cake                1200    150     Sweet
5       cheese              1100    140     Sweet
6       Juice               700     85      Drink
7       cabbage             60      13      vegetarian
8       cucumber            10      10      vegetarian
9       eggs                45      30      Breakfast

Я использую PuLP, чтобы минимизировать сахар с ограничением потребления калорий.

# Create the 'prob' variable to contain the problem data
prob = LpProblem("Simple Diet Problem",LpMinimize)
#create data variables and dictionary
food_items = list(df['name'])
calories = dict(zip(food_items,df['energy']))
sugars = dict(zip(food_items,df['sugar']))

food_vars =LpVariable.dicts("Food",food_items,lowBound=0,cat='Integer')

#Building the LP problem by adding the main objective function.
prob += lpSum([sugars[i]*food_vars[i] for i in food_items])

#adding calorie constraint
prob += lpSum([calories[f] * food_vars[f] for f in food_items]) >= 
1800.0, "CalorieMinimum"
prob += lpSum([calories[f] * food_vars[f] for f in food_items]) <= 
2200.0, "CalorieMaximum"

Я зацикливаюсь на prob.solve (), чтобы создать меню для разных дней

prob.writeLP("SimpleDietProblem.lp")
days = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday']
for i in days:
    print(i)

    prob.solve(PULP_CBC_CMD())
#    print("Status:", LpStatus[prob.status])
    print("Therefore, the optimal balanced diet consists of\n"+"-")
    for v in prob.variables():
        if v.varValue:
            print(v.name , "=", v.varValue)
    print("The total sugar of this balanced diet is: {}\n\n".format(round(value(prob.objective),2)))

Моя проблема в том, что вывод повторяется для всех дней. Как я могу получить "мясо" и "вегетарианец" в разные дни ??

1 Ответ

3 голосов
/ 26 апреля 2019

@ Ханед, самый простой способ сделать то, что ты хочешь, это настроить два экземпляра задачи.Один будет иметь мясные блюда, а другой - вегетарианские.Используйте каждый в разные дни.Вы можете чередовать начальную проблему для каждой недели, в которую вы хотите запустить план, чтобы получить двухнедельный план питания.

Вы можете настроить решатели следующим образом:

prob1 = LpProblem("Simple Diet Problem Meat Day",LpMinimize)
prob2 = LpProblem("Simple Diet Problem Vegetarian Day",LpMinimize)
#create data variables and dictionary
day1_df = df[df['Food_Groups'] != 'vegetarian']
day1_items = list(day1_df['name'])
day1_calories = dict(zip(day1_items,day1_df['energy']))
day1_sugars = dict(zip(day1_items,day1_df['sugar']))
day2_df = df[df['Food_Groups'] != 'Meat']
day2_items = list(day2_df['name'])
day2_calories = dict(zip(day2_items,day2_df['energy']))
day2_sugars = dict(zip(day2_items,day2_df['sugar']))
# variables
day1_vars =LpVariable.dicts("Food",day1_items,lowBound=0,cat='Integer')
day2_vars =LpVariable.dicts("Food",day2_items,lowBound=0,cat='Integer')

#Building the LP problem by adding the main objective function.
prob1 += lpSum([day1_sugars[i]*day1_vars[i] for i in day1_items])
prob2 += lpSum([day2_sugars[i]*day2_vars[i] for i in day2_items])

Если вы по-прежнемуЧтобы отображать варианты, которые вы не выбираете между мясными и вегетарианскими, во все дни, вам нужно создать более сложную модель с ограничениями, указав food_vars для этих элементов, равных нулю.

Решите обе проблемы по одному.

Затем назначьте каждому дню недели одну из проблем в списке, например:

days = [('Monday', prob1), ('Tuesday', prob2), ...]

Затем выполните циклическое переключение по дням и напечатайте переменные, как вы уже сделали.

for day, prob in days:
    print(day)
    print("Therefore, the optimal balanced diet consists of\n"+"-")
    for v in prob.variables():
        if v.varValue:
            print(v.name , "=", v.varValue)
    print("The total sugar of this balanced diet is: {}\n\n".format(round(value(prob.objective),2)))
...