Максимальное по рангу распределение: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[отпатрулированная версия][отпатрулированная версия]
Содержимое удалено Содержимое добавлено
м - изолированная статья
исправлены опечатки
Строка 1: Строка 1:
'''Максимальное по рангу распределение''' (МР, {{lang-en|Rank-maximal (RM) allocation}}) — это правило для [[Справедливый делёж|справедливого делёжа]] неделимых предметов. Предположим, что нам нужно распределить несколько предметов между некоторым количеством людей. Каждый человек может упорядочить предметы от лучших к худшим. МР-правило говорит, что мы должны дать как можно большему количеству людей лучший предмет (№1 в списке). Затем мы должны дать как можно большему количеству людей второй по значимости предмет (№2 в списке) и так далее.
'''Максимальное по рангу распределение''' (МР, {{lang-en|Rank-maximal (RM) allocation}}) — это правило для [[Справедливый делёж|справедливого дележа]] неделимых предметов. Предположим, что нам нужно распределить несколько предметов между некоторым количеством людей. Каждый человек может упорядочить предметы от лучших к худшим. МР-правило говорит, что мы должны дать как можно большему количеству людей лучший предмет (№1 в списке). Затем мы должны дать как можно большему количеству людей второй по значимости предмет (№2 в списке) и так далее.


В специальном случае, в котором каждое лицо должно получить один предмет (например, если «предметами» являются некоторые действтия и каждое действие должен выполнить один человек), задача называется '''паросочетанием максимального ранга''' или '''жадным паросочетанием'''.
В специальном случае, в котором каждое лицо должно получить один предмет (например, если «предметами» являются некоторые действтия и каждое действие должен выполнить один человек), задача называется '''паросочетанием максимального ранга''' или '''жадным паросочетанием'''.
Строка 6: Строка 6:


== Опредедения ==
== Опредедения ==
Имеется несколько предметов и несколько агентов. Каждый агент имеет [[Линейно упорядоченное множество|линейное упорядочение]] предметов. Агенты могут не различать по ценности некоторые предметы. Для каждого агента мы можем разбить предметы на классы эквивалентности, которые содержат предметы одного ранга. Например, Если отношением предпочтения Алисы является ''x > y,z > w'', это означает, что для Алисы лучшим выбором служит ''x'', который лучше всех остальных предметов. Затем Алиса предпочитает ''y'' и ''z'', которые в её глазах имеют одинаковую ценность, но не настолько ценны, как ''x''. На последнем месте у Алисы стоит ''w'', который она считает худшим из всех предметов.
Имеется несколько предметов и несколько агентов. Каждый агент имеет [[Линейно упорядоченное множество|линейное упорядочение]] предметов. Агенты могут не различать по ценности некоторые предметы. Для каждого агента мы можем разбить предметы на классы эквивалентности, которые содержат предметы одного ранга. Например, если отношением предпочтения Алисы является ''x > y, z > w'', это означает, что для Алисы лучшим выбором служит ''x'', который лучше всех остальных предметов. Затем Алиса предпочитает ''y'' и ''z'', которые в её глазах имеют одинаковую ценность, но не настолько ценны, как ''x''. На последнем месте у Алисы стоит ''w'', который она считает худшим из всех предметов.


Для любого распределения предметов агентам мы строим его ''ранговый вектор'' следующим образом. Элемент №1 в векторе равен общему числу предметов, которые стоят на первом месте для владельцев, элемент №2 равен общему числу предметов, которые для владельцев стоят на втором месте и так далее.
Для любого распределения предметов агентам мы строим его ''ранговый вектор'' следующим образом. Элемент №1 в векторе равен общему числу предметов, которые стоят на первом месте для владельцев, элемент №2 равен общему числу предметов, которые для владельцев стоят на втором месте и так далее.
Строка 13: Строка 13:


== Пример ==
== Пример ==
Три предмета, x y и z, следует разделит между тремя агентами, ранжирование у которых следующее:
Три предмета, x y и z, следует разделить между тремя агентами, ранжирование у которых следующее:


* Алиса: x > y > z
* Алиса: x > y > z
Строка 26: Строка 26:


== Алгоритмы ==
== Алгоритмы ==
МР-паросочетания первым изучал Роберт Ирвинг, который называл их ''жадными паросочетаниями''. Он предложил алгоритм, который находит МР-паросочетание за время <math>O(n^2 c^3)</math>, где ''n'' — число агентов, а ''c'' — наибольшая длина списка предпочтений агента{{sfn|Irving|2003|с=Tr–2003–136}}.
МР-паросочетания первым изучал Роберт Ирвинг, который называл их ''жадными паросочетаниями''. Он предложил [[алгоритм]], который находит МР-[[паросочетание]] за время <math>O(n^2 c^3)</math>, где ''n'' — число агентов, а ''c'' — наибольшая длина списка предпочтений агента{{sfn|Irving|2003|с=Tr–2003–136}}.


Позднее был найден алгоритм, который работает за время <math>O(m\cdot \min(n, C\sqrt{n}))</math>, где ''m'' — полная длина всех списков предпочтения (полное число рёбер в графе), а ''C'' — максимальный ранг предмета, использованного в МР-паросочетнании (то есть, максимальное число ненулевых элементов в оптимальном векторе рангов){{sfn|Irving, Kavitha и др.|2006|с=602–610}}.
Позднее был найден алгоритм, который работает за время <math>O(m\cdot \min(n, C\sqrt{n}))</math>, где ''m'' — полная длина всех списков предпочтения (полное число рёбер в графе), а ''C'' — максимальный ранг предмета, использованного в МР-паросочетнании (то есть, максимальное число ненулевых элементов в оптимальном векторе рангов){{sfn|Irving, Kavitha и др.|2006|с=602–610}}.
Строка 39: Строка 39:
2. В '''справедливом паросочетании''' целью является поиск паросочетания максимальной кардинальности, которое использует минимальное число рёбер ранга ''r'', затем минимальное число рёбер ранга ''r''−1 и так далее.
2. В '''справедливом паросочетании''' целью является поиск паросочетания максимальной кардинальности, которое использует минимальное число рёбер ранга ''r'', затем минимальное число рёбер ранга ''r''−1 и так далее.


Как максимальное по размеру RM паросочетание, так и справедливое паросочетание, могут быть найдены путём сведение к паросочетанию максимального веса{{sfn|Michail|2007|с=125–132}}.
Как максимальное по размеру МР-паросочетание, так и справедливое паросочетание, могут быть найдены путём сведение к паросочетанию максимального веса{{sfn|Michail|2007|с=125–132}}.


3. В задаче '''емкостного RM-паросочетания''' каждый агент имеет верхнюю ёмкость, которая определяет верхнюю границу общего числа предметов, которые можно передать агенту. Каждый предмет имеет верхнюю квоту, определяющую верхнюю границу числа различных агентов, которым предмет может быть передан. Задачу исследовали Мелхорн и Михаил, которые предложили алгоритм со временем работы <math>O(C n m \log(n^2/m)\log(n))</math>{{sfn|Mehlhorn, Michail|2005}}. Существует улучшенный алгоритм со временем работы <math>O(m\cdot \min(B, C \sqrt{B}))</math>, где ''B'' — минимум сумм квот агентов и сумм квот предметов. Он основывается на расширении {{не переведено 5|Декомпозиция Галаи — Эдмондса|декомпозиции Галаи — Эдмондса||Gallai–Edmonds decomposition}} многорёберных паросочетний {{sfn|Paluch|2013|с=324–335}}.
3. В задаче '''емкостного МР-паросочетания''' каждый агент имеет верхнюю ёмкость, которая определяет верхнюю границу общего числа предметов, которые можно передать агенту. Каждый предмет имеет верхнюю квоту, определяющую верхнюю границу числа различных агентов, которым предмет может быть передан. Задачу исследовали Мелхорн и Михаил, которые предложили алгоритм со временем работы <math>O(C n m \log(n^2/m)\log(n))</math>{{sfn|Mehlhorn, Michail|2005}}. Существует улучшенный алгоритм со временем работы <math>O(m\cdot \min(B, C \sqrt{B}))</math>, где ''B'' — минимум сумм квот агентов и сумм квот предметов. Он основывается на расширении {{не переведено 5|Декомпозиция Галаи — Эдмондса|декомпозиции Галаи — Эдмондса||Gallai–Edmonds decomposition}} многорёберных паросочетний {{sfn|Paluch|2013|с=324–335}}.


== См. также ==
== См. также ==

Версия от 16:11, 6 октября 2020

Максимальное по рангу распределение (МР, англ. Rank-maximal (RM) allocation) — это правило для справедливого дележа неделимых предметов. Предположим, что нам нужно распределить несколько предметов между некоторым количеством людей. Каждый человек может упорядочить предметы от лучших к худшим. МР-правило говорит, что мы должны дать как можно большему количеству людей лучший предмет (№1 в списке). Затем мы должны дать как можно большему количеству людей второй по значимости предмет (№2 в списке) и так далее.

В специальном случае, в котором каждое лицо должно получить один предмет (например, если «предметами» являются некоторые действтия и каждое действие должен выполнить один человек), задача называется паросочетанием максимального ранга или жадным паросочетанием.

Идея похожа на идею разрезания торта согласно полезности, где целью является максимизация суммы полезностей всех участников. Однако, правило полезности работает с кардиналистскими (количествеными) функциями полезности, в то время как МР-правило работает с ординалистскими полезностями (ранжированием).

Опредедения

Имеется несколько предметов и несколько агентов. Каждый агент имеет линейное упорядочение предметов. Агенты могут не различать по ценности некоторые предметы. Для каждого агента мы можем разбить предметы на классы эквивалентности, которые содержат предметы одного ранга. Например, если отношением предпочтения Алисы является x > y, z > w, это означает, что для Алисы лучшим выбором служит x, который лучше всех остальных предметов. Затем Алиса предпочитает y и z, которые в её глазах имеют одинаковую ценность, но не настолько ценны, как x. На последнем месте у Алисы стоит w, который она считает худшим из всех предметов.

Для любого распределения предметов агентам мы строим его ранговый вектор следующим образом. Элемент №1 в векторе равен общему числу предметов, которые стоят на первом месте для владельцев, элемент №2 равен общему числу предметов, которые для владельцев стоят на втором месте и так далее.

Распределение максимального ранга — это распределение, в котором ранговый вектор максимален (в лексикографическом порядке).

Пример

Три предмета, x y и z, следует разделить между тремя агентами, ранжирование у которых следующее:

  • Алиса: x > y > z
  • Боб: x > y > z
  • Карл: y > x > z

В распределении (x, y, z) Алиса получает первый элемент (x), Боб получает второй элемент (y), а Карл получает третий элемент (z). Ранговый вектор равен тогда (1,1,1).

В распределении (x,z,y), Алиса и Карл получают предметы с первого места, а Боб получает предмет, который для него стоит на 3-м месте. Ранговый вектор тогда равен (2,0,1), который лексикографически больше вектора (1,1,1) – он даёт большему числу людей их выбор 1-го места.

Легко проверить, что никакое распределение не даёт лексикографически больший ранговый вектор. Следовательно, распределение (x,z,y) максимально по рангу. Аналогично, распределение (z,x,y) максимально по рангу – оно даёт тот же самый ранговый вектор (2,0,1).

Алгоритмы

МР-паросочетания первым изучал Роберт Ирвинг, который называл их жадными паросочетаниями. Он предложил алгоритм, который находит МР-паросочетание за время , где n — число агентов, а c — наибольшая длина списка предпочтений агента[1].

Позднее был найден алгоритм, который работает за время , где m — полная длина всех списков предпочтения (полное число рёбер в графе), а C — максимальный ранг предмета, использованного в МР-паросочетнании (то есть, максимальное число ненулевых элементов в оптимальном векторе рангов)[2].

Отличное от этого решение с помощью паросочетания максимального веса достигает похожего времени работы — [3].

Варианты

Задача имеет несколько вариантов.

1. В МР-паросочетании максимальной кардинальности целью является поиск среди всех различных МР-паросочетаний паросочетание с максимальным числом сочетаний.

2. В справедливом паросочетании целью является поиск паросочетания максимальной кардинальности, которое использует минимальное число рёбер ранга r, затем минимальное число рёбер ранга r−1 и так далее.

Как максимальное по размеру МР-паросочетание, так и справедливое паросочетание, могут быть найдены путём сведение к паросочетанию максимального веса[3].

3. В задаче емкостного МР-паросочетания каждый агент имеет верхнюю ёмкость, которая определяет верхнюю границу общего числа предметов, которые можно передать агенту. Каждый предмет имеет верхнюю квоту, определяющую верхнюю границу числа различных агентов, которым предмет может быть передан. Задачу исследовали Мелхорн и Михаил, которые предложили алгоритм со временем работы [4]. Существует улучшенный алгоритм со временем работы , где B — минимум сумм квот агентов и сумм квот предметов. Он основывается на расширении декомпозиции Галаи — Эдмондса[англ.] многорёберных паросочетний [5].

См. также

Примечания

  1. Irving, 2003, с. Tr–2003–136.
  2. Irving, Kavitha и др., 2006, с. 602–610.
  3. 1 2 Michail, 2007, с. 125–132.
  4. Mehlhorn, Michail, 2005.
  5. Paluch, 2013, с. 324–335.

Литература

  • Robert W. Irving. Greedy matchings. — University of Glasgow, 2003. — (Technical report).
  • Robert W. Irving, Telikepalli Kavitha, Kurt Mehlhorn, Dimitrios Michail, Katarzyna E. Paluch. Rank-maximal Matchings // ACM Trans. Algorithms. — 2006. — Октябрь (vol. 2 (вып. 4). — С. 602–610. — ISSN 1549-6325. — doi:10.1145/1198513.1198520.
  • Dimitrios Michail. Reducing rank-maximal to maximum weight matching // Theoretical Computer Science. — 2007. — Декабрь (vol. 389). — ISSN 0304-3975. — doi:10.1016/j.tcs.2007.08.004.
  • Kurt Mehlhorn, Dimitrios Michail. Network Problems with Non-Polynomial Weights and Applications. — 2005.
  • Katarzyna Paluch. Capacitated Rank-Maximal Matchings. — Algorithms and Complexity. — Springer, Berlin, Heidelberg, 2013. — Т. 7878. — (Lecture Notes in Computer Science). — ISBN 978-3-642-38232-1. — doi:10.1007/978-3-642-38233-8_27.