С Новым годом! Форум программистов, компьютерный форум, киберфорум
Matlab
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
177 / 143 / 50
Регистрация: 07.02.2014
Сообщений: 489
1

Решение линейного уравнения

07.02.2015, 11:55. Показов 1988. Ответов 9
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день!

Решаю уравнение типа a1*x1+a2*x2+a3*x3+a4*x4=P, где величины a1...a4 и Р - известные числа. Нужно найти значения x1...x4, которые будут лежат в пределах: 1<x1<8, 12<x2<18, 15<x3<21 и 16<x4<23.
Примеры значений a1...a4 и Р:
Кликните здесь для просмотра всего текста

a1 / a2 / a3 / a4 / P
11,50 / 40,80 / 23,50 / 24,50 / 14,56
12,60 / 39,80 / 24,70 / 23,30 / 27,91
14,20 / 44,10 / 23,10 / 18,60 / 11,69
20,60 / 46,40 / 23,30 / 9,90 / 6,60
16,60 / 46,60 / 23,20 / 13,50 / 0,19
69,10 / 26,00 / 3,90 / 1,00 / 4,42
67,10 / 25,70 / 5,40 / 1,80 / 0,77
65,50 / 29,10 / 4,30 / 1,20 / 0,03
29,70 / 44,50 / 14,60 / 11,20 / 0,19


Подскажите, как это можно реализовать?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.02.2015, 11:55
Ответы с готовыми решениями:

Решение задачи линейного программирования
1.1 . Решить задачу линейного программирования f(x) = 4x1 + x2 → inf, x1 + x2 &gt; 2, x1 – x2...

Решение задачи Линейного программирования в Matlab
Доброго времени суток ! Помоги пожалуйста понять чего мне не хватает в моем решении задачи в...

Решение задач линейного программирования. Симплекс метод
5x1 + x2→ min, x1 + 7x2 ≥ 7, 7x1 + x2 ≥ 7, –2x1 + x2 ≤ 6, 2x1 + 5x2 ≥ 10, 5x1 + 2x2 ≥ 10, x1...

Решение линейного уравнения
Помогите с кодом по Excel,он должен решать уравнение ax=b.Выдаёт ошибку ЕСЛИ(И(A2=0;B2=0);x=Любое...

9
408 / 227 / 43
Регистрация: 10.02.2013
Сообщений: 780
07.02.2015, 15:29 2
а что мешает написать функцию вычисления уравнения и передавать туда параметры a1...a4 и Р ?
0
177 / 143 / 50
Регистрация: 07.02.2014
Сообщений: 489
07.02.2015, 16:31  [ТС] 3
Цитата Сообщение от shurikspk Посмотреть сообщение
а что мешает написать функцию вычисления уравнения и передавать туда параметры a1...a4 и Р ?
какой вид будет у функции? Я в матлабе да и в программировании не очень шарю
0
408 / 227 / 43
Регистрация: 10.02.2013
Сообщений: 780
07.02.2015, 16:55 4
Цитата Сообщение от Norwall Посмотреть сообщение
какой вид будет у функции? Я в матлабе да и в программировании не очень шарю
https://www.youtube.com/watch?v=CTFsJU3YMgE
0
5243 / 3571 / 379
Регистрация: 02.04.2012
Сообщений: 6,473
Записей в блоге: 17
09.02.2015, 10:53 5
одно уравнение с 4-мя неизвестными?
0
177 / 143 / 50
Регистрация: 07.02.2014
Сообщений: 489
09.02.2015, 11:22  [ТС] 6
Цитата Сообщение от Зосима Посмотреть сообщение
одно уравнение с 4-мя неизвестными?
Добрый день, Уважаемый Зосима!

Эти "неизвестные" не совсем таковыми являются Мы знаем эти значения в некоторых пределах, описанных выше. Нужно их подобрать так, чтобы невязка друг относительно друга была минимальной. Я пока вот такой код написал, но он, конечно, ничерта не считает... Я разбил произведение Р=а1*х2+...+а4*х4 на части: р1=а1*х1...р4=а4*х4. Далее хочу, чтобы была проверка, чтобы известное заранее значение Р было близко к Р_m. Вот такой код в итоге:
Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
clc
clear all
a1 = 9.1; 
a2 = 34.4;
a3 = 25.6;
a4 = 30.2;
P = 14.8;
k = 1:0.01:30;
x1 = length(k);
x2 = length(k);
x3 = length(k);
x4 = length(k);
x1>=1 && 8<=x1; %пределы изменения х1...х4
x2>=12 && 21<=x2;
x3>=14 && 24<=x3;
x4>=18 && 27<=x4;
p1 = a1*x1;
p2 = a2*x2;
p3 = a3*x3;
p4 = a4*x4;
P_m = p1+p2+p3+p4;
 
while (P-P_m)^2<=5 %цикл должен считать до тех пор, пока невязка не станет меньше 5
    x1=x1+0.01;
    x2=x2+0.01;
    x3=x3+0.01;
    x4=x4+0.01;
end
 
x = [x1 x2 x3 x4]
0
5243 / 3571 / 379
Регистрация: 02.04.2012
Сообщений: 6,473
Записей в блоге: 17
09.02.2015, 12:19 7
Лучший ответ Сообщение было отмечено Norwall как решение

Решение

Norwall, загвоздка в том, что мы не всегда сможем достичь требуемой невязки
гляди на примере первого набора (я использовать метод Монте-Карло):
Matlab M
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
clear, clc
 
a = [11.50; 40.80; 23.50; 24.50];
P = 14.56;
 
N = 1e5; % размер выборки случайных чисел
x(:,1) = 1 + 7*rand(N,1); % от 1 до 8
x(:,2) = 12 + 6*rand(N,1); % от 12 до 18
x(:,3) = 15 + 6*rand(N,1); % от 15 до 21
x(:,4) = 16 + 7*rand(N,1); % от 16 до 23
Y = x*a; % сумма произведений для каждой строки
 
[r i] = min( abs(Y-P) ) ; % индекс ближайшего значения
x(i,:) % значения иксов
Y(i) % значение суммы
В результате получаем набор сумм произведений Y(i) = a1*x1 + a2*x2 + a3*x3 + a4*x4 для разнообразных значений иксов, причем
минимальное значение: min(Y) = 1259.9
максимальное значение max(Y) = 1856.8
явно видно, что P = 14.56 сюда явно не попадает
0
177 / 143 / 50
Регистрация: 07.02.2014
Сообщений: 489
09.02.2015, 13:20  [ТС] 8
Все чудесно! Просто я неверно написал значения а1...а4... На самом деле они равны 0,1150, 0,4080, 0,2350 и 0,2450 - при таком раскладе все верно считает!
Спасибо Вам огромное, Зосима! Вы прям спасли меня - ведь завтра нужно уже отчет сдавать!

Добавлено через 31 минуту
Зосима, подскажите, параметр N - размер выборки случ.чисел - за что именно он отвечает? 10000 числе участвуют в расчете?
И еще расшифруйте, пожалуйста, запись...
Цитата Сообщение от Зосима Посмотреть сообщение
x(:,1) = 1 + 7*rand(N,1); % от 1 до 8
Добавлено через 16 минут
Каким-либо другим способом возможно найти ближайшее значение? По этому [r i] = min( abs(Y-P) ); получается большой разлет... Например, по факту Р=23,00, а получается 17,68...
0
5243 / 3571 / 379
Регистрация: 02.04.2012
Сообщений: 6,473
Записей в блоге: 17
09.02.2015, 14:34 9
Norwall, точность моего метода можно повысить, если увеличить N
Вот еще один метод - поиск минимума невязки, но тут возможен выход х за пределы допустимых значений, зато точность повыше (ее можно менять):
Matlab M
1
2
3
4
5
6
7
8
9
10
11
clear, clc
 
a = [0.115; 0.408; 0.235; 0.2450];
P = 14.56;
 
F = @(x) abs( x*a-P ); % функция невязки
 
x0 = [4.5, 15, 18, 19.5]; % начальное значение х для поиска
x = fminsearch(F, x0) % находим значения х для минимальной невязки
 
x*a - P % невязка
0
177 / 143 / 50
Регистрация: 07.02.2014
Сообщений: 489
10.02.2015, 12:52  [ТС] 10
Цитата Сообщение от Зосима Посмотреть сообщение
тут возможен выход х за пределы допустимых значений
К сожалению, именно условие ограничения x является самым главным
0
10.02.2015, 12:52
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.02.2015, 12:52
Помогаю со студенческими работами здесь

Решение линейного уравнения
Надо написать программу решения линейного уравнения. Входные данные поступают с клавиатуры....

Решение линейного уравнения
Добрый день! Подскажите пожалуйста, как решить уравнение вида:...

Решение линейного уравнения
Привет всем, прошу помощи. Необходимо написать программу для вычисления и вывода значения функции...

Решение линейного уравнения
Понимаю, задачка простая, но я лишь недавно начала изучать Java поэтому появился такой нубо вопрос....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
Полезные поделки на Arduino, которые можно сделать самому
raxper 06.01.2025
Arduino как платформа для творчества Arduino представляет собой удивительную платформу для технического творчества, которая открывает безграничные возможности для создания уникальных проектов. Эта. . .
Подборка решений задач на Python
IT_Exp 06.01.2025
Целью данной подборки является предоставление возможности ознакомиться с различными задачами и их решениями на Python, что может быть полезно как для начинающих, так и для опытных программистов. . . .
С чего начать программировать микроконтроллер­­ы
raxper 06.01.2025
Введение в мир микроконтроллеров Микроконтроллеры стали неотъемлемой частью современного мира, окружая нас повсюду: от простых бытовых приборов до сложных промышленных систем. Эти маленькие. . .
Из чего собрать игровой компьютер
inter-admin 06.01.2025
Сборка игрового компьютера требует особого внимания к выбору комплектующих и их совместимости. Правильно собранный игровой ПК не только обеспечивает комфортный геймплей в современных играх, но и. . .
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного сумматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­­­­­­­­­­­­­­­­­­­­­­­­­х­р­о­н­­н­­­ы­­й счётчик с управляющим сигналом зад
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru