Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени



Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени
Способ и устройство для ранжирования равноуровневых узлов в сети потоковой передачи р2р реального времени

 


Владельцы патента RU 2607238:

ПИЭРИАЛИЗМ АБ (SE)

Изобретение относится к области ранжирования равноуровневых узлов в сети Р2Р. Техническим результатом является повышение вероятности приема данных узлом из одного из соседних равноуровневых узлов, тем самым снижение риска того, что равноуровнему узлу будет необходимо принимать данные из источника потоковой передачи. Способ содержит этапы: из равноуровневого узла, вновь подключенного к сети, принимают запрос на прием данных информационного материала, определяют задержку, с которой указанный вновь подключенный равноуровневый узел должен будет принимать данные информационного материала по отношению к моменту воспроизведения реального времени указанных данных информационного материала, распространяемого источником потоковой передачи, осуществляют передачу в указанный вновь подключенный равноуровневый узел множества случайным образом выбранных равноуровневых узлов, из которых запрошенные данные информационного материала могут быть загружены с ожидаемой вероятностью в зависимости от указанной задержки. 3 н. и 13 з.п. ф-лы, 9 ил.

 

Область техники, к которой относится изобретение

Настоящее изобретение относится к способу ранжирования равноуровневых узлов в сети Р2Р (peer-to-peer) и к устройству для ранжирования равноуровневых узлов в сети Р2Р.

Уровень техники

В архитектуре клиент-сервер при потоковой передаче видео в реальном времени клиент принимает видеопоток из сервера потоковой передачи (источника). Видеопоток состоит из набора последовательных элементов данных (подмножеств данных), которые клиент с целью воспроизведения видео время от времени запрашивает. Чтобы удовлетворять потребности возрастающего количества клиентов через Интернет, в расширяемой службе потоковой передачи данных в реальном времени должен использоваться сервер потоковой передачи с высокой пропускной способностью. Чтобы снизить стоимость сервера потоковой передачи, был разработан способ потоковой передачи в реальном времени между узлами одного уровня (равноуровневыми узлами, peer-to-peer, Р2Р). Основной идеей потоковой передачи Р2Р в реальном времени является перенос части нагрузки с сервера потоковой передачи на клиентов, в данном контексте называемых равноуровневыми узлами.

В последние годы к системам потоковой передачи Р2Р в реальном времени привлечено значительное внимание из-за наличия у таких систем преимущества, дающего источнику потоковой передачи возможность транслировать, к примеру, видеоизображение проходящего в настоящий момент мероприятия в большое число равноуровневых узлов без необходимости обеспечения полной требуемой пропускной способности. Это достигается использованием при трансляции информационного материала в равноуровневые узлы имеющейся у самих равноуровневых узлов возможности передавать данные, помогая тем самым источнику потоковой передачи.

К сетям Р2Р относятся все сети, состоящие из элементов, каждый из которых предоставляет другим элементам доступ к части своих ресурсов (например, к вычислительной мощности, емкости дискового хранилища и/или пропускной способности). Концепция Р2Р отличается от концепции, используемой в сетях с обычной архитектурой клиент-сервер, где один или более элементов (например, компьютеров) специально предназначен для обслуживания других элементов сети. Как правило, элементы сети Р2Р используют аналогичные сетевые протоколы и программное обеспечение. Применения сетей Р2Р многочисленны: это может быть, например, передача и/или хранение данных в Интернете, в частности, распространение видеоматериалов владельцами последних.

Для использования способности самих равноуровневых узлов передавать данные разработано множество способов. Указанные способы можно разделить на две основные категории.

Системы на основе дерева строятся с использованием одного или более структурированных деревьев в наложенной сети, где равноуровневые узлы на вершине каждого дерева передают данные в нижележащие равноуровневые узлы. Этот способ хорошо работает, когда не происходит частого присоединения равноуровневых узлов к системе или отсоединения равноуровневых узлов от системы, поскольку дальнейшая передача потока данных осуществляется без передачи сообщений между равноуровневыми узлами. Однако при высокой нагрузке поддержание работоспособности дерева может требовать очень больших затрат, а иногда возникает необходимость в ликвидации и перестройке дерева (деревьев).

Системы на основе ячеистой сети не требуют построения дерева, иными словами, соединения между равноуровневыми узлами не образуют наложенной сети определенного типа, а являются бесструктурными. Указанные узлы обмениваются данными с использованием так называемой эпидемической передачи (gossip communication) или путем передачи между собой запросов данных. Недостатком систем на основе ячеистой сети является возможный рост времени распространения информации, поскольку узлы для поиска равноуровневых узлов должны выполнить согласование между собой. Однако способ на основе ячеистой сети используется во многих системах, поскольку он очень устойчив к высокой нагрузке. В таких системах у каждого равноуровневого узла есть несколько соседних узлов, из которых указанный узел принимает данные, и отказ одного из соседних узлов не столь критичен, как в способах на основе дерева.

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

В децентрализованной сети потоковой передачи Р2Р в реальном времени каждый равноуровневый узел имеет к соседних равноуровневых узлов, из которых он может пытаться принимать данные информационного материала. Таким образом, равноуровневый узел, вместо того, чтобы принимать данные информационного материала из сервера потоковой передачи, предпримет попытку найти соседний равноуровневый узел, из которого возможен прием указанных данных. Однако если в такой наложенной сети известного уровня техники равноуровневые узлы начнут потоковую передачу данных информационного материала с одного и того же момента времени, то ни один из равноуровневых узлов не сможет найти равноуровневый узел, из которого можно принять полезный информационный материал. В результате почти все равноуровневые узлы будут принимать данные из сервера потоковой передачи, и выигрыш в нагрузке на пропускную способность сервера потоковой передачи будет незначительным.

Раскрытие изобретения

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

С этой целью из равноуровневого узла, вновь подключенного к сети, принимают запрос на прием данных информационного материала. Затем определяют задержку, с которой указанный вновь подключенный равноуровневый узел должен будет принимать данные информационного материала по отношению к моменту воспроизведения в реальном времени указанных данных информационного материала, распространяемых источником потоковой передачи. После того, как задержка определена, в указанный вновь подключенный равноуровневый узел передают перечень множества случайным образом выбранных равноуровневых узлов, из которых запрошенные данные информационного материала могут быть загружены с ожидаемой вероятностью, зависящей от определенной таким образом задержки. Таким образом, вновь подключенный равноуровневый узел имеет возможность с ожидаемой вероятностью загрузить запрошенные данные информационного материала из выбранного одного из указанного множества случайным образом выбранных равноуровневых узлов с меньшей задержкой по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла.

В результате путем корректного выбора адекватной задержки для вновь подключенного равноуровневого узла можно повысить вероятность выполнения загрузки указанным узлом от одного из своих соседних равноуровневых узлов. Соответственно, снижается риск того, что равноуровневый узел должен будет загружать данные информационных материалов из источника потоковой передачи.

Следует принять во внимание, что настоящее изобретение относится ко всем возможным сочетаниям признаков, приведенных в формуле изобретения. Другие признаки и преимущества настоящего изобретения будут понятны при изучении прилагаемой формулы изобретения и нижеследующего раскрытия. Специалисту в данной области техники должно быть понятно, что различные признаки настоящего изобретения могут сочетаться с целью создания вариантов осуществления, отличающихся от раскрытых далее.

Краткое описание чертежей

Далее настоящее изобретение раскрывается посредством примера со ссылкой на сопровождающие чертежи, в которых:

на фиг. 1 показана потоковая передача данных в сети потоковой передачи Р2Р в реальном времени, соответствующей известному уровню техники;

на фиг. 2а и 2b показана потоковая передача данных в сети потоковой передачи Р2Р в реальном времени согласно варианту осуществления настоящего изобретения;

на фиг. 3 показана функция трекера согласно варианту осуществления настоящего изобретения;

на фиг. 4 показано распределение вероятности задержек для равноуровневых узлов сети по отношению к моменту воспроизведения реального времени в источнике потоковой передачи согласно варианту осуществления настоящего изобретения;

на фиг. 5 показан вариант осуществления настоящего изобретения, в котором равноуровневые узлы с задержкой di передают запросы в соседние равноуровневые узлы, относящиеся к области α;

на фиг. 6 показано распределение Пуассона, используемое для моделирования распределения задержек равноуровневых узлов сети согласно варианту осуществления настоящего изобретения;

на фиг. 7 показан выигрыш в пропускной способности источника потоковой передачи согласно варианту осуществления настоящего изобретения; и

на фиг. 8 показана гистограмма задержек равноуровневых узлов сети согласно варианту осуществления настоящего изобретения.

Осуществление изобретения

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

На фиг. 1 показана наложенная сеть Р2Р известного уровня техники с равноуровневыми узлами p1-p15, случайным образом соединенными с сервером SS потоковой передачи. Сервер потоковой передачи распространяет данные информационных материалов, разделенные на небольшие элементы данных, которые передаются в равноуровневые узлы сети. Таким образом, данные информационных материалов делят на последовательные элементы данных, в данной заявке называемые подмножествами данных. Это показано в нижней части фиг. 1, где данные информационного материала разделены на небольшие подмножества DS1-DS3 данных. По завершении источником SS потоковой передачи подготовки подмножества DS данных указанное подмножество может быть передано в равноуровневый узел, который начинает воспроизведение указанного подмножества данных, а источник потоковой передачи в это время готовит следующее подмножество данных. На фиг. 1 сервер потоковой передачи передает подмножество DS1 данных в равноуровневые узлы р1, р2, p3, p6, p8, p10 и р14, и в каждом из соответствующих равноуровневых узлов начинается воспроизведение DS1. Одновременно с этим сервер потоковой передачи формирует подмножество данных DS2, а когда равноуровневые узлы р1, р2, р3, p6, p8, p10 и р14 полностью воспроизведут подмножество DS1 данных, указанное подмножество сохраняется в буфере воспроизведения соответствующего равноуровневого узла. Затем сервер потоковой передачи передает в равноуровневые узлы р1, р2, р3, p6, p8, p10 и р14 подмножество DS2 данных, а равноуровневый узел р2 передает последнее полностью принятое подмножество DS1 данных в равноуровневые узлы р7, р9 и р13, равноуровневый узел р3 передает DS1 в равноуровневый узел р4 и т.д.

Соответственно, в таких сетях потоковой передачи Р2Р в реальном времени, соответствующих известному уровню техники, каждый равноуровневый узел, вновь подключенный к сети, запрашивает в трекере (не показан) информацию о последнем подмножестве данных, с которого следует начать прием данных, и информацию о k случайных равноуровневых узлах, являющихся соседними узлами. Затем указанный вновь подключенный равноуровневый узел обращается к своим соседним узлам за последним подмножеством данных, и если требуемое подмножество данных найдено на каком-либо соседнем равноуровневом узле, то указанный вновь подключенный равноуровневый узел начинает прием данных из указанного соседнего равноуровневого узла. Как пояснялось выше, из-за задержек в сети и асинхронизма вновь подключенный равноуровневый узел будет иметь задержку на по меньшей мере полную длительность одного подмножества данных, принимаемого из своего узла, предоставляющего данные, и по меньшей мере вдвое большую задержку по отношению к серверу потоковой передачи при условии, что указанный узел, предоставляющий данные указанному вновь подключенному равноуровневому узлу, имеет задержку на по меньшей мере полную длительность одного подмножества данных, принимаемого из указанного источника. Иными словами, по отношению к моменту RT воспроизведения реального времени данных информационного материала, распространяемого источником потоковой передачи, вновь подключенный равноуровневый узел будет иметь задержку по меньшей мере на два подмножества данных, а узел, предоставляющий данные, будет иметь задержку на по меньшей мере одно подмножество данных. Если вновь подключенный равноуровневый узел не может найти последнее подмножество данных на одном из своих соседних равноуровневых узлов, то указанный вновь подключенный равноуровневый узел принимает указанное подмножество данных из сервера потоковой передачи. По сравнению с обычной клиент-серверной сетью, где сервер распространяет информационные материалы по всем клиентам, в сети Р2Р на фиг. 1 выигрыш в нагрузке на сервер потоковой передачи составляет 8/15=0,53. Иными словами, вместо потоковой передачи информационного материала во все 15 равноуровневых узлов, сервер потоковой передачи SS передает информационный материал только в семь равноуровневых узлов, которые, передавая в свою очередь информационные материалы в остальные восемь равноуровневых узлов, уменьшают нагрузку на сервер.

На фиг. 2а, где показан вариант осуществления настоящего изобретения, новый равноуровневый узел pi подключился к сети и запросил у трекера прием данных информационного материала, изначально передающегося из источника SS потоковой передачи. Трекер определяет, что задержка по отношению к моменту RT воспроизведения реального времени данных информационного материала, распространяемого источником потоковой передачи, с которой вновь подключенный равноуровневый узел будет принимать данные информационного материала, равна di единиц времени, т.е. вновь подключенный равноуровневый узел примет и сможет воспроизвести указанное подмножество данных через di единиц времени после того, как указанное подмножество данных было подготовлено в реальном времени источником потоковой передачи. Затем трекер передает во вновь подключенный равноуровневый узел перечень случайным образом выбранных равноуровневых узлов, из которых могут быть приняты данные указанного информационного материала. Указанный перечень равноуровневых узлов определяется или формируется по функции плотности вероятности для указанного равноуровневого узла в зависимости от задержки. Таким образом, вновь подключенный равноуровневый узел получает возможность принять из выбранного подмножества содержащихся в указанном перечне равноуровневых узлов, имеющих меньшую задержку по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, данные информационного материала с определенной задержкой di по отношению к моменту воспроизведения реального времени в источнике потоковой передачи.

На фиг. 2а показано, что подмножеством данных, которое было сформировано источником потоковой передачи в реальном времени к моменту подключения равноуровневого узла к сети, является DS5. Если, например, указанная фиксированная задержка di равна 3 единицам и выражена в единицах длительности подмножества данных, т.е. указанная определенная задержка составляет три полных подмножества данных, а перечень, переданный трекером во вновь подключенный равноуровневый узел pi, содержит равноуровневые узлы р2, p5, р6, р7 и р8 (на практике количество узлов в перечне будет значительно большим), то вновь подключенный равноуровневый узел сможет найти требуемое подмножество DS2 данных в любом из равноуровневых узлов р2 и р6, при этом указанное подмножество данных будет последним полностью принятым подмножеством данных, хранящимся в буфере воспроизведения узлов р2 и р6, соответственно. Следовательно, DS2 представляет собой последнее подмножество данных, которое может быть передано из равноуровневых узлов р2 и р6. В этом конкретном примере, поскольку равноуровневый узел р2 передает данные в три других равноуровневых узла, предпочтительным может быть прием данных вновь подключенным равноуровневым узлом из р6. Следует отметить, что вновь подключенный равноуровневый узел не может принимать данные из узлов р5, р7 и р8, поскольку в момент подключения равноуровневого узла pi к сети все перечисленные узлы еще только выполняли обработку подмножества DS2 данных. По указанной причине последним полностью принятым подмножеством данных, хранящимся в соответствующем буфере воспроизведения р5, р7 и р8, является подмножество DS1 данных.

По сравнению с обычной клиент-серверной сетью выигрыш в нагрузке на сервер потоковой передачи сети Р2Р на фиг. 2а составляет 13/15=0,87. Иными словами, вместо передачи информационных материалов во все 15 равноуровневых узлов, источник SS потоковой передачи передает информационные материалы в два равноуровневых узла, которые, передавая в свою очередь информационный материал в остальные 13 равноуровневых узлов, снижают нагрузку на источник.

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

На фиг. 2b показан еще один вариант осуществления настоящего изобретения, в котором трекер снова определил, что задержка di для вновь подключенного равноуровневого узла pi должна составлять 3 единицы. В этом конкретном примере перечень, переданный трекером во вновь подключенный равноуровневый узел pi, содержит равноуровневые узлы р3, р4, р7, р8 и р11. В данном случае при определенной задержке, равной трем единицам, вновь подключенный равноуровневый узел не сможет найти требуемое подмножество DS2 данных ни в одном из содержащихся в перечне равноуровневых узлов. Для равноуровневых узлов р4 и р11 последним полностью принятым подмножеством данных, хранящимся в соответствующем буфере воспроизведения, является DS0, а для равноуровневых узлов р3, р7 и р8 последним полностью принятым подмножеством данных является DS1. Таким образом, ни один из равноуровневых узлов, содержащихся в перечне, не сможет передать затребованное подмножество DS2 данных во вновь подключенный равноуровневый узел, вследствие чего вновь подключенный равноуровневый узел за требуемым подмножеством данных будет вынужден обратиться к источнику потоковой передачи.

На фиг. 3 показан еще один вариант осуществления настоящего изобретения, сочетающий способы, рассмотренные совместно с фиг. 2а и 2b. Сплошными линиями обозначены сообщения запросов и ответов, пунктирными линиями обозначены каналы потоковой передачи. Новый равноуровневый узел pi подключается к сети и запрашивает у трекера Τ в шаге S101 через его коммуникационный интерфейс CI прием данных информационных материалов, изначально передаваемых из источника SS потоковой передачи. Трекер определяет задержку, с которой вновь подключенный равноуровневый узел должен принимать данные информационных материалов по отношению к моменту воспроизведения реального времени, и в шаге S102 передает во вновь подключенный равноуровневый узел перечень k случайным образом выбранных равноуровневых узлов, из которых могут быть приняты данные указанного информационного материала. Затем вновь подключенный равноуровневый узел запрашивает в шаге S103 у равноуровневых узлов из перечня предоставление последнего подмножества данных с учетом задержки, определенной для указанного вновь подключенного равноуровневого узла. Если имеется по меньшей мере один равноуровневый узел из k случайным образом выбранных равноуровневых узлов с задержкой по отношению к моменту воспроизведения реального времени, более низкой по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, то в шаге S104 запрошенные данные информационного материала передаются в указанный вновь подключенный равноуровневый узел. На фиг. 3 запрошенные данные информационного материала во вновь подключенный равноуровневый узел pi передает равноуровневый узел р3. Выбором задержки для вновь подключенного равноуровневого узла можно увеличить вероятность того, что равноуровневый узел сможет в шаге S104 передать запрошенные данные информационных материалов во вновь подключенный равноуровневый узел. При отсутствии случайным образом выбранного равноуровневого узла с задержкой по отношению к моменту воспроизведения реального времени, более низкой по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, т.е. если все k равноуровневых узлов имеют задержку, равную или более высокую по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, то передача запрошенных данных информационного материала во вновь подключенный равноуровневый узел в шаге S104 будет невозможной. В этом случае вновь подключенный равноуровневый узел в шаге S105 обратится за требуемыми данными информационного материала к серверу потоковой передачи SS, который затем в шаге S106 передаст запрошенные данные информационного материала во вновь подключенный равноуровневый узел. Соответственно, выбором задержки для вновь подключенного равноуровневого узла можно снизить вероятность того, что серверу потоковой передачи придется в шаге S106 передавать запрошенные данные информационного материала. Указанные вероятности более подробно рассматриваются ниже.

В вариантах осуществления настоящего изобретения трекер в соответствии с настоящим изобретением определяет задержку di, с которой подключенный равноуровневый узел должен будет принимать данные информационного материала по отношению к моменту воспроизведения реального времени данных указанного информационного материала, передаваемого источником потоковой передачи, на основании статистической информации. Поведение сети Р2Р, в которой осуществляется настоящее изобретение, является случайным, зависящим от равноуровневых узлов сети, осуществляющих потоковую передачу в настоящий момент. Таким образом, должна использоваться такая статистическая информация, которая позволила бы построить распределение вероятности, описывающее поведение равноуровневых узлов в сети потоковой передачи Р2Р в реальном времени. Имея распределение p(d) вероятности задержки относительно момента воспроизведения реального времени транслируемых данных информационного материала на сервере потоковой передачи, можно рассчитать ожидаемый выигрыш в нагрузке на пропускную способность сервера потоковой передачи. Соответственно, задавая для каждого вновь подключенного равноуровневого узла значение задержки в соответствии с распределением p(d), можно приблизить выигрыш для сервера потоковой передачи к указанному ожидаемому выигрышу, рассчитанному с использованием указанного распределения. То же самое иными словами: определяя подходящую задержку, с которой вновь подключенный равноуровневый узел должен будет принимать данные информационного материала, можно увеличить вероятность того, что будет найден равноуровневый узел сети, из которого вновь подключенный равноуровневый узел сможет принять запрошенные данные информационного материала. Таким образом, выигрыш в пропускной способности сервера потоковой передачи непосредственно связан с вероятностью того, сможет ли какой-либо равноуровневый узел сети передать запрошенные данные информационного материала во вновь подключенный равноуровневый узел.

Показанный на фиг. 3, трекер Т, относящийся к вариантам осуществления настоящего изобретения, как правило, представляет собой устройство, содержащее одно или более устройств CPU обработки данных в форме микропроцессора (микропроцессоров), с целью осуществления требуемой функциональности выполняющего надлежащую программу, хранимую в сопряженном запоминающем устройстве. Однако для управления системой Р2Р и определения задержек равноуровневых узлов путем выполнения надлежащей программы, хранимой в подходящем запоминающем устройстве, например, в оперативном запоминающем устройстве, во флэш-памяти или на жестком диске, в вариантах осуществления способа в соответствии с настоящим изобретением могут быть использованы и другие пригодные устройства с вычислительными возможностями, к примеру, специализированная интегральная схема (application specific integrated circuit, ASIC), программируемая пользователем матрица логических элементов (field programmable gate array, FPGA), сложное программируемое логическое устройство (complex programmable logic device, CPLD) и т.п.

На фиг. 4 показана предполагаемая форма распределения задержки по отношению к моменту воспроизведения реального времени в соответствии с вариантами осуществления настоящего изобретения. Поскольку распределением значений задержек управляет трекер, можно установить взаимосвязь между ожидаемым выигрышем и указанным распределением. В вариантах осуществления настоящего изобретения любой вновь подключенный равноуровневый узел i, имеющий k случайным образом выбранных соседей и некоторую определенную трекером задержку di по отношению к моменту воспроизведения реального времени, будет искать среди своих соседей требуемые данные информационного материала, т.е. подмножество данных, которое в числе подмножеств di данных ранее было подготовлено в реальном времени в источнике потоковой передачи, см. фиг. 2а и 2b. Если конкретное подмножество данных не будет найдено, то указанный вновь подключенный равноуровневый узел запросит указанное подмножество данных из сервера потоковой передачи, тем самым расходуя пропускную способность сервера потоковой передачи. Указанная нежелательная ситуация возникает, когда последнее полностью принятое каждым из указанных k соседей подмножество данных имеет задержку, равную или большую по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, т.е. задержку, лежащую в области β или в области между di - δ и di распределения p(d).

В то же время если один из указанных k соседних равноуровневых узлов имеет задержку, лежащую в области α (и имеет достаточную пропускную способность), то указанный равноуровневый узел сможет передавать данные во вновь подключенный равноуровневый узел, начиная с запрошенного подмножества данных. Возвращаясь к фиг. 2а и 2b, следует отметить, что область α отграничена значением di - δ, где δ обычно соответствует длительности одного подмножества данных. То есть если задержка, определенная для вновь подключенного равноуровневого узла, равна трем подмножествам данных, то указанный узел сможет принять требуемое подмножество данных из равноуровневого узла, имеющего задержку, равную двум подмножествам данных, считая от момента воспроизведения реального времени. Поэтому вновь подключенный равноуровневый узел сможет принять данные лишь из любого соседнего равноуровневого узла, который опережает указанный вновь подключенный равноуровневый узел по меньшей мере на величину δ. Следовательно, вероятность Pdi того, что для вновь подключенного равноуровневого узла случайным образом выбранный соседний равноуровневый узел относится к области α, равна просто значению интегральной функции распределения (cumulative distribution function, cdf) случайной переменной d в точке di - δ:

Таким образом, в варианте осуществления настоящего изобретения задержка di вновь подключенного равноуровневого узла определяется трекером с использованием принципа, выраженного формулой (1) благодаря чему запрошенные данные информационного материала с достаточно высокой вероятностью могут быть приняты из одного из k случайным образом выбранных равноуровневых узлов. В результате путем корректного выбора подходящей задержки для вновь подключенного равноуровневого узла вероятность того, что прием данных указанным вновь подключенным равноуровневым узлом будет осуществляться из одного из своих k соседних равноуровневых узлов, может быть повышена (или, при необходимости, снижена). Платой за повышение для вновь подключенного равноуровневого узла вероятности приема данных из соседнего равноуровневого узла является рост задержки, испытываемой указанным вновь подключенным равноуровневым узлом. Таким образом, если для данной сети потоковой передачи Р2Р в реальном времени вероятность успешного приема из соседнего равноуровневого узла и без того высока, то трекер может выбрать меньшую задержку с сохранением высокой вероятности приема.

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

Как указано выше, в каждый равноуровневый узел сообщается перечень k случайным образом выбранных соседних равноуровневых узлов, чтобы гарантировать, что определенные задержки от момента воспроизведения реального времени будут согласованы с распределением p(d) вероятности и поэтому не будет иметь место какое-либо несоответствие. Кроме того, как указано выше, вновь подключенный равноуровневый узел будут принимать данные из сервера потоковой передачи, если соответствующее последнее полностью принятое подмножество данных каждого равноуровневого узла из числа k соседних равноуровневых узлов старше, чем подмножество данных, которое указанный вновь подключенный равноуровневый узел запрашивает. Такая ситуация имеет место на фиг. 2b, где трекер определил, что задержка di вновь подключенного равноуровневого узла pi должна быть 3 подмножества данных а перечень, переданный трекером во вновь подключенный равноуровневый узел pi, содержит равноуровневые узлы р3, р4, p7, p8 и р11. В этом случае при определенной задержке, равной трем единицам, вновь подключенный равноуровневый узел не сможет найти требуемое подмножество DS2 данных ни в одном из содержащихся в перечне равноуровневых узлов. Для равноуровневых узлов р4 и р11 последним полностью принятым подмножеством данных, хранящимся в соответствующем буфере воспроизведения, является DS0, а для равноуровневых узлов р3, р7 и р8 последним полностью принятым подмножеством данных является DS1. Таким образом, ни один из равноуровневых узлов, содержащихся в перечне, не сможет передать затребованное подмножество DS2 данных во вновь подключенный равноуровневый узел, поскольку оба имеющихся в наличии подмножества данных DS1 и DS0 старше, чем запрошенное подмножество данных DS2, вследствие чего вновь подключенный равноуровневый узел за требуемым подмножеством данных будет вынужден обратиться к источнику потоковой передачи. При обращении к фиг. 4 видно, что указанная ситуация имеет место, если все k случайным образом выбранных соседних равноуровневых узла имеют более высокую задержку по сравнению с задержкой, определенной для вновь подключенного равноуровневого узла, т.е. задержку, лежащую в области β распределения p(d) вероятности.

В еще одном варианте осуществления настоящего изобретения вероятность того, что все k соседних равноуровневых узлов будут относиться к области β, может быть выражена как биномиальный эксперимент, в котором определяют вероятность получить нулевое количество успешных испытаний в общем наборе из k испытаний. Полагая успешным испытанием нахождение одного соседнего равноуровневого узла, относящегося к области α, вероятность PF нахождения нулевого числа соседних равноуровневых узлов, относящихся к области α, среди k соседних равноуровневых узлов может быть выражена как биномиальный эксперимент с x=0 следующим образом:

Таким образом, PF(di) выражает вероятность того, что принимающий данные равноуровневый узел с определенной задержкой di будет вынужден принимать требуемые данные информационного материала из сервера потоковой передачи, поскольку ни один соседний равноуровневый узел из k случайным образом выбранных равноуровневых узлов не находится в области α на фиг. 4. Соответственно, вероятность того, что вновь подключенный равноуровневый узел с задержкой di найдет среди k случайным образом выбранных равноуровневых узлов по меньшей мере один соседний равноуровневый узел, относящихся к области α (из которого он сможет принять требуемые данные информационного материала), может быть выражена как 1-PF(di). Данный вариант осуществления представляет простую модель, которую трекер может использовать для определения задержки di для вновь подключенного равноуровневого узла для того, чтобы данные информационного материала могли быть с некоторой вероятностью приняты из соседнего равноуровневого узла.

Однако в данной модели не принята во внимание ограниченная пропускная способность каждого из равноуровневых узлов сети. Может иметь место ситуация, в которой вновь подключенный к сети равноуровневый узел с задержкой di нашел среди к случайным образом выбранных равноуровневых узлов один или более соседних равноуровневых узлов, относящихся к области α, но указанные соседние равноуровневые узлы не могут передать данные в указанный вновь подключенный равноуровневый узел вследствие ограничений по пропускной способности. В варианте осуществления настоящего изобретения, описываемом далее, трекер принимает во внимание ограниченную пропускную способность равноуровневых узлов сети.

Для практических целей будет использоваться дискретное распределение вероятности p(d), поскольку на практике задержку относительно момента воспроизведения реального времени выражают дискретным значением, т.е. в единицах длительности подмножества данных. Таким образом, задержки принимают дискретные значения [d1; d2, d3, …], где для всех n выполняется условие dn+1-dn=δ. Дискретное распределение вероятности подразумевает, что ожидаемое количество равноуровневых узлов с задержкой di равно Ni=p(di)N. Для любой задержки dj относительно момента воспроизведения реального времени количество запросов приема данных из равноуровневых узлов с задержкой di равно:

Здесь Npi=(1-PF(di))Ni представляет собой ожидаемое количество равноуровневых узлов с задержкой di, которые будут пытаться принять данные из равноуровневых узлов, относящихся к области α. Причиной того, что попытка приема из других равноуровневых узлов, относящихся к области α, окажется успешной только у подмножества Npi всех равноуровневых узлов Ni, имеющих задержку di, является возможность отсутствия у равноуровневых узлов с задержкой di соседних равноуровневых узлов, относящихся к α, в результате чего указанные узлы будут вынуждены принимать данные из источника потоковой передачи.

Общее количество запросов приема информации, которое соседние равноуровневые узлы передают в равноуровневые узлы с задержкой dj, таким образом, равно:

На фиг. 5 показан пример, в котором равноуровневые узлы с задержкой di передают запросы в соседние равноуровневые узлы, относящиеся к области α, который иллюстрирует, что ни одного запроса не будет передано в соседние узлы, относящиеся к области β (данная ситуация соответствует второму условию в формуле 3).

Чтобы определить, сколько из этих запросов будет удовлетворено, примем количество равноуровневых узлов с задержкой dj равным Nj и будем считать, что каждый из указанных узлов может одновременно вести Е(u) загрузок, тогда вероятность того, что равноуровневый узел с задержкой dj ответит на l запросов из общего количества Rj запросов приема информации равна:

где Е(u) представляет собой среднее количество одновременных загрузок на равноуровневый узел и определяется распределением pbw пропускной способности и битовой скоростью br передачи данных. Среднее количество одновременных загрузок на равноуровневый узел, таким образом, рассчитывается как Е(u)=E(pbw/br). Например, если некоторому равноуровневому узлу задана пропускная способность 1 Мбит/с, а битовая скорость потоковой передачи данных равна 200 кбит/с, то указанный равноуровневый узел сможет одновременно передавать данные в пять других равноуровневых узлов. Bj(l) определяет долю равноуровневых узлов с задержкой dj, которые получат l запросов на прием информации. При l≤Е(u) количество успешных запросов будет равно l×Bj(l)×Nj, а при l>E(u) количество успешных запросов будет равно E(u)×Bj(l)×Nj. Таким образом, равноуровневые узлы с задержкой dj примут Rj запросов приема информации, и каждый из указанных запросов случайным образом попадет в один узел из множества Nj равноуровневых узлов, при этом распределение запросов приема информации может быть смоделировано биномиальным распределением.

Следовательно, ожидаемое количество успешных ответов, которым равноуровневые узлы с задержкой dj ответят на запросы приема информации из соседних равноуровневых узлов (т.е. нагрузка на равноуровневые узлы с задержкой dj) составит:

и потому ожидаемое количество равноуровневых узлов указанной сети Р2Р, осуществляющих потоковую передачу, равно общему количеству успешных загрузок:

Вероятность того, что запрос приема, который соседний равноуровневый узел делает в равноуровневые узлы с задержкой dj, окажется успешным, может быть рассчитана как отношение ожидаемого количества успешных ответов и указанного общего количества запросов приема информации, т.е. Lj/Rj.

Как результат, вероятность того, что запрос приема из равноуровневого узла с задержкой dj попадет в область α, равна (1-PF(dj)), т.е. вероятность того, что равноуровневый узел с задержкой di найдет среди к случайным образом выбранных равноуровневых узлов по меньшей мере один соседний равноуровневый узел, относящихся κ области α, из которого он сможет загрузить запрошенные данные информационных материалов, может быть выражена как 1-PF(di). Вероятность того, что один из указанных запросов в равноуровневые узлы, относящиеся к области α, действительно поступит в равноуровневые узлы, имеющие конкретную задержку dj, равна p(dj)/Pαi (выведено из формулы 3, которая определяет данную вероятность для количества Ni равноуровневых узлов с задержкой di). Данные вероятности в модели являются независимыми, и вероятность того, что равноуровневый узел, имеющий задержку di, сможет принять информационный материал из соседнего равноуровневого узла, имеющего конкретную задержку dj (с учетом ограниченной пропускной способности) может быть выражена как произведение указанных трех вероятностей. Отсюда следует, что вероятность того, что равноуровневый узел, имеющий задержку dj, осуществит успешную загрузку из сети Р2Р, т.е. примет данные из любого равноуровневого узла, имеющего задержку менее di, может быть выражена как сумма вероятностей:

Таким образом, суммирование охватывает все равноуровневые узлы, имеющие задержку менее dj, а не только равноуровневые узлы, имеющие конкретную задержку dj.

Ожидаемый выигрыш для источника потоковой передачи связан с вероятностью успешного приема каждым равноуровневым узлом в сети:

Однако выигрыш может быть выражен и более просто, как отношение успешных загрузок в равноуровневые узлы сети к общему количеству равноуровневых узлов в сети, т.е.:

Данный способ расчета выигрыша концептуально проще и более эффективен в вычислительном отношении. Обе формулы (7) и (8) дают одинаковый результат.

Резюмируя данный вариант осуществления настоящего изобретения, отметим, что ситуация, в которой принимающий данные равноуровневый узел с определенной задержкой di будет вынужден принимать требуемые данные информационного материала из сервера потоковой передачи, возникает, если:

(a) ни один соседний равноуровневый узел из к случайным образом выбранных равноуровневых узлов не находится в области α, т.е. ни один соседний равноуровневый узел не имеет задержку di - δ или менее, или

(b) среди к случайным образом выбранных равноуровневых узлов один или более соседних равноуровневых узлов находятся в области α, но указанные соседние равноуровневые узлы не могут отдавать данные из-за ограниченной пропускной способности.

Иными словами, несмотря на то, что в области α, показанной на фиг. 4, могут быть соседние равноуровневые узлы, у указанных узлов из-за ограниченной пропускной способности может не быть возможности передать данные в запрашивающий равноуровневый узел. Вышеприведенная формула 6 учитывает указанные ограничения пропускной способности и дает возможность рассчитать Ps(di), т.е. вероятность того, что равноуровневый узел, имеющий задержку di, выполнит успешную загрузку из сети Р2Р.

Соответственно, в данном варианте осуществления настоящего изобретения задержка di вновь подключенного равноуровневого узла определяется трекером с использованием принципа, выраженного формулой (6), благодаря чему запрошенные данные информационного материала с достаточно высокой вероятностью могут быть приняты из одного из k случайным образом выбранных равноуровневых узлов. В отличие от вышеописанных вариантов осуществления, данный вариант осуществления принимает во внимание ограничения в пропускной способности потоковой передачи.

В предыдущем варианте осуществления настоящего изобретения трекер не принимает во внимание ситуацию, в которой имеется совместная вероятность задержки и пропускной способности p(u,d). Моделируя задержку и пропускную способность с использованием совместной вероятности случайных событий, можно более качественно определить задержку для вновь подключенного равноуровневого узла. Распределение вероятности задержки di относительно момента воспроизведения реального времени представляет собой сумму по u совместной

вероятности p(u, d):

где и в соответствии с вышеприведенным описанием представляет собой количество одновременных загрузок для равноуровневого узла и определяется распределением pbw пропускной способности и битовой скоростью br передачи данных. Количество одновременных загрузок для равноуровневого узла u=pbw/br. В более совершенном варианте осуществления трекер принимает во внимание тот факт, что равноуровневые узлы, запрашивающие прием данных информационного материала, могут иметь различную пропускную способность u, т.е. различные равноуровневые узлы в сети Р2Р имеют возможность одновременно осуществлять неодинаковое количество загрузок данных. К примеру, в вариантах осуществления, показанных на фиг. 2 и 3, запрос, принимаемый трекером, будет поэтому дополнительно содержать пропускную способность равноуровневого узла по передаче данных.

Количество запросов загрузки из равноуровневых узлов с задержкой di в равноуровневые узлы с задержкой dj и пропускной способностью по передаче данных и равна:

Аналогично, общее количество запросов приема информации, которое соседние равноуровневые узлы передают в равноуровневые узлы с задержкой dj и пропускной способностью u, равно:

Чтобы определить, сколько из этих запросов будут удовлетворены, примем количество равноуровневых узлов с задержкой dj и пропускной способностью u по передаче данных равным Nju, тогда вероятность того, что равноуровневый узел с задержкой dj и пропускной способностью по передаче данных u ответит на l запросов приема данных из общего количества Rju запросов приема данных, равна:

где Nju=p(u, j)N представляет собой ожидаемое количество равноуровневых узлов с задержкой dj и пропускной способностью по передаче данных u. Следовательно, ожидаемое количество успешных ответов, которыми равноуровневые узлы с задержкой dj и пропускной способностью u по передаче данных ответят на запросы приема информации из соседних равноуровневых узлов (т.е. нагрузка на равноуровневые узлы с задержкой dj и пропускной способностью u по передаче данных) равна:

и потому ожидаемое количество равноуровневых узлов указанной сети Р2Р, осуществляющих потоковую передачу, равно общему количеству успешных загрузок:

По аналогии с причинами, изложенными выше в связи с формулой 6, вероятность того, что равноуровневый узел с задержкой di осуществит успешную загрузку из сети Р2Р, теперь может быть выражена как:

а выигрыш будет выражаться как в формулах (8) или (7).

В других вариантах осуществления настоящего изобретения, с одной стороны, может использоваться ранее обсуждавшаяся взаимосвязь между распределением p(d) задержек и вероятностью того, что вновь подключенный равноуровневый узел будет принимать данные из равноуровневого узла, имеющего меньшую задержку по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла; с другой стороны, для оптимизации указанного распределения задержек с целью достижения наивысшей возможной вероятности того, что указанный вновь подключенный равноуровневый узел будет принимать данные информационного материала из должным образом выбранного равноуровневого узла сети, может использоваться выигрыш.

При этом в качестве критерия для оценки распределения p(d) используют ожидаемый выигрыш для сервера потоковой передачи. После нахождения оптимального распределения с использованием известного алгоритма эволюционной оптимизации для каждого равноуровневого узла на основании указанного оптимального распределения задается задержка по отношению к моменту воспроизведения реального времени сервера потоковой передачи просто путем выбора трекером значений задержки из указанного оптимального распределения и задания выбранных значений равноуровневым узлам. При поиске оптимального распределения принимают во внимание ранее упомянутое среднее количество E(ui) одновременных загрузок, приходящихся на равноуровневый узел. В варианте осуществления настоящего изобретения учитывают изменения E(ui) и используют их для подгонки p(d) с целью оптимизации под периодические изменения в сети Р2Р. В первом варианте осуществления с целью оптимизации распределение задержек считают известным распределением, например, распределением Пуассона. Поскольку на форму стандартных распределений влияют параметры указанных распределений, необходимо лишь рассмотреть пространство значений этих параметров. Если предполагается, что случайная задержка d описывается распределением Пуассона, то оптимизировать следует параметр λ указанного распределения.

Как ясно из фиг. 6, для данной задержки di, определенной трекером для вновь подключенного равноуровневого узла, можно варьировать параметр λ до тех пор, пока не будет достигнуто наибольшее значение вероятности. Следовательно, максимизация вероятности того, что вновь подключенный равноуровневый узел будет принимать запрошенные данные информационного материала из равноуровневого узла сети равносильна максимизации выигрыша в нагрузке на пропускную способность сервера потоковой передачи. Например, в примере распределение Пуассона на фиг. 6 для определенной задержки di=10 максимальная вероятность достигается при λ=10.

Перед оптимизацией распределения в модуле оптимизации, который управляет оптимизацией распределения p(d|λ), должно быть задано количество к случайным образом выбранных соседних равноуровневых узлов и значение Е(ui), т.е. среднее количество одновременных загрузок на равноуровневый узел. После нахождения почти оптимального значения λ, которое максимизирует ожидаемый выигрыш для сервера потоковой передачи, путем выполнения генетического алгоритма (GA) на пространстве λ, трекер затем может начать использовать это оптимальное распределение для выбора значения задержки di для вновь подключенного равноуровневого узла pi. На фиг. 7 показан выигрыш по нагрузке на источник потоковой передачи для различных значений λ в предположении, что трекер передает во вновь подключенный равноуровневый узел перечень из k=50 случайным образом выбранных соседних равноуровневых узлов, а Е(ui)=3. При этих конкретных значениях система достигнет выигрыша около 82%. По оси x отложена задержка равноуровневого узла.

В еще одном варианте осуществления настоящего изобретения предполагается, что распределение p(d) задержек не является распределением заранее определенного вида, а должно оптимизироваться как гистограмма вероятностей. Польза такого способа обусловлена тем, что форма распределения не ограничивается конкретным распределением, а может быть произвольной. В данном контексте предполагается, что наибольшее число столбцов гистограммы, т.е. наибольшая возможная задержка di, равно Dmax. Таким образом, в целевом представлении в виде гистограммы будет только Dmax столбцов (называемых частотными значениями). На фиг. 8 Dmax выбрано равным 21, каждый столбец может принимать значения в интервале [0; 1], что означает, что пространство поиска в данной оптимизации будет содержать 21 переменную для принятия решения. Частоты гистограммы в сумме должны давать 1 (из-за ограничения, налагаемого тем, что гистограмма должна быть распределением вероятности), и хорошим алгоритмом оптимизации, который дает возможность учесть эти ограничения, является генетический алгоритм (GA). С теми же исходными значениями, которые использовались при оптимизации распределения Пуассона, показанного на фиг. 7, т.е. при k=50 и E(ui)=3, оптимальная гистограмма, показанная на фиг. 8, дает ожидаемый выигрыш около 85%.

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

1. Способ ранжирования равноуровневых узлов в сети Р2Р, содержащей источник потоковой передачи и множество равноуровневых узлов, включающий:

прием из вновь подключенного к сети равноуровневого узла запроса на прием данных информационного материала;

определение задержки по отношению к моменту воспроизведения в реальном времени данных информационного материала, распространяемых источником потоковой передачи, с которой указанный вновь подключенный равноуровневый узел должен будет принимать данные информационного материала, исходя из определенного распределения вероятности задержек, с которыми равноуровневые узлы сети принимают данные информационного материала, распространяемые источником потоковой передачи; и

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

2. Способ по п. 1, отличающийся тем, что шаг определения задержки для вновь подключенного равноуровневого узла включает:

определение вероятности того, что ни один из указанного множества случайным образом выбранных равноуровневых узлов не будет иметь задержку, меньшую по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, путем постановки биномиального эксперимента, в котором в количестве испытаний, равном количеству случайным образом выбранных равноуровневых узлов, определяются неуспешные исходы; и

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

3. Способ по п. 1, отличающийся тем, что вероятность того, что указанный вновь подключенный равноуровневый узел может загрузить запрошенные данные информационного материала из выбранного одного из множества случайным образом выбранных равноуровневых узлов, определяется как произведение

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

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

4. Способ по любому из предшествующих пунктов, отличающийся тем, что шаг учета пропускной способности указанного множества случайным образом выбранных равноуровневых узлов включает моделирование задержки и пропускной способности указанного множества случайным образом выбранных равноуровневых узлов как переменных совместной вероятности; при этом вероятность того, что указанный вновь подключенный равноуровневый узел может загрузить запрошенные данные информационного материала из выбранного одного из множества случайным образом выбранных равноуровневых узлов, определяют на основании совместной вероятности задержки и пропускной способности.

5. Способ по п. 4, отличающийся тем, что вероятность того, что указанный вновь подключенный равноуровневый узел может загрузить запрошенные данные информационного материала из выбранного одного из множества случайным образом выбранных равноуровневых узлов, определяется как произведение:

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

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

6. Способ по п. 1, отличающийся тем, что шаг определения задержки для вновь подключенного равноуровневого узла включает:

определение распределения вероятности для задержек, с которыми равноуровневые узлы сети принимают данные информационного материала, распространяемые источником потоковой передачи;

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

7. Способ по п. 6, отличающийся тем, что указанное распределение вероятности является распределением Пуассона, а параметром, подлежащим оптимизации, является параметр в распределении Пуассона.

8. Способ по п. 1, отличающийся тем, что шаг определения задержки для вновь подключенного равноуровневого узла включает:

определение гистограммы вероятностей для задержек, с которыми равноуровневые узлы сети принимают данные информационного материала, распространяемые источником потоковой передачи; и

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

9. Способ по любому из пп. 6-8, отличающийся тем, что используемым алгоритмом эволюционной оптимизации является генетический алгоритм (GA).

10. Устройство для ранжирования равноуровневого узла в сети Р2Р, содержащей источник потоковой передачи и множество равноуровневых узлов, содержащее

устройство обработки данных и

коммуникационный интерфейс, причем

указанный коммуникационный интерфейс выполнен с возможностью приема из вновь подключенного к сети равноуровневого узла запроса на прием данных информационного материала;

указанное устройство обработки данных выполнено с возможностью определения задержки по отношению к моменту воспроизведения в реальном времени данных информационного материала, распространяемых источником потоковой передачи, с которой указанный вновь подключенный равноуровневый узел должен будет принимать данные информационного материала, исходя из определенного распределения вероятности задержек, с которыми равноуровневые узлы сети принимают данные информационного материала, распространяемые источником потоковой передачи; и

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

11. Устройство по п. 10, отличающееся тем, что указанное устройство обработки данных дополнительно выполнено с возможностью определения задержки для вновь подключенного равноуровневого узла путем

определения вероятности того, что ни один из указанного множества случайным образом выбранных равноуровневых узлов не будет иметь задержку, меньшую по сравнению с задержкой, определенной для указанного вновь подключенного равноуровневого узла, путем постановки биномиального эксперимента, в котором в количестве испытаний, равном количеству случайным образом выбранных равноуровневых узлов, определяются неуспешные исходы; и

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

12. Устройство по п. 10, отличающееся тем, что указанное устройство обработки данных выполнено с возможностью определения вероятности того, что указанный вновь подключенный равноуровневый узел может загрузить запрошенные данные информационного материала из выбранного одного из множества случайным образом выбранных равноуровневых узлов, как произведения

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

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

13. Устройство по любому из пп. 10-12, отличающееся тем, что указанное устройство обработки данных выполнено с возможностью учета пропускной способности множества случайным образом выбранных равноуровневых узлов путем моделирования задержки и пропускной способности указанного множества случайным образом выбранных равноуровневых узлов как переменных совместной вероятности, при этом вероятность того, что указанный вновь подключенный равноуровневый узел может загрузить запрошенные данные информационного материала из выбранного одного из множества случайным образом выбранных равноуровневых узлов, определяется на основании совместной вероятности задержки и пропускной способности.

14. Устройство по п. 13, отличающееся тем, что указанное устройство обработки данных выполнено с возможностью определения вероятности того, что указанный вновь подключенный равноуровневый узел может загрузить запрошенные данные информационного материала из выбранного одного из множества случайным образом выбранных равноуровневых узлов, как произведения

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

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

15. Устройство по п. 10, отличающееся тем, что указанное устройство обработки данных дополнительно выполнено с возможностью определения задержки для вновь подключенного равноуровневого узла путем

определения распределения вероятности для задержек, с которыми равноуровневые узлы сети принимают данные информационного материала, распространяемые источником потоковой передачи; и

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

16. Машиночитаемый носитель информации с сохраненной на нем компьютерной программой, содержащей исполнимые компьютером компоненты, предназначенные для обеспечения выполнения устройством шагов, приведенных в любом из пп. 1-9, при выполнении указанных компонентов в устройстве обработки данных, содержащемся в указанном устройстве.



 

Похожие патенты:

Изобретение относится к области устройств беспроводной связи. Технический результат заключается в повышении функциональности и применимости устройства связи, выраженной в обеспечении возможности выполнения установленного на устройство беспроводной связи приложения как до, так и после установления беспроводного соединения.

Изобретение относится к области сетевых технологий и, в частности, к способу и устройству совместного использования ресурсов сети. Технический результат заключается в обеспечении снижения объема используемой памяти для получения совместно используемых ресурсов сети.

Изобретение относится к способу и устройству получения информации. Технический результат заключается в обеспечении получения информации обратной связи телефонной агентской системой.

Изобретение относится к технологиям сетевой связи. Технический результат заключается в повышении скорости передачи данных.

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

Изобретение относится к данным об углеводородной скважине, собираемым на мобильной буровой установке. Технический результат - увеличение пропускной способности системы.

Изобретение относится к устройству связи и способу управления устройством связи. Технический результат заключается в обеспечении возможности управления соединением тракта связи.

Изобретение относится к области сетей связи. Техническим результатом является минимизация возможности взлома защиты путем замены оригинала и передачи/приема ложных сообщений, посредством ассоциирования клиентского сетевого устройства с целевым сетевым устройством.

Изобретение относится к технологиям сетевой связи. Технический результат заключается в повышении скорости передачи данных.

Изобретение относится к средствам управления доступом пользователей Интернетом к ресурсам сети. Технический результат заключается в уменьшении времени задержки прохождения запросов к интернет-ресурсу через устройство фильтрации.

Изобретение относится к способам обновления регистрации услуг. Технический результат заключается в обеспечении возможности относительно легко обновлять зарегистрированные услуги после изменения идентификатора связи, таким образом, улучшая взаимодействие с пользователем. Способ обновления регистрации услуг для использования на серверной стороне содержит этапы, на которых: принимают первый запрос обновления регистрации услуг от клиентской стороны; получают услуги, зарегистрированные посредством первого идентификатора связи клиентской стороны, причем при получении услуг запрашивают и получают список зарегистрированных услуг, хранящийся локально и соответствующий первому идентификатору связи, используя первый идентификатор связи; при этом список зарегистрированных услуг содержит услуги, полученные из сообщений о регистрации услуг, принятых от клиентской стороны, с помощью первого идентификатора связи, и синхронизированных с сервером; и посылают второй запрос обновления регистрации услуг через сервер поставщикам зарегистрированных услуг, используя второй идентификатор связи клиентской стороны, чтобы обновить информацию регистрации этих услуг. 6 н. и 16 з.п. ф-лы, 8 ил.

Изобретение относится к области совместного использования данных. Технический результат – обеспечение совместного использования данных изображений при выполнении рендеринга изображений. Способ совместного использования данных изображений содержит этапы, на которых: при обнаружении изображения, обработанного посредством рендеринга в интерфейсе приложения рендеринга изображений, получают посредством первого терминала информацию изображений для упомянутого изображения и информацию местоположения, ассоциированную с информацией изображений, причем информация местоположения указывает местоположение упомянутого изображения в интерфейсе приложения рендеринга изображений; передают посредством первого терминала на сервер первые данные изображений, содержащие информацию изображений и информацию местоположения; передают посредством сервера первые данные изображений во второй терминал, который совместно использует изображения с первым терминалом; обрабатывают посредством рендеринга изображение посредством второго терминала на основе принимаемых первых данных изображений. 6 н. и 11 з.п. ф-лы, 10 ил.

Изобретение относится к области управления передачей данных, а именно к способу и устройству для передачи изображений, улучшения режима передачи и результата отображения изображений. Техническим результатом является упрощение процесса IP- соединения компьютера и мобильного терминала для передачи скриншотов и информации о направлении, относящейся к ориентации в пространстве мобильного терминала, за счет использования локально сохраненного в компьютере IP-адреса мобильного терминала посредством IP-уровня, что обеспечивает совместимость передачи с различными физическими режимами установления соединения. Для этого принимают запрос на установление IP-соединения, отправленный из компьютера, использующего локально сохраненный IP-адрес мобильного терминала для отправки на мобильный терминал запроса на установление IP-соединения, с тем чтобы установить IP-соединение между компьютером и мобильным терминалом, и получают IP-адрес компьютера согласно принятому запросу на установление IP-соединения. Далее получают скриншоты и информацию о направлении, относящуюся к скриншотам, и отправляют скриншоты и информацию о направлении в компьютер посредством IP-уровня согласно принятому IP-адресу. 6 н. и 10 з.п. ф-лы, 18 ил.
Наверх