Линейное сетевое кодирование - Linear network coding
Сетевое кодирование - это область исследований, основанная на серии статей с конца 1990-х до начала 2000-х годов. Однако концепция сетевого кодирования, в частности линейное сетевое кодирование, появился намного раньше. В статье 1978 г.[1] предложена схема повышения пропускной способности двусторонней связи через спутник. В этой схеме два пользователя, пытающиеся общаться друг с другом, передают свои потоки данных на спутник, который объединяет два потока, суммируя их по модулю 2, а затем транслирует объединенный поток. Каждый из двух пользователей, получив широковещательный поток, может декодировать другой поток, используя информацию своего собственного потока.
Газета 2000 года [2] привел пример сети «бабочка» (обсуждается ниже), который показывает, как линейное сетевое кодирование может превзойти маршрутизацию. Этот пример эквивалентен схеме спутниковой связи, описанной выше. В той же статье дается оптимальная схема кодирования для сети с одним исходным узлом и тремя конечными узлами. Это первый пример, иллюстрирующий оптимальность сверточного сетевого кодирования (более общая форма линейного сетевого кодирования) в циклической сети.
Линейное сетевое кодирование может использоваться для повышения пропускной способности, эффективности и производительности сети. масштабируемость, а также устойчивость к атакам и подслушиванию. Вместо того, чтобы просто передавать пакеты информации, которую они получают, узлы сети взять несколько пакеты и объединить их вместе для передачи. Это можно использовать для достижения максимально возможного Информация поток в сеть.
Математически доказано, что теоретически линейное кодирование достаточно для достижения верхней границы в задачах многоадресной рассылки с одним источником.[3] Однако линейного кодирования в целом недостаточно (например, с несколькими источниками, с несколькими каналами с произвольными требованиями), даже для более общих версий линейности, таких как сверточное кодирование и кодирование банка фильтров.[4] Поиск оптимальных кодовых решений для общих сетевых проблем с произвольными требованиями остается открытой проблемой.
Кодирование и декодирование
В задаче линейного сетевого кодирования группа узлов участвуют в перемещении данных из исходные узлы для приемные узлы. Каждый узел генерирует новые пакеты, которые представляют собой линейные комбинации ранее полученных пакетов, умножая их на коэффициенты выбран из конечное поле, обычно размером .
Каждый узел, с степень, , генерирует сообщение из линейной комбинации полученных сообщений отношением:
где значения коэффициенты, выбранные из . Обратите внимание, что, поскольку операции вычисляются в конечном поле, сгенерированное сообщение имеет ту же длину, что и исходные сообщения. Каждый узел пересылает вычисленное значение вместе с коэффициентами, , используемый в уровень, .
Узлы-приемники получают эти закодированные в сети сообщения и собирают их в матрицу. Исходные сообщения можно восстановить, выполнив Гауссово исключение на матрицу.[5] В сокращенной форме эшелона строк декодированные пакеты соответствуют строкам формы .
Краткая история
Сеть представлена ориентированный граф . это множество узлов или вершин, - множество направленных звеньев (или ребер), а дает емкость каждого звена . Позволять быть максимально возможной пропускной способностью от узла узел . Посредством теорема о максимальном потоке и минимальном отсечении, ограничена сверху минимальной емкостью всех порезы, который представляет собой сумму мощностей ребер на разрезе между этими двумя узлами.
Карл Менгер доказал, что всегда существует набор непересекающихся ребер путей, достигающих верхней границы в одноадресная передача сценарий, известный как теорема о максимальном потоке и минимальном отсечении. Позже Алгоритм Форда – Фулкерсона было предложено находить такие пути за полиномиальное время. Затем Эдмондс доказал в статье «Разветвления с непересекающимися краями», что верхняя граница в сценарии широковещательной рассылки также достижима, и предложил алгоритм с полиномиальным временем.
Однако ситуация в многоадресная передача сценарий более сложный, и на самом деле такая верхняя граница не может быть достигнута с помощью традиционных маршрутизация идеи. Альсведе и др. доказано, что это может быть достигнуто, если дополнительные вычислительные задачи (входящие пакеты объединяются в один или несколько исходящих пакетов) могут быть выполнены в промежуточных узлах.[2]
Пример сети бабочек
Сеть бабочек [2] часто используется для иллюстрации того, как линейное сетевое кодирование может превзойти маршрутизация. Два исходных узла (вверху рисунка) имеют информацию A и B, которая должна быть передана двум узлам назначения (внизу), каждый из которых хочет знать как A, так и B. Каждое ребро может нести только одно значение ( мы можем думать о фронте, передающем бит в каждом временном интервале).
Если бы была разрешена только маршрутизация, тогда центральный канал мог бы передавать только A или B, но не оба. Предположим, мы отправляем A через центр; тогда левый пункт назначения получит A дважды и вообще не узнает B. Отправка B создает аналогичную проблему для правильного пункта назначения. Мы говорим, что маршрутизации недостаточно, потому что ни одна схема маршрутизации не может передавать одновременно A и B в оба пункта назначения.
Используя простой код, как показано, A и B могут быть переданы в оба пункта назначения одновременно, отправив сумму символов через центр - другими словами, мы кодируем A и B по формуле «A + B». Левый пункт назначения получает A и A + B и может вычислить B, вычитая два значения. Точно так же правильный пункт назначения получит B и A + B, а также сможет определить как A, так и B.
Случайное линейное сетевое кодирование
Случайное линейное сетевое кодирование [6] - это простая, но мощная схема кодирования, которая в схемах широковещательной передачи обеспечивает близкую к оптимальной пропускную способность с использованием децентрализованного алгоритма. Узлы передают случайные линейные комбинации пакетов, которые они принимают, с коэффициентами, выбранными из поля Галуа. Если размер поля достаточно велик, вероятность того, что приемники получат линейно независимые комбинации (и, следовательно, получат инновационную информацию), приближается к 1. Однако следует отметить, что, хотя случайное линейное сетевое кодирование имеет отличную пропускную способность, если Получатель получает недостаточное количество пакетов, крайне маловероятно, что он сможет восстановить какой-либо из исходных пакетов. Эту проблему можно решить путем отправки дополнительных случайных линейных комбинаций до тех пор, пока получатель не получит соответствующее количество пакетов.
Открытые вопросы
Линейное сетевое кодирование - все еще относительно новая тема. Основываясь на предыдущих исследованиях, в RLNC есть три важных открытых вопроса:
- Высокая вычислительная сложность декодирования за счет использования метода исключения Гаусса-Жордана
- Высокие накладные расходы на передачу из-за присоединения больших векторов коэффициентов к кодированным блокам
- Линейная зависимость между векторами коэффициентов, которая может уменьшить количество инновационных кодированных блоков
Кодирование беспроводной сети
Широковещательная природа беспроводной связи (в сочетании с топологией сети) определяет характер вмешательство. Одновременные передачи в беспроводной сети обычно приводят к потере всех пакетов (т. Е. Конфликту, см. Множественный доступ с предотвращением конфликтов для беспроводной сети ). Поэтому для беспроводной сети требуется планировщик (как часть MAC функциональность), чтобы минимизировать такие помехи. Следовательно, любой выигрыш от сетевого кодирования сильно зависит от основного планировщика и будет отличаться от выигрыша, наблюдаемого в проводных сетях. Кроме того, беспроводные линии связи обычно являются полудуплексными из-за аппаратных ограничений; т.е. узел не может одновременно передавать и принимать из-за отсутствия достаточной изоляции между двумя путями.
Хотя изначально сетевое кодирование предлагалось использовать на сетевом уровне (см. Модель OSI ), в беспроводных сетях сетевое кодирование широко используется либо на уровне MAC, либо на PHY слой.[7] Было показано, что сетевое кодирование при использовании в беспроводных ячеистых сетях требует внимательного проектирования и размышлений, чтобы использовать преимущества смешивания пакетов, иначе преимущества не могут быть реализованы. Также существует множество факторов, влияющих на производительность, например протокол уровня доступа к среде передачи данных, алгоритмы управления перегрузкой и т. Д. Неочевидно, как сетевое кодирование может сосуществовать и не подвергать опасности то, что существующие алгоритмы управления перегрузками и потоками делают для нашего Интернета .[8]
Приложения
Поскольку линейное сетевое кодирование является относительно новым предметом, его внедрение в отраслях все еще не принято. В отличие от другого кодирования, линейное сетевое кодирование не полностью применимо в системе из-за его узкого специфического сценария использования. Теоретики пытаются подключиться к приложениям реального мира.[9] Фактически было обнаружено, что подход BitTorrent намного превосходит сетевое кодирование.[нечеткий ][нужна цитата ]
Предполагается, что сетевое кодирование будет полезно в следующих областях:
- Благодаря многоадресной доставке контента из нескольких источников Информационно-ориентированные сети в целом и Именованная сеть передачи данных в частности, линейное кодирование может улучшить эффективность всей сети. [10]
- Альтернативой упреждающее исправление ошибок и ARQ в традиционных и беспроводных сетях с потерей пакетов. например.: Кодированный TCP,[11] Многопользовательский ARQ[12]
- Надежность и устойчивость к сетевым атакам, таким как отслеживание, перехват, воспроизведение или повреждение данных.[13][14]
- Распространение цифровых файлов и обмен файлами P2P. например.: Лавина от Microsoft
- Распределенное хранилище.[15][16][17]
- Увеличение пропускной способности в беспроводных ячеистых сетях. например : СПРАВИТЬСЯ,[18] ОСНОВНОЙ,[19] Маршрутизация с учетом кодирования,[20][21] БЭТМЕН.[22]
- Уменьшение буфера и задержки в пространственных сенсорных сетях: Мультиплексирование пространственного буфера [23]
- Уменьшите количество повторных передач пакетов для односкачковой беспроводной многоадресной передачи и, следовательно, улучшите пропускную способность сети.[24]
- Распределенный обмен файлами [25]
- Потоковое видео низкой сложности на мобильные устройства [26]
- От устройства к устройству (D2D) расширения[27][28][29][30][31]
Появляются новые методы использования сетевого кодирования в системах с множественным доступом для разработки программно-определяемых проводных сетей (SD-WAN), которые могут предложить меньшую задержку, джиттер и высокую надежность. [32]В предложении упоминается, что метод не зависит от базовых технологий, таких как LTE, Ethernet, 5G.[33]
Срок погашения и проблемы
Поскольку эта область относительно нова, а математическая обработка этого предмета в настоящее время ограничена небольшим количеством людей, сетевое кодирование все же нашло свой путь к коммерциализации продуктов и услуг. На данном этапе неясно, будет ли этот предмет преобладать или прекратится как хорошее математическое упражнение.[34]
Исследователи четко указали на необходимость особого внимания к изучению того, как сетевое кодирование может сосуществовать с существующей маршрутизацией, доступом к среде передачи, перегрузкой, алгоритмами управления потоком и протоколом TCP. В противном случае сетевое кодирование может не дать больших преимуществ и может увеличить сложность вычислений и требования к памяти.[35]
Смотрите также
Рекомендации
- ^ Селебилер, М .; Г. Стетте (1978). «Об увеличении пропускной способности регенеративного спутникового ретранслятора в прямом канале связи в двухточечной связи». Труды IEEE. 66 (1): 98–100. Дои:10.1109 / PROC.1978.10848.
- ^ а б c Альсведе, Рудольф; Н. Цай; С.-Ю. Р. Ли; Р. В. Йунг (2000). «Сетевой информационный поток». IEEE Transactions по теории информации. 46 (4): 1204–1216. CiteSeerX 10.1.1.722.1409. Дои:10.1109/18.850663.
- ^ С. Ли, Р. Юнг и Н. Цай, "Линейное сетевое кодирование" (PDF ), в IEEE Transactions on Information Theory, Vol 49, No. 2, pp. 371–381, 2003.
- ^ Р. Догерти, К. Фрейлинг, и К. Зегер, "Недостаточность линейного кодирования в потоке сетевой информации" (PDF ), в IEEE Transactions on Information Theory, Vol. 51, No. 8, pp. 2745-2759, август 2005 г. ( ошибка )
- ^ Чоу, Филип А .; У, Юньнань; Джайн, Камаль (октябрь 2003 г.), «Практическое сетевое кодирование», Конференция Allerton по коммуникациям, управлению и вычислениям,
Затем любой приемник может восстановить исходные векторы, используя исключение Гаусса на векторах в его час (или больше) полученных пакетов
. - ^ Т. Хо, Р. Кёттер, М. Медар, Д. Р. Каргер и М. Эффрос, «Преимущества кодирования над маршрутизацией в случайном порядке» В архиве 2017-10-31 в Wayback Machine в 2003 г. на международном симпозиуме IEEE по теории информации. Дои:10.1109 / ISIT.2003.1228459
- ^ М. Х. Фируз, З. Чен, С. Рой и Х. Лю, (Кодирование беспроводной сети через модифицированный 802.11 MAC / PHY: разработка и реализация на SDR ) в журнале IEEE по избранным областям коммуникаций, 2013.
- ^ XOR в воздухе: практическое кодирование беспроводной сети
- ^ «Насколько практично сетевое кодирование? Меа Ван, Баочунь Ли». CiteSeerX 10.1.1.77.6402. Цитировать журнал требует
| журнал =
(помощь) - ^ Билал, Мухаммед; и другие. (2019). "Подход сетевого кодирования для информационных сетей". Системный журнал IEEE. 13 (2): 1376–1385. arXiv:1808.00348. Bibcode:2019ISysJ..13.1376B. Дои:10.1109 / JSYST.2018.2862913.
- ^ Ким, Минджи (2012). «Сетевой протокол TCP (CTCP)». arXiv:1212.2291 [cs.NI ].
- ^ «Архивная копия» (PDF). Архивировано из оригинал (PDF) на 2007-11-08. Получено 2007-06-16.CS1 maint: заархивированная копия как заголовок (связь)
- ^ «Добро пожаловать в систему безопасности сетевого кодирования - безопасное сетевое кодирование».
- ^ http://home.eng.iastate.edu/~yuzhen/publications/ZhenYu_INFOCOM_2008.pdf[постоянная мертвая ссылка ]
- ^ Билал, Мухаммед; и другие. (2019). "Подход сетевого кодирования для информационных сетей". Системный журнал IEEE. 13 (2): 1376–1385. arXiv:1808.00348. Bibcode:2019ISysJ..13.1376B. Дои:10.1109 / JSYST.2018.2862913.
- ^ «Архивная копия» (PDF). Архивировано из оригинал (PDF) в 2013-09-19. Получено 2013-04-18.CS1 maint: заархивированная копия как заголовок (связь)
- ^ Димакис, Александрос (2007). «Сетевое кодирование для распределенных систем хранения». arXiv:cs / 0702015.
- ^ http://people.csail.mit.edu/rahul/papers/cope-ton2008.pdf
- ^ Кригслунд, Йеппе; Хансен, Йонас; Хундеболл, Мартин; Lucani, Daniel E .; Фитцек, Фрэнк Х. П. (2013). Ядро: БОЛЬШЕ КОПИРА в беспроводных ячеистых сетях. 77-я Конференция по автомобильным технологиям, IEEE, 2013 (весна VTC). С. 1–6. Дои:10.1109 / VTCSpring.2013.6692495. ISBN 978-1-4673-6337-2.
- ^ «Архивная копия» (PDF). Архивировано из оригинал (PDF) на 2008-10-11. Получено 2007-05-10.CS1 maint: заархивированная копия как заголовок (связь)
- ^ http://www.cs.wisc.edu/~shravan/infocom-07-2.pdf
- ^ "NetworkCoding - batman-adv - Open Mesh". www.open-mesh.org. Получено 2015-10-28.
- ^ Добро пожаловать в IEEE Xplore 2.0: Взгляд на большие сети: кодирование против очередей
- ^ Донг Нгуен; Туан Тран; Тхинь Нгуен; Бозе, Б. (2009). «Беспроводное вещание с использованием сетевого кодирования». Транзакции IEEE по автомобильным технологиям. 58 (2): 914–925. CiteSeerX 10.1.1.321.1962. Дои:10.1109 / TVT.2008.927729.
- ^ Распространение данных в беспроводных сетях с сетевым кодированием
- ^ Полосные коды для энергоэффективного сетевого кодирования с применением для мобильной потоковой передачи P2P
- ^ Ву Ю., Лю В., Ван С., Го В. и Чу X. (2015, июнь). Сетевое кодирование при обмене данными между устройствами (D2D), лежащих в основе сотовых сетей. В 2015 году Международная конференция по коммуникациям IEEE (ICC) (стр. 2072-2077). IEEE.
- ^ Чжао, Ю., Ли, Ю., и Ге, Н. (2015, декабрь). Сетевое кодирование на физическом уровне, поддерживающее двустороннюю связь между устройствами, лежащую в основе сотовых сетей. В 2015 году IEEE Global Communications Conference (GLOBECOM) (стр. 1-6). IEEE.
- ^ Абрардо, А., Фодор, Г., и Тола, Б. (2015, июнь). Схемы сетевого кодирования для ретрансляции на основе связи между устройствами для расширения покрытия сотовой связи. В 2015 году IEEE 16-й Международный семинар по достижениям в обработке сигналов в беспроводной связи (SPAWC) (стр. 670-674). IEEE.
- ^ Гао, К., Ли, Ю., Чжао, Ю., и Чен, С. (2017). Двухуровневый подход теории игр для совместного выбора ретранслятора и распределения ресурсов в D2D-коммуникациях с помощью сетевого кодирования. IEEE Transactions on Mobile Computing, 16 (10), 2697-2711.
- ^ Чжоу, Т., Сюй, Б., Сю, Т., Ху, Х., и Сюн, Л. (2015). Индивидуальная для пользователя схема адаптации канала для многоадресного сетевого кодирования от устройства к устройству. IET Communications, 9 (3), 367-374.
- ^ SD-WAN с сетевым кодированием в системах множественного доступа для контроля задержек
- ^ Контроллер SD-WAN для минимизации джиттера задержки в системах с кодированным множественным доступом
- ^ «Насколько практично сетевое кодирование?». CiteSeerX 10.1.1.77.6402. Цитировать журнал требует
| журнал =
(помощь) - ^ "XOR в воздухе" (PDF).
- Fragouli, C .; Ле Будек, Дж. И Видмер, Дж. «Сетевое кодирование: мгновенный учебник» в Обзор компьютерных коммуникаций, 2006.
Али Фарзамния, Шарифа К. Сайед-Юсоф, Норшейла Фиса «Многоадресное множественное кодирование описания с использованием p-Cycle Network Coding», Транзакции KSII в Интернете и информационных системах, Том 7, № 12, 2013.
внешняя ссылка
- Домашняя страница сетевого кодирования
- Библиография сетевого кодирования
- Раймонд В. Йунг, Теория информации и сетевое кодирование, Springer 2008 г., http://iest2.ie.cuhk.edu.hk/~whyeung/book2/
- Раймонд В. Йунг и др., Теория сетевого кодирования, ныне Publishers, 2005, http://iest2.ie.cuhk.edu.hk/~whyeung/netcode/monograph.html
- Кристина Фрагули и др., Сетевое кодирование: мгновенный учебник, ACM SIGCOMM 2006, http://infoscience.epfl.ch/getfile.py?mode=best&recid=58339.
- Файловая система Avalanche, http://research.microsoft.com/en-us/projects/avalanche/default.aspx
- Случайное сетевое кодирование, https://web.archive.org/web/20060618083034/http://www.mit.edu/~medard/coding1.htm
- Коды цифровых фонтанов, http://www.icsi.berkeley.edu/~luby/
- Маршрутизация с учетом кодирования, https://web.archive.org/web/20081011124616/http://arena.cse.sc.edu/papers/rocx.secon06.pdf
- MIT предлагает курс: Введение в сетевое кодирование
- Сетевое кодирование: следующая революция в сети?
- Дизайн протокола с учетом кодирования для беспроводных сетей: http://scholarcommons.sc.edu/etd/230/