Объединение матроидов, проверка множества на независимость — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
(Отмена правки 10403 участника Vincent (обсуждение))
м
Строка 1: Строка 1:
Пусть нам даны три матроида:
+
{{Определение
 +
|definition =
 +
Пусть <tex>M_1 = \langle X, \mathcal{I}_1 \rangle </tex> и <tex> M_2 = \langle X, \mathcal{I}_2 \rangle </tex> {{---}} два матроида на множестве элементов <tex>X</tex> с наборами независимых множеств <tex>\mathcal{I}_1</tex> и <tex>\mathcal{I}_2</tex>.  Положим <tex> \mathcal{I} = \mathcal {f} A \mid A = A_1 \cup A_2, A_1 \in \mathcal{I}_1, A_2 \in \mathcal{I}_2  \mathcal {g} </tex>. Множество <tex>\mathcal{I}</tex> удовлетворяет [[Объединение матроидов, доказательство того, что объединение является матроидом|аксиомам независимости]], следовательно, <tex>\langle X, \mathcal{I} \rangle </tex> {{---}} матроид, для которого <tex>\mathcal{I}</tex> служит независимым множеством. Этот матроид называется '''объединением матроидов''' (англ. ''matroid union'') <tex>M_1</tex> и <tex>M_2</tex>, и обозначается <tex> M_1 \cup M_2 </tex>
 +
}}
 +
Обычно термин "объединение" применяется, когда  носители <tex>X</tex> в обоих матроидах одинаковы, однако это не является необходимым, мы можем дополнить их до объединения, заметим, что от этого <tex>M_1</tex> и <tex>M_2</tex> не перестанут быть матроидами. Если в <tex>M_1</tex> и <tex>M_2</tex> носители непересекающиеся, тогда это будет являться [[Прямая сумма матроидов|прямой суммой матроидов]].
  
<tex>M_1 = \langle X, I_1 \rangle</tex>,
+
* Операция объединения матроидов ассоциативна, следовательно, можно говорить об объединении нескольких матроидов.
 +
* В отличие от пересечения матроидов, объединение двух конечных (англ. ''finite matroid'') матроидов всегда является матроидом, однако объединение двух бесконечных матроидов (англ. ''infinite matroid'') не обязательно будет им.
 +
* Объединение применяется к независимым множествам, а не к матроидам в целом, то есть это операция на другом уровне, по сравнению с пересечение матроидов.
  
<tex>M_2 = \langle X, I_2 \rangle</tex>,
 
 
<tex>M = M_1 \cup M_2 = \langle X, I = \{A \mid A = A_1 \cup A_2, A_1 \in I_1, A_2 \in I_2\} \rangle</tex>.
 
 
Для простоты мы считаем, что носители в обоих матроидах одинаковы, если не так, то дополним их до объединения, заметим, что от этого <tex>M_1</tex> и <tex>M_2</tex> не перестанут быть матроидами.
 
  
 
Давайте зададим функцию <tex>P_1</tex> : <tex> X \times Y \rightarrow X</tex>: <tex>P_1((x, y)) = x</tex>, а для множества <tex>B \in X \times Y</tex> выполняется <tex>P_1(B) = \{A \subset X| \forall x \in A</tex> <tex>\exists y \in B : P_1(y) = x\}</tex>.
 
Давайте зададим функцию <tex>P_1</tex> : <tex> X \times Y \rightarrow X</tex>: <tex>P_1((x, y)) = x</tex>, а для множества <tex>B \in X \times Y</tex> выполняется <tex>P_1(B) = \{A \subset X| \forall x \in A</tex> <tex>\exists y \in B : P_1(y) = x\}</tex>.
Строка 23: Строка 24:
  
 
== Литература ==
 
== Литература ==
Асанов М. О., Баранский В. А., Расин В. В. - Дискретная математика: Графы, матроиды, алгоритмы. ISBN 978-5-8114-1068-2 (и на какой же странице это написано?)
+
* Емеличев В. А., Мельников О. И., Сарванов В. И., Тышкевич Р. И. {{---}} Лекции по теории графов
 +
* Chandra Chekuri {{---}} [https://courses.engr.illinois.edu/cs598csc/sp2010/Lectures/Lecture19.pdf '''Combinatorial Optimization''']
 +
* https://en.wikipedia.org/wiki/Matroid

Версия 03:36, 21 мая 2016

Определение:
Пусть [math]M_1 = \langle X, \mathcal{I}_1 \rangle [/math] и [math] M_2 = \langle X, \mathcal{I}_2 \rangle [/math] — два матроида на множестве элементов [math]X[/math] с наборами независимых множеств [math]\mathcal{I}_1[/math] и [math]\mathcal{I}_2[/math]. Положим [math] \mathcal{I} = \mathcal {f} A \mid A = A_1 \cup A_2, A_1 \in \mathcal{I}_1, A_2 \in \mathcal{I}_2 \mathcal {g} [/math]. Множество [math]\mathcal{I}[/math] удовлетворяет аксиомам независимости, следовательно, [math]\langle X, \mathcal{I} \rangle [/math] — матроид, для которого [math]\mathcal{I}[/math] служит независимым множеством. Этот матроид называется объединением матроидов (англ. matroid union) [math]M_1[/math] и [math]M_2[/math], и обозначается [math] M_1 \cup M_2 [/math]

Обычно термин "объединение" применяется, когда носители [math]X[/math] в обоих матроидах одинаковы, однако это не является необходимым, мы можем дополнить их до объединения, заметим, что от этого [math]M_1[/math] и [math]M_2[/math] не перестанут быть матроидами. Если в [math]M_1[/math] и [math]M_2[/math] носители непересекающиеся, тогда это будет являться прямой суммой матроидов.

  • Операция объединения матроидов ассоциативна, следовательно, можно говорить об объединении нескольких матроидов.
  • В отличие от пересечения матроидов, объединение двух конечных (англ. finite matroid) матроидов всегда является матроидом, однако объединение двух бесконечных матроидов (англ. infinite matroid) не обязательно будет им.
  • Объединение применяется к независимым множествам, а не к матроидам в целом, то есть это операция на другом уровне, по сравнению с пересечение матроидов.


Давайте зададим функцию [math]P_1[/math] : [math] X \times Y \rightarrow X[/math]: [math]P_1((x, y)) = x[/math], а для множества [math]B \in X \times Y[/math] выполняется [math]P_1(B) = \{A \subset X| \forall x \in A[/math] [math]\exists y \in B : P_1(y) = x\}[/math].

Определим ещё несколько матроидов, которые нам понадобятся:

[math]M_{\oplus} = M_1 \oplus M_2 = \langle (X \times \{1\}) \cup (X \times \{2\}),[/math] [math] I = \{A \mid A = A_1 \cup A_2, A_1 \in I_1, A_2 \in I_2\} \rangle[/math].

[math]M_{P_1} = \langle (X \times \{1\}) \cup (X \times \{2\}),[/math] [math] I_{P_1} = \{A \mid |P_1(A)| = |A|\} \rangle[/math].

Теперь перейдём к задаче. У нас есть множество и нужно проверить его независимость в объединении матроидов. Множество [math]U[/math] - независимо, если [math]r(U) = |U|[/math]. А можно заметить, что в матроиде [math]M[/math] выполняется [math]r(U) = \max\limits_{A \in I, A \in I_{P_1}, P_1(A) \subset U} |A|[/math]. Т.е. мы свели задачу о проверке множества на независимость в объединении к нахождению мощности максимального независимого множества в пересечении матроидов [math]M_{\oplus}[/math] и [math]M_{P_1}[/math]. Мы это уже умеем делать - Алгоритм построения базы в пересечении матроидов.

Литература