diff --git "a/01. \320\236\321\201\320\275\320\276\320\262\321\213 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\320\270 \320\262 Engee.ngscript" "b/01. \320\236\321\201\320\275\320\276\320\262\321\213 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\320\270 \320\262 Engee.ngscript"
index eb8bb85bc2deacaba74dfa3fefeaf7aaaf4e2167..388e10570e4490b3a63b51bbe2fc6b945ee6d35e 100644
--- "a/01. \320\236\321\201\320\275\320\276\320\262\321\213 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\320\270 \320\262 Engee.ngscript"	
+++ "b/01. \320\236\321\201\320\275\320\276\320\262\321\213 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\320\270 \320\262 Engee.ngscript"	
@@ -1 +1,1798 @@
-{"cells":[{"cell_type":"markdown","source":["# Основы оптимизации в Engee"],"id":"53aa3dad","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9928c6a6"}},{"cell_type":"markdown","source":["В данном разделе используются функции из следующих библиотек языка **Julia**: <code>JuMP</code>, <code>GLPK</code>. Они предустановлены в **Engee**. Для их использования необходимо выполнить команду ниже:"],"id":"c6acee48","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3a706497"}},{"outputs":[],"cell_type":"code","source":["Pkg.add([\"GLPK\", \"JuMP\"])"],"id":"mj0zrozt","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"nr3cdifd"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["using JuMP, GLPK; "],"id":"2032a6e8","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a10a64b1"},"execution_count":0},{"cell_type":"markdown","source":["`JuMP` (Julia for Mathematical Programming) – это библиотека с открытым исходным кодом, в которой реализован язык алгебраического моделирования, позволяющий пользователям формулировать широкий спектр задач оптимизации (линейные, нелинейные, с ограничениями и без ограничений). Сам язык моделирования не решает задач оптимизации, его цель\r\n– передать задачу в процедуру оптимизации (решатель или солвер). Подробную документацию можно найти на сайте https://jump.dev/.\r\n\r\nЗадачи, которые должен выполнять язык моделирования, можно\r\nусловно разделить на две части: \r\n1.   загрузить в память задачу, введенную пользователем;\r\n2.   сгенерировать входные данные, требуемые процедурой оптимизации в соответствии с типом задачи. \r\n\r\nОбе эти задачи решает библиотека `JuMP`, которая использует технику автоматического дифференцирования для вычисления производных выражений, введенных пользователем."],"id":"7fe6c94d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"469337bb"}},{"cell_type":"markdown","source":["`GLPK` (GNU Linear Programming Kit library) – библиотека линейной оптимизации. Она предоставляет выбор большого числа решателей. Документацию по этой библиотеке можно найти на сайте http://www.gnu.org/software/glpk/."],"id":"ff458fb1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b6107c77"}},{"cell_type":"markdown","source":["## 1. Создание оптимизационной задачи и переменных\r\n\r\n"],"id":"b3c5b940","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"333288cd"}},{"cell_type":"markdown","source":["Создать оптимизационную задачу можно с помощью команды <code>Model()</code>. В скобках нужно указать название решателя, который будет использован для решения задачи, и сохранить команду в переменной.  \r\n**Например:**"],"id":"416ed921","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c538cdca"}},{"outputs":[],"cell_type":"code","source":["optimization_problem = Model(GLPK.Optimizer)"],"id":"df8f4f0a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ae17fc58"},"execution_count":0},{"cell_type":"markdown","source":["Решатель можно также добавить позднее с помощью команды <code>set_optimizer()</code>. В скобках через запятую указывается имя оптимизационной задачи, которой присваивается переменная, и название решателя. **Например:**"],"id":"07418759","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f0b4885a"}},{"outputs":[],"cell_type":"code","source":["set_optimizer(optimization_problem, GLPK.Optimizer)"],"id":"d925f1aa","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7c74392f"},"execution_count":0},{"cell_type":"markdown","source":["Для объявления переменной без присваивания ей числового значения в **Engee** используется команда <code>@variable()</code>. В скобках через запятую указывается имя оптимизационной задачи, которой присваивается переменная, и имя самой переменной.\r\n**Например:**"],"id":"2a7876be","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c8f66c7a"}},{"outputs":[],"cell_type":"code","source":["@variable(optimization_problem, opt_variable);"],"id":"90385932","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"15bc0931"},"execution_count":0},{"cell_type":"markdown","source":["Вы также можете задать границы возможных значений для вашей переменной. **Например:**"],"id":"899c0987","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"33f086db"}},{"outputs":[],"cell_type":"code","source":["@variable(optimization_problem, opt_variable_1 >= 1);"],"id":"3149ede7","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e106b6a4"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 1"],"id":"1e79d3f9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a218501d"}},{"cell_type":"markdown","source":["Чтобы добавить свой код в сценарий, нужно щелкнуть по серому полю, предназначенному для ввода кода. Когда нужный код добавлен, вы можете запустить его и узнать результат, щелкнув по кнопке **Запуска** ![image.png]() слева от ячейки."],"id":"45bf74a0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2e206579"}},{"cell_type":"markdown","source":["Создайте оптимизационную задачу, применив к ней линейный решатель <code>GLPK</code>, и сохраните ее в переменной <code>opt_prob</code>.      "],"id":"343b438e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2b2cdf69"}},{"outputs":[],"cell_type":"code","source":[""],"id":"0f1cc152","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e3a52de3"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"f0623764","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"ca478c67"}},{"outputs":[],"cell_type":"code","source":["opt_prob = Model(GLPK.Optimizer)"],"id":"bbc058a7","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"db3e5543"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 2"],"id":"a4ac4c36","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"67d9bbbf"}},{"cell_type":"markdown","source":["Создайте переменную <code>x</code> и присвойте ее вашей оптимизационной задаче <code>opt_prob</code>."],"id":"91059fdb","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"72427e8b"}},{"outputs":[],"cell_type":"code","source":[""],"id":"afd3287b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b5915f14"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"3d56f964","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"29cc99eb"}},{"outputs":[],"cell_type":"code","source":["@variable(opt_prob, x);"],"id":"4b7da73e","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"5ff80e51"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 3"],"id":"7cdbd2ac","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f19c6030"}},{"cell_type":"markdown","source":["Создайте переменную <code>y</code>, присвойте ее вашей оптимизационной задаче <code>opt_prob</code> и задайте границы: <code>y</code> больше или равно <code>1</code>, но меньше или равно <code>4</code>."],"id":"80109f18","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b9f838b5"}},{"outputs":[],"cell_type":"code","source":[""],"id":"ea0ea730","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3d586004"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"a6cbbe26","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"6c849aba"}},{"outputs":[],"cell_type":"code","source":["@variable(opt_prob, 1 <= y <= 4)"],"id":"e27bbdeb","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"e9a4c030"},"execution_count":0},{"cell_type":"markdown","source":["## 2. Создание целевых функций"],"id":"f0098bb9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"80c9076e"}},{"cell_type":"markdown","source":["Целевая функция – это функция, подлежащая оптимизации для решения оптимизационной задачи."],"id":"87e76786","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6cd03466"}},{"cell_type":"markdown","source":["В зависимости от того, является ли функция линейной или нелинейной, целевая функция задается двумя разными командами. Линейная целевая функция задается командой <code>@objective()</code>, а нелинейная целевая функция – командой <code>@NLobjective()</code>.\r\n"],"id":"921b0e69","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ea907a1e"}},{"cell_type":"markdown","source":["В скобках через запятую указывается название оптимизационной задачи, <code>Min</code> для минимизации или <code>Max</code> для максимизации и математическое выражение. **Например:**"],"id":"439ef356","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"acfa1ef0"}},{"outputs":[],"cell_type":"code","source":["@objective(optimization_problem, Min, opt_variable + 3*opt_variable_1)"],"id":"e735ea7f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1c7605ab"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 4"],"id":"800e00d2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"02bb5999"}},{"cell_type":"markdown","source":["Создайте линейную целевую функцию для оптимизационной задачи <code>opt_prob</code> с целью максимизировать выражение <code>y - x</code>."],"id":"ab38894e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"8d775b0e"}},{"outputs":[],"cell_type":"code","source":[""],"id":"9672b15d","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f3359422"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"804e21d9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"57961bea"}},{"outputs":[],"cell_type":"code","source":["@objective(opt_prob, Max, y - x)"],"id":"08040e3a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"c6c8b8c3"},"execution_count":0},{"cell_type":"markdown","source":["## 3. Создание условий оптимизации  "],"id":"540b7427","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"8be97416"}},{"cell_type":"markdown","source":["Вы также можете задать условия, которые наложат ограничения на поиск оптимального решения задачи."],"id":"db72e04a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5189d507"}},{"cell_type":"markdown","source":["Так же, как и целевые функции, условия могут быть линейными и нелинейными. Линейные условия задаются командой <code>@constraint()</code>, а нелинейные – командой <code>@NLconstraint()</code>. "],"id":"2b0287bc","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"22dcd68d"}},{"cell_type":"markdown","source":["В скобках через запятую указывается название оптимизационной задачи и математическое выражение для условия. **Например:**"],"id":"e56dd3dc","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3654ff30"}},{"outputs":[],"cell_type":"code","source":["@constraint(optimization_problem, opt_variable + opt_variable_1 >= 6)"],"id":"bd35b6d5","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e826aaf2"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 5 "],"id":"4bca0454","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e7d21a3b"}},{"cell_type":"markdown","source":["Создайте линейное условие для оптимизационной задачи <code>opt_prob</code> где <code>x + y == 5</code>."],"id":"a22ac6c3","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"11633804"}},{"outputs":[],"cell_type":"code","source":[""],"id":"e8182492","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4ec35bec"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"627ee01c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"a691eb98"}},{"outputs":[],"cell_type":"code","source":["@constraint(opt_prob, x + y == 5)"],"id":"233c43a6","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"61c68b1e"},"execution_count":0},{"cell_type":"markdown","source":["## 4. Решение оптимизационных задач"],"id":"c96b0117","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"400641f2"}},{"cell_type":"markdown","source":["Решить оптимизационную задачу можно с помощью команды <code>optimize!()</code>. В скобках указывается название оптимизационной задачи. **Например:**"],"id":"2c2f5e42","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d795f80f"}},{"outputs":[],"cell_type":"code","source":["optimize!(optimization_problem)"],"id":"09ed84ff","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"aef8e90d"},"execution_count":0},{"cell_type":"markdown","source":["Просмотреть оптимизационную задачу можно с помощью команды <code>print()</code>. В скобках указывается название оптимизационной задачи. **Например:**"],"id":"f3f3d388","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"024d5ec3"}},{"outputs":[],"cell_type":"code","source":["print(optimization_problem)"],"id":"145a10d5","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ab6f76d2"},"execution_count":0},{"cell_type":"markdown","source":["Просмотреть информацию о решении задачи можно с помощью команды <code>solution_summary()</code>. В скобках указывается название оптимизационной задачи. Например:"],"id":"08bf341e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c31dfa44"}},{"outputs":[],"cell_type":"code","source":["solution_summary(optimization_problem)"],"id":"3892e462","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c7682ddc"},"execution_count":0},{"cell_type":"markdown","source":["Просмотреть целевое значение можно с помощью команды <code>objective_value()</code>. В скобках указывается название оптимизационной задачи. **Например:**"],"id":"98279679","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6f3a700e"}},{"outputs":[],"cell_type":"code","source":["objective_value(optimization_problem)"],"id":"fb3dfd9b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"021f66fd"},"execution_count":0},{"cell_type":"markdown","source":["Просмотреть оптимизированные значения переменных можно с помощью команды <code>value()</code>. В скобках указывается имя переменной. **Например:**"],"id":"d0d4f839","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"0c664008"}},{"outputs":[],"cell_type":"code","source":["value(opt_variable)"],"id":"3c816c4a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4f9d8b5b"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["value(opt_variable_1)"],"id":"35b6be71","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6ef88087"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 6"],"id":"f766b240","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ddf63721"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу <code>opt_prob</code>. Просмотрите задачу с помощью <code>print()</code> и информацию о решениях с помощью <code>solution_summary()</code>. Просмотрите целевое значение задачи и оптимизированные значения обеих переменных <code>x</code> и <code>y</code>."],"id":"925cc16f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2839def5"}},{"outputs":[],"cell_type":"code","source":[""],"id":"24855ae4","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"dda709b3"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"2cc0e863","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"553a7fca"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"c4e689a4","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"085e78f7"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"188584a0","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4c7fd0a6"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"aff23dbe","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7337f512"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"a7cfeb98","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"35e71bbc"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"9e24f9b4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":6,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"1481cc87"}},{"outputs":[],"cell_type":"code","source":["optimize!(opt_prob)"],"id":"6d38cbbb","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"2250529c"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["print(opt_prob)"],"id":"df5b8f49","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"c9b24ebd"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["solution_summary(opt_prob)"],"id":"f4676ef8","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"519369a9"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["objective_value(opt_prob)"],"id":"17066a3f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"f3c00fe5"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["value(x)"],"id":"cb4a6353","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"d5f32af7"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["value(y)"],"id":"e7dec4b6","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"20f85c75"},"execution_count":0},{"cell_type":"markdown","source":["## Тест для получения сертификата"],"id":"e29fda63","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"16d0d89c"}},{"cell_type":"markdown","source":["Если вы впервые проходите тестирование на платформе **Этюд** по ссылке из **Engee**, то, нажав на ссылку ниже, вы увидите следующее диалоговое окно:\r\n\r\n![Предоставить доступ к платформе Этюд 3.png](attachment:Предоставить доступ к платформе Этюд 3.png)\r\n\r\nНажмите на кнопку \"Предоставить\", чтобы авторизоваться на платформе **Этюд** с данными вашего профиля Engee ID.\r\n\r\nЕсли вы раньше уже проходили тестирование по ссылке из **Engee**, то ваша авторизация выполнится автоматически и тестирование начнется сразу же после нажатия на ссылку.\r\n\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"],"id":"8ae7534c","attachments":{"Предоставить доступ к платформе Этюд 3.png":{"image/png":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"0469700d"}},{"cell_type":"markdown","source":["<p align=\"center\">\r\n<a style=\"padding: 8px 16px;\r\n    border: 3px blue;\r\n    border-radius: 15px;\r\n    color: white;\r\n    background-color: #1b83ba;\r\n    font-size: 24pt; \r\n    text-decoration: none;\" href=\"https://my.etude.org/link/6KXUTaY8By2xl5cq3Bo_J1UG4Pz00W0pPyfdI2WuSHwCmROR5vs90xyOD_oqRE3tzfvqyZZmkpJmtlR0exOWduAEGNLRqoOk-yvW0WHpEmkw8oVlmPmLLNAMv0LJvhpNPGqjzp_wlWhxI7Im-RLMHVHX7T50jda4xqKz0ZbN_D0=?engee\"\r\n     target=\"_blank\">Пройти тест по разделу >></a>\r\n</p>"],"id":"f276368d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"73f18676"}}],"nbformat_minor":5,"metadata":{"engee":{},"language_info":{"file_extension":".jl","name":"julia","version":"1.9.3"},"kernelspec":{"name":"ijulia-1.9","display_name":"IJulia 1.9.3","language":"julia"}},"nbformat":4}
\ No newline at end of file
+{
+  "nbformat": 4,
+  "nbformat_minor": 5,
+  "metadata": {
+    "kernelspec": {
+      "name": "ijulia-1.9",
+      "display_name": "IJulia 1.9.3",
+      "language": "julia"
+    },
+    "language_info": {
+      "name": "julia",
+      "file_extension": ".jl",
+      "version": "1.9.3"
+    },
+    "engee": {}
+  },
+  "cells": [
+    {
+      "id": "53aa3dad",
+      "cell_type": "markdown",
+      "source": [
+        "# Основы оптимизации в Engee"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9928c6a6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c6acee48",
+      "cell_type": "markdown",
+      "source": [
+        "В данном разделе используются функции из следующих библиотек языка **Julia**: <code>JuMP</code>, <code>GLPK</code>. Они предустановлены в **Engee**. Для их использования необходимо выполнить команду ниже:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3a706497",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2032a6e8",
+      "cell_type": "code",
+      "source": [
+        "using JuMP, GLPK; "
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "a10a64b1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7fe6c94d",
+      "cell_type": "markdown",
+      "source": [
+        "`JuMP` (Julia for Mathematical Programming) – это библиотека с открытым исходным кодом, в которой реализован язык алгебраического моделирования, позволяющий пользователям формулировать широкий спектр задач оптимизации (линейные, нелинейные, с ограничениями и без ограничений). Сам язык моделирования не решает задач оптимизации, его цель\r\n– передать задачу в процедуру оптимизации (решатель или солвер). Подробную документацию можно найти на сайте https://jump.dev/.\r\n\r\nЗадачи, которые должен выполнять язык моделирования, можно\r\nусловно разделить на две части: \r\n1.   загрузить в память задачу, введенную пользователем;\r\n2.   сгенерировать входные данные, требуемые процедурой оптимизации в соответствии с типом задачи. \r\n\r\nОбе эти задачи решает библиотека `JuMP`, которая использует технику автоматического дифференцирования для вычисления производных выражений, введенных пользователем."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "469337bb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ff458fb1",
+      "cell_type": "markdown",
+      "source": [
+        "`GLPK` (GNU Linear Programming Kit library) – библиотека линейной оптимизации. Она предоставляет выбор большого числа решателей. Документацию по этой библиотеке можно найти на сайте http://www.gnu.org/software/glpk/."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b6107c77",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b3c5b940",
+      "cell_type": "markdown",
+      "source": [
+        "## 1. Создание оптимизационной задачи и переменных\r\n\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "333288cd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "416ed921",
+      "cell_type": "markdown",
+      "source": [
+        "Создать оптимизационную задачу можно с помощью команды <code>Model()</code>. В скобках нужно указать название решателя, который будет использован для решения задачи, и сохранить команду в переменной.  \r\n**Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c538cdca",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "df8f4f0a",
+      "cell_type": "code",
+      "source": [
+        "optimization_problem = Model(GLPK.Optimizer)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "ae17fc58",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "07418759",
+      "cell_type": "markdown",
+      "source": [
+        "Решатель можно также добавить позднее с помощью команды <code>set_optimizer()</code>. В скобках через запятую указывается имя оптимизационной задачи, которой присваивается переменная, и название решателя. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f0b4885a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d925f1aa",
+      "cell_type": "code",
+      "source": [
+        "set_optimizer(optimization_problem, GLPK.Optimizer)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7c74392f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "2a7876be",
+      "cell_type": "markdown",
+      "source": [
+        "Для объявления переменной без присваивания ей числового значения в **Engee** используется команда <code>@variable()</code>. В скобках через запятую указывается имя оптимизационной задачи, которой присваивается переменная, и имя самой переменной.\r\n**Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c8f66c7a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "90385932",
+      "cell_type": "code",
+      "source": [
+        "@variable(optimization_problem, opt_variable);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "15bc0931",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "899c0987",
+      "cell_type": "markdown",
+      "source": [
+        "Вы также можете задать границы возможных значений для вашей переменной. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "33f086db",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "3149ede7",
+      "cell_type": "code",
+      "source": [
+        "@variable(optimization_problem, opt_variable_1 >= 1);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "e106b6a4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "1e79d3f9",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 1"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a218501d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "45bf74a0",
+      "cell_type": "markdown",
+      "source": [
+        "Чтобы добавить свой код в сценарий, нужно щелкнуть по серому полю, предназначенному для ввода кода. Когда нужный код добавлен, вы можете запустить его и узнать результат, щелкнув по кнопке **Запуска** ![image.png]() слева от ячейки."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2e206579",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "343b438e",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте оптимизационную задачу, применив к ней линейный решатель <code>GLPK</code>, и сохраните ее в переменной <code>opt_prob</code>.      "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2b2cdf69",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0f1cc152",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "e3a52de3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f0623764",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ca478c67",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "bbc058a7",
+      "cell_type": "code",
+      "source": [
+        "opt_prob = Model(GLPK.Optimizer)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "db3e5543",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a4ac4c36",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 2"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "67d9bbbf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "91059fdb",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте переменную <code>x</code> и присвойте ее вашей оптимизационной задаче <code>opt_prob</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "72427e8b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "afd3287b",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b5915f14",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "3d56f964",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "29cc99eb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4b7da73e",
+      "cell_type": "code",
+      "source": [
+        "@variable(opt_prob, x);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5ff80e51",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7cdbd2ac",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 3"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f19c6030",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "80109f18",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте переменную <code>y</code>, присвойте ее вашей оптимизационной задаче <code>opt_prob</code> и задайте границы: <code>y</code> больше или равно <code>1</code>, но меньше или равно <code>4</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b9f838b5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ea0ea730",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "3d586004",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a6cbbe26",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6c849aba",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e27bbdeb",
+      "cell_type": "code",
+      "source": [
+        "@variable(opt_prob, 1 <= y <= 4)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "e9a4c030",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f0098bb9",
+      "cell_type": "markdown",
+      "source": [
+        "## 2. Создание целевых функций"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "80c9076e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "87e76786",
+      "cell_type": "markdown",
+      "source": [
+        "Целевая функция – это функция, подлежащая оптимизации для решения оптимизационной задачи."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6cd03466",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "921b0e69",
+      "cell_type": "markdown",
+      "source": [
+        "В зависимости от того, является ли функция линейной или нелинейной, целевая функция задается двумя разными командами. Линейная целевая функция задается командой <code>@objective()</code>, а нелинейная целевая функция – командой <code>@NLobjective()</code>.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ea907a1e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "439ef356",
+      "cell_type": "markdown",
+      "source": [
+        "В скобках через запятую указывается название оптимизационной задачи, <code>Min</code> для минимизации или <code>Max</code> для максимизации и математическое выражение. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "acfa1ef0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e735ea7f",
+      "cell_type": "code",
+      "source": [
+        "@objective(optimization_problem, Min, opt_variable + 3*opt_variable_1)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1c7605ab",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "800e00d2",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 4"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "02bb5999",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ab38894e",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте линейную целевую функцию для оптимизационной задачи <code>opt_prob</code> с целью максимизировать выражение <code>y - x</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "8d775b0e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9672b15d",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "f3359422",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "804e21d9",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "57961bea",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "08040e3a",
+      "cell_type": "code",
+      "source": [
+        "@objective(opt_prob, Max, y - x)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c6c8b8c3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "540b7427",
+      "cell_type": "markdown",
+      "source": [
+        "## 3. Создание условий оптимизации  "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "8be97416",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "db72e04a",
+      "cell_type": "markdown",
+      "source": [
+        "Вы также можете задать условия, которые наложат ограничения на поиск оптимального решения задачи."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "5189d507",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2b0287bc",
+      "cell_type": "markdown",
+      "source": [
+        "Так же, как и целевые функции, условия могут быть линейными и нелинейными. Линейные условия задаются командой <code>@constraint()</code>, а нелинейные – командой <code>@NLconstraint()</code>. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "22dcd68d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e56dd3dc",
+      "cell_type": "markdown",
+      "source": [
+        "В скобках через запятую указывается название оптимизационной задачи и математическое выражение для условия. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3654ff30",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "bd35b6d5",
+      "cell_type": "code",
+      "source": [
+        "@constraint(optimization_problem, opt_variable + opt_variable_1 >= 6)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "e826aaf2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "4bca0454",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 5 "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e7d21a3b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a22ac6c3",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте линейное условие для оптимизационной задачи <code>opt_prob</code> где <code>x + y == 5</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "11633804",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e8182492",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4ec35bec",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "627ee01c",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a691eb98",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "233c43a6",
+      "cell_type": "code",
+      "source": [
+        "@constraint(opt_prob, x + y == 5)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "61c68b1e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c96b0117",
+      "cell_type": "markdown",
+      "source": [
+        "## 4. Решение оптимизационных задач"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "400641f2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2c2f5e42",
+      "cell_type": "markdown",
+      "source": [
+        "Решить оптимизационную задачу можно с помощью команды <code>optimize!()</code>. В скобках указывается название оптимизационной задачи. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d795f80f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "09ed84ff",
+      "cell_type": "code",
+      "source": [
+        "optimize!(optimization_problem)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "aef8e90d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f3f3d388",
+      "cell_type": "markdown",
+      "source": [
+        "Просмотреть оптимизационную задачу можно с помощью команды <code>print()</code>. В скобках указывается название оптимизационной задачи. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "024d5ec3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "145a10d5",
+      "cell_type": "code",
+      "source": [
+        "print(optimization_problem)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "ab6f76d2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "08bf341e",
+      "cell_type": "markdown",
+      "source": [
+        "Просмотреть информацию о решении задачи можно с помощью команды <code>solution_summary()</code>. В скобках указывается название оптимизационной задачи. Например:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c31dfa44",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "3892e462",
+      "cell_type": "code",
+      "source": [
+        "solution_summary(optimization_problem)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c7682ddc",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "98279679",
+      "cell_type": "markdown",
+      "source": [
+        "Просмотреть целевое значение можно с помощью команды <code>objective_value()</code>. В скобках указывается название оптимизационной задачи. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6f3a700e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "fb3dfd9b",
+      "cell_type": "code",
+      "source": [
+        "objective_value(optimization_problem)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "021f66fd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d0d4f839",
+      "cell_type": "markdown",
+      "source": [
+        "Просмотреть оптимизированные значения переменных можно с помощью команды <code>value()</code>. В скобках указывается имя переменной. **Например:**"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "0c664008",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "3c816c4a",
+      "cell_type": "code",
+      "source": [
+        "value(opt_variable)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4f9d8b5b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "35b6be71",
+      "cell_type": "code",
+      "source": [
+        "value(opt_variable_1)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "6ef88087",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f766b240",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 6"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ddf63721",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "925cc16f",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу <code>opt_prob</code>. Просмотрите задачу с помощью <code>print()</code> и информацию о решениях с помощью <code>solution_summary()</code>. Просмотрите целевое значение задачи и оптимизированные значения обеих переменных <code>x</code> и <code>y</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2839def5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "24855ae4",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "dda709b3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "2cc0e863",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "553a7fca",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c4e689a4",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "085e78f7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "188584a0",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4c7fd0a6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "aff23dbe",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7337f512",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a7cfeb98",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "35e71bbc",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9e24f9b4",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1481cc87",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 6,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "6d38cbbb",
+      "cell_type": "code",
+      "source": [
+        "optimize!(opt_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "2250529c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "df5b8f49",
+      "cell_type": "code",
+      "source": [
+        "print(opt_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c9b24ebd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f4676ef8",
+      "cell_type": "code",
+      "source": [
+        "solution_summary(opt_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "519369a9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "17066a3f",
+      "cell_type": "code",
+      "source": [
+        "objective_value(opt_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "f3c00fe5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "cb4a6353",
+      "cell_type": "code",
+      "source": [
+        "value(x)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "d5f32af7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e7dec4b6",
+      "cell_type": "code",
+      "source": [
+        "value(y)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "20f85c75",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e29fda63",
+      "cell_type": "markdown",
+      "source": [
+        "## Тест для получения сертификата"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "16d0d89c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8ae7534c",
+      "cell_type": "markdown",
+      "source": [
+        "Если вы впервые проходите тестирование на платформе **Этюд** по ссылке из **Engee**, то, нажав на ссылку ниже, вы увидите следующее диалоговое окно:\r\n\r\n![Предоставить доступ к платформе Этюд 3.png](attachment:Предоставить доступ к платформе Этюд 3.png)\r\n\r\nНажмите на кнопку \"Предоставить\", чтобы авторизоваться на платформе **Этюд** с данными вашего профиля Engee ID.\r\n\r\nЕсли вы раньше уже проходили тестирование по ссылке из **Engee**, то ваша авторизация выполнится автоматически и тестирование начнется сразу же после нажатия на ссылку.\r\n\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"
+      ],
+      "attachments": {
+        "Предоставить доступ к платформе Этюд 3.png": {
+          "image/png": ""
+        }
+      },
+      "metadata": {
+        "id": "0469700d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f276368d",
+      "cell_type": "markdown",
+      "source": [
+        "<p align=\"center\">\r\n<a style=\"padding: 8px 16px;\r\n    border: 3px blue;\r\n    border-radius: 15px;\r\n    color: white;\r\n    background-color: #1b83ba;\r\n    font-size: 24pt; \r\n    text-decoration: none;\" href=\"https://my.etude.org/link/6KXUTaY8By2xl5cq3Bo_J1UG4Pz00W0pPyfdI2WuSHwCmROR5vs90xyOD_oqRE3tzfvqyZZmkpJmtlR0exOWduAEGNLRqoOk-yvW0WHpEmkw8oVlmPmLLNAMv0LJvhpNPGqjzp_wlWhxI7Im-RLMHVHX7T50jda4xqKz0ZbN_D0=?engee\"\r\n     target=\"_blank\">Пройти тест по разделу >></a>\r\n</p>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "73f18676",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    }
+  ]
+}
\ No newline at end of file
diff --git "a/02. \320\221\320\265\320\267\321\203\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript" "b/02. \320\221\320\265\320\267\321\203\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript"
index b7e3efe6c2781b7bfa498f214ea445ac21ed2bcc..6a144ecc5b416452efd8776565d5e11ea6823dac 100644
--- "a/02. \320\221\320\265\320\267\321\203\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript"	
+++ "b/02. \320\221\320\265\320\267\321\203\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript"	
@@ -1 +1,1479 @@
-{"cells":[{"cell_type":"markdown","source":["# Безусловная оптимизация"],"id":"52ed6e94","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6c595fa8"}},{"cell_type":"markdown","source":["Задачи безусловной оптимизации состоят в поиске максимума или минимума заданной функции при отсутствии каких-либо ограничений."],"id":"aa53fb8e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d31a6e29"}},{"cell_type":"markdown","source":["В этом разделе мы рассмотрим логистическую задачу нелинейной безусловной оптимизации по поиску оптимальной локации складского помещения.\r\n\r\nВ целях сокращения логистических расходов складское помещение должно быть размещено на оптимальном удалении от четырех предприятий, поставки на которые осуществляются с этого склада.\r\n"],"id":"1873d311","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c2f2690b"}},{"cell_type":"markdown","source":["## 1. Создание нелинейной оптимизационной задачи\r\n"],"id":"d630cd6e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4a06ae09"}},{"cell_type":"markdown","source":["Нелинейная оптимизационная задача подразумевает наличие нелинейной целевой функции или нелинейных условий, наложенных на поиск оптимального решения, или обоих факторов одновременно.\r\n"],"id":"5eb103a7","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"752b9738"}},{"cell_type":"markdown","source":["Создание нелинейной оптимизационной задачи отличается от создания линейной оптимизационной задачи применением нелинейного решателя. "],"id":"f5753014","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1e0cc5f0"}},{"cell_type":"markdown","source":["Для решения данной задачи мы используем оптимизационную библиотеку <code>JuMP</code> и нелинейный решатель <code>Ipopt</code>. Для их использования необходимо выполнить команду ниже:"],"id":"8c5de96d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6700a3d8"}},{"outputs":[],"cell_type":"code","source":["Pkg.add([\"Ipopt\", \"JuMP\"])"],"id":"bz1cozqy","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"x7eulezs"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["using JuMP, Ipopt;"],"id":"80835aa9","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4902a715"},"execution_count":0},{"cell_type":"markdown","source":["`Ipopt` (Interior Point OPTimizer) – библиотека для нелинейной оптимизации задач большой размерности. Подробную документацию по этой библиотеке можно найти на сайте https://github.com/coin-or/Ipopt."],"id":"56383d41","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e5061cc3"}},{"cell_type":"markdown","source":["С помощью библиотеки `Ipopt` оптимизационные задачи решаются **методом внутренней точки** (**interior-point method**), который позволяет решать выпуклые задачи оптимизации с условиями, заданными в виде неравенств. В этом методе исходную для поиска точку можно выбирать только внутри допустимой области."],"id":"c8c84ee4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4426be34"}},{"cell_type":"markdown","source":["### ✏️Задание 1"],"id":"2a1998ab","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"0d7b5e78"}},{"cell_type":"markdown","source":["Создайте оптимизационную задачу, применив к ней нелинейный решатель <code>Ipopt</code>, и сохраните ее в переменной <code>NL_prob</code>.      "],"id":"59716d21","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"14238997"}},{"outputs":[],"cell_type":"code","source":[""],"id":"ef36878f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1cf75a84"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"294e74e7","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"96e9e921"}},{"outputs":[],"cell_type":"code","source":["NL_prob = Model(Ipopt.Optimizer)"],"id":"4ffb1a5c","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"7f74f9ba"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 2"],"id":"8cc76435","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"8c47cc8b"}},{"cell_type":"markdown","source":["Создайте переменные <code>x</code> и <code>y</code>, определяющие позицию склада в двумерном пространстве, и присвойте их вашей оптимизационной задаче. Для текущей задачи через запятую необходимо указать, что значение переменных не может быть меньше нуля. "],"id":"87a0fedf","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"eadcf20f"}},{"outputs":[],"cell_type":"code","source":["\r\n"],"id":"4b9b97df","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"101ef27f"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"b45683ec","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"d1e5f215"}},{"outputs":[],"cell_type":"code","source":["@variable(NL_prob, x >= 0);\r\n@variable(NL_prob, y >= 0);"],"id":"674f5d52","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"fd6e9951"},"execution_count":0},{"cell_type":"markdown","source":["## 2. Ввод координат предприятий"],"id":"eb101720","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"82018874"}},{"cell_type":"markdown","source":["Склад обслуживает 4 предприятия, имеющие разные координаты. Координаты можно ввести в виде соответствующих четырехэлементных векторов <code>X</code> и <code>Y</code>. Координаты следует перевести в тип float для осуществления последующих расчетов. Это можно сделать, добавив <code>.</code> после каждого значения.\r\n\r\nВыполните команду ниже для ввода координат предприятий:\r\n"],"id":"29dfd85f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"212d9f14"}},{"outputs":[],"cell_type":"code","source":["X = [23., 34., 45., 72.];\r\nY = [11., 61., 19., 38.];"],"id":"7bc9aee8","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1f6c6a76"},"execution_count":0},{"cell_type":"markdown","source":["## 3. Ввод начальных координат склада"],"id":"44d510c2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d2e1dbe4"}},{"cell_type":"markdown","source":["В некоторых случаях для решения оптимизационных задач оптимизируемым переменным необходимо задать начальные значения. В данном случае вы можете присвоить переменным <code>x</code> и <code>y</code> произвольные значения. Начальные значения не повлияют на конечный результат.\r\nВыполните команду ниже для ввода начальных координат оптимизируемых переменных <code>x</code> и <code>y</code>:"],"id":"b32d7d6a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"535ba4e8"}},{"outputs":[],"cell_type":"code","source":["set_start_value(x, 1) \r\nset_start_value(y, 1)"],"id":"13f424c7","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"71164ee1"},"execution_count":0},{"cell_type":"markdown","source":["## 4. Создание нелинейной целевой функции"],"id":"ec828a72","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"63947945"}},{"cell_type":"markdown","source":["Для создания нелинейной целевой функции необходимо использовать команду <code>@NLobjective()</code>. В скобках через запятую указывается имя оптимизационной задачи, которой присваивается целевая функция, *Min* или *Max* для нахождения минимального или максимального значения и математическое выражение целевой функции."],"id":"1ef882cb","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"05bdf3e2"}},{"cell_type":"markdown","source":["Расчет расстояния между складом и отдельно взятым предприятием осуществляется с помощью теоремы Пифагора по разнице координат точек:\r\n$$R=\\sqrt{(x - X)^2 + (y - Y)^2}$$\r\nДля расчета расстояния между складом и всеми предприятиями необходимо повторить операцию с координатами всех предприятий и суммировать результат:\r\n$$R_{total}=\\sum_{i=1}^{4}\\sqrt{(x - X_i)^2 + (y - Y_i)^2}$$\r\nЦелевым значением нашей задачи являются двумерные координаты оптимальной локации склада, при которых сумма расстояний от склада до всех предприятий ($R_{total}$) принимает минимальное значение."],"id":"7abaaf90","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2f9777a2"}},{"cell_type":"markdown","source":["### ✏️Задание 3"],"id":"9c5ab2de","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fa6ddd96"}},{"cell_type":"markdown","source":["С помощью команды <code>@NLobjective()</code> создайте целевую функцию, содержащую описанное выше выражение для расчета суммы расстояний от склада до всех предприятий $R_{total}$. Присвойте функцию оптимизационной задаче <code>NL_prob</code>.\r\n\r\n"],"id":"a376c625","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"086d8815"}},{"outputs":[],"cell_type":"code","source":[""],"id":"0f0d505a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1412b5a5"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Подсказка</span>"],"id":"20a668d2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":3,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"d6e808da"}},{"cell_type":"markdown","source":["Для суммирования расстояний между складом и всеми четырьмя предприятиями необходимо повторить операцию 4 раза. Этого можно достичь, задав цикл `for i = 1:4` внутри скобок команды sum()."],"id":"6f0b9f0a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"003fff11"}},{"cell_type":"markdown","source":["##### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"104cad66","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":false},"id":"ab082e32"}},{"outputs":[],"cell_type":"code","source":["@NLobjective(NL_prob, Min, sum(sqrt((x - X[i])^2 + (y - Y[i])^2) for i = 1:4))"],"id":"b7d059c4","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"57092da6"},"execution_count":0},{"cell_type":"markdown","source":["## 5. Решение нелинейной оптимизационной задачи"],"id":"24edf7f7","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9d4064ab"}},{"cell_type":"markdown","source":["### ✏️Задание 4"],"id":"d22934bd","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1e0a0be2"}},{"cell_type":"markdown","source":["Используйте команды <code>optimize!()</code>, <code>print()</code> и <code>objective_value()</code> для решения, вывода результата и целевого значения оптимизационной задачи <code>NL_prob</code>."],"id":"e21bc912","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ef06f49a"}},{"outputs":[],"cell_type":"code","source":[""],"id":"52faf2f6","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e3dbc3a3"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"54f42294","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9556f132"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"1ac00d16","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6f4f2567"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"1268ba17","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":3,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"be1b7ddf"}},{"outputs":[],"cell_type":"code","source":["optimize!(NL_prob)"],"id":"8f6fda72","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"990a8a22"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["print(NL_prob)"],"id":"7d64fe2a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"dbbc3006"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["objective_value(NL_prob)"],"id":"c02dabdb","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"96ea9244"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 5"],"id":"eeba3342","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2d36e2fb"}},{"cell_type":"markdown","source":["Используйте команду <code>value()</code> с аргументами <code>x</code> и <code>y</code> для получения координат оптимального расположения склада. Сохраните новые значения в переменных <code>x_opt</code> и <code>y_opt</code>."],"id":"06ba6f9d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d6cfa6a2"}},{"outputs":[],"cell_type":"code","source":[""],"id":"077097bb","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"cdcffbd3"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"6724edea","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"cddd3ac4"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"96d52793","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"64902bd3"}},{"outputs":[],"cell_type":"code","source":["x_opt = value(x)"],"id":"11b51429","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"7191c383"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["y_opt = value(y)"],"id":"70873b7b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"7b549ba3"},"execution_count":0},{"cell_type":"markdown","source":["## 6. Визуализация результатов"],"id":"98de71b5","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9464917b"}},{"cell_type":"markdown","source":["Для визуализации результатов на графике мы используем библиотеку <code>Plots</code>. Для ее использования необходимо выполнить команду ниже:"],"id":"3f83b3e0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"465f7c77"}},{"outputs":[],"cell_type":"code","source":["using Plots;"],"id":"f12958cb","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fae77303"},"execution_count":0},{"cell_type":"markdown","source":["Задайте параметры графиков, запустив команду ниже:"],"id":"957a5146","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f2a04fd9"}},{"outputs":[],"cell_type":"code","source":["gr(size=(1700, 700), legend=false, grid=true, widen=1.5, ticks = 20)"],"id":"420914b7","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ebedc4d8"},"execution_count":0},{"cell_type":"markdown","source":["Отобразите позиции предприятий на графике. Внутри команды <code>plot</code> вы можете задать дополнительные параметры визуализации, такие как форма, цвет и размер маркера."],"id":"85c84f64","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9a0d5e87"}},{"outputs":[],"cell_type":"code","source":["Plots.plot(X, Y, seriestype=:scatter,markershape=:hexagon, color = :orange, markersize = 5, markerstrokewidth=1, aspect_ratio = :equal)"],"id":"4c0406c7","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"613fa40d"},"execution_count":0},{"cell_type":"markdown","source":["Отобразите оптимальную позицию склада на том же графике. Для этого используйте <code>!</code> после команды <code>plot</code>. Вы можете изменить параметры визуализации внутри команды <code>plot</code> для наглядности. "],"id":"22e12fe4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"62d5f722"}},{"cell_type":"markdown","source":["Обратите внимание, что получив координаты <code>x_opt</code> и <code>y_opt</code> с помощью команды <code>value()</code>, мы изменили тип переменной и нам нужно заключить их в <code>[]</code> для передачи в команду <code>plot()</code>."],"id":"a81230a4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"8d89cb1b"}},{"outputs":[],"cell_type":"code","source":["plot!([x_opt], [y_opt], seriestype=:scatter,markershape=:diamond, color = :green, markersize = 5, markerstrokewidth=1)"],"id":"648dca0f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"637b1ce9"},"execution_count":0},{"cell_type":"markdown","source":["Вы также можете вывести дополнительные пояснения на график."],"id":"d2a5d4b0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6b8e1ce2"}},{"outputs":[],"cell_type":"code","source":["ptstr = string([x_opt y_opt])\r\nxvalstr = string(\"   Оптимальная локация\")\r\nannotate!(([x_opt y_opt]...,text(xvalstr, 13, :left, :black)))"],"id":"9db76245","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"623c3280"},"execution_count":0},{"cell_type":"markdown","source":["## Тест для получения сертификата\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"],"id":"d113f3b7","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6b91badb"}},{"cell_type":"markdown","source":["<p align=\"center\">\r\n<a style=\"padding: 8px 16px;\r\n    border: 3px blue;\r\n    border-radius: 15px;\r\n    color: white;\r\n    background-color: #1b83ba;\r\n    font-size: 24pt; \r\n    text-decoration: none;\" href=\"https://my.etude.org/link/qTMxZZhZhgSdUgxIqPY8V2Oj4RAHdadM5e-pcBhquB_Ab8GSxprZF5BZ589szp7ThZC69v73VNrp0NGZae7smAEnN1gEBEG76U4mGRUvNpAJT0R5vdvatggpM9fTCD6MPVDmc9O3dZ3ScBi8hzWrAY-85OuyIn2jxwOUbRLl8FE=?engee\"\r\n     target=\"_blank\">Пройти тест по разделу >></a>\r\n</p>"],"id":"f276368d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c80dd9a9"}}],"nbformat_minor":5,"metadata":{"engee":{},"language_info":{"file_extension":".jl","name":"julia","version":"1.9.3"},"kernelspec":{"name":"ijulia-1.9","display_name":"IJulia 1.9.3","language":"julia"}},"nbformat":4}
\ No newline at end of file
+{
+  "nbformat": 4,
+  "nbformat_minor": 5,
+  "metadata": {
+    "kernelspec": {
+      "name": "ijulia-1.9",
+      "display_name": "IJulia 1.9.3",
+      "language": "julia"
+    },
+    "language_info": {
+      "name": "julia",
+      "file_extension": ".jl",
+      "version": "1.9.3"
+    },
+    "engee": {}
+  },
+  "cells": [
+    {
+      "id": "52ed6e94",
+      "cell_type": "markdown",
+      "source": [
+        "# Безусловная оптимизация"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6c595fa8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aa53fb8e",
+      "cell_type": "markdown",
+      "source": [
+        "Задачи безусловной оптимизации состоят в поиске максимума или минимума заданной функции при отсутствии каких-либо ограничений."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d31a6e29",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1873d311",
+      "cell_type": "markdown",
+      "source": [
+        "В этом разделе мы рассмотрим логистическую задачу нелинейной безусловной оптимизации по поиску оптимальной локации складского помещения.\r\n\r\nВ целях сокращения логистических расходов складское помещение должно быть размещено на оптимальном удалении от четырех предприятий, поставки на которые осуществляются с этого склада.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c2f2690b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d630cd6e",
+      "cell_type": "markdown",
+      "source": [
+        "## 1. Создание нелинейной оптимизационной задачи\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4a06ae09",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5eb103a7",
+      "cell_type": "markdown",
+      "source": [
+        "Нелинейная оптимизационная задача подразумевает наличие нелинейной целевой функции или нелинейных условий, наложенных на поиск оптимального решения, или обоих факторов одновременно.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "752b9738",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f5753014",
+      "cell_type": "markdown",
+      "source": [
+        "Создание нелинейной оптимизационной задачи отличается от создания линейной оптимизационной задачи применением нелинейного решателя. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1e0cc5f0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8c5de96d",
+      "cell_type": "markdown",
+      "source": [
+        "Для решения данной задачи мы используем оптимизационную библиотеку <code>JuMP</code> и нелинейный решатель <code>Ipopt</code>. Для их использования необходимо выполнить команду ниже:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6700a3d8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "80835aa9",
+      "cell_type": "code",
+      "source": [
+        "using JuMP, Ipopt;"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4902a715",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "56383d41",
+      "cell_type": "markdown",
+      "source": [
+        "`Ipopt` (Interior Point OPTimizer) – библиотека для нелинейной оптимизации задач большой размерности. Подробную документацию по этой библиотеке можно найти на сайте https://github.com/coin-or/Ipopt."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e5061cc3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c8c84ee4",
+      "cell_type": "markdown",
+      "source": [
+        "С помощью библиотеки `Ipopt` оптимизационные задачи решаются **методом внутренней точки** (**interior-point method**), который позволяет решать выпуклые задачи оптимизации с условиями, заданными в виде неравенств. В этом методе исходную для поиска точку можно выбирать только внутри допустимой области."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4426be34",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2a1998ab",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 1"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "0d7b5e78",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "59716d21",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте оптимизационную задачу, применив к ней нелинейный решатель <code>Ipopt</code>, и сохраните ее в переменной <code>NL_prob</code>.      "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "14238997",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ef36878f",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1cf75a84",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "294e74e7",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "96e9e921",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4ffb1a5c",
+      "cell_type": "code",
+      "source": [
+        "NL_prob = Model(Ipopt.Optimizer)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7f74f9ba",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "8cc76435",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 2"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "8c47cc8b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "87a0fedf",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте переменные <code>x</code> и <code>y</code>, определяющие позицию склада в двумерном пространстве, и присвойте их вашей оптимизационной задаче. Для текущей задачи через запятую необходимо указать, что значение переменных не может быть меньше нуля. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "eadcf20f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4b9b97df",
+      "cell_type": "code",
+      "source": [
+        "\r\n"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "101ef27f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b45683ec",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d1e5f215",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "674f5d52",
+      "cell_type": "code",
+      "source": [
+        "@variable(NL_prob, x >= 0);\r\n@variable(NL_prob, y >= 0);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "fd6e9951",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "eb101720",
+      "cell_type": "markdown",
+      "source": [
+        "## 2. Ввод координат предприятий"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "82018874",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "29dfd85f",
+      "cell_type": "markdown",
+      "source": [
+        "Склад обслуживает 4 предприятия, имеющие разные координаты. Координаты можно ввести в виде соответствующих четырехэлементных векторов <code>X</code> и <code>Y</code>. Координаты следует перевести в тип float для осуществления последующих расчетов. Это можно сделать, добавив <code>.</code> после каждого значения.\r\n\r\nВыполните команду ниже для ввода координат предприятий:\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "212d9f14",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "7bc9aee8",
+      "cell_type": "code",
+      "source": [
+        "X = [23., 34., 45., 72.];\r\nY = [11., 61., 19., 38.];"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1f6c6a76",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "44d510c2",
+      "cell_type": "markdown",
+      "source": [
+        "## 3. Ввод начальных координат склада"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d2e1dbe4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b32d7d6a",
+      "cell_type": "markdown",
+      "source": [
+        "В некоторых случаях для решения оптимизационных задач оптимизируемым переменным необходимо задать начальные значения. В данном случае вы можете присвоить переменным <code>x</code> и <code>y</code> произвольные значения. Начальные значения не повлияют на конечный результат.\r\nВыполните команду ниже для ввода начальных координат оптимизируемых переменных <code>x</code> и <code>y</code>:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "535ba4e8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "13f424c7",
+      "cell_type": "code",
+      "source": [
+        "set_start_value(x, 1) \r\nset_start_value(y, 1)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "71164ee1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "ec828a72",
+      "cell_type": "markdown",
+      "source": [
+        "## 4. Создание нелинейной целевой функции"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "63947945",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1ef882cb",
+      "cell_type": "markdown",
+      "source": [
+        "Для создания нелинейной целевой функции необходимо использовать команду <code>@NLobjective()</code>. В скобках через запятую указывается имя оптимизационной задачи, которой присваивается целевая функция, *Min* или *Max* для нахождения минимального или максимального значения и математическое выражение целевой функции."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "05bdf3e2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "7abaaf90",
+      "cell_type": "markdown",
+      "source": [
+        "Расчет расстояния между складом и отдельно взятым предприятием осуществляется с помощью теоремы Пифагора по разнице координат точек:\r\n$$R=\\sqrt{(x - X)^2 + (y - Y)^2}$$\r\nДля расчета расстояния между складом и всеми предприятиями необходимо повторить операцию с координатами всех предприятий и суммировать результат:\r\n$$R_{total}=\\sum_{i=1}^{4}\\sqrt{(x - X_i)^2 + (y - Y_i)^2}$$\r\nЦелевым значением нашей задачи являются двумерные координаты оптимальной локации склада, при которых сумма расстояний от склада до всех предприятий ($R_{total}$) принимает минимальное значение."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2f9777a2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9c5ab2de",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 3"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "fa6ddd96",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a376c625",
+      "cell_type": "markdown",
+      "source": [
+        "С помощью команды <code>@NLobjective()</code> создайте целевую функцию, содержащую описанное выше выражение для расчета суммы расстояний от склада до всех предприятий $R_{total}$. Присвойте функцию оптимизационной задаче <code>NL_prob</code>.\r\n\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "086d8815",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0f0d505a",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1412b5a5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "20a668d2",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Подсказка</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d6e808da",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 3,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "6f0b9f0a",
+      "cell_type": "markdown",
+      "source": [
+        "Для суммирования расстояний между складом и всеми четырьмя предприятиями необходимо повторить операцию 4 раза. Этого можно достичь, задав цикл `for i = 1:4` внутри скобок команды sum()."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "003fff11",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "104cad66",
+      "cell_type": "markdown",
+      "source": [
+        "##### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ab082e32",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b7d059c4",
+      "cell_type": "code",
+      "source": [
+        "@NLobjective(NL_prob, Min, sum(sqrt((x - X[i])^2 + (y - Y[i])^2) for i = 1:4))"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "57092da6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "24edf7f7",
+      "cell_type": "markdown",
+      "source": [
+        "## 5. Решение нелинейной оптимизационной задачи"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9d4064ab",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d22934bd",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 4"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1e0a0be2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e21bc912",
+      "cell_type": "markdown",
+      "source": [
+        "Используйте команды <code>optimize!()</code>, <code>print()</code> и <code>objective_value()</code> для решения, вывода результата и целевого значения оптимизационной задачи <code>NL_prob</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ef06f49a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "52faf2f6",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "e3dbc3a3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "54f42294",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "9556f132",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "1ac00d16",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "6f4f2567",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "1268ba17",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "be1b7ddf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 3,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8f6fda72",
+      "cell_type": "code",
+      "source": [
+        "optimize!(NL_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "990a8a22",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7d64fe2a",
+      "cell_type": "code",
+      "source": [
+        "print(NL_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "dbbc3006",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c02dabdb",
+      "cell_type": "code",
+      "source": [
+        "objective_value(NL_prob)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "96ea9244",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "eeba3342",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 5"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2d36e2fb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "06ba6f9d",
+      "cell_type": "markdown",
+      "source": [
+        "Используйте команду <code>value()</code> с аргументами <code>x</code> и <code>y</code> для получения координат оптимального расположения склада. Сохраните новые значения в переменных <code>x_opt</code> и <code>y_opt</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d6cfa6a2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "077097bb",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "cdcffbd3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6724edea",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "cddd3ac4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "96d52793",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "64902bd3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "11b51429",
+      "cell_type": "code",
+      "source": [
+        "x_opt = value(x)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7191c383",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "70873b7b",
+      "cell_type": "code",
+      "source": [
+        "y_opt = value(y)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7b549ba3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "98de71b5",
+      "cell_type": "markdown",
+      "source": [
+        "## 6. Визуализация результатов"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9464917b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "3f83b3e0",
+      "cell_type": "markdown",
+      "source": [
+        "Для визуализации результатов на графике мы используем библиотеку <code>Plots</code>. Для ее использования необходимо выполнить команду ниже:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "465f7c77",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f12958cb",
+      "cell_type": "code",
+      "source": [
+        "using Plots;"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "fae77303",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "957a5146",
+      "cell_type": "markdown",
+      "source": [
+        "Задайте параметры графиков, запустив команду ниже:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f2a04fd9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "420914b7",
+      "cell_type": "code",
+      "source": [
+        "gr(size=(1700, 700), legend=false, grid=true, widen=1.5, ticks = 20)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "ebedc4d8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "85c84f64",
+      "cell_type": "markdown",
+      "source": [
+        "Отобразите позиции предприятий на графике. Внутри команды <code>plot</code> вы можете задать дополнительные параметры визуализации, такие как форма, цвет и размер маркера."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9a0d5e87",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4c0406c7",
+      "cell_type": "code",
+      "source": [
+        "Plots.plot(X, Y, seriestype=:scatter,markershape=:hexagon, color = :orange, markersize = 5, markerstrokewidth=1, aspect_ratio = :equal)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "613fa40d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "22e12fe4",
+      "cell_type": "markdown",
+      "source": [
+        "Отобразите оптимальную позицию склада на том же графике. Для этого используйте <code>!</code> после команды <code>plot</code>. Вы можете изменить параметры визуализации внутри команды <code>plot</code> для наглядности. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "62d5f722",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a81230a4",
+      "cell_type": "markdown",
+      "source": [
+        "Обратите внимание, что получив координаты <code>x_opt</code> и <code>y_opt</code> с помощью команды <code>value()</code>, мы изменили тип переменной и нам нужно заключить их в <code>[]</code> для передачи в команду <code>plot()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "8d89cb1b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "648dca0f",
+      "cell_type": "code",
+      "source": [
+        "plot!([x_opt], [y_opt], seriestype=:scatter,markershape=:diamond, color = :green, markersize = 5, markerstrokewidth=1)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "637b1ce9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d2a5d4b0",
+      "cell_type": "markdown",
+      "source": [
+        "Вы также можете вывести дополнительные пояснения на график."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6b8e1ce2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9db76245",
+      "cell_type": "code",
+      "source": [
+        "ptstr = string([x_opt y_opt])\r\nxvalstr = string(\"   Оптимальная локация\")\r\nannotate!(([x_opt y_opt]...,text(xvalstr, 13, :left, :black)))"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "623c3280",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d113f3b7",
+      "cell_type": "markdown",
+      "source": [
+        "## Тест для получения сертификата\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6b91badb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f276368d",
+      "cell_type": "markdown",
+      "source": [
+        "<p align=\"center\">\r\n<a style=\"padding: 8px 16px;\r\n    border: 3px blue;\r\n    border-radius: 15px;\r\n    color: white;\r\n    background-color: #1b83ba;\r\n    font-size: 24pt; \r\n    text-decoration: none;\" href=\"https://my.etude.org/link/qTMxZZhZhgSdUgxIqPY8V2Oj4RAHdadM5e-pcBhquB_Ab8GSxprZF5BZ589szp7ThZC69v73VNrp0NGZae7smAEnN1gEBEG76U4mGRUvNpAJT0R5vdvatggpM9fTCD6MPVDmc9O3dZ3ScBi8hzWrAY-85OuyIn2jxwOUbRLl8FE=?engee\"\r\n     target=\"_blank\">Пройти тест по разделу >></a>\r\n</p>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c80dd9a9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    }
+  ]
+}
\ No newline at end of file
diff --git "a/03. \320\243\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript" "b/03. \320\243\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript"
index d7d0c6f92cf9a87e95ceb3c9718e053f0f8cad1a..c3d394501fabd49f766bca760d2b50fd06764a40 100644
--- "a/03. \320\243\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript"	
+++ "b/03. \320\243\321\201\320\273\320\276\320\262\320\275\320\260\321\217 \320\276\320\277\321\202\320\270\320\274\320\270\320\267\320\260\321\206\320\270\321\217.ngscript"	
@@ -1 +1,4564 @@
-{"cells":[{"cell_type":"markdown","source":["# Условная оптимизация"],"id":"d29c980e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f6f4c649"}},{"cell_type":"markdown","source":["Задачи условной оптимизации состоят в поиске максимума или минимума заданной функции при наличии определенных условий, накладывающих ряд ограничений на возможные решения задачи."],"id":"c74dab53","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f609a092"}},{"cell_type":"markdown","source":["В этом разделе мы рассмотрим задачу условной оптимизации по подбору оптимального рациона питания."],"id":"199fdbcd","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"745473af"}},{"cell_type":"markdown","source":["## 1. Создание условной оптимизационной задачи"],"id":"cd2caff4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4ff05e94"}},{"cell_type":"markdown","source":["Для решения данной задачи мы используем оптимизационную библиотеку <code>JuMP</code> и линейный решатель <code>GLPK</code>. Нам также понадобятся библиотеки <code>XLSX</code> и <code>DataFrames</code> для работы с табличными данными и библиотека <code>Plots</code> для визуализации результатов. Для их использования необходимо выполнить команду ниже:"],"id":"4aa7afb2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4832462a"}},{"outputs":[],"cell_type":"code","source":["Pkg.add([\"GLPK\", \"XLSX\", \"JuMP\"])"],"id":"evnnyn7f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"cfzgrthf"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["using JuMP, GLPK, XLSX, DataFrames, Plots;"],"id":"c1473b7b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c77ccfb2"},"execution_count":0},{"cell_type":"markdown","source":["Загрузите таблицу с данными, выполнив команду ниже: "],"id":"b9065907","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7b427f99"}},{"outputs":[],"cell_type":"code","source":["Nutrition = DataFrame(XLSX.readtable(\"nutrition.xlsx\", \"Sheet1\"))"],"id":"dabc599f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b8f239a1"},"execution_count":0},{"cell_type":"markdown","source":["Таблица содержит информацию о содержании питательных веществ в двадцати различных продуктах, а также их условную цену."],"id":"c40a5580","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6e271c0f"}},{"cell_type":"markdown","source":["### ✏️Задание 1"],"id":"b902071e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e6c34755"}},{"cell_type":"markdown","source":["Создайте оптимизационную задачу, применив к ней линейный решатель <code>GLPK</code>, и сохраните ее в переменной <code>Opt_ration</code>.      "],"id":"9578c16a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"58be6041"}},{"outputs":[],"cell_type":"code","source":[""],"id":"01bcba34","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9d977a82"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"7c1f5148","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"b626b814"}},{"outputs":[],"cell_type":"code","source":["Opt_ration = Model(GLPK.Optimizer)"],"id":"1ad4fafe","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"1720629d"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 2"],"id":"964d2c13","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"073ebc47"}},{"cell_type":"markdown","source":["Используя команду <code>@variable()</code>, создайте переменную <code>Portions</code>, определяющую количество порций того или иного продукта, которое будет рассчитано исходя из поставленных нами условий подбора рациона. Используйте <code>Portions[]</code>, чтобы обозначить необходимое количество элементов переменной <code>Portions</code> для размещения всех видов продуктов таблицы <code>Nutrition</code>."],"id":"cb3db56b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5edcbeb7"}},{"cell_type":"markdown","source":["Для текущей задачи через запятую также необходимо указать, что значения переменных не могут быть меньше нуля (<code>lower_bound = 0</code>)."],"id":"d726d12e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7bb2819c"}},{"outputs":[],"cell_type":"code","source":[""],"id":"0a3317f3","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"eca1f462"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"be14055c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"d943c128"}},{"outputs":[],"cell_type":"code","source":["@variable(Opt_ration, Portions[1:20], lower_bound = 0)"],"id":"823d4adc","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"6a8154c0"},"execution_count":0},{"cell_type":"markdown","source":["Данная переменная будет содержать количество порций того или иного продукта, полученное нами после выполнения условий подбора рациона.\r\n"],"id":"060629d3","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"a100f633"}},{"cell_type":"markdown","source":["### ✏️Задание 3 "],"id":"191c7da4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9e50b0b1"}},{"cell_type":"markdown","source":["В данном упражнении мы минимизируем затраты на наш рацион. Поэтому целевая функция нашей оптимизационной задачи будет основана на стоимости продуктов питания."],"id":"a3645cd8","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"52d0ced8"}},{"cell_type":"markdown","source":["Перемножьте столбец <code>Nutrition.\"Price\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Price</code>."],"id":"45210933","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c0a42450"}},{"outputs":[],"cell_type":"code","source":[""],"id":"df896412","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"bd7ba9f5"},"execution_count":0},{"cell_type":"markdown","source":["#### Подсказка"],"id":"227adbf3","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":4,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"ce24e095"}},{"cell_type":"markdown","source":["Используйте <code>.*</code> для перемножения векторов."],"id":"8aaa4f22","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"fe096ac9"}},{"cell_type":"markdown","source":["##### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"aa393e90","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":false},"id":"9424e64a"}},{"outputs":[],"cell_type":"code","source":["Price = Nutrition.\"Price\" .* Portions"],"id":"03af655b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"5eb4a19b"},"execution_count":0},{"cell_type":"markdown","source":["Теперь переменная <code>Price</code> будет содержать стоимость полученного нами в дальнейшем количества порций того или иного продукта питания."],"id":"390867ad","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"01d057ab"}},{"cell_type":"markdown","source":["### ✏️Задание 4 "],"id":"c1806b7f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"66796751"}},{"cell_type":"markdown","source":["Суммируйте все значения переменной <code>Price</code>, чтобы получить стоимость всего рациона, и сохраните результат в переменной <code>TotalPrice</code>."],"id":"4ec565ec","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"0ae3c23b"}},{"outputs":[],"cell_type":"code","source":[""],"id":"1fadc5f3","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"99fc4eeb"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"6c24db1b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"a376fed9"}},{"outputs":[],"cell_type":"code","source":["TotalPrice = sum(Price)"],"id":"514c778a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"bb9ebbbf"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 5"],"id":"20ef4141","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"14e36f03"}},{"cell_type":"markdown","source":["Создайте целевую функцию для нашей оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@objective()</code>. Помните, что нам необходимо найти возможный минимум затрат на все продукты питания, из которых мы можем составить наш рацион."],"id":"f7331848","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5ac47f69"}},{"outputs":[],"cell_type":"code","source":[""],"id":"f3bcf8f3","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"cf8140b5"},"execution_count":0},{"cell_type":"markdown","source":["#### Подсказка"],"id":"b54372fb","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":3,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"941f0630"}},{"cell_type":"markdown","source":["Используйте <code>Min</code> и <code>TotalPrice</code> через запятую как второй и третий аргумент в команде <code>@objective()</code>."],"id":"17ea76da","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"16d8f5d5"}},{"cell_type":"markdown","source":["##### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"749109cf","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":false},"id":"0014a533"}},{"outputs":[],"cell_type":"code","source":["@objective(Opt_ration, Min, TotalPrice)"],"id":"847982a7","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"0cf27322"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 6"],"id":"21279400","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"866e36f6"}},{"cell_type":"markdown","source":["Проверьте работу целевой функции на данном этапе. Для этого решите оптимизационную задачу и визуализируйте полученный результат."],"id":"5028f372","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fc495900"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."],"id":"595dde80","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"69c05c2a"}},{"outputs":[],"cell_type":"code","source":[""],"id":"d5b2a4af","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c6771992"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"22e08b12","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"094b422c"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"1ed34ce8","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"ea83d826"}},{"outputs":[],"cell_type":"code","source":["optimize!(Opt_ration)"],"id":"64bca8ee","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"3ac1171f"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["display(Opt_ration)"],"id":"6748987c","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"cc868755"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 7"],"id":"782dce3f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"542d182e"}},{"cell_type":"markdown","source":["Получите оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в новой переменной <code>Op_portions</code>."],"id":"a6feb038","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e8f8c97a"}},{"outputs":[],"cell_type":"code","source":[""],"id":"defc233b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"22fdb181"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"7e2389d4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"26933775"}},{"outputs":[],"cell_type":"code","source":["Op_portions = value.(Portions)"],"id":"6a168833","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"69b9f6a0"},"execution_count":0},{"cell_type":"markdown","source":["Совпадают ли результаты с вашими ожиданиями? Попробуйте объяснить, почему оптимизированные значения равны нулю. "],"id":"83145c2e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"3cfb1245"}},{"cell_type":"markdown","source":["### ✏️Задание 8"],"id":"c797b840","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a92c4aed"}},{"cell_type":"markdown","source":["Для визуализации результатов мы будем использовать библиотеку <code>Plots</code>. Для этого мы присоединим вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведем в тип <code>DataFrame</code> и сохраним в новой переменной <code>Price_port</code>. Затем передадим нашу новую переменную в команду <code>plot</code>, укажем имена столбцов, которые хотим визуализировать, и поставим тип графика как <code>bar</code>. Столбец `Op_portions`, значения которого мы хотим визуализировать, при добавлении к таблице по умолчанию получает имя `x1`. Выполните команды ниже: "],"id":"cb640c86","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7530670c"}},{"outputs":[],"cell_type":"code","source":["Price_port = DataFrame([Nutrition Op_portions])\r\nplot(Price_port.Name, Price_port.x1, seriestype=\"bar\")"],"id":"0a76b4ae","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"96bcadab"},"execution_count":0},{"cell_type":"markdown","source":["## 2. Условие калорийности рациона"],"id":"1b89c0c5","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a368ecba"}},{"cell_type":"markdown","source":["Теперь создадим условия оптимизации нашего рациона. Мы оптимизируем рацион по количеству калорий, белков, углеводов и жиров, которые он должен содержать."],"id":"94959904","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b22b1db3"}},{"cell_type":"markdown","source":["Для начала установим границы калорийности нашего рациона."],"id":"db15e5ab","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"572c30c3"}},{"cell_type":"markdown","source":["### ✏️Задание 9"],"id":"cad68e56","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7323a9e7"}},{"cell_type":"markdown","source":["Перемножьте столбец <code>Nutrition.\"Calories\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Calories</code>."],"id":"7d85d28a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"8ce81888"}},{"outputs":[],"cell_type":"code","source":[""],"id":"fc712645","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9607ddc5"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"542578c1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"310f5fbc"}},{"outputs":[],"cell_type":"code","source":["Calories = Nutrition.\"Calories\" .* Portions"],"id":"5f0f3e88","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"3dbc2ab2"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 10 "],"id":"d37cbb32","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"af7056a8"}},{"cell_type":"markdown","source":["Рассчитайте сумму всех элементов вектора <code>Calories</code> и сохраните ее в переменной <code>TotalCals</code>."],"id":"e135584e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f0a8b7a8"}},{"outputs":[],"cell_type":"code","source":[""],"id":"31414976","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"908d9581"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"7c506fc2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"e05a04b7"}},{"outputs":[],"cell_type":"code","source":["TotalCals = sum(Calories)"],"id":"d143c157","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"572062ee"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 11"],"id":"d5b1d7cc","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c5930968"}},{"cell_type":"markdown","source":["Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C1</code> и границы переменной <code>TotalCals</code> между 2000 и 2500 калорий. "],"id":"edb1abd4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"239dc5c6"}},{"outputs":[],"cell_type":"code","source":[""],"id":"7e75da74","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b22c7cf8"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"7164ab08","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"4171ec4c"}},{"outputs":[],"cell_type":"code","source":["@constraint(Opt_ration, C1, 2000 <= TotalCals <= 2500)"],"id":"4e5f390c","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"edb3f952"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 12"],"id":"f5f93272","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"80a60ee4"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."],"id":"8b7f3bcf","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"92759a37"}},{"outputs":[],"cell_type":"code","source":[""],"id":"a82bda31","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"8c24d6bd"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"725ff32b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b66191db"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"f66b4556","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"017b73f2"}},{"outputs":[],"cell_type":"code","source":["optimize!(Opt_ration)"],"id":"0c64e5b0","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"8ee35fb6"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["display(Opt_ration)"],"id":"06f54864","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"42f7b413"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 13"],"id":"6ace1f03","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"44eaea28"}},{"cell_type":"markdown","source":["Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."],"id":"966278c5","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"34d1d681"}},{"cell_type":"markdown","source":["Затем визуализируйте новые результаты. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Cals_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code> по аналогии с **Заданием 8**."],"id":"ec15f888","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3119ea31"}},{"outputs":[],"cell_type":"code","source":[""],"id":"a170f44d","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b9b78cf5"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"fc181745","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6f81cae1"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"6496b4e1","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"bb726751"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"45a956f2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":4,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"d9101f95"}},{"outputs":[],"cell_type":"code","source":["Op_portions = value.(Portions)"],"id":"073e5425","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"463cf948"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["Cals_port = DataFrame([Nutrition Op_portions])"],"id":"7d3f4a5b","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"7cd3192c"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["plot(Cals_port.Name, Cals_port.x1, seriestype=\"bar\")"],"id":"41bd1c9f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"6419cea2"},"execution_count":0},{"cell_type":"markdown","source":["Теперь результат отображает выполнение условия калорийности при минимальной стоимости рациона."],"id":"bf0eb400","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"d0832b4f"}},{"cell_type":"markdown","source":["## 3. Условие наличия минимального количества белка"],"id":"a21b5840","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3038eae0"}},{"cell_type":"markdown","source":["Теперь мы зададим дополнительное условие по наличию минимального количества белка в нашем рационе."],"id":"9350caa9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4993a67b"}},{"cell_type":"markdown","source":["### ✏️Задание 14"],"id":"0975408f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6572c769"}},{"cell_type":"markdown","source":["Перемножьте столбец <code>Nutrition.\"Protein (g)\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Protein</code>.\r\n"],"id":"796160ae","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c0202c4d"}},{"outputs":[],"cell_type":"code","source":[""],"id":"ee1d3832","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"0a0aa5f7"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"07947469","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"9db841b5"}},{"outputs":[],"cell_type":"code","source":["Protein = Nutrition.\"Protein (g)\" .* Portions"],"id":"c73bea0e","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"b51a0731"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 15"],"id":"ab525975","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"dd34f756"}},{"cell_type":"markdown","source":["Рассчитайте сумму всех элементов вектора <code>Protein</code> и сохраните в переменной <code>TotalProt</code>."],"id":"d42b5b3c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fb9eb789"}},{"outputs":[],"cell_type":"code","source":[""],"id":"e017558e","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"05577e68"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"d6b7072e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"ee26524e"}},{"outputs":[],"cell_type":"code","source":["TotalProt = sum(Protein)"],"id":"2d3df0c2","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"39d36934"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 16"],"id":"3b59d1ae","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"556fe634"}},{"cell_type":"markdown","source":["Создадим условие, чтобы наш рацион содержал как минимум 100 граммов белка."],"id":"51400f05","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e3cbb9ba"}},{"cell_type":"markdown","source":["Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C2</code> и значение переменной <code>TotalProt</code> больше или равно (>=) 100. "],"id":"2ea42467","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7cbcc13f"}},{"outputs":[],"cell_type":"code","source":[""],"id":"880573c5","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"843e8ad7"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"bddc874f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"3ccf5f7a"}},{"outputs":[],"cell_type":"code","source":["@constraint(Opt_ration, C2, TotalProt >= 100)"],"id":"53e8f77c","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"33f8ca38"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 17"],"id":"9f01971b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b433f704"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."],"id":"9bb1639d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f178a05e"}},{"outputs":[],"cell_type":"code","source":[""],"id":"87f30960","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1c64a659"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"41364673","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f8c696d8"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"9a4995af","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"dcc30c7a"}},{"outputs":[],"cell_type":"code","source":["optimize!(Opt_ration)"],"id":"1fc0ad87","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"4e80dd43"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["display(Opt_ration)"],"id":"d59f9b6a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"312a3c52"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 18"],"id":"08011ce9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7b0f41ce"}},{"cell_type":"markdown","source":["Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."],"id":"d8ffad23","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c7c9d8e7"}},{"cell_type":"markdown","source":["Затем визуализируйте новые результаты. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Prot_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code>."],"id":"cf25ebe9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"26bcaa8d"}},{"outputs":[],"cell_type":"code","source":[""],"id":"145aa1e1","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fe2110d1"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"e787f3c6","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f05dc12d"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"41c829cc","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1831db9b"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"9a8c8c74","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":4,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"cd7aeaec"}},{"outputs":[],"cell_type":"code","source":["Op_portions = value.(Portions)"],"id":"65942c2c","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"361234d8"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["Prot_port = DataFrame([Nutrition Op_portions])"],"id":"e4d5d19f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"c71f265f"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["plot(Prot_port.Name, Prot_port.x1, seriestype=\"bar\")"],"id":"4c52b571","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"cfaa3c0e"},"execution_count":0},{"cell_type":"markdown","source":["Теперь результат отображает выполнение условий калорийности и наличия минимального количества белка при минимальной стоимости рациона."],"id":"69bd4494","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"f6bacafd"}},{"cell_type":"markdown","source":["## 4. Условие наличия минимального количества жиров"],"id":"6909cf79","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"696dd462"}},{"cell_type":"markdown","source":["Зададим дополнительное условие по наличию минимального количества жиров в нашем рационе."],"id":"b4c31855","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ec4704fd"}},{"cell_type":"markdown","source":["### ✏️Задание 19"],"id":"9611fed3","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d05d6870"}},{"cell_type":"markdown","source":["Перемножьте столбец <code>Nutrition.\"Fat (g)\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Fats</code>.\r\n"],"id":"620bff59","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"71128bcc"}},{"outputs":[],"cell_type":"code","source":[""],"id":"180bed11","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e6575cf2"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"9a1474df","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"246d3b2e"}},{"outputs":[],"cell_type":"code","source":["Fats = Nutrition.\"Fat (g)\".* Portions"],"id":"9a59a939","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"5e885b3d"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 20"],"id":"04377942","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a03cf6a9"}},{"cell_type":"markdown","source":["Рассчитайте сумму всех элементов вектора <code>Fats</code> и сохраните в переменной <code>TotalFats</code>."],"id":"c15ab0e1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b45f46f0"}},{"outputs":[],"cell_type":"code","source":[""],"id":"f7ac34e9","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7f8b6795"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"2b6c15bb","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"b027cb89"}},{"outputs":[],"cell_type":"code","source":["TotalFats = sum(Fats)"],"id":"f39726c9","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"dd24609d"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 21"],"id":"1f6e8bff","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3af300ae"}},{"cell_type":"markdown","source":["Создадим условие, чтобы наш рацион содержал как минимум 70 граммов жиров."],"id":"e35abf07","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"628ffd43"}},{"cell_type":"markdown","source":["Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C3</code> и значение переменной <code>TotalFats</code> больше или равно (>=) 70."],"id":"76c62c66","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e001c473"}},{"outputs":[],"cell_type":"code","source":[""],"id":"5a9c9657","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"39d35ef0"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"d8681d47","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"8dff7cb3"}},{"outputs":[],"cell_type":"code","source":["@constraint(Opt_ration, C3,  TotalFats >= 70)"],"id":"4c8e2259","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"b8358a8e"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 22"],"id":"0d107213","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3618072e"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."],"id":"f0a6642b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"07370e30"}},{"outputs":[],"cell_type":"code","source":[""],"id":"d300ce3f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a939697a"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"98dfac30","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a130b9a6"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"f84b1dcd","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"9d9319eb"}},{"outputs":[],"cell_type":"code","source":["optimize!(Opt_ration)"],"id":"4d872b45","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"4016b110"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["display(Opt_ration)"],"id":"27606596","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"b4fab54c"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 23"],"id":"71d208a9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"30169674"}},{"cell_type":"markdown","source":["Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."],"id":"0ffea48e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"136118ec"}},{"cell_type":"markdown","source":["Затем визуализируйте новые результаты. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Fats_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code>."],"id":"45f8cb60","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"688c46c4"}},{"outputs":[],"cell_type":"code","source":[""],"id":"68e73903","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4f17a752"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"31d14338","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5a9d9da6"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"f4029fc6","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"62845327"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"9dcf3563","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":3,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"4db98646"}},{"outputs":[],"cell_type":"code","source":["Op_portions = value.(Portions)"],"id":"9da1cc67","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"37380d11"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["Fats_port = DataFrame([Nutrition Op_portions])"],"id":"eb3cf284","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"905dc35a"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["plot(Fats_port.Name, Fats_port.x1, seriestype=\"bar\")"],"id":"7bb687d8","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"5537aaf6"},"execution_count":0},{"cell_type":"markdown","source":["## 5. Условие наличия минимального количества углеводов"],"id":"3a9494d0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c236d79c"}},{"cell_type":"markdown","source":["Зададим последнее дополнительное условие по наличию минимального количества углеводов в нашем рационе."],"id":"70764c00","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d52fccfc"}},{"cell_type":"markdown","source":["### ✏️Задание 24"],"id":"90683f05","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6963e8a6"}},{"cell_type":"markdown","source":["Перемножьте столбец <code>Nutrition.\"Carbohydrate (g)\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Carbs</code>."],"id":"5b1fbd34","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"cc43ba7e"}},{"outputs":[],"cell_type":"code","source":[""],"id":"a86de430","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c420e7be"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"d9a052c6","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"087b5e50"}},{"outputs":[],"cell_type":"code","source":["Carbs = Nutrition.\"Carbohydrate (g)\" .* Portions"],"id":"28bc681e","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"2511c521"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 25"],"id":"9df4c41a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"25333a5b"}},{"cell_type":"markdown","source":["Рассчитайте сумму всех элементов вектора <code>Carbs</code> и сохраните в переменной <code>TotalCarbs</code>."],"id":"0531a8a7","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"43cd940d"}},{"outputs":[],"cell_type":"code","source":[""],"id":"f18783c5","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"37abcf60"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"13f6e4f4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"1d2ae58c"}},{"outputs":[],"cell_type":"code","source":["TotalCarbs = sum(Carbs)"],"id":"3f7c7f11","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"d4cc061c"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 26"],"id":"22b990cb","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"02160b5a"}},{"cell_type":"markdown","source":["Создадим условие, чтобы наш рацион содержал как минимум 400 граммов углеводов."],"id":"0828d4da","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2805a567"}},{"cell_type":"markdown","source":["Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C4</code> и значение переменной <code>TotalCarbs</code> больше или равно (>=) 400."],"id":"3339ccd8","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"30dc02d8"}},{"outputs":[],"cell_type":"code","source":[""],"id":"6c5d0a03","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4e99e4c2"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"b7cb0b65","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"3ec0a39c"}},{"outputs":[],"cell_type":"code","source":["@constraint(Opt_ration, C4, TotalCarbs >= 400)"],"id":"0cdd87fd","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"7f1032c3"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 27"],"id":"697489f1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"849fde35"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."],"id":"f8604211","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"70206915"}},{"outputs":[],"cell_type":"code","source":[""],"id":"18809596","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f8ff3d40"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"c5f1803f","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c64e0c07"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"f673095c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"02d8ade1"}},{"outputs":[],"cell_type":"code","source":["optimize!(Opt_ration)"],"id":"02c23945","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"7a34402b"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["display(Opt_ration)"],"id":"e7cbf5bb","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"16821441"},"execution_count":0},{"cell_type":"markdown","source":["## 6. Итоговые результаты "],"id":"d88306b5","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"34060dcc"}},{"cell_type":"markdown","source":["Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."],"id":"b8bf1270","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"699f4f5d"}},{"cell_type":"markdown","source":["Визуализируйте итоговый результат оптимизационной задачи. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Total_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code>."],"id":"af348f82","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a45de88e"}},{"outputs":[],"cell_type":"code","source":[""],"id":"9152bd87","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"31cae01a"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"b01d6379","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c45dbf6b"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"242c7bf2","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5d3c3735"},"execution_count":0},{"cell_type":"markdown","source":["Вы можете вывести информацию о решениях и убедиться, что они удовлетворяют заданным вами условиям с помощью команды <code>solution_summary()</code>."],"id":"31a290ad","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f744128f"}},{"outputs":[],"cell_type":"code","source":[""],"id":"af0c3a50","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"14fba39d"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"553d6b93","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":4,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"6adf7b38"}},{"outputs":[],"cell_type":"code","source":["Op_portions = value.(Portions)"],"id":"beb248d0","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"690e7e3f"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["Total_port = DataFrame([Nutrition Op_portions])"],"id":"7bc6761a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"2a55e1b9"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["plot(Total_port.Name, Total_port.x1, seriestype=\"bar\")"],"id":"a9fe6fda","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"8d094acb"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["solution_summary(Opt_ration)"],"id":"c3680178","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"9b5ee0ac"},"execution_count":0},{"cell_type":"markdown","source":["## Тест для получения сертификата\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"],"id":"d29bcabc","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"80ad445a"}},{"cell_type":"markdown","source":["<p align=\"center\">\r\n<a style=\"padding: 8px 16px;\r\n    border: 3px blue;\r\n    border-radius: 15px;\r\n    color: white;\r\n    background-color: #1b83ba;\r\n    font-size: 24pt; \r\n    text-decoration: none;\" href=\"https://my.etude.org/link/8ZbqTmayk3dAuH-WExVO_NvngJH4fEDfhU24gwSVcz0uSmRImg2NSrxBXBhE_RiuKlG2ap9F9po7ZrCV3rVVDVAMIQwT4IGWY16JbFiuLWuqvdxlKykLI18E_IKsyPkW4z8XrjyOFZ0Xn_pJd46UjFnJ-WhzK-PT-WNfYmsSXJU=?engee\"\r\n     target=\"_blank\">Пройти тест по разделу >></a>\r\n</p>"],"id":"f276368d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5bd0d7a4"}}],"nbformat_minor":5,"metadata":{"engee":{},"language_info":{"file_extension":".jl","name":"julia","version":"1.9.3"},"kernelspec":{"name":"ijulia-1.9","display_name":"IJulia 1.9.3","language":"julia"}},"nbformat":4}
\ No newline at end of file
+{
+  "nbformat": 4,
+  "nbformat_minor": 5,
+  "metadata": {
+    "kernelspec": {
+      "name": "ijulia-1.9",
+      "display_name": "IJulia 1.9.3",
+      "language": "julia"
+    },
+    "language_info": {
+      "name": "julia",
+      "file_extension": ".jl",
+      "version": "1.9.3"
+    },
+    "engee": {}
+  },
+  "cells": [
+    {
+      "id": "d29c980e",
+      "cell_type": "markdown",
+      "source": [
+        "# Условная оптимизация"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f6f4c649",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c74dab53",
+      "cell_type": "markdown",
+      "source": [
+        "Задачи условной оптимизации состоят в поиске максимума или минимума заданной функции при наличии определенных условий, накладывающих ряд ограничений на возможные решения задачи."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f609a092",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "199fdbcd",
+      "cell_type": "markdown",
+      "source": [
+        "В этом разделе мы рассмотрим задачу условной оптимизации по подбору оптимального рациона питания."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "745473af",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cd2caff4",
+      "cell_type": "markdown",
+      "source": [
+        "## 1. Создание условной оптимизационной задачи"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4ff05e94",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4aa7afb2",
+      "cell_type": "markdown",
+      "source": [
+        "Для решения данной задачи мы используем оптимизационную библиотеку <code>JuMP</code> и линейный решатель <code>GLPK</code>. Нам также понадобятся библиотеки <code>XLSX</code> и <code>DataFrames</code> для работы с табличными данными и библиотека <code>Plots</code> для визуализации результатов. Для их использования необходимо выполнить команду ниже:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4832462a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c1473b7b",
+      "cell_type": "code",
+      "source": [
+        "using JuMP, GLPK, XLSX, DataFrames, Plots;"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c77ccfb2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b9065907",
+      "cell_type": "markdown",
+      "source": [
+        "Загрузите таблицу с данными, выполнив команду ниже: "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7b427f99",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "dabc599f",
+      "cell_type": "code",
+      "source": [
+        "Nutrition = DataFrame(XLSX.readtable(\"nutrition.xlsx\", \"Sheet1\"))"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b8f239a1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c40a5580",
+      "cell_type": "markdown",
+      "source": [
+        "Таблица содержит информацию о содержании питательных веществ в двадцати различных продуктах, а также их условную цену."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6e271c0f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b902071e",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 1"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e6c34755",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9578c16a",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте оптимизационную задачу, применив к ней линейный решатель <code>GLPK</code>, и сохраните ее в переменной <code>Opt_ration</code>.      "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "58be6041",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "01bcba34",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "9d977a82",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7c1f5148",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b626b814",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1ad4fafe",
+      "cell_type": "code",
+      "source": [
+        "Opt_ration = Model(GLPK.Optimizer)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1720629d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "964d2c13",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 2"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "073ebc47",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cb3db56b",
+      "cell_type": "markdown",
+      "source": [
+        "Используя команду <code>@variable()</code>, создайте переменную <code>Portions</code>, определяющую количество порций того или иного продукта, которое будет рассчитано исходя из поставленных нами условий подбора рациона. Используйте <code>Portions[]</code>, чтобы обозначить необходимое количество элементов переменной <code>Portions</code> для размещения всех видов продуктов таблицы <code>Nutrition</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "5edcbeb7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d726d12e",
+      "cell_type": "markdown",
+      "source": [
+        "Для текущей задачи через запятую также необходимо указать, что значения переменных не могут быть меньше нуля (<code>lower_bound = 0</code>)."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7bb2819c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0a3317f3",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "eca1f462",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "be14055c",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d943c128",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "823d4adc",
+      "cell_type": "code",
+      "source": [
+        "@variable(Opt_ration, Portions[1:20], lower_bound = 0)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "6a8154c0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "060629d3",
+      "cell_type": "markdown",
+      "source": [
+        "Данная переменная будет содержать количество порций того или иного продукта, полученное нами после выполнения условий подбора рациона.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a100f633",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "191c7da4",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 3 "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9e50b0b1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a3645cd8",
+      "cell_type": "markdown",
+      "source": [
+        "В данном упражнении мы минимизируем затраты на наш рацион. Поэтому целевая функция нашей оптимизационной задачи будет основана на стоимости продуктов питания."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "52d0ced8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "45210933",
+      "cell_type": "markdown",
+      "source": [
+        "Перемножьте столбец <code>Nutrition.\"Price\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Price</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c0a42450",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "df896412",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "bd7ba9f5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "227adbf3",
+      "cell_type": "markdown",
+      "source": [
+        "#### Подсказка"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ce24e095",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 4,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8aaa4f22",
+      "cell_type": "markdown",
+      "source": [
+        "Используйте <code>.*</code> для перемножения векторов."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "fe096ac9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aa393e90",
+      "cell_type": "markdown",
+      "source": [
+        "##### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9424e64a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "03af655b",
+      "cell_type": "code",
+      "source": [
+        "Price = Nutrition.\"Price\" .* Portions"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5eb4a19b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "390867ad",
+      "cell_type": "markdown",
+      "source": [
+        "Теперь переменная <code>Price</code> будет содержать стоимость полученного нами в дальнейшем количества порций того или иного продукта питания."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "01d057ab",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c1806b7f",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 4 "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "66796751",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4ec565ec",
+      "cell_type": "markdown",
+      "source": [
+        "Суммируйте все значения переменной <code>Price</code>, чтобы получить стоимость всего рациона, и сохраните результат в переменной <code>TotalPrice</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "0ae3c23b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1fadc5f3",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "99fc4eeb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6c24db1b",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a376fed9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "514c778a",
+      "cell_type": "code",
+      "source": [
+        "TotalPrice = sum(Price)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "bb9ebbbf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "20ef4141",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 5"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "14e36f03",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f7331848",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте целевую функцию для нашей оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@objective()</code>. Помните, что нам необходимо найти возможный минимум затрат на все продукты питания, из которых мы можем составить наш рацион."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "5ac47f69",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f3bcf8f3",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "cf8140b5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b54372fb",
+      "cell_type": "markdown",
+      "source": [
+        "#### Подсказка"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "941f0630",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 3,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "17ea76da",
+      "cell_type": "markdown",
+      "source": [
+        "Используйте <code>Min</code> и <code>TotalPrice</code> через запятую как второй и третий аргумент в команде <code>@objective()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "16d8f5d5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "749109cf",
+      "cell_type": "markdown",
+      "source": [
+        "##### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "0014a533",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "847982a7",
+      "cell_type": "code",
+      "source": [
+        "@objective(Opt_ration, Min, TotalPrice)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "0cf27322",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "21279400",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 6"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "866e36f6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5028f372",
+      "cell_type": "markdown",
+      "source": [
+        "Проверьте работу целевой функции на данном этапе. Для этого решите оптимизационную задачу и визуализируйте полученный результат."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "fc495900",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "595dde80",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "69c05c2a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d5b2a4af",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c6771992",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "22e08b12",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "094b422c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "1ed34ce8",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ea83d826",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "64bca8ee",
+      "cell_type": "code",
+      "source": [
+        "optimize!(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "3ac1171f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6748987c",
+      "cell_type": "code",
+      "source": [
+        "display(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "cc868755",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "782dce3f",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 7"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "542d182e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a6feb038",
+      "cell_type": "markdown",
+      "source": [
+        "Получите оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в новой переменной <code>Op_portions</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e8f8c97a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "defc233b",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "22fdb181",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7e2389d4",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "26933775",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "6a168833",
+      "cell_type": "code",
+      "source": [
+        "Op_portions = value.(Portions)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "69b9f6a0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "83145c2e",
+      "cell_type": "markdown",
+      "source": [
+        "Совпадают ли результаты с вашими ожиданиями? Попробуйте объяснить, почему оптимизированные значения равны нулю. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3cfb1245",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c797b840",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 8"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a92c4aed",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cb640c86",
+      "cell_type": "markdown",
+      "source": [
+        "Для визуализации результатов мы будем использовать библиотеку <code>Plots</code>. Для этого мы присоединим вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведем в тип <code>DataFrame</code> и сохраним в новой переменной <code>Price_port</code>. Затем передадим нашу новую переменную в команду <code>plot</code>, укажем имена столбцов, которые хотим визуализировать, и поставим тип графика как <code>bar</code>. Столбец `Op_portions`, значения которого мы хотим визуализировать, при добавлении к таблице по умолчанию получает имя `x1`. Выполните команды ниже: "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7530670c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0a76b4ae",
+      "cell_type": "code",
+      "source": [
+        "Price_port = DataFrame([Nutrition Op_portions])\r\nplot(Price_port.Name, Price_port.x1, seriestype=\"bar\")"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "96bcadab",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "1b89c0c5",
+      "cell_type": "markdown",
+      "source": [
+        "## 2. Условие калорийности рациона"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a368ecba",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "94959904",
+      "cell_type": "markdown",
+      "source": [
+        "Теперь создадим условия оптимизации нашего рациона. Мы оптимизируем рацион по количеству калорий, белков, углеводов и жиров, которые он должен содержать."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b22b1db3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "db15e5ab",
+      "cell_type": "markdown",
+      "source": [
+        "Для начала установим границы калорийности нашего рациона."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "572c30c3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cad68e56",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 9"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7323a9e7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "7d85d28a",
+      "cell_type": "markdown",
+      "source": [
+        "Перемножьте столбец <code>Nutrition.\"Calories\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Calories</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "8ce81888",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "fc712645",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "9607ddc5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "542578c1",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "310f5fbc",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5f0f3e88",
+      "cell_type": "code",
+      "source": [
+        "Calories = Nutrition.\"Calories\" .* Portions"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "3dbc2ab2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d37cbb32",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 10 "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "af7056a8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e135584e",
+      "cell_type": "markdown",
+      "source": [
+        "Рассчитайте сумму всех элементов вектора <code>Calories</code> и сохраните ее в переменной <code>TotalCals</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f0a8b7a8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "31414976",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "908d9581",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7c506fc2",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e05a04b7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d143c157",
+      "cell_type": "code",
+      "source": [
+        "TotalCals = sum(Calories)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "572062ee",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d5b1d7cc",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 11"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c5930968",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "edb1abd4",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C1</code> и границы переменной <code>TotalCals</code> между 2000 и 2500 калорий. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "239dc5c6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "7e75da74",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b22c7cf8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7164ab08",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4171ec4c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4e5f390c",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Opt_ration, C1, 2000 <= TotalCals <= 2500)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "edb3f952",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f5f93272",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 12"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "80a60ee4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8b7f3bcf",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "92759a37",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a82bda31",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "8c24d6bd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "725ff32b",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b66191db",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f66b4556",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "017b73f2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0c64e5b0",
+      "cell_type": "code",
+      "source": [
+        "optimize!(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "8ee35fb6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "06f54864",
+      "cell_type": "code",
+      "source": [
+        "display(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "42f7b413",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6ace1f03",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 13"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "44eaea28",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "966278c5",
+      "cell_type": "markdown",
+      "source": [
+        "Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "34d1d681",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ec15f888",
+      "cell_type": "markdown",
+      "source": [
+        "Затем визуализируйте новые результаты. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Cals_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code> по аналогии с **Заданием 8**."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3119ea31",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a170f44d",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b9b78cf5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "fc181745",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "6f81cae1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6496b4e1",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "bb726751",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "45a956f2",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d9101f95",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 4,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "073e5425",
+      "cell_type": "code",
+      "source": [
+        "Op_portions = value.(Portions)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "463cf948",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7d3f4a5b",
+      "cell_type": "code",
+      "source": [
+        "Cals_port = DataFrame([Nutrition Op_portions])"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7cd3192c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "41bd1c9f",
+      "cell_type": "code",
+      "source": [
+        "plot(Cals_port.Name, Cals_port.x1, seriestype=\"bar\")"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "6419cea2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "bf0eb400",
+      "cell_type": "markdown",
+      "source": [
+        "Теперь результат отображает выполнение условия калорийности при минимальной стоимости рациона."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d0832b4f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a21b5840",
+      "cell_type": "markdown",
+      "source": [
+        "## 3. Условие наличия минимального количества белка"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3038eae0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9350caa9",
+      "cell_type": "markdown",
+      "source": [
+        "Теперь мы зададим дополнительное условие по наличию минимального количества белка в нашем рационе."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4993a67b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0975408f",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 14"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6572c769",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "796160ae",
+      "cell_type": "markdown",
+      "source": [
+        "Перемножьте столбец <code>Nutrition.\"Protein (g)\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Protein</code>.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c0202c4d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ee1d3832",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "0a0aa5f7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "07947469",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9db841b5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c73bea0e",
+      "cell_type": "code",
+      "source": [
+        "Protein = Nutrition.\"Protein (g)\" .* Portions"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b51a0731",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "ab525975",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 15"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "dd34f756",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d42b5b3c",
+      "cell_type": "markdown",
+      "source": [
+        "Рассчитайте сумму всех элементов вектора <code>Protein</code> и сохраните в переменной <code>TotalProt</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "fb9eb789",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e017558e",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "05577e68",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d6b7072e",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ee26524e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2d3df0c2",
+      "cell_type": "code",
+      "source": [
+        "TotalProt = sum(Protein)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "39d36934",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "3b59d1ae",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 16"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "556fe634",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "51400f05",
+      "cell_type": "markdown",
+      "source": [
+        "Создадим условие, чтобы наш рацион содержал как минимум 100 граммов белка."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e3cbb9ba",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2ea42467",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C2</code> и значение переменной <code>TotalProt</code> больше или равно (>=) 100. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7cbcc13f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "880573c5",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "843e8ad7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "bddc874f",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3ccf5f7a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "53e8f77c",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Opt_ration, C2, TotalProt >= 100)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "33f8ca38",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9f01971b",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 17"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b433f704",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9bb1639d",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f178a05e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "87f30960",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1c64a659",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "41364673",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "f8c696d8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9a4995af",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "dcc30c7a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1fc0ad87",
+      "cell_type": "code",
+      "source": [
+        "optimize!(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4e80dd43",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d59f9b6a",
+      "cell_type": "code",
+      "source": [
+        "display(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "312a3c52",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "08011ce9",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 18"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7b0f41ce",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d8ffad23",
+      "cell_type": "markdown",
+      "source": [
+        "Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c7c9d8e7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cf25ebe9",
+      "cell_type": "markdown",
+      "source": [
+        "Затем визуализируйте новые результаты. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Prot_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "26bcaa8d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "145aa1e1",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "fe2110d1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e787f3c6",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "f05dc12d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "41c829cc",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1831db9b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9a8c8c74",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "cd7aeaec",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 4,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "65942c2c",
+      "cell_type": "code",
+      "source": [
+        "Op_portions = value.(Portions)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "361234d8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e4d5d19f",
+      "cell_type": "code",
+      "source": [
+        "Prot_port = DataFrame([Nutrition Op_portions])"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c71f265f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "4c52b571",
+      "cell_type": "code",
+      "source": [
+        "plot(Prot_port.Name, Prot_port.x1, seriestype=\"bar\")"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "cfaa3c0e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "69bd4494",
+      "cell_type": "markdown",
+      "source": [
+        "Теперь результат отображает выполнение условий калорийности и наличия минимального количества белка при минимальной стоимости рациона."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f6bacafd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "6909cf79",
+      "cell_type": "markdown",
+      "source": [
+        "## 4. Условие наличия минимального количества жиров"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "696dd462",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b4c31855",
+      "cell_type": "markdown",
+      "source": [
+        "Зададим дополнительное условие по наличию минимального количества жиров в нашем рационе."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ec4704fd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9611fed3",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 19"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d05d6870",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "620bff59",
+      "cell_type": "markdown",
+      "source": [
+        "Перемножьте столбец <code>Nutrition.\"Fat (g)\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Fats</code>.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "71128bcc",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "180bed11",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "e6575cf2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9a1474df",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "246d3b2e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9a59a939",
+      "cell_type": "code",
+      "source": [
+        "Fats = Nutrition.\"Fat (g)\".* Portions"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5e885b3d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "04377942",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 20"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a03cf6a9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c15ab0e1",
+      "cell_type": "markdown",
+      "source": [
+        "Рассчитайте сумму всех элементов вектора <code>Fats</code> и сохраните в переменной <code>TotalFats</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b45f46f0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f7ac34e9",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7f8b6795",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "2b6c15bb",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b027cb89",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f39726c9",
+      "cell_type": "code",
+      "source": [
+        "TotalFats = sum(Fats)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "dd24609d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "1f6e8bff",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 21"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3af300ae",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e35abf07",
+      "cell_type": "markdown",
+      "source": [
+        "Создадим условие, чтобы наш рацион содержал как минимум 70 граммов жиров."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "628ffd43",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "76c62c66",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C3</code> и значение переменной <code>TotalFats</code> больше или равно (>=) 70."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e001c473",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5a9c9657",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "39d35ef0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d8681d47",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "8dff7cb3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4c8e2259",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Opt_ration, C3,  TotalFats >= 70)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b8358a8e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "0d107213",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 22"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3618072e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f0a6642b",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "07370e30",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d300ce3f",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "a939697a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "98dfac30",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "a130b9a6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f84b1dcd",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9d9319eb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4d872b45",
+      "cell_type": "code",
+      "source": [
+        "optimize!(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4016b110",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "27606596",
+      "cell_type": "code",
+      "source": [
+        "display(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b4fab54c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "71d208a9",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 23"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "30169674",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0ffea48e",
+      "cell_type": "markdown",
+      "source": [
+        "Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "136118ec",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "45f8cb60",
+      "cell_type": "markdown",
+      "source": [
+        "Затем визуализируйте новые результаты. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Fats_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "688c46c4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "68e73903",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4f17a752",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "31d14338",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5a9d9da6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f4029fc6",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "62845327",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9dcf3563",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4db98646",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 3,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9da1cc67",
+      "cell_type": "code",
+      "source": [
+        "Op_portions = value.(Portions)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "37380d11",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "eb3cf284",
+      "cell_type": "code",
+      "source": [
+        "Fats_port = DataFrame([Nutrition Op_portions])"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "905dc35a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7bb687d8",
+      "cell_type": "code",
+      "source": [
+        "plot(Fats_port.Name, Fats_port.x1, seriestype=\"bar\")"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5537aaf6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "3a9494d0",
+      "cell_type": "markdown",
+      "source": [
+        "## 5. Условие наличия минимального количества углеводов"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c236d79c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "70764c00",
+      "cell_type": "markdown",
+      "source": [
+        "Зададим последнее дополнительное условие по наличию минимального количества углеводов в нашем рационе."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "d52fccfc",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "90683f05",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 24"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6963e8a6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5b1fbd34",
+      "cell_type": "markdown",
+      "source": [
+        "Перемножьте столбец <code>Nutrition.\"Carbohydrate (g)\"</code> на переменную <code>Portions</code> и сохраните результат в переменной <code>Carbs</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "cc43ba7e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "a86de430",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c420e7be",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d9a052c6",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "087b5e50",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "28bc681e",
+      "cell_type": "code",
+      "source": [
+        "Carbs = Nutrition.\"Carbohydrate (g)\" .* Portions"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "2511c521",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "9df4c41a",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 25"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "25333a5b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0531a8a7",
+      "cell_type": "markdown",
+      "source": [
+        "Рассчитайте сумму всех элементов вектора <code>Carbs</code> и сохраните в переменной <code>TotalCarbs</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "43cd940d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f18783c5",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "37abcf60",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "13f6e4f4",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1d2ae58c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "3f7c7f11",
+      "cell_type": "code",
+      "source": [
+        "TotalCarbs = sum(Carbs)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "d4cc061c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "22b990cb",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 26"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "02160b5a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0828d4da",
+      "cell_type": "markdown",
+      "source": [
+        "Создадим условие, чтобы наш рацион содержал как минимум 400 граммов углеводов."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2805a567",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "3339ccd8",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте условие для оптимизационной задачи <code>Opt_ration</code> с помощью команды <code>@constraint()</code>. В команде через запятую укажите имя условия как <code>C4</code> и значение переменной <code>TotalCarbs</code> больше или равно (>=) 400."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "30dc02d8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "6c5d0a03",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4e99e4c2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b7cb0b65",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3ec0a39c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0cdd87fd",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Opt_ration, C4, TotalCarbs >= 400)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7f1032c3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "697489f1",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 27"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "849fde35",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f8604211",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу с заданным условием и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>display()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "70206915",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "18809596",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "f8ff3d40",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c5f1803f",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c64e0c07",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f673095c",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "02d8ade1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "02c23945",
+      "cell_type": "code",
+      "source": [
+        "optimize!(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "7a34402b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e7cbf5bb",
+      "cell_type": "code",
+      "source": [
+        "display(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "16821441",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d88306b5",
+      "cell_type": "markdown",
+      "source": [
+        "## 6. Итоговые результаты "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "34060dcc",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b8bf1270",
+      "cell_type": "markdown",
+      "source": [
+        "Получите новые оптимизированные значения порций из переменной <code>Portions</code>. Для этого используйте команду <code>value.()</code>. Обратите внимание, что так как оптимизационная переменная Portions является вектором, нам необходимо добавить <code>.</code> в команде перед скобками. Сохраните результат в переменной <code>Op_portions</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "699f4f5d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "af348f82",
+      "cell_type": "markdown",
+      "source": [
+        "Визуализируйте итоговый результат оптимизационной задачи. Для этого присоедините вектор с оптимизированными значениями порций <code>Op_portions</code> к изначальной таблице <code>Nutrition</code>, переведите в тип <code>DataFrame</code> и сохраните в новой переменной <code>Total_port</code>. Затем передайте нашу новую переменную в команду <code>plot</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a45de88e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9152bd87",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "31cae01a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b01d6379",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c45dbf6b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "242c7bf2",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5d3c3735",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "31a290ad",
+      "cell_type": "markdown",
+      "source": [
+        "Вы можете вывести информацию о решениях и убедиться, что они удовлетворяют заданным вами условиям с помощью команды <code>solution_summary()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f744128f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "af0c3a50",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "14fba39d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "553d6b93",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6adf7b38",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 4,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "beb248d0",
+      "cell_type": "code",
+      "source": [
+        "Op_portions = value.(Portions)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "690e7e3f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7bc6761a",
+      "cell_type": "code",
+      "source": [
+        "Total_port = DataFrame([Nutrition Op_portions])"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "2a55e1b9",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a9fe6fda",
+      "cell_type": "code",
+      "source": [
+        "plot(Total_port.Name, Total_port.x1, seriestype=\"bar\")"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "8d094acb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c3680178",
+      "cell_type": "code",
+      "source": [
+        "solution_summary(Opt_ration)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "9b5ee0ac",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d29bcabc",
+      "cell_type": "markdown",
+      "source": [
+        "## Тест для получения сертификата\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "80ad445a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f276368d",
+      "cell_type": "markdown",
+      "source": [
+        "<p align=\"center\">\r\n<a style=\"padding: 8px 16px;\r\n    border: 3px blue;\r\n    border-radius: 15px;\r\n    color: white;\r\n    background-color: #1b83ba;\r\n    font-size: 24pt; \r\n    text-decoration: none;\" href=\"https://my.etude.org/link/8ZbqTmayk3dAuH-WExVO_NvngJH4fEDfhU24gwSVcz0uSmRImg2NSrxBXBhE_RiuKlG2ap9F9po7ZrCV3rVVDVAMIQwT4IGWY16JbFiuLWuqvdxlKykLI18E_IKsyPkW4z8XrjyOFZ0Xn_pJd46UjFnJ-WhzK-PT-WNfYmsSXJU=?engee\"\r\n     target=\"_blank\">Пройти тест по разделу >></a>\r\n</p>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "5bd0d7a4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    }
+  ]
+}
\ No newline at end of file
diff --git "a/04. \320\230\321\202\320\276\320\263\320\276\320\262\321\213\320\271 \320\277\321\200\320\276\320\265\320\272\321\202.ngscript" "b/04. \320\230\321\202\320\276\320\263\320\276\320\262\321\213\320\271 \320\277\321\200\320\276\320\265\320\272\321\202.ngscript"
index 60a9f903a9680bc542a033c0f14eb11b5842ce71..3d06260d2c19407842eb75b1a157f20c2cd1101d 100644
--- "a/04. \320\230\321\202\320\276\320\263\320\276\320\262\321\213\320\271 \320\277\321\200\320\276\320\265\320\272\321\202.ngscript"	
+++ "b/04. \320\230\321\202\320\276\320\263\320\276\320\262\321\213\320\271 \320\277\321\200\320\276\320\265\320\272\321\202.ngscript"	
@@ -1 +1,2503 @@
-{"cells":[{"cell_type":"markdown","source":["# Итоговый проект"],"id":"2f9065cd","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"661f4eee"}},{"cell_type":"markdown","source":["В итоговом проекте мы применим полученные знания для решения оптимизационной задачи, связанной с расчетом дозы радиационного излучения при лечении опухоли головного мозга лучевой терапией."],"id":"870c7ff1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"cacf8b7f"}},{"cell_type":"markdown","source":["## Введение"],"id":"f002ee00","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e9bd9714"}},{"cell_type":"markdown","source":["### Лучевая терапия опухоли головного мозга"],"id":"81e2cee1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"031a3b13"}},{"cell_type":"markdown","source":["Лучевая терапия (радиотерапия) – это один из способов лечения опухолей, при котором воздействие на патологический очаг происходит с помощью ионизирующего излучения. Для воздействия могут применяться различные типы излучения, как волновые, так и корпускулярные (потоки заряженных частиц).\r\n\r\n"],"id":"40508e0f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"91515f5c"}},{"cell_type":"markdown","source":["![Pikt_6_mozg-01.png](attachment:Pikt_6_mozg-01.png)\r\n"],"id":"db8abff7","attachments":{"Pikt_6_mozg-01.png":{"image":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d0149aa7"}},{"cell_type":"markdown","source":["При лечении лучевой терапией необходимо целенаправленно передать достаточную дозу радиации в область патологического очага, при этом минимизировав дозу облучения, полученную здоровыми тканями."],"id":"9e896792","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a6d0a6a6"}},{"cell_type":"markdown","source":["![Pikt_6_mozg-02.png](attachment:Pikt_6_mozg-02.png)\r\n"],"id":"e61c194c","attachments":{"Pikt_6_mozg-02.png":{"image":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"03058816"}},{"cell_type":"markdown","source":["Формы опухолей и их расположение могут значительно варьироваться, а интенсивность радиоактивного излучения снижается, проходя через ткани головного мозга. "],"id":"095966e9","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1cde02a7"}},{"cell_type":"markdown","source":["В связи с этим, для того чтобы передать необходимую дозу радиации в пораженные участки ткани, минимизировав при этом радиационное поражение здоровых тканей, облучение производится несколькими лучами разных интенсивностей с различных направлений.  "],"id":"25bd8eaf","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1f1a4e88"}},{"cell_type":"markdown","source":["![Pikt_6_mozg-03.png](attachment:Pikt_6_mozg-03.png)\r\n"],"id":"f78b3840","attachments":{"Pikt_6_mozg-03.png":{"image":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"65cc9cbb"}},{"cell_type":"markdown","source":["## 1. Создание оптимизационной задачи\r\n"],"id":"ff5ef756","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7a8552be"}},{"cell_type":"markdown","source":["Для решения данной задачи мы используем оптимизационную библиотеку <code>JuMP</code> и линейный решатель <code>GLPK</code>. Нам также понадобятся библиотека <code>DataFrames</code> для работы с табличными данными и библиотека <code>Plots</code> для визуализации результатов. Для их использования необходимо выполнить команду ниже:"],"id":"1964ad7f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ba39e559"}},{"outputs":[],"cell_type":"code","source":["Pkg.add([\"GLPK\", \"JuMP\"])"],"id":"c0q4ueph","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ivyexbwn"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["using JuMP, GLPK, DataFrames, Plots;"],"id":"cc8e715d","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"615d1977"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 1"],"id":"b522882d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ddc33e4c"}},{"cell_type":"markdown","source":["Создайте оптимизационную задачу, применив к ней линейный решатель <code>GLPK</code>, и сохраните ее в переменной <code>Rad_opt</code>.      "],"id":"aa067865","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"80623aea"}},{"outputs":[],"cell_type":"code","source":[""],"id":"0ac42120","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"49a7b44b"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"a411092d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"3835c043"}},{"outputs":[],"cell_type":"code","source":["Rad_opt = Model(GLPK.Optimizer)"],"id":"2ff443d4","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"bb8196ba"},"execution_count":0},{"cell_type":"markdown","source":["## 2. Зоны радиационного облучения"],"id":"e55740bb","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"00537157"}},{"cell_type":"markdown","source":["В данном примере мы рассчитаем переданную дозу радиационного облучения в двумерном пространстве."],"id":"0dbcd75f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a094a3ee"}},{"cell_type":"markdown","source":["Радиационное облучение проводится с двух направлений, по горизонтали и вертикали. На каждом направлении действуют четыре луча. Доза подающегося излучения каждого из лучей может контролироваться по отдельности."],"id":"1d1f6e46","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2ce2dd5c"}},{"cell_type":"markdown","source":["Таким образом, зона облучения может быть представлена в виде матрицы размером 4x4. "],"id":"f87dddfd","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4c548101"}},{"cell_type":"markdown","source":["Зона облучения содержит три вида регионов:\r\n* Опухоль – ткань, являющаяся целью лучевой терапии.\r\n* Здоровая ткань – ткань, не затронутая опухолью, долю радиационного излучения на которую мы хотим сократить.\r\n* Спинной мозг – регион, где расположен спинной мозг. Доза радиации, поступающая в регионы спинного мозга, не должна превышать установленный порог в связи с рисками повреждения органа.\r\n"],"id":"cb8e9920","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"096a7dea"}},{"cell_type":"markdown","source":["![Pikt_6_mozg-04.png](attachment:Pikt_6_mozg-04.png)\r\n"],"id":"60bd259a","attachments":{"Pikt_6_mozg-04.png":{"image":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"126885a0"}},{"cell_type":"markdown","source":["Интенсивность луча снижается по мере прохождения сквозь ткани головного мозга. Наибольшая интенсивность в первом квадрате выражена коэффициентом 1. Интенсивность в самом удаленном квадрате выражена коэффициентом 0.25."],"id":"5546629c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ed708918"}},{"cell_type":"markdown","source":["![Pikt_6_mozg-05.png](attachment:Pikt_6_mozg-05.png)\r\n"],"id":"568ad911","attachments":{"Pikt_6_mozg-05.png":{"image":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"2ff529ee"}},{"cell_type":"markdown","source":["### ✏️Задание 2"],"id":"5aa81e82","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a08d0e0a"}},{"cell_type":"markdown","source":["Создайте оптимизационную переменную <code>D</code>, определяющую **дозу радиации**, передаваемую каждым из лучей. Используйте <code>D[]</code>, чтобы обозначить необходимое количество элементов переменной <code>D</code> по количеству лучей."],"id":"2c531663","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"01ad21e8"}},{"cell_type":"markdown","source":["Установите нижнюю границу значений переменной <code>D</code> равную <code>0</code>, так как доза радиации не может быть отрицательной, и верхнюю границу равную <code>7</code> как максимальную мощность радиационного луча."],"id":"9a5a9c88","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c9cdd3f0"}},{"outputs":[],"cell_type":"code","source":[""],"id":"f74973f9","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"46dc8435"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"e198d149","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"2b843691"}},{"outputs":[],"cell_type":"code","source":["@variable(Rad_opt, D[1:8], lower_bound = 0.0, upper_bound = 7.0)"],"id":"23279b84","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"5974f980"},"execution_count":0},{"cell_type":"markdown","source":["## 3. Формулировка целевой функции "],"id":"a0858a98","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"050ae608"}},{"cell_type":"markdown","source":["Одной из целей оптимизационной задачи является минимизация дозы радиации, полученной не пораженными опухолью регионами."],"id":"9f432268","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1a50bf76"}},{"cell_type":"markdown","source":["Для этого перемножим коэффициент интенсивности радиационного облучения на каждый элемент переменной <code>D</code> (дозу радиации, передаваемую каждым лучом) в регионах здоровой ткани и спинного мозга, пропуская при этом регионы, пораженные опухолью."],"id":"641604cc","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6273b46d"}},{"cell_type":"markdown","source":["![Pikt_6_mozg-06.png](attachment:Pikt_6_mozg-06.png)\r\n"],"id":"feaa3e00","attachments":{"Pikt_6_mozg-06.png":{"image":""}},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"db636da7"}},{"cell_type":"markdown","source":["### ✏️Задание 3"],"id":"f4f31c3e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a2e4457d"}},{"cell_type":"markdown","source":["Повторите вычисления для <code>D5</code>, <code>D6</code>, <code>D7</code> и <code>D8</code>. Создайте вектор <code>d</code>, содержащий все восемь коэффициентов. "],"id":"ac4db899","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a5cd9da6"}},{"outputs":[],"cell_type":"code","source":[""],"id":"e0555180","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b2ebac75"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"cef1ce81","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"b5a319f7"}},{"outputs":[],"cell_type":"code","source":["d = [2.5, 2.25, 0.5, 1.25, 2.0, 1.75, 2.25, 1.25]"],"id":"fb9cdf33","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"2c5a342d"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 4"],"id":"0b50592e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e741628b"}},{"cell_type":"markdown","source":["Перемножьте переменную <code>d</code>, содержащую коэффициенты интенсивности радиационного облучения на не пораженные ткани, и оптимизационную переменную <code>D</code>. Сохраните результат в переменной <code>Dose</code>."],"id":"43323260","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b15611d3"}},{"outputs":[],"cell_type":"code","source":[""],"id":"414da450","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"3dc89b49"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"11ab69a4","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"f5a73343"}},{"outputs":[],"cell_type":"code","source":["Dose = d .* D"],"id":"72a4431a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"22cc8471"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 5"],"id":"b2470b7b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b59ad416"}},{"cell_type":"markdown","source":["Суммируйте значения переменной <code>Dose</code> и сохраните в переменной <code>Total_dose</code>."],"id":"82774938","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"49dd0bcf"}},{"outputs":[],"cell_type":"code","source":[""],"id":"7849c065","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"965f0141"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"8cd9900a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"6d4671af"}},{"outputs":[],"cell_type":"code","source":["Total_dose = sum(Dose)"],"id":"aa1b7df2","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"87b412bf"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 6"],"id":"441be568","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"38583f40"}},{"cell_type":"markdown","source":["Создайте целевую функцию для оптимизационной задачи <code>Rad_opt</code>. Используйте функцию минимизации на переменной <code>Total_dose</code>, содержащей общую дозу радиационного облучения на не пораженные регионы."],"id":"8fc41b58","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"a356fec6"}},{"outputs":[],"cell_type":"code","source":[""],"id":"643bbad3","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1a54d5d4"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"ecf4f714","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"032868e3"}},{"outputs":[],"cell_type":"code","source":["@objective(Rad_opt, Min, Total_dose)"],"id":"66a3cee9","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"817b9d70"},"execution_count":0},{"cell_type":"markdown","source":["## 4. Формулировка условий распределения доз радиоактивного излучения"],"id":"6d5e65d8","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"7064f9d5"}},{"cell_type":"markdown","source":["Целевая функция, описанная нами выше, минимизирует радиационное облучение не пораженных участков головного мозга. В то же время для достижения эффективного результата лучевой терапии необходимо сформулировать дополнительные условия."],"id":"efccd958","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"11d3591e"}},{"cell_type":"markdown","source":["### ✏️Задание 7"],"id":"b0c1883a","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9f2666fb"}},{"cell_type":"markdown","source":["В целях минимизации рисков нанесения повреждений спинному мозгу, вызванных радиационным излучением, необходимо ограничить дозу облучения, передаваемую в регионы его расположения."],"id":"728bab19","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f4406505"}},{"cell_type":"markdown","source":["Задайте условия оптимизационной задачи <code>Rad_opt</code> для двух регионов расположения спинного мозга, указанных на предыдущей картинке, где общая доза переданной радиации не может превышать <code>2</code>. Дайте условиям имена <code>C1</code> и <code>C2</code>. "],"id":"4f5bb00b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fa6cbe95"}},{"cell_type":"markdown","source":["Вы можете проиндексировать регионы по номеру луча <code>(D1-D8)</code> и коэффициенту интенсивности излучения в этом регионе."],"id":"5454056c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"fffae0cf"}},{"outputs":[],"cell_type":"code","source":[""],"id":"4c14eed4","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b7ab7962"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"d25acebd","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"586a1268"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Подсказка</span>"],"id":"94fe7c9f","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":4,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"96a61991"}},{"cell_type":"markdown","source":["Не забудьте, что каждый регион может получить облучение с двух направлений. По горизонтали, от лучей D1-D4, и по вертикали, от лучей D5-D8.  "],"id":"d3d8c2a3","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"28f00efb"}},{"cell_type":"markdown","source":["##### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"2fbd827c","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":2,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":false},"id":"46bb90e3"}},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, C1, 0.5*D[2]+0.75*D[7] <= 2);"],"id":"d75444ff","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"39e45a94"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, C2, 0.5*D[3]+0.5*D[7] <= 2);"],"id":"d7056c49","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"02ed1d33"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 8"],"id":"ef906c5d","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f69278c2"}},{"cell_type":"markdown","source":["Для успеха лучевой терапии необходимо задать условия передачи минимальной дозы радиационного облучения в регионы, пораженные опухолью."],"id":"13d3aeb0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"320a3f72"}},{"cell_type":"markdown","source":["Задайте условия оптимизационной задачи <code>Rad_opt</code> для шести регионов, пораженных опухолью, указанных на предыдущей картинке, где общая доза переданной радиации не может быть меньше <code>4</code>. Дайте условиям имена <code>c1-c6</code>."],"id":"45c3a795","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"c9c47305"}},{"outputs":[],"cell_type":"code","source":[""],"id":"e2eb9359","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4b8133fd"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"92ed2759","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"d6e11632"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"33f63e61","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"abac1e85"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"ae7eeb88","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"976f2581"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"01045555","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"04c213c5"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"8e84e2e2","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ffeb86b1"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"6196bcdc","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":6,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"e347567e"}},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, c1, D[3]+0.5*D[5] >= 4);"],"id":"43ecce84","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"2310755e"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, c2, 0.75*D[3]+0.5*D[6] >= 4);"],"id":"b051dcde","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"dcefa508"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, c3, 0.75*D[4]+0.25*D[6] >= 4);"],"id":"93498f2e","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"a1ad1d7a"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, c4, 0.5*D[4]+0.25*D[7] >= 4);"],"id":"fe60743e","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"ab527296"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, c5, 0.25*D[2]+0.75*D[8] >= 4);"],"id":"77632d91","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"83f0d419"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["@constraint(Rad_opt, c6, 0.25*D[3]+0.5*D[8] >= 4);"],"id":"060b5bbe","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"48747e6d"},"execution_count":0},{"cell_type":"markdown","source":["## 5. Решение оптимизационной задачи"],"id":"7878b3e0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"b667a437"}},{"cell_type":"markdown","source":["Теперь решим оптимизационную задачу."],"id":"aa8c6291","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"183e0d30"}},{"cell_type":"markdown","source":["### ✏️Задание 9"],"id":"5908b4ff","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"ec06d99f"}},{"cell_type":"markdown","source":["Решите оптимизационную задачу и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>print()</code>."],"id":"aab21b04","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"9e11927f"}},{"cell_type":"markdown","source":["Затем выведите информацию о решениях и убедитесь, что они удовлетворяют заданным вами условиям с помощью команды <code>solution_summary()</code>."],"id":"57c004ff","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"34362516"}},{"outputs":[],"cell_type":"code","source":[""],"id":"5b2ea696","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"1bfd0c8b"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"635bff31","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6506f41b"},"execution_count":0},{"outputs":[],"cell_type":"code","source":[""],"id":"a2f891ea","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"85793d6b"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"3ccda170","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":3,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"b483d04d"}},{"outputs":[],"cell_type":"code","source":["optimize!(Rad_opt)"],"id":"c7d82f9a","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"ceb0fb8e"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["print(Rad_opt)"],"id":"b1d7ddb5","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"78e97ba4"},"execution_count":0},{"outputs":[],"cell_type":"code","source":["solution_summary(Rad_opt)"],"id":"02e84345","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"252a12df"},"execution_count":0},{"cell_type":"markdown","source":["## 6. Итоговые результаты"],"id":"ff5aa795","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"02a6fbdf"}},{"cell_type":"markdown","source":["### ✏️Задание 10"],"id":"f27bfdb1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"90f78c06"}},{"cell_type":"markdown","source":["Выведите полученное целевое значение оптимизационной задачи <code>Rad_Opt</code>."],"id":"c019c2d8","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"e243499b"}},{"outputs":[],"cell_type":"code","source":[""],"id":"ccccabae","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"4aa69938"},"execution_count":0},{"cell_type":"markdown","source":["Целевое значение показывает минимальную сумму доз радиационного облучения не пораженных участков головного мозга при выполнении всех заданных условий."],"id":"c9fdedc2","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f44ac805"}},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"bf269c1e","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"db98bb33"}},{"outputs":[],"cell_type":"code","source":["objective_value(Rad_opt)"],"id":"c2febc6d","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"c2d277eb"},"execution_count":0},{"cell_type":"markdown","source":["### ✏️Задание 11"],"id":"aeb243d0","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"6d9da3cf"}},{"cell_type":"markdown","source":["Выведите оптимизированные значения доз радиационного излучения, передаваемого лучами. Для этого используйте команду <code>value.()</code>. Сохраните результат в переменной <code>Opt_dose</code>."],"id":"aa2422fa","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5911d662"}},{"outputs":[],"cell_type":"code","source":[""],"id":"41a0d21d","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"0634089e"},"execution_count":0},{"cell_type":"markdown","source":["#### <span style=\"background-color: #c2ebff\">Решение</span>"],"id":"a1f5f5d1","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":1,"codeOutputHidden":false,"isClosedParagraph":true,"isDisplay":true},"id":"68c801f0"}},{"outputs":[],"cell_type":"code","source":["Opt_dose = value.(D)"],"id":"146fe12d","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":false},"id":"06340a72"},"execution_count":0},{"cell_type":"markdown","source":["## 6. Визуализация результатов"],"id":"f481c85b","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":true,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f352ba18"}},{"cell_type":"markdown","source":["Визуализируйте результаты по номерам лучей с помощью команды ниже:\r\n\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"],"id":"8cfab134","attachments":{},"metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"5e2218ef"}},{"outputs":[],"cell_type":"code","source":["plot(Opt_dose, kind=\"bar\")"],"id":"74d9c1d3","metadata":{"name":"Название секции","engee":{"codeOutputView":"col","isParagraph":false,"outputInfo":{"isExpanded":false,"scrollTop":0},"amountHideCellsInside":0,"codeOutputHidden":false,"isClosedParagraph":false,"isDisplay":true},"id":"f7e6735e"},"execution_count":0}],"nbformat_minor":5,"metadata":{"engee":{},"language_info":{"file_extension":".jl","name":"julia","version":"1.9.3"},"kernelspec":{"name":"ijulia-1.9","display_name":"IJulia 1.9.3","language":"julia"}},"nbformat":4}
\ No newline at end of file
+{
+  "nbformat": 4,
+  "nbformat_minor": 5,
+  "metadata": {
+    "kernelspec": {
+      "name": "ijulia-1.9",
+      "display_name": "IJulia 1.9.3",
+      "language": "julia"
+    },
+    "language_info": {
+      "name": "julia",
+      "file_extension": ".jl",
+      "version": "1.9.3"
+    },
+    "engee": {}
+  },
+  "cells": [
+    {
+      "id": "2f9065cd",
+      "cell_type": "markdown",
+      "source": [
+        "# Итоговый проект"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "661f4eee",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "870c7ff1",
+      "cell_type": "markdown",
+      "source": [
+        "В итоговом проекте мы применим полученные знания для решения оптимизационной задачи, связанной с расчетом дозы радиационного излучения при лечении опухоли головного мозга лучевой терапией."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "cacf8b7f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f002ee00",
+      "cell_type": "markdown",
+      "source": [
+        "## Введение"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e9bd9714",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "81e2cee1",
+      "cell_type": "markdown",
+      "source": [
+        "### Лучевая терапия опухоли головного мозга"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "031a3b13",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "40508e0f",
+      "cell_type": "markdown",
+      "source": [
+        "Лучевая терапия (радиотерапия) – это один из способов лечения опухолей, при котором воздействие на патологический очаг происходит с помощью ионизирующего излучения. Для воздействия могут применяться различные типы излучения, как волновые, так и корпускулярные (потоки заряженных частиц).\r\n\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "91515f5c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "db8abff7",
+      "cell_type": "markdown",
+      "source": [
+        "![Pikt_6_mozg-01.png](attachment:Pikt_6_mozg-01.png)\r\n"
+      ],
+      "attachments": {
+        "Pikt_6_mozg-01.png": {
+          "image": ""
+        }
+      },
+      "metadata": {
+        "id": "d0149aa7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9e896792",
+      "cell_type": "markdown",
+      "source": [
+        "При лечении лучевой терапией необходимо целенаправленно передать достаточную дозу радиации в область патологического очага, при этом минимизировав дозу облучения, полученную здоровыми тканями."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a6d0a6a6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e61c194c",
+      "cell_type": "markdown",
+      "source": [
+        "![Pikt_6_mozg-02.png](attachment:Pikt_6_mozg-02.png)\r\n"
+      ],
+      "attachments": {
+        "Pikt_6_mozg-02.png": {
+          "image": ""
+        }
+      },
+      "metadata": {
+        "id": "03058816",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "095966e9",
+      "cell_type": "markdown",
+      "source": [
+        "Формы опухолей и их расположение могут значительно варьироваться, а интенсивность радиоактивного излучения снижается, проходя через ткани головного мозга. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1cde02a7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "25bd8eaf",
+      "cell_type": "markdown",
+      "source": [
+        "В связи с этим, для того чтобы передать необходимую дозу радиации в пораженные участки ткани, минимизировав при этом радиационное поражение здоровых тканей, облучение производится несколькими лучами разных интенсивностей с различных направлений.  "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1f1a4e88",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f78b3840",
+      "cell_type": "markdown",
+      "source": [
+        "![Pikt_6_mozg-03.png](attachment:Pikt_6_mozg-03.png)\r\n"
+      ],
+      "attachments": {
+        "Pikt_6_mozg-03.png": {
+          "image": ""
+        }
+      },
+      "metadata": {
+        "id": "65cc9cbb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ff5ef756",
+      "cell_type": "markdown",
+      "source": [
+        "## 1. Создание оптимизационной задачи\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7a8552be",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1964ad7f",
+      "cell_type": "markdown",
+      "source": [
+        "Для решения данной задачи мы используем оптимизационную библиотеку <code>JuMP</code> и линейный решатель <code>GLPK</code>. Нам также понадобятся библиотека <code>DataFrames</code> для работы с табличными данными и библиотека <code>Plots</code> для визуализации результатов. Для их использования необходимо выполнить команду ниже:"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ba39e559",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cc8e715d",
+      "cell_type": "code",
+      "source": [
+        "using JuMP, GLPK, DataFrames, Plots;"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "615d1977",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b522882d",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 1"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ddc33e4c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aa067865",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте оптимизационную задачу, применив к ней линейный решатель <code>GLPK</code>, и сохраните ее в переменной <code>Rad_opt</code>.      "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "80623aea",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0ac42120",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "49a7b44b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a411092d",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "3835c043",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2ff443d4",
+      "cell_type": "code",
+      "source": [
+        "Rad_opt = Model(GLPK.Optimizer)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "bb8196ba",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e55740bb",
+      "cell_type": "markdown",
+      "source": [
+        "## 2. Зоны радиационного облучения"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "00537157",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "0dbcd75f",
+      "cell_type": "markdown",
+      "source": [
+        "В данном примере мы рассчитаем переданную дозу радиационного облучения в двумерном пространстве."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a094a3ee",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "1d1f6e46",
+      "cell_type": "markdown",
+      "source": [
+        "Радиационное облучение проводится с двух направлений, по горизонтали и вертикали. На каждом направлении действуют четыре луча. Доза подающегося излучения каждого из лучей может контролироваться по отдельности."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2ce2dd5c",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f87dddfd",
+      "cell_type": "markdown",
+      "source": [
+        "Таким образом, зона облучения может быть представлена в виде матрицы размером 4x4. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "4c548101",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "cb8e9920",
+      "cell_type": "markdown",
+      "source": [
+        "Зона облучения содержит три вида регионов:\r\n* Опухоль – ткань, являющаяся целью лучевой терапии.\r\n* Здоровая ткань – ткань, не затронутая опухолью, долю радиационного излучения на которую мы хотим сократить.\r\n* Спинной мозг – регион, где расположен спинной мозг. Доза радиации, поступающая в регионы спинного мозга, не должна превышать установленный порог в связи с рисками повреждения органа.\r\n"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "096a7dea",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "60bd259a",
+      "cell_type": "markdown",
+      "source": [
+        "![Pikt_6_mozg-04.png](attachment:Pikt_6_mozg-04.png)\r\n"
+      ],
+      "attachments": {
+        "Pikt_6_mozg-04.png": {
+          "image": ""
+        }
+      },
+      "metadata": {
+        "id": "126885a0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5546629c",
+      "cell_type": "markdown",
+      "source": [
+        "Интенсивность луча снижается по мере прохождения сквозь ткани головного мозга. Наибольшая интенсивность в первом квадрате выражена коэффициентом 1. Интенсивность в самом удаленном квадрате выражена коэффициентом 0.25."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ed708918",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "568ad911",
+      "cell_type": "markdown",
+      "source": [
+        "![Pikt_6_mozg-05.png](attachment:Pikt_6_mozg-05.png)\r\n"
+      ],
+      "attachments": {
+        "Pikt_6_mozg-05.png": {
+          "image": ""
+        }
+      },
+      "metadata": {
+        "id": "2ff529ee",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5aa81e82",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 2"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a08d0e0a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2c531663",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте оптимизационную переменную <code>D</code>, определяющую **дозу радиации**, передаваемую каждым из лучей. Используйте <code>D[]</code>, чтобы обозначить необходимое количество элементов переменной <code>D</code> по количеству лучей."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "01ad21e8",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9a5a9c88",
+      "cell_type": "markdown",
+      "source": [
+        "Установите нижнюю границу значений переменной <code>D</code> равную <code>0</code>, так как доза радиации не может быть отрицательной, и верхнюю границу равную <code>7</code> как максимальную мощность радиационного луча."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c9cdd3f0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f74973f9",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "46dc8435",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "e198d149",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "2b843691",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "23279b84",
+      "cell_type": "code",
+      "source": [
+        "@variable(Rad_opt, D[1:8], lower_bound = 0.0, upper_bound = 7.0)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "5974f980",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a0858a98",
+      "cell_type": "markdown",
+      "source": [
+        "## 3. Формулировка целевой функции "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "050ae608",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "9f432268",
+      "cell_type": "markdown",
+      "source": [
+        "Одной из целей оптимизационной задачи является минимизация дозы радиации, полученной не пораженными опухолью регионами."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "1a50bf76",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "641604cc",
+      "cell_type": "markdown",
+      "source": [
+        "Для этого перемножим коэффициент интенсивности радиационного облучения на каждый элемент переменной <code>D</code> (дозу радиации, передаваемую каждым лучом) в регионах здоровой ткани и спинного мозга, пропуская при этом регионы, пораженные опухолью."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6273b46d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "feaa3e00",
+      "cell_type": "markdown",
+      "source": [
+        "![Pikt_6_mozg-06.png](attachment:Pikt_6_mozg-06.png)\r\n"
+      ],
+      "attachments": {
+        "Pikt_6_mozg-06.png": {
+          "image": ""
+        }
+      },
+      "metadata": {
+        "id": "db636da7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f4f31c3e",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 3"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a2e4457d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ac4db899",
+      "cell_type": "markdown",
+      "source": [
+        "Повторите вычисления для <code>D5</code>, <code>D6</code>, <code>D7</code> и <code>D8</code>. Создайте вектор <code>d</code>, содержащий все восемь коэффициентов. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a5cd9da6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e0555180",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b2ebac75",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "cef1ce81",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b5a319f7",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "fb9cdf33",
+      "cell_type": "code",
+      "source": [
+        "d = [2.5, 2.25, 0.5, 1.25, 2.0, 1.75, 2.25, 1.25]"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "2c5a342d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "0b50592e",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 4"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e741628b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "43323260",
+      "cell_type": "markdown",
+      "source": [
+        "Перемножьте переменную <code>d</code>, содержащую коэффициенты интенсивности радиационного облучения на не пораженные ткани, и оптимизационную переменную <code>D</code>. Сохраните результат в переменной <code>Dose</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b15611d3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "414da450",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "3dc89b49",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "11ab69a4",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f5a73343",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "72a4431a",
+      "cell_type": "code",
+      "source": [
+        "Dose = d .* D"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "22cc8471",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b2470b7b",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 5"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b59ad416",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "82774938",
+      "cell_type": "markdown",
+      "source": [
+        "Суммируйте значения переменной <code>Dose</code> и сохраните в переменной <code>Total_dose</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "49dd0bcf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "7849c065",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "965f0141",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "8cd9900a",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6d4671af",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aa1b7df2",
+      "cell_type": "code",
+      "source": [
+        "Total_dose = sum(Dose)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "87b412bf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "441be568",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 6"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "38583f40",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8fc41b58",
+      "cell_type": "markdown",
+      "source": [
+        "Создайте целевую функцию для оптимизационной задачи <code>Rad_opt</code>. Используйте функцию минимизации на переменной <code>Total_dose</code>, содержащей общую дозу радиационного облучения на не пораженные регионы."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "a356fec6",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "643bbad3",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1a54d5d4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "ecf4f714",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "032868e3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "66a3cee9",
+      "cell_type": "code",
+      "source": [
+        "@objective(Rad_opt, Min, Total_dose)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "817b9d70",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6d5e65d8",
+      "cell_type": "markdown",
+      "source": [
+        "## 4. Формулировка условий распределения доз радиоактивного излучения"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "7064f9d5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "efccd958",
+      "cell_type": "markdown",
+      "source": [
+        "Целевая функция, описанная нами выше, минимизирует радиационное облучение не пораженных участков головного мозга. В то же время для достижения эффективного результата лучевой терапии необходимо сформулировать дополнительные условия."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "11d3591e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "b0c1883a",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 7"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9f2666fb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "728bab19",
+      "cell_type": "markdown",
+      "source": [
+        "В целях минимизации рисков нанесения повреждений спинному мозгу, вызванных радиационным излучением, необходимо ограничить дозу облучения, передаваемую в регионы его расположения."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f4406505",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4f5bb00b",
+      "cell_type": "markdown",
+      "source": [
+        "Задайте условия оптимизационной задачи <code>Rad_opt</code> для двух регионов расположения спинного мозга, указанных на предыдущей картинке, где общая доза переданной радиации не может превышать <code>2</code>. Дайте условиям имена <code>C1</code> и <code>C2</code>. "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "fa6cbe95",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5454056c",
+      "cell_type": "markdown",
+      "source": [
+        "Вы можете проиндексировать регионы по номеру луча <code>(D1-D8)</code> и коэффициенту интенсивности излучения в этом регионе."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "fffae0cf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "4c14eed4",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "b7ab7962",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d25acebd",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "586a1268",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "94fe7c9f",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Подсказка</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "96a61991",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 4,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d3d8c2a3",
+      "cell_type": "markdown",
+      "source": [
+        "Не забудьте, что каждый регион может получить облучение с двух направлений. По горизонтали, от лучей D1-D4, и по вертикали, от лучей D5-D8.  "
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "28f00efb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "2fbd827c",
+      "cell_type": "markdown",
+      "source": [
+        "##### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "46bb90e3",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 2,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "d75444ff",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, C1, 0.5*D[2]+0.75*D[7] <= 2);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "39e45a94",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "d7056c49",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, C2, 0.5*D[3]+0.5*D[7] <= 2);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "02ed1d33",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "ef906c5d",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 8"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f69278c2",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "13d3aeb0",
+      "cell_type": "markdown",
+      "source": [
+        "Для успеха лучевой терапии необходимо задать условия передачи минимальной дозы радиационного облучения в регионы, пораженные опухолью."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "320a3f72",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "45c3a795",
+      "cell_type": "markdown",
+      "source": [
+        "Задайте условия оптимизационной задачи <code>Rad_opt</code> для шести регионов, пораженных опухолью, указанных на предыдущей картинке, где общая доза переданной радиации не может быть меньше <code>4</code>. Дайте условиям имена <code>c1-c6</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "c9c47305",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "e2eb9359",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4b8133fd",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "92ed2759",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "d6e11632",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "33f63e61",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "abac1e85",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "ae7eeb88",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "976f2581",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "01045555",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "04c213c5",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "8e84e2e2",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "ffeb86b1",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "6196bcdc",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e347567e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 6,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "43ecce84",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, c1, D[3]+0.5*D[5] >= 4);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "2310755e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b051dcde",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, c2, 0.75*D[3]+0.5*D[6] >= 4);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "dcefa508",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "93498f2e",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, c3, 0.75*D[4]+0.25*D[6] >= 4);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "a1ad1d7a",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "fe60743e",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, c4, 0.5*D[4]+0.25*D[7] >= 4);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "ab527296",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "77632d91",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, c5, 0.25*D[2]+0.75*D[8] >= 4);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "83f0d419",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "060b5bbe",
+      "cell_type": "code",
+      "source": [
+        "@constraint(Rad_opt, c6, 0.25*D[3]+0.5*D[8] >= 4);"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "48747e6d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "7878b3e0",
+      "cell_type": "markdown",
+      "source": [
+        "## 5. Решение оптимизационной задачи"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b667a437",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aa8c6291",
+      "cell_type": "markdown",
+      "source": [
+        "Теперь решим оптимизационную задачу."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "183e0d30",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5908b4ff",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 9"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "ec06d99f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aab21b04",
+      "cell_type": "markdown",
+      "source": [
+        "Решите оптимизационную задачу и просмотрите ее параметры с помощью команд <code>optimize!()</code> и <code>print()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "9e11927f",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "57c004ff",
+      "cell_type": "markdown",
+      "source": [
+        "Затем выведите информацию о решениях и убедитесь, что они удовлетворяют заданным вами условиям с помощью команды <code>solution_summary()</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "34362516",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "5b2ea696",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "1bfd0c8b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "635bff31",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "6506f41b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a2f891ea",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "85793d6b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "3ccda170",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "b483d04d",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 3,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c7d82f9a",
+      "cell_type": "code",
+      "source": [
+        "optimize!(Rad_opt)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "ceb0fb8e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "b1d7ddb5",
+      "cell_type": "code",
+      "source": [
+        "print(Rad_opt)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "78e97ba4",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "02e84345",
+      "cell_type": "code",
+      "source": [
+        "solution_summary(Rad_opt)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "252a12df",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "ff5aa795",
+      "cell_type": "markdown",
+      "source": [
+        "## 6. Итоговые результаты"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "02a6fbdf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "f27bfdb1",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 10"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "90f78c06",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c019c2d8",
+      "cell_type": "markdown",
+      "source": [
+        "Выведите полученное целевое значение оптимизационной задачи <code>Rad_Opt</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "e243499b",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "ccccabae",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "4aa69938",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "c9fdedc2",
+      "cell_type": "markdown",
+      "source": [
+        "Целевое значение показывает минимальную сумму доз радиационного облучения не пораженных участков головного мозга при выполнении всех заданных условий."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f44ac805",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "bf269c1e",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "db98bb33",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "c2febc6d",
+      "cell_type": "code",
+      "source": [
+        "objective_value(Rad_opt)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "c2d277eb",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "aeb243d0",
+      "cell_type": "markdown",
+      "source": [
+        "### ✏️Задание 11"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "6d9da3cf",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "aa2422fa",
+      "cell_type": "markdown",
+      "source": [
+        "Выведите оптимизированные значения доз радиационного излучения, передаваемого лучами. Для этого используйте команду <code>value.()</code>. Сохраните результат в переменной <code>Opt_dose</code>."
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "5911d662",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "41a0d21d",
+      "cell_type": "code",
+      "source": [
+        ""
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "0634089e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "a1f5f5d1",
+      "cell_type": "markdown",
+      "source": [
+        "#### <span style=\"background-color: #c2ebff\">Решение</span>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "68c801f0",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": true,
+          "amountHideCellsInside": 1,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "146fe12d",
+      "cell_type": "code",
+      "source": [
+        "Opt_dose = value.(D)"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "06340a72",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": false,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    },
+    {
+      "id": "f481c85b",
+      "cell_type": "markdown",
+      "source": [
+        "## 6. Визуализация результатов"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "f352ba18",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": true,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "8cfab134",
+      "cell_type": "markdown",
+      "source": [
+        "Визуализируйте результаты по номерам лучей с помощью команды ниже:\r\n\r\n<noscript><div><img src=\"https://mc.yandex.ru/watch/97656070\" style=\"position:absolute; left:-9999px;\" alt=\"\" /></div></noscript>"
+      ],
+      "attachments": {},
+      "metadata": {
+        "id": "5e2218ef",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false
+        }
+      }
+    },
+    {
+      "id": "74d9c1d3",
+      "cell_type": "code",
+      "source": [
+        "plot(Opt_dose, kind=\"bar\")"
+      ],
+      "execution_count": 0,
+      "outputs": [],
+      "metadata": {
+        "id": "f7e6735e",
+        "name": "Название секции",
+        "engee": {
+          "isDisplay": true,
+          "isParagraph": false,
+          "isClosedParagraph": false,
+          "amountHideCellsInside": 0,
+          "codeOutputView": "col",
+          "codeOutputHidden": false,
+          "outputInfo": {
+            "isExpanded": false,
+            "scrollTop": 0
+          }
+        }
+      }
+    }
+  ]
+}
\ No newline at end of file