FI108692B - Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi - Google Patents

Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi Download PDF

Info

Publication number
FI108692B
FI108692B FI992834A FI19992834A FI108692B FI 108692 B FI108692 B FI 108692B FI 992834 A FI992834 A FI 992834A FI 19992834 A FI19992834 A FI 19992834A FI 108692 B FI108692 B FI 108692B
Authority
FI
Finland
Prior art keywords
data
data packet
delay
received
playback delay
Prior art date
Application number
FI992834A
Other languages
English (en)
Swedish (sv)
Other versions
FI19992834A (fi
Inventor
Vilho Raeisaenen
Original Assignee
Nokia Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nokia Corp filed Critical Nokia Corp
Priority to FI992834A priority Critical patent/FI108692B/fi
Priority to EP00660156A priority patent/EP1113645A3/en
Priority to US09/749,055 priority patent/US6977942B2/en
Publication of FI19992834A publication Critical patent/FI19992834A/fi
Application granted granted Critical
Publication of FI108692B publication Critical patent/FI108692B/fi

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/56Queue scheduling implementing delay-aware scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/764Media network packet handling at the destination 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/50Queue scheduling
    • H04L47/56Queue scheduling implementing delay-aware scheduling
    • H04L47/564Attaching a deadline to packets, e.g. earliest due date first
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/752Media network packet handling adapting media to network capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1101Session protocols

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Multimedia (AREA)
  • Computer Security & Cryptography (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Description

1 108692
Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi - Förfarande ooh anordning för att tidsplanera processering av datapaket
Esillä oleva keksintö koskee menetelmää ja laitetta datapakettien prosessoinnin 5 ajoittamiseksi.
Tekniikan tausta
Perinteisesti soitettaessa puhelimella puhe on siirretty piirikytkentäisissä 10 verkoissa, kuten puhelinverkossa (PSTN, Public Switched Telephone Network). Puhelimella soitettaessa digitaalisessa piirikytkentäisessä verkossa, jokaiselle puhelulle muodostetaan 64 kbps (kilo bits per second) kiinteä yhteys. Yhteyden vakiokaista, 64 kbps, johtuu analogisen puheen näytteenotossa tarvittavasta bittinopeudesta käytettäessä 8-bittistä pulssikoodimodulaatiota (PCM, Pulse Code 15 Modulation) 8-kHz:n näytteenottotaajuudella, mikä menettely mahdollistaa analogisen 300-3400 Hz:n puheen lähettämisen digitaalisessa muodossa.
| Edellä kuvattu nykyisin yleisesti käytössä oleva digitaalinen puhelinverkko on kuitenkin hyvin tehoton ja käyttää siten paljon verkon resursseja. Puhelinverkossa 20 yhteyden kaista on varattuna myös silloin, kun yhteyttä ei aktiivisesti käytetä eli kumpikaan yhteyden osapuoli ei siirrä informatiota yhteyttä pitkin. Tällainen t staattisen kaistan käyttö kuluttaa paljon tiedonsiirtoresursseja, minkä seurauksena käyttäjämäärien kasvaessa joudutaan investoimaan lisäkapasiteettiin. Lisäksi • · · myös puhelinverkossa standardoidun tehottoman koodausmenettelyn (Coding .:·. 25 Scheme) takia tuhlataan kaistaa. Esimerkiksi G.729-koodaus suoriutuu » I * .· :·. näytteenotosta jopa niinkin alhaisella bittinopeudella kuin 8 kbps. Ongelmia edellä kuvatunlaisesta tehottomuudesta syntyy etenkin mannerten välisissä puheluissa, missä tiedonsiirtokapasiteetin kasvattaminen ei ole yhtä helppoa kuin muuten.
: ’: Ongelma näkyy osittain myös puheluiden hinnoissa, kalliit investoinnit ,·’ : 30 kapasiteettiin on katettava korkeilla käyttömaksuilla.
Etenkin maiden välisiin yhteydenottoihin on staattisen kaistan varauksen sijasta I * ,: ‘: alettu markkinoimaan niin sanottuja IP-puheluita (Internet Protocol Telephony). IP- 2 108092 puhelussa puhe muunnetaan ensin analogisesta digitaaliseen muotoon, kompressoidaan ja lopuksi muunnetaan IP-paketeiksi, jotka kuljetetaan IP-verkon yli jakaen kaista muun IP-liikenteen kanssa. IP-puheluissa kaistaa voidaan käyttää huomattavasti tehokkaammin kuin staattisen kaistan varaavissa puheluissa, mikä 5 näkyy myös puheluiden hinnoissa. Lisäksi voidaan käyttää myös uusia tehokkaampia koodausmenettelyjä, kuten esimerkiksi G.729-koodausta.
IP-puheluissa käyttäjä voi soittaa tavallisella puhelimella yhdyskäytävän kautta toiseen tavalliseen puhelimeen. Yhdyskäytävä toimittaa puhelun vastaanottajan 10 yhdyskäytävään IP-pohjaisen tietoverkon, kuten esimerkiksi Internetin, välityksellä, josta puhelu ohjataan edelleen vastaanottajan paikallisen puhelinverkon kautta vastaanottajalle. Vastaajan yhdyskäytävässä puhelu yhdistyy takaisin yleiseen puhelinverkkoon. Toinen vaihtoehto on käyttäjän oleminen kiinteässä verkkoyhteydessä IP-pohjaiseen tietoverkkoon, esimerkiksi paikallisverkon 15 välityksellä, jolloin hänen ei tarvitse lainkaan avata staattista puhekaistaa puhelinverkkoon vaan reititin, jonka takana hän on, voi reitittää hänen puhelunsa vastaanottajalle normaalin pakettipohjaisen tiedonsiirron tapaan. IP-puhelut perustuvat Internet-protokollaan, jonka avulla siirretään puhetta paketteina IP- verkon yli. Tämä tarkoittaa sitä, että IP-puheluita voidaan siirtää periaatteessa 20 missä tahansa dataverkossa, joka käyttää IP-protokollaa, esimerkiksi Internetissä, . Intraneteissä tai lähiverkoissa.
* · * • * · '·,·. IP-puheluissa ongelmaksi muodostuu kuitenkin palvelun laatu (QoS, Quality of .·. : Service). IP-pakettien saapumisaikaa vastaanottajalle ei tiedetä ennen pakettien • * * . : . 25 saapumista. IP-protokolla reitittää tietovuon pakettikohtaisesti, minkä ansiosta . ·: ’. pakettien viive verkossa voi vaihdella suuresti ja pakettien järjestys voi vaihtua.
Lisäksi paketit voivat hävitä esimerkiksi reitittimien puskureissa tapahtuvien * ’ * ’; tulevan datan ylivuotojen (over flow) seurauksena. Käyttämällä luotettavaa : :‘: protokollaa kuten TCP (Transmission Control Protocol), voidaan tällaiset ,*! ; 30 pakettihäviöt tunnistaa automaattisesti protokollan tasolla ja lähettää kadonneet t * .,..: paketit uudestaan. Kyseisenlaiset uudelleenlähetykset aiheuttaisivat kuitenkin edelleen vaihtelevaa viivettä pakettien matkatessa verkon halki, joten IP-puheluissa käytetään tavallisesti UDP-protokollaa (User Datagram Protocol), jossa 108692 3 uudelleenlähetyksiä ei ole. Näinollen puheesta tulee helposti pätkittäistä ja sekavaa pakettien välisten taukojen kasvaessa vaikkei yhtään pakettia katoaisikaan matkalla.
5 Ratkaisua tähän ongelmaan on esitetty esimerkiksi julkaisussa, Ramjee R., Kurose K., Towsley D. 1994. Adaptive Playout Mechanism for Packetized Audio Applications in Wide-Area Networks., jossa tuleva pakettipohjainen puhetieto puskuroidaan ja useita paketteja käsittävän yhtenäisen puhepurskeen soittamisen aloittamista vastaanottajalle viivästetään. Viiveen pituuden määrittämisessä 10 hyödynnetään viimeksi tulleiden pakettien myöhästymisarvoista laskettua lyhyen aikavälin myöhästymistrendiä, eli myöhästymisarvoista laskettua liukuvaa keskiarvoa.
Tällainen suora päästä-päähän (end-to-end) viivästämisen hallinta ei kuitenkaan 15 yleisesti riitä esimerkiksi interaktiivisen reaaliaikaisen datavirran laadun varmistamiseksi. Ei riitä pelkästään määrittää viivettä siten, että vain esimerkiksi yksi prosentti paketeista menetetään, kuten edellä kuvatussa mallissa. On myös tärkeää huomioida menetettyjen pakettien välinen korrelaatio, eli ns.
häviökorrelaatio (loss correlation). Yhteyden laadun kannalta on suuri merkitys 20 sillä menetetäänkö paketteja yksi siellä toinen toisaalla (ei häviökorrelaatiota) vai . useita peräjälkeen (suuri häviökorrelaatio). Häviökorrelaation merkitys kasvaa > entisestään huomioitaessa lisäksi käytettävän koodekin ominaisuuksia, koska • · * ·. ·, esimerkiksi VoIP- terminaalissa (Voice over Internet Protocol) käytetty koodekki, : esimerkiksi G.723.1, voisi pystyä peittämään kahden peräkkäisen paketin , *: ·. 25 menetyksen käyttämällä FEC-virheenkorjausta (Forward Error Correction), mutta , '; ’. kolmen peräkkäisen paketin menetys saattaisi aiheuttaa kuultavissa olevan häiriön. Tällöin pitäisikin käytetyn menetelmän pystyä huomioimaan myös ; : pakettien häviökorrelaatioita viivettä päättäessään. Tekniikan tasoa kuvastava :* Γ: menetelmä puskurin hallitsemiseksi ei kuitenkaan huomioi pakettien välisiä .·’ ·, 30 häviökorrelaatioita.
* I · • · » III··
I * I
• » » t * ' I t ) I k • 1 4 1 O 8 6 9 2
Keksinnön yhteenveto
Nyt on keksitty menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi, joka parantaa esimerkiksi reaaliaikaisen pakettipohjaisen puheyhteyden puheenlaatua 5 huomioimalla myös pakettien välisiä häviökorrelaatioita.
Keksinnön erään ensimmäisen aspektin mukaan on toteutettu laite datapakettien prosessoinnin ajoittamiseksi, käsittäen muistin laitteelle datapurskeen osana tulevan datapaketin tallentamiseksi, kellon ajankulun määrittämiseksi, ja 10 prosessointivälineet muistista lähtevän datapaketin prosessoimiseksi, tunnettu siitä, että laite käsittää lisäksi laskentavälineet sellaisen arvon laskemiseksi toistoviiveelle, jolla n:stä ajallisesti viimeisestä datapaketista vain m kappaletta olisi jäänyt vastaanottamatta, jos kyseiset datapaketit käsittävien datapurskeiden prosessoinnin aloittamista olisi viivästytetty mainitun toistoviiveen verran, missä n 15 ja m ovat luonnollisia lukuja, ja siirtovälineet pakettien siirtämiseksi muistista prosessointivälineille kellolta saatavan vasteen pohjalta mainitun toistoviiveen arvon saavuttamisesta siitä kun datapaketti vastaanotettiin.
Keksinnön erään toisen aspektin mukaan on toteutettu menetelmä datapakettien 20 prosessoinnin ajoittamiseksi, jossa menetelmässä vastaanotetaan datapurskeen . osana oleva datapaketti, tallennetaan vastaanotettu datapaketti muistiin, otetaan :· /: datapaketti muistista toistoviiveen jälkeen siitä kun datapaketti vastaanotettiin, ./·/·. tunnettu siitä, että lasketaan toistoviiveelle arvo, jolla toistoviiveen arvolla n:stä ·/ ·. I ajallisesti viimeisestä datapaketista vain m kappaletta olisi jäänyt O · : V: 25 vastaanottamatta, jos kyseiset datapaketit käsittävien datapurskeiden prosessoinnin aloittamista olisi viivästytetty mainitun toistoviiveen verran, missä n ja m ovat luonnollisia lukuja, ja siirretään datapaketti muistista : ,· ’· prosessointivälineille kellolta saadun vasteen pohjalta mainitun toistoviiveen arvon v : saavuttamisesta siitä kun datapaketti vastaanotettiin.
30 • · •: · i Datapurskeella tarkoitetaan tässä yhteydessä purskeisen informaation, kuten . · ·. puheen tai videon, yhtäjaksoista tauotonta lähettämistä. Datapurskeen kesto on siis esimerkiksi sen pituinen kuin lähettäjä vaikkapa puhuu yhtäjaksoisesti, ja siten 5 108692 lähettäjän pitäessä tauon puhumisessaan myös datapurske loppuu. Erilaisia datapurskeita ovat esimerkiksi puhepurske, jossa lähetetään purskeista puheinformaatiota, ja videopurske, jossa lähetetään purskeista videokuvaa. Datapurskeeseen voi siten kuulua suurikin määrä datapaketteja, joilla 5 datapaketeilla käsitetään tässä yhteydessä ensisijaisesti analogisesta informaatiosta, kuten puhe ja kuva, otettua digitaalista näytettä. Datakehyksellä taas käsitetään seuraavassa esimerkiksi IP-pohjaisessa tietoverkossa lähetettäessä datapaketin/datapakettien ympärille asetettavan otsikkokentän ja datapaketin/datapakettien muodostamaa yhtenäistä kokonaisuutta.
10
Keksinnön mukainen laite ja menetelmä pohjautuvat olettamuksiin peräkkäin menetettyjen pakettien lukumäärän rajoituksesta ja maksimi toistoviiveestä datapurskeen ensimmäisen datapaketin prosessoinnin aloittamisessa. Peräkkäin menetettyjen pakettien lukumääräraja riippuu esimerkiksi käytetyn koodekin 15 ominaisuuksista. Jos käytetty koodekki pystyy korjaamaan kahden peräkkäin menetetyn datapaketin menetyksen käytetään peräkkäin menetettyjen datapakettien maksimilukumääränä lmax arvoa kaksi, mikäli muita asiaan vaikuttavia tekijöitä ei ole. Toistoviive d taas asetetaan siten, että peräkkäisten menetettyjen datapakettien lukumäärä i , n:stä viimeksi vastaanotetusta . 20 datapaketista käsin tarkasteltuna, olisi enintään peräkkäin menetettyjen ·'·’: datapakettien maksimilukumäärä ^max, jos vain toistoviiveen maksimiarvo rfmax •sallii näin suuren toistoviiveen arvon.
• · , » v : Yleisesti voidaan sanoa peräkkäisten menetettyjen pakettien lukumäärän ‘ 25 pienenevän toistoviiveen arvon kasvaessa. Ääritapauksessa voitaisiin ajatella toistoviiveen olevan niin suuri, että koko datapurske ehdittäisiin vastaanottamaan ‘/ ennen ensimmäisen datapaketin prosessoinnin aloittamista toistoviiveen jälkeen ’ ·. kyseisen datapaketin vastaanottamisesta, tällöin yhtään datapakettia ei :‘ : menetettäisi myöhästymisen takia. Näin suuri toistoviiveen arvo kuitenkin ‘ 30 romuttaisi yhteyden kaksisuuntaisen (full duplex), reaaliaikaisuuden ja interaktiivisuuden. Suurilla toistoviiveen arvoilla yhteyden koettu laatu (QoS) ‘ / heikkenee esimerkiksi yhteydessä olevien osapuolien lähettämien informaatioiden, 108692 6 kuten puheen, mennessä päällekkäin. Toistoviiveen maksimiarvon määrittäminen onkin monitavoiteoptimointitehtävä, tavoitteena toistoviiveen ja peräkkäin menetettyjen datapakettien lukumäärän minimointi, jonka ratkaisu yleensä muuttuu verkon olosuhteiden muuttuessa.
5
Eli toisin sanottuna keksinnön mukaisessa menetelmässä lasketaan toistoviiveelle d arvo, joka on pienin mahdollinen arvo, jolle pätee £ < £^ kuitenkin siten, että toistoviiveelle pätee d < d^, eli jolle arvolle pätee, että se on pienempi tai yhtä pieni kuin toistoviiveen maksimiarvo, tai menetettyjen peräkkäisten 10 datapakettien lukumäärä on pienempi tai yhtä pieni kuin menetettyjen peräkkäisten datapakettien maksimiarvo, jos tämä voidaan saavuttaa toistoviiveellä, joka on pienempi kuin toistoviiveen maksimiarvo.
Seuraavassa datapaketin viivästymisajalla tarkoitetaan datapurskeen 15 ensimmäisen datapaketin vastaanottajan laitteelle saapumisesta laskettua datapaketin teoreettista saapumisajasta myöhästymistä. Jos k on datapurskeen ensimmäisen datapaketin saapumisaika ja v on lähettäjän käyttämä näytteenottoväli, saadaan datapurskeen n:nnen datapaketin teoreettinen saapumisaika laskettua yhtälöstä saapumisaika = k + n * v, mihin arvoon . 20 toteutunutta saapumisaikaa sitten verrataan viivästymisajan laskemiseksi.
, Käytettäessä RTP-protokollaa, jolloin datakehyksen RTP-otsikkokenttä sisältää ’ · . sekä datapaketin aikaleiman että järjestysnumeron, teoreettinen saapumisaika . ·, : voidaan laskea vertaamalla datapurskeen ensimmäisen datapaketin ja laskennan • · . ·: -. kohteena olevan datapaketin aikaleimoja toisiinsa. Tämä lähestymistapa olisikin .·:*; 25 ehdoton mikäli jostain syystä lähettäjän käyttämä näytteenottoväli ei olisi vakio datapurskeen sisällä.
: ’: ‘: Keksinnön eräässä edullisessa suoritusmuodossa laitetta ja menetelmää . -. : käytetään verkkopuhelussa datapurskeiden datapakettien viiveiden hallinassa.
• · 30 Keksinnön mukaisella menetelmällä viivästetään datapurskeen ensimmäisen datapaketin prosessoinnin aloittamista sen verran, että jo saapuneiden edellisten .‘! t datapurskeiden datapakettien viivästymisajoista arvioiden n:stä viimeisestä jo 108692 7 saapuneesta datapaketista olisi toistoviiveen puitteissa maksimissaan jäänyt saapumatta m:n peräkkäisen datapaketin pituinen ryhmä. Keksinnön mukainen laite voi olla erillinen verkkopuhelin, verkkokuvapuhelin, langaton puhelin tai muu vastaava tai se voi hyödyntää tietokoneen prosessoria, mikrofonia, kaiuttimia, 5 videokorttia ynnä muita sellaisia, jolloin sen käytännön toteuttamisessa ei välttämättä tarvitsisi erillistä laitetta vaan se voitaisiin toteuttaa ohjelmallisesti hyödyntämällä nykyaikaisista tietokoneista yleisesti löytyviä laitteita.
Keksinnöllä aikaansaadaan suhteellisen helppo ja yksinkertainen menetelmä ja 10 laite datapakettien prosessoinnin ajoittamiseksi. Keksintö on erityisen käyttökelpoinen reaaliaikaisessa interaktiivisessa yhteydenpidossa tietoverkon, kuten esimerkiksi Internetin, kautta. Keksinnöllä pystytään aikaisempaa tehokkaammin mukautumaan vastaanottajapäässä stokastisten verkko-olosuhteiden aiheuttamien eri pituisten viivästymisten aiheuttamiin ongelmiin, ja 15 siten parantamaan koettua yhteydenlaatua (QoS, Quality of Service). Tämä aikaansaadaan, aikaisemmasta poiketen, huomioimalla pelkän datapakettien viivästymisten lisäksi myös saapumattomien datapakettien välisiä häviökorrelaatioita, jotka saattavat vaikuttaa merkittävästi koettuun yhteyden laatuun.
20 ,;. Keksintöä selostetaan seuraavassa yksityiskohtaisesti viittaamalla oheisiin piirus- • · · · tuksiin, joissa • * • · · kuviossa 1 on esitetty yleisesti lohkokaaviona keksinnön mukainen 25 toimintaympäristö, : kuviossa 2 on esitetty yleisesti lohkokaaviona eräs keksinnön mukaisen edullisen toimintaympäristön arkkitehtuuri, : / ' kuviossa 3 on esitetty kaavio keksinnön mukaisen laitteen eräästä edullisesta v : toimintamuodosta toimintaympäristössään, : ·, · 30 Kuviossa 4 on esitetty yleisesti IP-pohjaisissa tietoverkoissa reaaliaikaisen datan •: * i tiedonsiirrossa käytettävä datakehys, . ·. kuviossa 5 on esitetty lohkokaaviona kuvaus keksinnön mukaisesta laitteesta datapakettien prosessoinnin ajoittamiseksi, ΊΓ\ Γ) Γ·· \jobyz 8 kuviossa 6 on kuvattu vuokaaviolla yhtä keksinnön mukaisen menetelmän edullista toimintamuotoa, ja kuviossa 7 on esitetty havaintoesimerkki toistoviiveen ja menetettyjen peräkkäisten datapakettien muodostaman jonon pituuden välisestä suhteesta.
5
Kuviossa 1 on esitetty yleisesti keksinnön erään suoritusmuodon mukaisen laitteen eräs edullinen toimintaympäristö lohkokaaviona. Toimintaympäristö käsittää reaaliaikasovelluksia, kuten esimerkiksi VolP:ta tai pakketipohjaista videota, käyttävän päätelaitteen 10, joka päätelaite voi olla esimerkiksi VolP-10 puhelin, kuvapuhelin, tietokoneen reaaliaikainen interaktiivinen videotapaamissovellus tms. Päätelaite 10 on sovittimen 11, joka voi koostua esimerkiksi puhelinverkossa (PSTN, Public Switched Telephone Network) sijaitsevasta yhdyskäytävästä (gateway), välityksellä yhteydessä IP-pohjaiseen verkkoon 12 (IP cloud, Internet Protocol), kuten esimerkiksi Intemettiin. Internet on 15 yksinkertaistetusti eri verkoista muodostunut verkko, joka tukee TCP/IP-pohjaisia sovelluksia, kuten esimerkiksi WWW:tä (World Wide Web), SMTP (Simple Mail Transfer Protocol) emaikiä tai FTP:tä (File Transfer Protocol). Internetin muodostavat osaverkot voivat olla esimerkiksi ATM-13 (Asynchronous Transfer Mode), PPP/SDH-14 (Point-to-Point Protocol / Synchronous Digital Hierarchy), 20 Ethernet-15 (kts. esimerkiksi standardi IEEE 802.3), X25-16 (ITU-T:n standardi), FR-17 (Frame Relay), tai FDDI-pohjaisia 18 (Fiber Distributed Data Interface) ; verkkoja. Intemettiin on kytkeytynyt käyttäjiä, jotka käyttävät esimerkiksi ftp- ja email-pohjaisia sovelluksia 19 tai esimerkiksi telnet- ja http-pohjaisia (Hypertext Transfer Protocol) sovelluksia 20. On ilmeistä, ettei keksinnön mukainen , * i ’: 25 toimintaympäristö rajoitu edellä esitettyyn vaan todellisuudessa Internet koostuu : : paljon suuremmasta määrästä käyttäjiä ja verkkoja.
'· Kuviossa 2 on esitetty yleisesti lohkokaaviona eräs keksinnön mukaisen laitteen v : edullinen toimintaympäristöarkkitehtuuri (VoFR-arkkitehtuuri)(Voice over Frame ' ·.: 30 Relay), joka toimintaympäristö käsittää reaaliaikasovelluksia hyödyntäviä •: · ·: päätelaitteita 21 ja päätelaitteiden väliseen reaaliaikaiseen tiedonsiirtoon viiveitä aiheuttavia reitittimiä 29. Päätelaitteet 21 on kytketty ATM-pohjaiseen FR-•. ·; verkkoon 22, joko puhelinverkon kautta (PSTN) 23 yhdyskäytävää 24 pitkin tai 9 1 !J i) 6 9 2 päätelaitteiden ollessa suorassa verkkoyhteydessä PBX:n 25 (private branch exchange) kautta VFRAD-laitteeseen 26 (Voice Frame Delay Access Device) ja sieltä edelleen FR-verkkoon. VFRAD mahdollistaa datan, äänen ja taxin multipleksoimisen/demultipleksoimisen eri lähteiden ja sovellusten ja yhden 5 verkkoliitäntäpisteen (netwotk access point) välillä. VFRAD;n toisella puolella voi olla myös paikallisverkon reititin 27 ja reitittimen 27 takana useita päätelaitteita 28.
Kuviossa 3 on kaaviolla havainnollistettu keksinnön mukaisen laitteen erästä edullista käyttömuotoa toimintaympäristössään. Toimintaympäristö koostuu 10 kahdesta toisiinsa verkon yli reaaliaikaisessa interaktiivisessa yhteydessä olevasta osapuolesta - lähettäjästä 31 ja vastaanottajasta 39. Koska on kyseessä interaktiivinen yhteys kahden osapuolen välillä on selvää, että osapuolten roolit lähettäjänä ja vastaanottajana saattavat vaihtua yhteyden aikana. Lähettäjä 31 on reaaliaikaisessa interaktiivisessa tiedonsiirtoyhteydessä, kuten esimerkiksi VolP-; 15 yhteydessä, vastaanottajan 39 kanssa. Lähettäjän lähettämästä analogisesta informaatiosta, esimerkiksi puheesta, otetaan näytteitä sopivin vakioväliajoin näytteenottimella 32, joka on esimerkiksi mikrofoni, digitaalinen videokamera tai muu vastaava A/D muuntimen käsittävä näytteenotin, analogisen tiedon muuttamiseksi digitaaliseen muotoon. Saadut näytteet varastoidaan 20 lähetyspuskuriin 33 odottamaan lähetyspakkausta. Lähetyspuskurista näytteet ohjataan kooderille 34, joka koodaa ne verkossa siirrettävään muotoon, • · · * :’.*; esimerkiksi kehystää ne. Kooderilta datapaketti lähetetään verkkoon 35 : kuljetettavaksi vastaanottajalle 39. Datapakettien kulkua verkossa hidastuttavat lähinnä reitittimissä 29 (kuvassa 2) jonottamiset ja fyysisen etenemisen : : 25 (propagation) viemä aika. Fyysiseen etenemiseen käytetty aika voi myös olla eri : pituinen eri datapaketeille, tai tarkemmin datakehyksille koska datapaketit on tässä vaiheessa asetettu kehyksen sisään, johtuen esimerkiksi jonkun reitittimen v · reititystaulukon muuttumisesta kesken datapurskeen lähetyksen, joka näin ohjaa :: muutoksen jälkeen tulleet datapaketit eri reittiä pitkin kuin ennen reititystaulukon 30 päivittymistä. Verkosta datapaketit siirtyvät jitter-puskuriin 36 (jitter-buffer) IP- ja ··.·*. UDP-protokollapinojen kautta, jotka poistavat datakehyksestä ko. protokollia . · . vastaavat kentät, odottamaan prosessointiaan ja siirtämistään dekooderille 37.
Vastaanottajan päätelaite ottaa puskurista 36 näytteitä määrättyjen kriteerien 10 108692 täyttyessä ja siirtää ne dekooderille 37, missä datakehys puretaan, ja sieltä edelleen soittajalle 38 (player), kuten esimerkiksi tietokoneen puheensoittosovellus, videonkäsittelysovellus, verkkopuhelimen D/A muuntimen ja kaiuttimen yhdistelmä tai muu vastaava D/A muuntimen käsittävä sovellus, 5 muunnettaviksi digitaalisesta takaisin analogiseen muotoon, prosessoitaviksi ja esitettäviksi siten vastaanottajalle.
Kuviossa 4 on esitetty yleisesti IP-pohjaisissa tietoverkoissa reaaliaikaisen datan tiedonsiirrossa käytettävä datakehys 41. Datakehys käsittää IP-otsikkokentän 42, 10 joka käsittää yleisesti lähinnä tietoa lähettäjän ja vastaanottajan IP-osoitteista. IP-otsikkokentän jälkeen seuraa esimerkiksi UDP-otsikkokenttä 43, UDP-pohjaisen tiedonsiirron olleessa kysymyksessä, mitä esimerkiksi IP-verkossa siirrettävät puhe- ja videoinformaatio yleisesti käyttävät. UDP-otsikkokenttä käsittää tietoa lähettäjän ja vastaanottajan porttien numeroista ja haluttaessa kenttään voidaan 15 lisätä ylimääräinen datakentän tarkistussumma. UDP-otsikkokenttää seuraa RTP-otsikkokenttä 44, joka käsittää tietoa esimerkiksi siitä mille vastaanottajan sovellukselle kyseinen datapaketti on menossa ja tietoa siitä miten kyseinen datapaketti asettuu samalle sovellukselle siirettävään tietovirtaan, eli datapaketin järjestysnumeron. RTP-otsikkokenttää seuraa varsinainen tietoverkon yli 20 lähetettävä datapaketti 45 tai useita datapaketteja.
·*; Kuviossa 5 on esitetty lohkokaaviona kuvaus keksinnön mukaisesta laiteesta : Y: datapakettien prosessoinnin ajoittamiseksi. Laite käsittää tietoliikenneyhteyden 51 IP-pohjaiseen tietoverkkoon 12, joka tietoliikenneyhteys voi olla toteutettu : : 25 esimerkiksi yleisen puhelinverkon ja yhteyskäytävän välityksellä, suoraan : paikallisverkon kautta tai langattoman yhteyden kautta tietoverkkoon.
Tietoliikenneyhteyttä 51 pitkin laitteelle siirretään tietoa datakehysten 41 sisällä : tulevissa datapaketeissa 45. Datapaketeissa tuleva tieto vastaanotetaan laitetta :, ; : ohjaavassa yksikössä 52 (MCU, Master Controlling Unit), joka on esimerkiksi : ‘ ·.: 30 mikroprosessori. Laitetta ohjaava yksikkö on järjestetty muistiin 53 tallennetun :": ohjelman perusteella tallentamaan datakehyksessä tulleen datapaketin tai · ·. datapaketit muistiin 53. Kuviossa on alempana esitetty laitteenohjausosan 52 . . ., fyysinen lohkokaavio ja kuviossa on ylempänä katkoviivan sisällä esitetty 11 108092 laitteenohjausosan 52 toiminnallinen lohkokaavio. Laitetta ohjaava yksikkö käsittää lisäksi kellon 54, esimerkiksi mikroprosessorin kello, ajankulun määrittämiseksi ja muistiin 53 tallennetuilla ohjelmilla toteutetut toiminnot datapaketin myöhästymisen laskemiseksi 55 lähetysajan ja saapumisajan erotuksesta ja toistoviiveen 5 laskemiseksi 56 n:n viimeisen datapaketin viivästymisarvojen perusteella. Laitetta ohjaava yksikkö on järjestetty muistiin 53 tallennetun ohjelman perusteella purkamaan datakehyksen dekooderi-sovelluksella kellolta saatavan vasteen pohjalta. Lisäksi muistiin on tallennettu siirtotoiminto 57 datapakettien siirtämiseksi prosessoitavaksi laitetta ohjaavaan yksikköön ja esitettäväksi käyttäjälle soittajalla 10 38 kellolta saatavan vasteen pohjalta määrätyn aikarajan saavuttamisesta.
Kuviossa 6 on kuvattu vuokaaviolla yhtä keksinnön mukaisen menetelmän edullista toimintamuotoa, missä menetelmässä laitteelle tulee tietoverkosta tietoliikenneyhteyttä pitkin datakehys 41 (vaihe 61). Laitteessa datakehys 15 puretaan, eli datakehyksen käsittämät otsikkokentät poistetaan ja itse datapaketti otetaan talteen (vaihe 62). Datapaketista saatavien tietojen pohjalta lasketaan kyseisen datapaketin viivästymisaika, eli se toistoviive jolla paketin sisältämä ääninäyte olisi voitu käyttää hyväksi, ja tämä viivästymisaika talletetaan muistiin, jossa on n:n viimeksi tulleen datapaketin viivästymisajat tallennettuina (vaihe 63), 20 jossa n on luonnollinen luku. Lasketaan päivitetyn n:n viimeisen viivästymisajan ·’;· perusteella uusi arvo toistoviiveelle, jolla toistoviiveen arvolla n:stä viimeksi : saapuneesta datapaketista maksimissaan m peräkkäisen datapaketin jono olisi : V: jäänyt saapumatta ajallaan viivästytettäessä datapurskeen ensimmäisen ; ·.: datapaketin prosessoinnin aloittamista toistoviiveen verran sen saapumisesta ja : ’: 25 prosessoitaessa datapurskeen ensimmäistä datapakettia seuraavia datapaketteja : näytteenottovälein ensimmäisen datapaketin prosessoimisen jälkeen (vaihe 64).
Edellisessä mainittu arvo m voi edullisesti olla esimerkiksi 2 ja mainittu arvo n voi edullisesti olla esimerkiksi luokkaa muutama kymmenen.
: ’ ·.: 30 Siinä erikoistapauksessa, jossa datapaketti on koko kyseisen yhteyden •:' * · ensimmäinen datapaketti, jolloin ei ole olemassa tietoa yhteyden aikaisempien . ·': datapakettien viivästymisajoista, asetetaan toistoviiveen arvoksi alkuarvausarvo, • ‘ : joka on edullisesti esimerkiksi edellisellä kerralla laitteella käytetty viimeinen 1 O B 6 9 2 12 toistoviiveenarvo tai jonkinlainen muu arvausarvo, esimerkiksi tehdasasetusten perusteella.
Uusien arvojen laskemistoimenpiteiden jälkeen tunnistetaan vielä onko datapaketti 5 uuden datapurskeen, kuten esimerkiksi puhepurskeen tai videopurskeen, ensimmäinen datapaketti vai onko kyseessä datapurskeen ensimmäistä datapakettia seuraava datapaketti (vaihe 65). Tämän jälkeen tallennetaan kyseinen datapaketti laitteen muistiin odottamaan kyseisen datapaketin prosessoitavaksi siirtämistä (vaihe 66). Tietysti siinä tapauksessa, että kyseisen 10 datapaketin prosessointiaika on jo ohitettu ei datapakettia talleteta, mutta datapaketin viivästymisaika kylläkin.
Edellä kuvatut vaiheet 63-65 voidaan myös suorittaa edullisesti edellä kuvatusta poikkeavassa järjestyksessä ilman hankaluuksia ja siten myös nämä 15 toteutusmuodot kuuluvat keksinnön mukaisen menetelmän piiriin.
Mikäli datapaketti oli uuden datapurskeen ensimmäinen datapaketti asetetaan kellon tarkkailemaksi viiveajaksi mainittu laskettu uusi toistoviiveen arvo kyseisen datapaketin laitteelle saapumisajasta laskien (vaihe 67). Mikäli datapaketti ei ollut 20 datapurskeen ensimmäinen datapaketti asetetaan kellon tarkkailemaksi viiveajaksi .; · lähettäjän näytteenottoväli, joka yleensä, mutta ei välttämättä, on vakio, kyseistä : ’ ’: datapakettia edeltävän datapaketin prosessoitavaksi siirtämisestä laskennan : V: aloittaen (vaihe 68). Esimerkiksi puhepurskeessa purskeen ensimmäistä datapakettia voidaan viivästyttää niin pitkään kuin halutaan kuullun puheen laadun ’’· 25 kärsimättä, suurilla viivästyksillä kuitenkin menetettäisiin reaaliaikainen • i > :, kaksisuuntaisuus, joten viivearvolle on olemassa maksimiarvo. Datapurskeen ensimmäistä datapakettia seuraavia datapaketteja ei voida kuitenkaan enää •.: : viivästyttää vaan ne täytyy prosessoida, tai olla prosessoimatta siinä tapauksessa etteivät ne ole saapuneet määrättyyn aikaan mennessä, määrätyin väliajoin / . i 30 toisistaan Tämä väliaika on yhtä suuri kuin näytteenottoaikaväli lähettäjän päässä •:" yhteyttä. Esimerkiksi puheen tapauksessa muiden kuin ensimmäisen datapaketin . ·. viivästyttäminen vakioviiveestä poiketen huomattaisiin puheen "laahaamisena " :' '; vastaanottajalle soitettaessa tai vastaavasti liian nopea datapakettien soittaminen 108692 13 havaittaisiin normaalia nopeampana ja eri kuuloisena puheena. Kummassakin tilanteessa vastaanottajan tuntema yhteyden laatu (Quality of Service) huononisi viiveen erotessa näyttenottovälistä. Edellä kuvatunlaisen efektin voi myös helposti todeta esimerkiksi videonauhurilla hidastuttamalla videonauhalle tallennetun 5 tiedon prosessointia videonauhurissa painamalla hidastusvalitsinta tai vastaavasti nopeuttamalla videonauhan informaation prosessointia.
Viiveaikojen asettamisen jälkeen odotetaan kunnes asetettu viiveaika täyttyy. Datapurskeen ensimmäisen datapaketin tapauksessa odotetaan, että toistoviive 10 kyseisen datapaketin saapumisesta laitteelle saavutetaan (vaihe 69).
Datapurskeen muiden datapakettien tapauksessa odotetaan, että näyttenottovälin mittainen aika kyseistä datapakettia edeltävän datapaketin siirtämisestä, tai siitä kuin ajallisesti edellinen datapaketti olisi pitänyt siirtää mutta jäi esimerkiksi saapumatta siirtoaikansa puitteissa eikä siten kuitenkaan tullut siirrettyä, 15 prosessoitavaksi saavutetaan (vaihe 70). Toistoviiveen, datapaketin ollessa datapurskeen ensimmäinen datapaketti, tai näytteenottovälin, datapaketin ollessa muu kuin datapurskeen ensimmäinen datapaketti, mennessä umpeen siirretään kyseinen datapaketti prosessoitavaksi esimerkiksi soittajalle (player) 38 tai jollekin muulle sovellukselle tai välineelle (vaihe 71).
20 .;. Edellä kuvattu menetelmä voitaisiin myös kuvata kaksiosaisena, jolloin : 1 '; ensimmäisen osan muodostaisivat vaiheet 61 -66 ja toinen osa kävisi kellolta : Y: saatavan vasteen pohjalta hakemasta puskurista datapaketin, mikäli datapaketti :1 ·. i olisi ehtinyt saapua. Menetelmässä olisi siis osa joka veisi tiedot ja datan puskuriin : Ύ: 25 ja muistiin ja osa joka hakisi datan ja käyttäisi muistiin talletettuja tietoja viiveiden : laskennassa.
’·’· Kuviossa 7 on esitetty havaintoesimerkki toistoviiveen ja menetettyjen v : peräkkäisten datapakettien muodostaman jonon pituuden välisestä suhteesta.
30 Kuviossa pystyakselilla on esitetty datapurskeen ensimmäisen datapaketin, ja : siten koko datapurskeen, viivästämisessä käytettävän toistoviiveen arvo . ”. millisekunneissa ja vaaka-akselilla on ilmoitettu datapurskeen datapakettien :1.'; järjestysnumerot. Jatkuva viiva (merkitty "tri") kuvaa kunkin datapaketin <1 Γι o ,' n n 14 i U OO 7 ά myöhästymistä datapurskeen ensimmäisen datapaketin ja näytteenottoaikavälin perusteella lasketusta teoreettisesta saapumisajasta. Katkoviivat (30 ja 40) kuvaavat, toistoviiveiden arvoilla 30 ja 40 millisekuntia, sitä ehtivätkö datapaketit prosessoitaviksi kyseisten toistoviiveiden arvojen puitteissa, jos datapaketti saapui 5 katkoviivan yläpuolella se ei olisi ehtinyt saapua prosessoitavaksi viiveajan puitteissa ja jos se saapui katkoviivan alapuolella se olisi ehtinyt saapua prosessoitavaksi viiveajan puitteissa. Kuten kuviosta käy ilmi pisin viiveajan puitteissa saapumatta jäänyt peräkkäisten datapakettien muodostama jono toistoviiveen arvolle 30 millisekuntia sisältää kahdeksan datapakettia 10 (järjestysnumeroiden 540-560 välillä). Toistoviiveen arvolle 40 millisekuntia pisin viiveajan puitteissa peräkkäisten saapumatta jääneiden datapakettien muodostama jono oli enää vain kahden paketin pituinen. Kahden peräkkäisen datapaketin menetys voitaisiin saada korjattua käytettävällä koodekilla ja siten toistoviiveen arvolla 40 millisekuntia yhteydessä ei havaittaisi datapakettien 15 häviöitä. Tässä tapauksessa kuviossa esitettyjen viivästymisaikojen perusteella toistoviiveen arvoksi voitaisiinkin edullisesti valita 40 millisekuntia.
Tässä on esitetty keksinnön toteutusta ja suoritusmuotoja esimerkkien avulla. Alan ammattimiehelle on ilmeistä, ettei keksintö rajoitu edellä esitettyjen 20 suoritusmuotojen yksityiskohtiin ja että keksintö voidaan toteuttaa muussakin . . muodossa poikkeamatta keksinnön tunnusmerkeistä. Esitettyjä suoritusmuotoja tulisi pitää valaisevina, muttei rajoittavina. Siten keksinnön toteutus- ja käyttömahdollisuuksia rajoittavatkin ainoastaan oheistetut patenttivaatimukset. Täten vaatimusten määrittelemät erilaiset keksinnön toteutusvaihtoehdot, myös :‘‘: 25 ekvivalenttiset toteutukset kuuluvat keksinnön piiriin. 1 » * 4 · · »

Claims (19)

1 f' o o o i J O O ^ Z
1. Laite datapakettien prosessoinnin ajoittamiseksi, käsittäen muistin (53) laitteelle datapurskeen osana tulevan datapaketin tallentamiseksi, kellon (54) ajankulun määrittämiseksi, ja prosessointivälineet (38) muistista 5 lähtevän datapaketin prosessoimiseksi, tunnettu siitä, että laite käsittää lisäksi laskentavälineet (56) sellaisen arvon laskemiseksi toistoviiveelle, jolla n:stä ajallisesti viimeisestä datapaketista vain m kappaletta olisi jäänyt vastaanottamatta, jos kyseiset datapaketit käsittävien datapurskeiden prosessoinnin aloittamista olisi viivästytetty mainitun toistoviiveen verran, missä n 10 ja m ovat luonnollisia lukuja, ja siirtovälineet (57) pakettien siirtämiseksi muistista prosessointivälineille (38) kellolta (54) saatavan vasteen pohjalta mainitun toistoviiveen arvon saavuttamisesta siitä kun datapaketti vastaanotettiin.
2. Patenttivaatimuksen 1 mukainen laite, tunnettu siitä, että lisäksi laite käsittää 15 toistoviiveelle määritetyn maksimiarvon ja mainitun toistoviiveen arvon ollessa suurempi kuin toistoviiveelle määritetty maksimiarvo on laite järjestetty käyttämään toistoviiveen arvona toistoviiveen maksimiarvoa.
3. Patenttivaatimuksen 1 mukainen laite, tunnettu siitä, että mainittu datapaketti 20 on datapurskeen ensimmäinen datapaketti.
4. Patenttivaatimuksen 3 mukainen laite, tunnettu siitä, että mainitut siirtovälineet (57) on järjestetty siirtämään ensimmäistä datapakettia seuraavia samaan datapurskeeseen kuuluvia vastaanotettuja datapaketteja muistista viiveen jälkeen 25 siitä kun ajallisesti edellinen datapaketti otettiin muistista.
5. Patenttivaatimuksen 4 mukainen laite, tunnettu siitä, että mainittu viive : : on näytteenottoväli. I · : 30 6. Patenttivaatimuksen 1 mukainen laite, tunnettu siitä, että mainittu datapurske ; · · käsittää reaaliaikaista interaktiivista dataa. I 1
16. O G 6 S 2
7. Patenttivaatimuksen 6 mukainen laite, tunnettu siitä, että datapurske käsittää yhtä seuraavista: packet video over IP, Voice over IP, audio/video streaming over IP. j j
8. Patenttivaatimuksen 1 mukainen laite, tunnettu siitä, että mainitun datapurskeen kesto on yhtäpitkä aika kuin jona lähettäjä lähettää informaatiota tauottomasti.
9. Patenttivaatimuksen 1 mukainen laite, tunnettu siitä, että mainitut 10 datapaketit vastaanotetaan tietoverkosta reaaliaikaisen yhteyden kautta johonkin toiseen tietoverkon osapuoleen.
10. Patenttivaatimuksen 1 mukainen laite, tunnettu siitä, että mainittu laite on reaaliaikaista informaatiota hyödyntävän laitteen synkronointivirhepuskuri (jitter 15 buffer).
11. Menetelmä datapakettien prosessoinnin ajoittamiseksi, jossa menetelmässä vastaanotetaan datapurskeen osana oleva datapaketti, 20 tallennetaan vastaanotettu datapaketti muistiin (53), otetaan datapaketti muistista toistoviiveen jälkeen siitä kun datapaketti ; vastaanotettiin, tunnettu siitä, että lasketaan toistoviiveelle arvo, jolla toistoviiveen arvolla n:stä ajallisesti 25 viimeisestä datapaketista vain m kappaletta olisi jäänyt vastaanottamatta, jos kyseiset datapaketit käsittävien datapurskeiden prosessoinnin aloittamista olisi viivästytetty mainitun toistoviiveen verran, missä n ja m ovat luonnollisia lukuja, ja siirretään datapaketti muistista prosessointivälineille (38) kellolta (54) saadun vasteen pohjalta mainitun toistoviiveen arvon saavuttamisesta siitä kun datapaketti I 30 vastaanotettiin. 1 108692 ^.Patenttivaatimuksen 11 mukainen menetelmä, tunnettu siitä, että lisäksi toistoviiveelle on määritetty maksimiarvo ja mainitun toistoviiveen arvon ollessa suurempi kuin toistoviiveelle määritetty maksimiarvo käytetään toistoviiveen arvona toistoviiveen maksimiarvoa. 5
13. Patenttivaatimuksen 11 mukainen menetelmä, tunnettu siitä, että mainittu datapaketti on datapurskeen ensimmäinen datapaketti.
14. Patenttivaatimuksen 13 mukainen menetelmä, tunnettu siitä, että 10 otetaan vastaanotettuja samaan datapurskeeseen kuuluvia ensimmäistä datapakettia seuraavia datapaketteja muistista viiveen jälkeen siitä kun ajallisesti edellinen datapaketti otettiin muistista.
15. Patenttivaatimuksen 14 mukainen menetelmä, tunnettu siitä, että mainittu 15 viive on näytteenottoväli.
16. Patenttivaatimuksen 11 mukainen menetelmä, tunnettu siitä, että mainittu datapurske käsittää reaaliaikaista interaktiivista dataa.
17. Patenttivaatimuksen 16 mukainen menetelmä, tunnettu siitä, että datapurske ,;. käsittää yhtä seuraavista: packet video over IP, Voice over IP, audio/video v. streaming over IP. • I · . ·. t: 18. Patenttivaatimuksen 11 mukainen menetelmä, tunnettu siitä, että mainitun ! ♦ 25 datapurskeen kesto on yhtäpitkä aika kuin jona lähettäjä lähettää informaatiota tauottomasti. :': ’. 19. Patenttivaatimuksen 11 mukainen menetelmä, tunnettu siitä, että mainitut : ’: : datapaketit vastaanotetaan tietoverkosta reaaliaikaisen yhteyden kautta johonkin •. f; 30 toiseen tietoverkon osapuoleen. • · 1 η Π K Q 9 •j^ I uoo/i
FI992834A 1999-12-30 1999-12-30 Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi FI108692B (fi)

Priority Applications (3)

Application Number Priority Date Filing Date Title
FI992834A FI108692B (fi) 1999-12-30 1999-12-30 Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi
EP00660156A EP1113645A3 (en) 1999-12-30 2000-09-13 A method and device for timing the processing of data packets
US09/749,055 US6977942B2 (en) 1999-12-30 2000-12-27 Method and a device for timing the processing of data packets

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
FI992834 1999-12-30
FI992834A FI108692B (fi) 1999-12-30 1999-12-30 Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi

Publications (2)

Publication Number Publication Date
FI19992834A FI19992834A (fi) 2001-07-01
FI108692B true FI108692B (fi) 2002-02-28

Family

ID=8555846

Family Applications (1)

Application Number Title Priority Date Filing Date
FI992834A FI108692B (fi) 1999-12-30 1999-12-30 Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi

Country Status (3)

Country Link
US (1) US6977942B2 (fi)
EP (1) EP1113645A3 (fi)
FI (1) FI108692B (fi)

Families Citing this family (39)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7373413B1 (en) * 2000-06-28 2008-05-13 Cisco Technology, Inc. Devices and methods for minimizing start up delay in transmission of streaming media
US20040057382A1 (en) * 2000-10-09 2004-03-25 Anurag Kumar Method of distributed voice transmission
US7149187B1 (en) * 2000-12-28 2006-12-12 Cisco Technology, Inc. Random early detection policer using randomization of packet drops
US20020172229A1 (en) * 2001-03-16 2002-11-21 Kenetec, Inc. Method and apparatus for transporting a synchronous or plesiochronous signal over a packet network
US7453897B2 (en) * 2001-10-03 2008-11-18 Global Ip Solutions, Inc. Network media playout
US7574597B1 (en) 2001-10-19 2009-08-11 Bbn Technologies Corp. Encoding of signals to facilitate traffic analysis
US7283475B2 (en) * 2001-10-19 2007-10-16 Bbn Technologies Corp. Fractal dimension analysis for data stream isolation
US7162418B2 (en) * 2001-11-15 2007-01-09 Microsoft Corporation Presentation-quality buffering process for real-time audio
US7263109B2 (en) * 2002-03-11 2007-08-28 Conexant, Inc. Clock skew compensation for a jitter buffer
AU2003243433A1 (en) * 2002-06-07 2003-12-22 Ember Corporation Ad hoc wireless network using gradient routing
US7782813B2 (en) 2002-06-07 2010-08-24 Ember Corporation Monitoring network traffic
US20050249186A1 (en) * 2002-06-07 2005-11-10 Kelsey Richard A Routing in an asymmetrical link wireless network
US20050249185A1 (en) * 2002-06-07 2005-11-10 Poor Robert D Routing in wireless networks
US20050226195A1 (en) * 2002-06-07 2005-10-13 Paris Matteo N Monitoring network traffic
US7269141B2 (en) * 2002-09-24 2007-09-11 Accton Technology Corporation Duplex aware adaptive playout method and communications device
US7245608B2 (en) * 2002-09-24 2007-07-17 Accton Technology Corporation Codec aware adaptive playout method and playout device
US7474624B2 (en) * 2003-05-29 2009-01-06 Motorola, Inc. Method and apparatus for reducing delay jitter
US7852993B2 (en) * 2003-08-11 2010-12-14 Microsoft Corporation Speech recognition enhanced caller identification
US20050152406A2 (en) * 2003-10-03 2005-07-14 Chauveau Claude J. Method and apparatus for measuring network timing and latency
US7778225B2 (en) * 2003-10-08 2010-08-17 Research In Motion Limited Method and apparatus for dynamic packet transport in CDMA2000 networks
KR100631201B1 (ko) * 2004-02-11 2006-10-04 삼성전자주식회사 백오프 기법을 사용하는 비용 기반의 라우팅방법
US20050226169A1 (en) * 2004-02-19 2005-10-13 Kelsey Richard A Dynamic identification of nodes in a network
US20050249215A1 (en) * 2004-02-19 2005-11-10 Kelsey Richard A Directing packets in a mesh network
US7466692B2 (en) * 2004-09-09 2008-12-16 Alcatel-Lucent Usa Inc. Method and apparatus for performing quality-of-service calculations on packet-based networks
US7529189B2 (en) * 2005-09-29 2009-05-05 Via Technologies, Inc. Mechanism for imposing a consistent delay on information sets received from a variable rate information stream
US7742413B1 (en) * 2006-02-01 2010-06-22 Sprint Communications Company, L.P. Utilizing a null jitter buffer to monitor session traffic
US8213444B1 (en) 2006-02-28 2012-07-03 Sprint Communications Company L.P. Adaptively adjusting jitter buffer characteristics
GB0705329D0 (en) * 2007-03-20 2007-04-25 Skype Ltd Method of transmitting data in a communication system
US7948897B2 (en) * 2007-08-15 2011-05-24 Adc Telecommunications, Inc. Delay management for distributed communications networks
US8503465B2 (en) 2007-09-17 2013-08-06 Qualcomm Incorporated Priority scheduling and admission control in a communication network
US8688129B2 (en) 2007-09-17 2014-04-01 Qualcomm Incorporated Grade of service (GoS) differentiation in a wireless communication network
US8160104B2 (en) * 2008-08-11 2012-04-17 Research In Motion Ltd. System and method for communicating using an in-vehicle system
US8743718B2 (en) 2011-06-21 2014-06-03 Adc Telecommunications, Inc. End-to-end delay management for distributed communications networks
GB2520867B (en) 2011-10-25 2016-05-18 Skype Ltd Jitter buffer
EP2786535B1 (en) 2011-11-29 2018-05-16 Huawei Technologies Co., Ltd. Delay timer device, method for managing a plurality of delays, and apparatus for delaying a plurality of data packets
JP2013134119A (ja) * 2011-12-26 2013-07-08 Sony Corp 送信装置、送信方法、受信装置、受信方法、同期伝送システム、同期伝送方法、およびプログラム
US9450689B2 (en) 2013-10-07 2016-09-20 Commscope Technologies Llc Systems and methods for delay management in distributed antenna system with direct digital interface to base station
FR3053197A1 (fr) * 2016-06-24 2017-12-29 Orange Procede de communication udp via des chemins multiples entre deux terminaux
FR3053196A1 (fr) 2016-06-24 2017-12-29 Orange Procede de communication udp via des chemins multiples entre deux terminaux

Family Cites Families (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1995022233A1 (en) 1994-02-11 1995-08-17 Newbridge Networks Corporation Method of dynamically compensating for variable transmission delays in packet networks
US5623483A (en) * 1995-05-11 1997-04-22 Lucent Technologies Inc. Synchronization system for networked multimedia streams
US5768527A (en) * 1996-04-23 1998-06-16 Motorola, Inc. Device, system and method of real-time multimedia streaming
US6400681B1 (en) * 1996-06-20 2002-06-04 Cisco Technology, Inc. Method and system for minimizing the connection set up time in high speed packet switching networks
US5963551A (en) * 1996-09-30 1999-10-05 Innomedia Pte Ltd. System and method for dynamically reconfigurable packet transmission
US6304567B1 (en) * 1996-11-26 2001-10-16 Lucent Technologies Inc. Methods and apparatus for providing voice communications through a packet network
US6282196B1 (en) * 1997-04-14 2001-08-28 Lucent Technologies Inc. Dynamic build-out approach for use in packet voice systems
JPH114292A (ja) * 1997-06-12 1999-01-06 Hitachi Ltd 通信システム
US6434606B1 (en) * 1997-10-01 2002-08-13 3Com Corporation System for real time communication buffer management
US6360271B1 (en) * 1999-02-02 2002-03-19 3Com Corporation System for dynamic jitter buffer management based on synchronized clocks
US6366959B1 (en) * 1997-10-01 2002-04-02 3Com Corporation Method and apparatus for real time communication system buffer size and error correction coding selection
EP0921666A3 (en) 1997-12-02 1999-07-14 Nortel Networks Corporation Speech reception via a packet transmission facility
US6301258B1 (en) * 1997-12-04 2001-10-09 At&T Corp. Low-latency buffering for packet telephony
US6219339B1 (en) * 1998-02-20 2001-04-17 Lucent Technologies Inc. Method and apparatus for selectively discarding packets
US6259691B1 (en) * 1998-07-24 2001-07-10 3Com Corporation System and method for efficiently transporting dual-tone multi-frequency/multiple frequency (DTMF/MF) tones in a telephone connection on a network-based telephone system
US6259677B1 (en) * 1998-09-30 2001-07-10 Cisco Technology, Inc. Clock synchronization and dynamic jitter management for voice over IP and real-time data
WO2000042479A1 (de) 1999-01-14 2000-07-20 Siemens Aktiengesellschaft Steuerungsverfahren sowie numerische steuerung zur schwingungsarmen beschleunigungsführung eines bewegbaren maschinenelementes
US6452950B1 (en) * 1999-01-14 2002-09-17 Telefonaktiebolaget Lm Ericsson (Publ) Adaptive jitter buffering
US6512761B1 (en) * 1999-02-02 2003-01-28 3Com Corporation System for adjusting billing for real-time media transmissions based on delay
US6584104B1 (en) * 1999-07-06 2003-06-24 Lucent Technologies, Inc. Lost-packet replacement for a digital voice signal
US6574213B1 (en) * 1999-08-10 2003-06-03 Texas Instruments Incorporated Wireless base station systems for packet communications
US6570849B1 (en) * 1999-10-15 2003-05-27 Tropic Networks Inc. TDM-quality voice over packet
US6665317B1 (en) * 1999-10-29 2003-12-16 Array Telecom Corporation Method, system, and computer program product for managing jitter
US6704329B2 (en) * 2001-05-08 2004-03-09 Path 1 Network Technologies Inc. Minimizing the effect of jitter upon the quality of service operation of networked gateway devices
US7269141B2 (en) * 2002-09-24 2007-09-11 Accton Technology Corporation Duplex aware adaptive playout method and communications device

Also Published As

Publication number Publication date
EP1113645A2 (en) 2001-07-04
US6977942B2 (en) 2005-12-20
US20010012300A1 (en) 2001-08-09
EP1113645A3 (en) 2009-04-08
FI19992834A (fi) 2001-07-01

Similar Documents

Publication Publication Date Title
FI108692B (fi) Menetelmä ja laite datapakettien prosessoinnin ajoittamiseksi
US7079486B2 (en) Adaptive threshold based jitter buffer management for packetized data
US6570849B1 (en) TDM-quality voice over packet
US7379466B2 (en) In band signal detection and presentation for IP phone
JP3636348B2 (ja) 音声パケット遅延揺らぎ吸収装置及び吸収方法
KR100551859B1 (ko) 패킷 처리 장치
US6360271B1 (en) System for dynamic jitter buffer management based on synchronized clocks
JP5174182B2 (ja) 再生遅延推定
US6512761B1 (en) System for adjusting billing for real-time media transmissions based on delay
EP1183681B1 (en) Sub-packet insertion for packet loss compensation in voice over ip networks
KR101590972B1 (ko) 통신 네트워크에서의 전송 스케줄링 방법, 해당 통신 노드 및 컴퓨터 프로그램 생성물
CN105071897B (zh) 一种网络实时音频会话媒体数据多径冗余传输方法
US7668968B1 (en) Closed-loop voice-over-internet-protocol (VOIP) with sender-controlled bandwidth adjustments prior to onset of packet losses
US7346005B1 (en) Adaptive playout of digital packet audio with packet format independent jitter removal
US7769054B2 (en) Method of conducting a communications session using incorrect timestamps
US20100158008A1 (en) Switching exchange
US7542465B2 (en) Optimization of decoder instance memory consumed by the jitter control module
JP4130612B2 (ja) パケット処理装置
US6546009B1 (en) Method of reducing delays in packet data transmission
US20080123639A1 (en) Relay apparatus and routing method
JP4667811B2 (ja) 音声通信装置、音声通信方法
KR100939128B1 (ko) 영상 통화를 위한 단말 및 방법
JP2005252429A (ja) Ipパケット化装置
Hirannaiah et al. Influence of codecs on adaptive jitter buffer algorithm
JP2004222150A (ja) Ip電話端末およびそのデータ変換方法

Legal Events

Date Code Title Description
MA Patent expired