2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки


Правила форума


Посмотреть правила форума



Начать новую тему Ответить на тему На страницу 1, 2  След.
 
 Когда полином равен нулю?
Сообщение22.02.2017, 22:01 
Аватара пользователя


12/03/11
693
Рассмотрим полином $F = A_1 x^{\alpha_1} y^{\beta_1} + A_2 x^{\alpha_2} y^{\beta_2}.$
Он равен нулю в случае когда либо:
1) $A_1 = A_2 = 0$
либо
2) $\alpha_1 = \alpha_2, \beta_1 = \beta_2, A_1 = -A_2$.

Возьмем теперь произвольный случай: $F = A_1 x^{\alpha_1} y^{\beta_1} + A_2 x^{\alpha_2} y^{\beta_2} + ... + A_n x^{\alpha_n} y^{\beta_n}.$
Интересно как теперь найти все возможные условия равенства нулю.
Полагаю, можно свести это дело к какому-нибудь известному алгоритму. Есть идеи? :roll:

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение22.02.2017, 22:07 


25/08/11

1074
У Вас не все случаи равенства нулю рассмотрены, даже для первого двучлена. Например, переменные могут равняться нулю, когда вынесешь общий множитель. А так вопрос почти безсодержательный-найти нулю и при одной переменной нельзя аналитически, что уж при двух. Или Вы что-то не договариваете.

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение22.02.2017, 22:13 
Заслуженный участник
Аватара пользователя


30/01/06
72407
Рассмотрите все возможные разбиения множества $\{1,\ldots,n\}$ на подмножества. В каждом подмножестве показатели должны быть равны друг другу, а сумма коэффициентов - нулю. Ваши случаи соответствуют разбиениям:
1) $\{1\},\{2\};$
2) $\{1,2\}.$

-- 22.02.2017 22:14:43 --

sergei1961
Очевидно, спрашивается, когда выражение равно нулю не как значение функции в точке, а как функция.

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение22.02.2017, 22:28 
Заслуженный участник
Аватара пользователя


20/08/14
8679
Дабы избегать таких недоразумений, можно пользоваться оборотом "тождественно равен нулю".

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение22.02.2017, 22:37 
Заслуженный участник


27/04/09
28128
Или «равен нулевому [многочлену]».

Кстати, не понимаю, зачем разбиения — нужно просто привести его к виду
DLL в сообщении #1194686 писал(а):
$F = A_1 x^{\alpha_1} y^{\beta_1} + A_2 x^{\alpha_2} y^{\beta_2} + ... + A_n x^{\alpha_n} y^{\beta_n}.$
в котором, однако, не более одного слагаемого для каждого набора степеней переменных. Тогда равенство нулю — это просто одновременное равенство нулю всех $A_i$. Это и для компьютерных вычислений практичнее, if any.

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 01:46 
Заслуженный участник
Аватара пользователя


30/01/06
72407
arseniiv в сообщении #1194697 писал(а):
Или «равен нулевому [многочлену]».

Ну, если альфы и беты, не дай бог, нецелые, то является ли это многочленом? (Вопрос риторический.)

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 01:56 
Заслуженный участник
Аватара пользователя


13/08/08
14496
arseniiv, привести подобные, как в 7 классе? :-)

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 09:00 


25/08/11

1074
arseniiv - согласен с Вами. Если спрашивается про тождественно, то по определению. Для немногочленов-непонятно. Для рациональных степеней можно свести дело к многочленам заменами, иначе это похоже безнадёжно, или как?

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 10:11 
Аватара пользователя


12/03/11
693
arseniiv в сообщении #1194697 писал(а):
Или «равен нулевому [многочлену]».

Кстати, не понимаю, зачем разбиения — нужно просто привести его к виду
DLL в сообщении #1194686 писал(а):
$F = A_1 x^{\alpha_1} y^{\beta_1} + A_2 x^{\alpha_2} y^{\beta_2} + ... + A_n x^{\alpha_n} y^{\beta_n}.$
в котором, однако, не более одного слагаемого для каждого набора степеней переменных. Тогда равенство нулю — это просто одновременное равенство нулю всех $A_i$. Это и для компьютерных вычислений практичнее, if any.

ОК, но на самом деле задача чуть сложнее.
Некоторые альфы и беты заданы как числа.
А некоторые как неизвестные, но максимум в виде линейной комбинации.
Например: $3m - 5n$ :roll:

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 14:42 
Аватара пользователя


12/03/11
693
Ну то есть речь скажем идет:
$F = A_1 x^{4m-5n} y^{n+2} + A_2 x^{m+n} y^{2n - 1}$.
P.S: альфы и беты зависят от неизвестных линейно!

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 15:11 
Заслуженный участник


27/04/09
28128
Munin в сообщении #1194721 писал(а):
Ну, если альфы и беты, не дай бог, нецелые, то является ли это многочленом? (Вопрос риторический.)
Вообще, конечно, вопрос темы допускает такое расширение с ровно аналогичным же решением, но я в формулировках оставался в рамках того, что написал ТС. :wink:

gris в сообщении #1194725 писал(а):
arseniiv, привести подобные, как в 7 классе? :-)
Да, именно.

sergei1961 в сообщении #1194742 писал(а):
иначе это похоже безнадёжно, или как?
Да вроде всё надёжно и для возможно иррациональных степеней, если ничего не упускаю.

DLL в сообщении #1194746 писал(а):
А некоторые как неизвестные, но максимум в виде линейной комбинации.
Например: $3m - 5n$ :roll:
Но общее решение этим не отменяется. Просто возникнет много условных конструкций, ну так и что?

Пример: $$ax^\alpha + a'x^{\alpha'} = (\alpha=\alpha') \mathbin? (a + a')x^\alpha : (ax^\alpha + a'x^{\alpha'}),$$где справа выражение в «каноническом» виде (что вообще уместно представлять как списки, множества или что-то в этом духе, если мы о вычислениях), а слева не обязательно. Или можно скобками Айверсона записать, тут уж зависит от того, чем будет удобнее манипулировать.

DLL в сообщении #1194786 писал(а):
P.S: альфы и беты зависят от неизвестных линейно!
Значит, в худшем случае придётся решать лишь линейные системы. :-)

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 19:31 
Заслуженный участник


27/04/09
28128
Да, разбиения всё-таки полезны оказываются, если писать реализацию. Например, для выражения
Код:
x^a[1] A[1] + x^a[2] A[2] + x^a[3] A[3] + x^a[4] A[4]
можно получить
Код:
(a[1] == a[2] == a[3] == a[4] && A[1] + A[2] + A[3] + A[4] == 0) ||
(a[1] == a[2] && a[3] == a[4] && A[1] + A[2] == A[3] + A[4] == 0) ||
(a[1] == a[4] && a[2] == a[3] && A[1] + A[4] == A[2] + A[3] == 0) ||
(a[1] == a[3] && a[2] == a[4] && A[1] + A[3] == A[2] + A[4] == 0) ||
(a[2] == a[3] == a[4] && A[1] == A[2] + A[3] + A[4] == 0) ||
(a[1] == a[3] == a[4] && A[1] + A[3] + A[4] == A[2] == 0) ||
(a[1] == a[2] == a[3] && A[1] + A[2] + A[3] == A[4] == 0) ||
(a[1] == a[2] == a[4] && A[1] + A[2] + A[4] == A[3] == 0) ||
(a[3] == a[4] && A[1] == A[2] == A[3] + A[4] == 0) ||
(a[2] == a[3] && A[1] == A[2] + A[3] == A[4] == 0) ||
(a[2] == a[4] && A[1] == A[2] + A[4] == A[3] == 0) ||
(a[1] == a[2] && A[1] + A[2] == A[3] == A[4] == 0) ||
(a[1] == a[3] && A[1] + A[3] == A[2] == A[4] == 0) ||
(a[1] == a[4] && A[1] + A[4] == A[2] == A[3] == 0) ||
A[1] == A[2] == A[3] == A[4] == 0

Это, конечно, без учёта того, что a[i] могут быть линейными комбинациями других переменных, в случае чего равенства могут давать несовместные системы, и для таких равенств можно будет выкидывать соответствующий член дизъюнкции.

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение23.02.2017, 23:15 
Аватара пользователя


12/03/11
693
Это в каком пакете получено?

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение24.02.2017, 00:54 
Заслуженный участник


27/04/09
28128
Немного кода на Mathematica 8. Но я схитрил, и на входе на самом деле вот такое:
Код:
{{A[1], a[1]}, {A[2], a[2]}, {A[3], a[3]}, {A[4], a[4]}}
А код работы с этим такой:
Код:
Needs["Combinatorica`"]; (* SetPartitions *)
Clear[zeroCondition, partitionEqMap, partitionEqMap2]
partitionEqMap[f_, p_List] := And @@ Map[Equal @@ # &, Map[f, p, {2}]]
partitionEqMap2[f_, p_List] := Equal @@ Append[Map[Plus @@ (f /@ #) &, p], 0]
zeroCondition[expr_] := Block[
    {len = Length[expr], pns},
    pns = SetPartitions[len];
    Or @@ Map[And[
        partitionEqMap[expr[[#, 2]] &, #],
        partitionEqMap2[expr[[#, 1]] &, #]] &, pns]]
Документация не прилагается. :roll:

 Профиль  
                  
 
 Re: Когда полином равен нулю?
Сообщение24.02.2017, 01:12 
Заслуженный участник
Аватара пользователя


30/01/06
72407
arseniiv в сообщении #1194792 писал(а):
Вообще, конечно, вопрос темы допускает такое расширение

Кто сказал, что это расширение?

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 18 ]  На страницу 1, 2  След.

Модераторы: Модераторы Математики, Супермодераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: SomePupil


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group