# SOME DESCRIPTIVE TITLE.
# Copyright (C) 2019 Olivier Bonaventure
# This file is distributed under the same license as the Computer networking
# : Principles, Protocols and Practice package.
# FIRST AUTHOR <EMAIL@ADDRESS>, 2019.
#
msgid ""
msgstr ""
"Project-Id-Version: Computer networking : Principles, Protocols and Practice "
"3\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2019-10-09 12:39+0000\n"
"PO-Revision-Date: 2021-05-15 11:49+0000\n"
"Last-Translator: Philippe D <philippe.dan@student.uclouvain.be>\n"
"Language-Team: French <http://weblate.info.ucl.ac.be/projects/cnp3-ebook/"
"principlesreliability/fr/>\n"
"Language: fr\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=n > 1;\n"
"X-Generator: Weblate 3.9.1\n"
"Generated-By: Babel 2.7.0\n"

#: ../../principles/reliability.rst:8
msgid "Connecting two hosts"
msgstr "Connexion entre deux hôtes"

#: ../../principles/reliability.rst:14
msgid ""
"This is an unpolished draft of the third edition of this e-book. If you "
"find any error or have suggestions to improve the text, please create an "
"issue via https://github.com/CNP3/ebook/issues?milestone=1 or help us by "
"providing pull requests to close the existing issues."
msgstr ""
"Ceci est un brouillon non peaufiné de la troisième édition de cet e-book. Si "
"vous avez trouvé une erreur ou avez des suggestions pour améliorer le texte, "
"merci de créer une *issue* via https://github.com/CNP3/ebook/"
"issues?milestone=1 ou de nous aider en ouvrant des *pull requests* pour "
"fermer les *issues* existantes."

#: ../../principles/reliability.rst:17
msgid ""
"The first step when building a network, even a worldwide network such as "
"the Internet, is to connect two hosts together. This is illustrated in "
"the figure below."
msgstr ""
"La première étape lorsque l'on construit un réseau, même dans le cas d'un "
"réseau mondial tel qu'Internet, est de connecter deux hôtes ensemble. Ceci "
"est illustré par la figure ci-dessous."

#: ../../principles/reliability.rst:31
msgid ""
"To enable the two hosts to exchange information, they need to be linked "
"together by some kind of physical media. Computer networks have used "
"various types of physical media to exchange information, notably :"
msgstr ""
"Pour permettre à deux hôtes d'échanger de l'information, il est nécessaire "
"de les lier ensemble au moyen d'un support physique quelconque. Les réseaux "
"informatiques utilisent divers types de supports physiques pour échanger de "
"l'information, notamment :"

#: ../../principles/reliability.rst:33
msgid ""
"`electrical cable`. Information can be transmitted over different types "
"of electrical cables. The most common ones are the twisted pairs (that "
"are used in the telephone network, but also in enterprise networks) and "
"the coaxial cables (that are still used in cable TV networks, but are no "
"longer used in enterprise networks). Some networking technologies operate"
" over the classical electrical cable."
msgstr ""
"des `câbles électriques`. Les informations peuvent être transmises à travers "
"différents types de câbles électriques. Les plus courants sont les paires "
"torsadées (qui sont utilisées pour le réseau téléphonique, mais aussi dans "
"les réseaux d'entreprise) et les câbles coaxiaux (qui sont toujours utilisés "
"pour les réseaux de télévision câblée, mais qui ne sont plus utilisés dans "
"les réseaux d'entreprise). Plusieurs technologies de réseau fonctionnent au "
"moyen d'un câble électrique classique."

#: ../../principles/reliability.rst:34
msgid ""
"`optical fiber`. Optical fibers are frequently used in public and "
"enterprise networks when the distance between the communication devices "
"is larger than one kilometer. There are two main types of optical fibers "
": multi-mode and single-mode. Multi-mode is much cheaper than single-mode"
" fiber because a LED can be used to send a signal over a multi-mode fiber"
" while a single-mode fiber must be driven by a laser. Due to the "
"different modes of propagation of light, single-mode fibers are limited "
"to distances of a few kilometers while multi-mode fibers can be used over"
" distances greater than several tens of kilometers. In both cases, "
"repeaters can be used to regenerate the optical signal at one endpoint of"
" a fiber to send it over another fiber."
msgstr ""
"des `fibres optiques` Les fibres optiques sont souvent employées dans les "
"réseaux publiques et d'entreprise lorsque la distance entre les deux "
"appareils qui communiquent est plus grande qu'un kilomètre. Il existe deux "
"grands types de fibres optiques: les multimodes et les monomodes. Les fibres "
"multimodes sont bien moins chères que les fibres monomode parce qu'une DEL "
"peut être utilisée pour envoyer un signal via une fibre multimode alors "
"qu'un laser doit être utilisé dans le cas d'une fibre monomode."

#: ../../principles/reliability.rst:35
msgid ""
"`wireless`. In this case, a radio signal is used to encode the "
"information exchanged between the communicating devices. Many types of "
"modulation techniques are used to send information over a wireless "
"channel and there is lot of innovation in this field with new techniques "
"appearing every year. While most wireless networks rely on radio signals,"
" some use a laser that sends light pulses to a remote detector. These "
"optical techniques allow to create point-to-point links while radio-based"
" techniques can be used to build networks containing devices spread over "
"a small geographical area."
msgstr ""
"le `sans fil`. Dans ce cas, un signal radio est utilisé pour encoder les "
"informations échangées entre les deux appareils qui communiquent. Plusieurs "
"types de modulations sont utilisées pour envoyer de l'information sur un "
"canal sans-fil et ce domaine témoigne de beaucoup d'innovations avec de "
"nouvelles techniques faisant leur apparition chaque année. Alors que la "
"plupart des réseaux sans-fils reposent sur un signal radio, quelques uns "
"utilisent un laser pour envoyer des pulsations de lumières à un détecteur à "
"distance. Ces technologies optiques permettent de créer des liaisons point à "
"point tandis que les technologies reposant sur un signal radio permettent de "
"construire des réseaux avec des appareils dispersés au sein d'une petite "
"zone géographique."

#: ../../principles/reliability.rst:39
msgid "The physical layer"
msgstr "La couche physique"

#: ../../principles/reliability.rst:41
msgid ""
"These physical media can be used to exchange information once this "
"information has been converted into a suitable electrical signal. Entire "
"telecommunication courses and textbooks are devoted to the problem of "
"converting analog or digital information into an electrical signal so "
"that it can be transmitted over a given physical `link`. In this book, we"
" only consider two very simple schemes that allow to transmit information"
" over an electrical cable. This enables us to highlight the key problems "
"when transmitting information over a physical link. We are only "
"interested in techniques that allow to transmit digital information "
"through the wire and will focus on the transmission of bits, i.e. either "
"`0` or `1`."
msgstr ""
"Ces supports physiques peuvent être utilisés pour échanger de l'information "
"une fois celle-ci convertie en un signal électrique adéquat. Des cours et "
"livres de références entiers en télécommunications sont dédiés au problème "
"de conversion d'informations analogiques ou digitales en un signal "
"électrique peuvent être transmis sur une `liaison` physique donnée. Dans ce "
"livre,  nous nous limitons à deux procédés simples pour transférer de "
"l'information sur un câble électrique. Cela nous permet de mettre en "
"évidence les principaux problèmes éprouvés lors du transfert d'information "
"sur une liaison physique. Nous nous intéressons uniquement aux procédés "
"permettant le transfert d'information digitale à travers le câble et plus "
"particulièrement à la transmission de bits, c'est-à-dire soit `0` soit `1`."

#: ../../principles/reliability.rst:44 ../../principles/reliability.rst:49
msgid "Bit rate"
msgstr "Débit"

#: ../../principles/reliability.rst:46
msgid ""
"In computer networks, the bit rate of the physical layer is always "
"expressed in bits per second. One Mbps is one million bits per second and"
" one Gbps is one billion bits per second. This is in contrast with memory"
" specifications that are usually expressed in bytes (8 bits), KiloBytes ("
" 1024 bytes) or MegaBytes (1048576 bytes). Thus transferring one MByte "
"through a 1 Mbps link lasts 8.39 seconds."
msgstr ""
"Dans les réseaux informatiques, le débit de la couche physique est toujours "
"exprimée en bits par seconde. Un Mbps correspond à un million de bits par "
"seconde et un Gbps correspond à un milliard de bits par seconde. En "
"revanche, les spécifications en terme de mémoire sont généralement exprimées "
"en octets (8 bits), kilo-octets (1024 octets) ou méga-octets (1048576 octets)"
". Dès lors, transférer un mega-octet via une liaison 1Mbps prend 8.39 "
"secondes."

#: ../../principles/reliability.rst:49
msgid "Bits per second"
msgstr "Bits par seconde"

#: ../../principles/reliability.rst:51
msgid "1 Kbps"
msgstr "1 Kbps"

#: ../../principles/reliability.rst:51
msgid ":math:`10^3`"
msgstr ":math:`10^3`"

#: ../../principles/reliability.rst:52
msgid "1 Mbps"
msgstr "1 Mbps"

#: ../../principles/reliability.rst:52
msgid ":math:`10^6`"
msgstr ":math:`10^6`"

#: ../../principles/reliability.rst:53
msgid "1 Gbps"
msgstr "1 Gbps"

#: ../../principles/reliability.rst:53
msgid ":math:`10^9`"
msgstr ":math:`10^9`"

#: ../../principles/reliability.rst:54
msgid "1 Tbps"
msgstr "1 Tbps"

#: ../../principles/reliability.rst:54
msgid ":math:`10^{12}`"
msgstr ":math:`10^{12}`"

#: ../../principles/reliability.rst:59
msgid ""
"To understand some of the principles behind the physical transmission of "
"information, let us consider the simple case of an electrical wire that "
"is used to transmit bits. Assume that the two communicating hosts want to"
" transmit one thousand bits per second. To transmit these bits, the two "
"hosts can agree on the following rules :"
msgstr ""
"Pour comprendre les principes de la transmission physique d'information, "
"considérons le cas d'un fil électrique qui est utilisé pour transmettre des "
"bits. Supposons que les deux hôtes qui communiquent veulent transmettre un "
"millier de bits par seconde. Pour transmettre ces bits, les deux hôtes "
"peuvent se mettre d'accord sur les règles suivantes :"

#: ../../principles/reliability.rst:63
msgid "On the sender side :"
msgstr "Du côté de l'émetteur :"

#: ../../principles/reliability.rst:62
msgid ""
"set the voltage on the electrical wire at ``+5V`` during one millisecond "
"to transmit a bit set to `1`"
msgstr ""
"mettre la tension sur le fil électeique à ``+5V`` pendant une milliseconde "
"pour transmettre un bit mis à `1`"

#: ../../principles/reliability.rst:63
msgid ""
"set the voltage on the electrical wire at ``-5V`` during one millisecond "
"to transmit a bit set to `0`"
msgstr ""
"mettre la tension sur le fil électrique à ``-5V`` pendant une milliseconde "
"pour transmettre un bit mis à `0`"

#: ../../principles/reliability.rst:66
msgid "On the receiver side :"
msgstr "Du côté du récepteur :"

#: ../../principles/reliability.rst:66
msgid ""
"every millisecond, record the voltage applied on the electrical wire. If "
"the voltage is set to ``+5V``, record the reception of bit `1`. "
"Otherwise, record the reception of bit `0`"
msgstr ""
"chaque milliseconde, enregistrer la tension appliquée sur le fil électrique. "
"Si la tension est de ``+5V``, enregistrer le bit reçu comme étant `1`. "
"Sinon, enregistrer le bit reçu comme étant `0`"

#: ../../principles/reliability.rst:70
msgid ""
"This transmission scheme has been used in some early networks. We use it "
"as a basis to understand how hosts communicate.  From a Computer Science "
"viewpoint, dealing with voltages is unusual. Computer scientists "
"frequently rely on models that enable them to reason about the issues "
"that they face without having to consider all implementation details. The"
" physical transmission scheme described above can be represented by using"
" a `time-sequence diagram`."
msgstr ""
"Ce procédé de transmission a été utilisé pour quelques-uns des tout premiers "
"réseaux. Nous l'utilisons comme base pour comprendre comment deux hôtes "
"communiquent. Pour un informaticien, travailler avec des tensions est "
"inhabituel. Les informaticiens reposent plutôt sur des modèles qui leur "
"permettent de raisonner aux problèmes auxquels ils font face sans avoir à "
"prendre en compte tous les détails d'implémentation. Le procédé de "
"transmission physique décrit ci-dessus peut être représenté en utilisant un `"
"diagramme de séquence`."

#: ../../principles/reliability.rst:72
msgid ""
"A `time-sequence diagram` describes the interactions between "
"communicating hosts. By convention, the communicating hosts are "
"represented in the left and right parts of the diagram while the "
"electrical link occupies the middle of the diagram. In such a time-"
"sequence diagram, time flows from the top to the bottom of the diagram. "
"The transmission of one bit of information is represented by three "
"arrows. Starting from the left, the first horizontal arrow represents the"
" request to transmit one bit of information. This request is represented "
"by using a `primitive` which can be considered as a kind of procedure "
"call. This primitive has one parameter (the bit being transmitted) and a "
"name (`DATA.request` in this example). By convention, all primitives that"
" are named `something.request` correspond to a request to transmit some "
"information. The dashed arrow indicates the transmission of the "
"corresponding electrical signal on the wire. Electrical and optical "
"signals do not travel instantaneously. The diagonal dashed arrow "
"indicates that it takes some time for the electrical signal to be "
"transmitted from `Host A` to `Host B`. Upon reception of the electrical "
"signal, the electronics on `Host B`'s network interface detects the "
"voltage and converts it into a bit. This bit is delivered as a "
"`DATA.indication` primitive. All primitives that are named "
"`something.indication` correspond to the reception of some information. "
"The dashed lines also represents the relationship between two (or more) "
"primitives. Such a time-sequence diagram provides information about the "
"ordering of the different primitives, but the distance between two "
"primitives does not represent a precise amount of time."
msgstr ""
"Un `diagramme de séquence` décrit les interactions entre deux hôtes qui "
"communiquent. Par convention, les hôtes sont représentés sur les parties "
"gauche et droites du diagramme alors que le fil électrique est placé au "
"milieu du diagramme. Dans un tel diagramme de séquence, le temps s'écoule de "
"haut en bas. La transmission d'un bit d'information est représentée à l'aide "
"de trois flèches. Commençant par la gauche, la première flèche horizontale "
"représente la requête pour envoyer un bit d'information. Cette requête est "
"représentée à l'aide d'une `primitive`qui peut être considérée comme une "
"sorte d'appel de procédure. Cette primitive prend un paramètre (le bit à "
"transférer) et un nom (`DATA.request`dans cet exemple). Par convention, "
"toutes les primitives qui sont nommées `qqch.request`correspondent à une "
"demande  pour transmettre de l'information. La flèche en pointillés indique "
"la transmission du signal électrique correspond sur le fil. Les signaux "
"électriques et optiques ne se déplacent pas de manière instantanée. La "
"flèche en pointillés diagonale indique que le signal électrique prend du "
"temps pour être transmis de `Hôte A` à `Hôte B`. A la réception du signal "
"électrique, le circuit électronique de l'interface réseau de `Hôte B` "
"détecte la tension et la convertit en un bit. Ce bit est reçu sous la forme "
"d'une primitive `DATA.indication`. Toutes les primitives qui sont nommées "
"`qqch.indication`correspondent à la réception d'information. Les lignes en "
"pointillés représentent aussi la relation entre deux (ou plusieurs) "
"primitives. Un tel diagramme de séquence fournit de l'information sur "
"l'ordre des différentes primitives, mais la distances séparant deux "
"primitives ne représente pas un intervalle de temps précis."

#: ../../principles/reliability.rst:88
msgid ""
"Time-sequence diagrams are useful when trying to understand the "
"characteristics of a given communication scheme. When considering the "
"above transmission scheme, is it useful to evaluate whether this scheme "
"allows the two communicating hosts to reliably exchange information ? A "
"digital transmission will be considered as reliable when a sequence of "
"bits that is transmitted by a host is received correctly at the other end"
" of the wire. In practice, achieving perfect reliability when "
"transmitting information using the above scheme is difficult. Several "
"problems can occur with such a transmission scheme."
msgstr ""
"Les diagrammes de séquence sont particulièrement utiles lorsque l'on tente "
"de comprendre les caractéristiques d'un schéma de communication. En prenant "
"le schéma ci-dessus, est-ce utile d'évaluer la fiabilité de la transmission "
"d'information entre les deux hôtes ? Une transmission digitale d'information "
"est considérée comme fiable lorsqu'une séquence de bits transmis par un hôte "
"est réceptionnée correctement de l'autre côté du fil de communication. En "
"pratique, ce n'est pas facile d'atteindre une fiabilité parfaite avec le "
"schéma ci-dessus car plusieurs problèmes peuvent survenir."

#: ../../principles/reliability.rst:91
msgid ""
"The first problem is that electrical transmission can be affected by "
"electromagnetic interference. Interference can have various sources "
"including natural phenomenons like thunderstorms, variations of the "
"magnetic field, but also can be caused by interference with other "
"electrical signals such as interference from neighboring cables, "
"interference from neighboring antennas, ... Due to these various types of"
" interference, there is unfortunately no guarantee that when a host "
"transmit one bit on a wire, the same bit is received at the other end. "
"This is illustrated in the figure below where a `DATA.request(0)` on the "
"left host leads to a `Data.indication(1)` on the right host."
msgstr ""
"Tout d'abord, la transmission électrique est sensible aux interférences "
"électromagnétiques. Celles-ci peuvent être d'origine naturelle comme par "
"exemple les orages ou les variations du champ magnétique mais elles peuvent "
"aussi être causées par l'interférence avec d'autres signaux électriques "
"comme par exemple ceux des câbles aux alentours ou les interférences des "
"antennes. À cause de ces nombreuses interférences, il n'y a aucune garantie "
"que le signal envoyé par un hôte soit effectivement reçu de l'autre côté du "
"fil. Ce phénomène est illustré sur la figure ci-dessous où une "
"`Data.request(0)` venant de l'hôte sur la gauche mène à une "
"`Data.indication(1)` sur l'hôte de droite."

#: ../../principles/reliability.rst:106
msgid ""
"With the above transmission scheme, a bit is transmitted by setting the "
"voltage on the electrical cable to a specific value during some period of"
" time. We have seen that due to electromagnetic interference, the voltage"
" measured by the receiver can differ from the voltage set by the "
"transmitter. This is the main cause of transmission errors. However, this"
" is not the only type of problem that can occur. Besides defining the "
"voltages for bits `0` and `1`, the above transmission scheme also "
"specifies the duration of each bit. If one million bits are sent every "
"second, then each bit lasts 1 microsecond. On each host, the transmission"
" (resp. the reception) of each bit is triggered by a local clock having a"
" 1 MHz frequency. These clocks are the second source of problems when "
"transmitting bits over a wire. Although the two clocks have the same "
"specification, they run on different hosts, possibly at a different "
"temperature and with a different source of energy. In practice, it is "
"possible that the two clocks do not operate at exactly the same "
"frequency. Assume that the clock of the transmitting host operates at "
"exactly 1000000 Hz while the receiving clock operates at 999999 Hz. This "
"is a very small difference between the two clocks. However, when using "
"the clock to transmit bits, this difference is important. With its "
"1000000 Hz clock, the transmitting host will generate one million bits "
"during a period of one second. During the same period, the receiving host"
" will sense the wire 999999 times and thus will receive one bit less than"
" the bits originally transmitted. This small difference in clock "
"frequencies implies that bits can \"disappear\" during their transmission"
" on an electrical cable. This is illustrated in the figure below."
msgstr ""
"Avec le schéma de transmission ci-dessus, un bit est transmis en fixant la "
"tension sur un câble électrique à une valeur spécifique durant un laps de "
"temps donné. Nous avons vu qu'en raison des interférences "
"électromagnétiques, la tension mesurée par le récepteur peut être différente "
"de celle définie par l'émetteur. C'est la cause principale des erreurs de "
"transmission. Cependant, ce n'est pas l'unique type de problème qui peut "
"survenir. En plus de définir tes tensions spécifiques pour les bits `0` et "
"`1`, le schéma ci-dessus définit aussi la durée de chaque bit. Si un million "
"de bits sont envoyés chaque seconde, alors chaque bit a une durée de 1 "
"microseconde. Sur chaque hôte, la transmission (resp. la réception) de "
"chaque bit est déclenchée par une horloge locale ayant une fréquence de 1 "
"MHz. Ces horloges constituent la deuxième source de problèmes lors de la "
"transmission de bits par câble. Bien que les deux horloges aient les mêmes "
"caractéristiques, elles tournent sur des hôtes différents, potentiellement à "
"des températures différentes et des sources d'énergie différentes. En "
"pratique, il est possible que les deux horloges ne soient pas précisément "
"synchronisées sur la même fréquence. Considérons que l'horloge de l'émetteur "
"tourne à précisément 1000000 Hz alors que l'horloge du récepteur tourne à "
"999999 Hz. Une différence minime entre les deux horloges, pourtant, cette "
"différence est importante lorsque l'on utilise l'une ou l'autre horloge pour "
"transmettre un bit. Dans le cas de l'horloge à 1 MHz, il y aura un million "
"de bits générés durant une période de une seconde alors que pour la même "
"durée, le récepteur ne détectera le signal sur le câble que 999999 fois et "
"recevra un bit de moins que ce qui a été transmis initialement. Cette légère "
"différence de fréquence implique la disparition potentielle de certains bits "
"durant leur transmission sur un câble électrique. Ce phénomène est illustré "
"sur la figure ci-dessous."

#: ../../principles/reliability.rst:128
msgid ""
"A similar reasoning applies when the clock of the sending host is slower "
"than the clock of the receiving host. In this case, the receiver will "
"sense more bits than the bits that have been transmitted by the sender. "
"This is illustrated in the figure below where the second bit received on "
"the right was not transmitted by the left host."
msgstr ""
"Un raisonnement similaire s'applique lorsque la fréquence d'horloge de "
"l'hôte émetteur est plus basse que celle de l'hôte récepteur. Dans ce cas, "
"le récepteur va mesurer plus de bits que ce qui n'a été transmis par "
"l'émetteur. La figure ci-dessous illustre ce phénomène. Le second bit reçu à "
"droite n'a pas été transmis par l'hôte de gauche."

#: ../../principles/reliability.rst:150
msgid ""
"From a Computer Science viewpoint, the physical transmission of "
"information through a wire is often considered as a black box that allows"
" to transmit bits. This black box is often referred to as the `physical "
"layer service` and is represented by using the `DATA.request` and "
"`DATA.indication` primitives introduced earlier. This physical layer "
"service facilitates the sending and receiving of bits. This service "
"abstracts the technological details that are involved in the actual "
"transmission of the bits as an electromagnetic signal. However, it is "
"important to remember that the `physical layer service` is imperfect and "
"has the following characteristics :"
msgstr ""
"D'un point de vue informatique, la transmission physique d'information à "
"travers un câble est souvent considérée comme une boîte noire qui permet la "
"transmission de bits. On se réfère souvent à cette boîte noire comme le `"
"service de la couche physique` et est représentée par l'usage des primitives "
"`Data.request` et `Data.indication` vues précédemment. Ce service de la "
"couche physique facilite l'envoi et la réception de bits. Ce service agit "
"comme une abstraction des détails technologiques qui sont impliqués dans la "
"véritable transmission des bits en tant que signal électromagnétique. "
"Cependant, il est important de se rappeler que le `service de la couche "
"physique` est imparfait et possède les caractéristiques suivantes :"

#: ../../principles/reliability.rst:152
msgid ""
"the `Physical layer service` may change, e.g. due to electromagnetic "
"interference, the value of a bit being transmitted"
msgstr ""
"le `service de la couche physique` peut changer, c'est le cas notamment lors "
"d'interférences électromagnétiques où la valeur d'un bit transmis peut être "
"altérée"

#: ../../principles/reliability.rst:153
msgid ""
"the `Physical layer service` may deliver `more` bits to the receiver than"
" the bits sent by the sender"
msgstr ""
"le `service de la couche physique` peut délivrer `plus` de bits au récepteur "
"que l'émetteur n'en a réellement envoyé"

#: ../../principles/reliability.rst:154
msgid ""
"the `Physical layer service` may deliver `fewer` bits to the receiver "
"than the bits sent by the sender"
msgstr ""
"le `service de la couche physique` peut délivrer `moins` de bits au "
"récepteur que ce qui a été envoyé par l'émetteur"

#: ../../principles/reliability.rst:160
msgid ""
"Many other types of encodings have been defined to transmit information "
"over an electrical cable. All physical layers are able to send and "
"receive physical symbols that represent values `0` and `1`. However, for "
"various reasons that are outside the scope of this chapter, several "
"physical layers exchange other physical symbols as well. For example, the"
" Manchester encoding used in several physical layers can send four "
"different symbols. The Manchester encoding is a differential encoding "
"scheme in which time is divided into fixed-length periods. Each period is"
" divided in two halves and two different voltage levels can  be applied. "
"To send a symbol, the sender must set one of these two voltage levels "
"during each half period. To send a `1` (resp. `0`), the sender must set a"
" high (resp. low) voltage during the first half of the period and a low "
"(resp. high) voltage during the second half. This encoding ensures that "
"there will be a transition at the middle of each period and allows the "
"receiver to synchronize its clock to the sender's clock. Apart from the "
"encodings for `0` and `1`, the Manchester encoding also supports two "
"additional symbols : `InvH` and `InvB`  where the same voltage level is "
"used for the two half periods. By definition, these two symbols cannot "
"appear inside a frame which is only composed of `0` and `1`. Some "
"technologies use these special symbols as markers for the beginning or "
"end of frames."
msgstr ""
"De nombreux autres types de codages ont été définis pour transmettre des "
"informations sur un câble électrique. Toutes les couches physiques sont "
"capables d'envoyer et de recevoir des symboles physiques qui représentent "
"les valeurs `0` et `1`. Cependant, pour diverses raisons qui sortent du "
"cadre de ce chapitre, plusieurs couches physiques échangent également "
"d'autres symboles physiques. Par exemple, le codage Manchester utilisé dans "
"plusieurs couches physiques peut envoyer quatre symboles différents. Le "
"codage Manchester est un schéma de codage différentiel dans lequel le temps "
"est divisé en périodes de longueur fixe. Chaque période est divisée en deux "
"moitiés et deux niveaux de tension différents peuvent être appliqués. Pour "
"envoyer un symbole, l'expéditeur doit définir l'un de ces deux niveaux de "
"tension pendant chaque demi-période. Pour envoyer un `1` (resp. `0`), "
"l'expéditeur doit définir une tension élevée (resp. faible) pendant la "
"première moitié de la période et une tension faible (resp. élevée) pendant "
"la seconde moitié. Ce codage garantit qu'il y aura une transition au milieu "
"de chaque période et permet au récepteur de synchroniser son horloge avec "
"celle de l'émetteur. Outre les codages pour `0` et `1`, le codage Manchester "
"supporte également deux symboles supplémentaires : `InvH` et `InvB` où le "
"même niveau de tension est utilisé pour les deux demi-périodes. Par "
"définition, ces deux symboles ne peuvent pas apparaître à l'intérieur d'une "
"trame qui n'est composée que de `0` et `1`. Certaines technologies utilisent "
"ces symboles spéciaux comme marqueurs de début ou de fin de trame."

#: ../../principles/reliability.rst:167
msgid "Manchester encoding"
msgstr "Le codage Manchester"

#: ../../principles/reliability.rst:178
msgid "The Physical layer"
msgstr "La couche physique"

#: ../../principles/reliability.rst:180
msgid ""
"All the functions related to the physical transmission or information "
"through a wire (or a wireless link) are usually known as the `physical "
"layer`. The physical layer allows thus two or more entities that are "
"directly attached to the same transmission medium to exchange bits. Being"
" able to exchange bits is important as virtually any information can be "
"encoded as a sequence of bits. Electrical engineers are used to "
"processing streams of bits, but computer scientists usually prefer to "
"deal with higher level concepts. A similar issue arises with file "
"storage. Storage devices such as hard-disks also store streams of bits. "
"There are hardware devices that process the bit stream produced by a "
"hard-disk, but computer scientists have designed filesystems to allow "
"applications to easily access such storage devices. These filesystems are"
" typically divided into several layers as well. Hard-disks store sectors "
"of 512 bytes or more. Unix filesystems group sectors in larger blocks "
"that can contain data or `inodes` representing the structure of the "
"filesystem. Finally, applications manipulate files and directories that "
"are translated in blocks, sectors and eventually bits by the operating "
"system."
msgstr ""
"Toutes les fonctions liées à la transmission physique ou à l'information "
"transmise à travers un câble (ou une connexion sans fil) sont regroupées "
"sous l'appellation `couche physique`. La couche physique permet ainsi à deux "
"entités ou plus qui sont directement reliées par un même moyen de "
"transmission d'échanger des bits. Pouvoir échanger des bits est fondamental "
"puisque pratiquement n'importe quelle information peut être encodée comme "
"une séquence de bits. Les ingénieurs électriciens sont habitués à traiter "
"des flux de bits mais les informaticiens préfèrent habituellement faire "
"usage de concepts plus haut niveau. Un problème similaire se pose quant aux "
"systèmes de fichiers. Les périphériques de stockage tels que les disques "
"durs stockent également des flux de bits. Il y a des périphériques matériels "
"qui traitent directement le flux de bit produit par le disque dur mais les "
"informaticiens ont conçu des systèmes de fichiers destinés à permettre aux "
"applications d'accéder facilement à ces périphériques de stockage. Ces "
"systèmes de fichiers sont généralement également divisés en plusieurs "
"couches. Les disques durs stockent des secteurs de 512 bytes ou plus. Les "
"systèmes de fichiers Unix regroupent les secteurs par blocs plus larges "
"pouvant contenir des données ou `inodes` représentant la structure du "
"système de fichiers. Enfin, les applications manipulent des fichiers et "
"répertoires qui sont traduits en blocs, secteurs et enfin en bits par le "
"système d'exploitation."

#: ../../principles/reliability.rst:184
msgid ""
"Computer networks use a similar approach. Each layer provides a service "
"that is built above the underlying layer and is closer to the needs of "
"the applications. The datalink layer builds upon the service provided by "
"the physical layer. We will see that it also contains several functions."
msgstr ""
"Les réseaux informatiques utilisent une approche similaire. Chaque couche "
"fournit un service construit sur la couche en-dessous et est plus proche des "
"besoins des applications. La couche de liaison de données est construite à "
"partir du service fourni par la couche physique. Nous allons voir qu'elle "
"contient aussi plusieurs fonctions."

#: ../../principles/reliability.rst:188
msgid "The datalink layer"
msgstr "La couche de liaison de données"

#: ../../principles/reliability.rst:192
msgid ""
"Computer scientists are usually not interested in exchanging bits between"
" two hosts. They prefer to write software that deals with larger blocks "
"of data in order to transmit messages or complete files. Thanks to the "
"physical layer service, it is possible to send a continuous stream of "
"bits between two hosts. This stream of bits can include logical blocks of"
" data, but we need to be able to extract each block of data from the bit "
"stream despite the imperfections of the physical layer. In many networks,"
" the basic unit of information exchanged between two directly connected "
"hosts is often called a `frame`. A `frame` can be defined has a sequence "
"of bits that has a particular syntax or structure. We will see examples "
"of such frames later in this chapter."
msgstr ""
"Les informaticiens ne sont généralement pas intéressés par l'échange de bits "
"entre deux hôtes. Ils préfèrent écrire des logiciels qui traitent des blocs "
"de données plus importants afin de transmettre des messages ou des fichiers "
"complets. Grâce au service de la couche physique, il est possible d'envoyer "
"un flux continu de bits entre deux hôtes. Ce flux de bits peut inclure des "
"blocs logiques de données, mais il faut pouvoir extraire chaque bloc de "
"données du flux de bits malgré les imperfections de la couche physique. Dans "
"de nombreux réseaux, l'unité de base des informations échangées entre deux "
"hôtes directement connectés est souvent appelée une `frame`. Une `frame` "
"peut être définie comme une séquence de bits ayant une syntaxe ou une "
"structure particulière. Nous verrons des exemples de telles trames plus loin "
"dans ce chapitre."

#: ../../principles/reliability.rst:194
msgid ""
"To enable the transmission/reception of frames, the first problem to be "
"solved is how to encode a frame as a sequence of bits, so that the "
"receiver can easily recover the received frame despite the limitations of"
" the physical layer."
msgstr ""

#: ../../principles/reliability.rst:199
msgid ""
"If the physical layer were perfect, the problem would be very simple. We "
"would simply need to define how to encode each frame as a sequence of "
"consecutive bits. The receiver would then easily be able to extract the "
"frames from the received bits. Unfortunately, the imperfections of the "
"physical layer make this framing problem slightly more complex. Several "
"solutions have been proposed and are used in practice in different "
"network technologies."
msgstr ""

#: ../../principles/reliability.rst:202
msgid "Framing"
msgstr ""

#: ../../principles/reliability.rst:204
msgid ""
"The `framing` problem can be defined as : \"`How does a sender encode "
"frames so that the receiver can efficiently extract them from the stream "
"of bits that it receives from the physical layer`\"."
msgstr ""

#: ../../principles/reliability.rst:206
msgid ""
"A first solution to this problem is to require the physical layer to "
"remain idle for some time after the transmission of each frame. These "
"idle periods can be detected by the receiver and serve as a marker to "
"delineate frame boundaries. Unfortunately, this solution is not "
"acceptable for two reasons. First, some physical layers cannot remain "
"idle and always need to transmit bits. Second, inserting an idle period "
"between frames decreases the maximum bit rate that can be achieved."
msgstr ""

#: ../../principles/reliability.rst:208
msgid "Bit rate and bandwidth"
msgstr ""

#: ../../principles/reliability.rst:210
msgid ""
"Bit rate and bandwidth are often used to characterize the transmission "
"capacity of the physical service. The original definition of `bandwidth "
"<https://www.merriam-webster.com/dictionary/bandwidth>`_, as listed in "
"the `Webster dictionary <https://www.merriam-webster.com/dictionary>`_ is"
" `a range of radio frequencies which is occupied by a modulated carrier "
"wave, which is assigned to a service, or over which a device can "
"operate`. This definition corresponds to the characteristics of a given "
"transmission medium or receiver. For example, the human ear is able to "
"decode sounds in roughly the 0-20 KHz frequency range. By extension, "
"bandwidth is also used to represent the capacity of a communication "
"system in bits per second. For example, a Gigabit Ethernet link is "
"theoretically capable of transporting one billion bits per second."
msgstr ""

#: ../../principles/reliability.rst:215
msgid ""
"Given that multi-symbol encodings cannot be used by all physical layers, "
"a generic solution which can be used with any physical layer that is able"
" to transmit and receive only bits `0` and `1` is required. This generic "
"solution is called `stuffing` and two variants exist : `bit stuffing` and"
" `character stuffing`. To enable a receiver to easily delineate the frame"
" boundaries, these two techniques reserve special bit strings as frame "
"boundary markers and encode the frames so that these special bit strings "
"do not appear inside the frames."
msgstr ""

#: ../../principles/reliability.rst:217
msgid ""
"`Bit stuffing` reserves the `01111110` bit string as the frame boundary "
"marker and ensures that there will never be six consecutive `1` symbols "
"transmitted by the physical layer inside a frame. With bit stuffing, a "
"frame is sent as follows. First, the sender transmits the marker, i.e. "
"`01111110`. Then, it sends all the bits of the frame and inserts an "
"additional bit set to `0` after each sequence of five consecutive `1` "
"bits. This ensures that the sent frame never contains a sequence of six "
"consecutive bits set to `1`. As a consequence, the marker pattern cannot "
"appear inside the frame sent. The marker is also sent to mark the end of "
"the frame. The receiver performs the opposite to decode a received frame."
" It first detects the beginning of the frame thanks to the `01111110` "
"marker. Then, it processes the received bits and counts the number of "
"consecutive bits set to `1`. If a `0` follows five consecutive bits set "
"to `1`, this bit is removed since it was inserted by the sender. If a `1`"
" follows five consecutive bits sets to `1`, it indicates a marker if it "
"is followed by a bit set to `0`. The table below illustrates the "
"application of bit stuffing to some frames."
msgstr ""

#: ../../principles/reliability.rst:220 ../../principles/reliability.rst:258
msgid "Original frame"
msgstr ""

#: ../../principles/reliability.rst:220 ../../principles/reliability.rst:258
msgid "Transmitted frame"
msgstr ""

#: ../../principles/reliability.rst:222
msgid "0001001001001001001000011"
msgstr ""

#: ../../principles/reliability.rst:222
msgid "01111110000100100100100100100001101111110"
msgstr ""

#: ../../principles/reliability.rst:223
msgid "0110111111111111111110010"
msgstr ""

#: ../../principles/reliability.rst:223
msgid "01111110011011111011111011111011001001111110"
msgstr ""

#: ../../principles/reliability.rst:224
msgid "01111110"
msgstr ""

#: ../../principles/reliability.rst:224
msgid "0111111001111101001111110"
msgstr ""

#: ../../principles/reliability.rst:228
msgid ""
"For example, consider the transmission of `0110111111111111111110010`. "
"The sender will first send the `01111110` marker followed by `011011111`."
" After these five consecutive bits set to `1`, it inserts a bit set to "
"`0` followed by `11111`. A new `0` is inserted, followed by `11111`. A "
"new `0` is inserted followed by the end of the frame `110010` and the "
"`01111110` marker."
msgstr ""

#: ../../principles/reliability.rst:231
msgid ""
"`Bit stuffing` increases the number of bits required to transmit each "
"frame. The worst case for bit stuffing is of course a long sequence of "
"bits set to `1` inside the frame. If transmission errors occur, stuffed "
"bits or markers can be in error. In these cases, the frame affected by "
"the error and possibly the next frame will not be correctly decoded by "
"the receiver, but it will be able to resynchronize itself at the next "
"valid marker."
msgstr ""

#: ../../principles/reliability.rst:236
msgid ""
"`Bit stuffing` can be easily implemented in hardware. However, "
"implementing it in software is difficult given the complexity of "
"performing bit manipulations in software. Software implementations prefer"
" to process characters than bits, software-based datalink layers usually "
"use `character stuffing`. This technique operates on frames that contain "
"an integer number of characters. In computer networks, characters are "
"usually encoded by relying on the :term:`ASCII` table. This table defines"
" the encoding of various alphanumeric characters as a sequence of bits. "
":rfc:`20` provides the ASCII table that is used by many protocols on the "
"Internet. For example, the table defines the following binary "
"representations :"
msgstr ""

#: ../../principles/reliability.rst:238
msgid "`A` : `1000011` b"
msgstr ""

#: ../../principles/reliability.rst:239
msgid "`0` : `0110000` b"
msgstr ""

#: ../../principles/reliability.rst:240
msgid "`z` : `1111010` b"
msgstr ""

#: ../../principles/reliability.rst:241
msgid "`@` : `1000000` b"
msgstr ""

#: ../../principles/reliability.rst:242
msgid "`space` : `0100000` b"
msgstr ""

#: ../../principles/reliability.rst:244
msgid ""
"In addition, the :term:`ASCII` table also defines several non-printable "
"or control characters. These characters were designed to allow an "
"application to control a printer or a terminal. These control characters "
"include `CR` and `LF`, that are used to terminate a line, and the `BEL` "
"character which causes the terminal to emit a sound."
msgstr ""

#: ../../principles/reliability.rst:246
msgid "`NUL`: `0000000` b"
msgstr ""

#: ../../principles/reliability.rst:247
msgid "`BEL`: `0000111` b"
msgstr ""

#: ../../principles/reliability.rst:248
msgid "`CR` : `0001101` b"
msgstr ""

#: ../../principles/reliability.rst:249
msgid "`LF` : `0001010` b"
msgstr ""

#: ../../principles/reliability.rst:250
msgid "`DLE`: `0010000` b"
msgstr ""

#: ../../principles/reliability.rst:251
msgid "`STX`: `0000010` b"
msgstr ""

#: ../../principles/reliability.rst:252
msgid "`ETX`: `0000011` b"
msgstr ""

#: ../../principles/reliability.rst:254
msgid ""
"Some characters are used as markers to delineate the frame boundaries. "
"Many `character stuffing` techniques use the `DLE`, `STX` and `ETX` "
"characters of the ASCII character set. `DLE STX` (resp. `DLE ETX`) is "
"used to mark the beginning (end) of a frame. When transmitting a frame, "
"the sender adds a `DLE` character after each transmitted `DLE` character."
" This ensures that none of the markers can appear inside the transmitted "
"frame. The receiver detects the frame boundaries and removes the second "
"`DLE` when it receives two consecutive `DLE` characters. For example, to "
"transmit frame `1 2 3 DLE STX 4`, a sender will first send `DLE STX` as a"
" marker, followed by `1 2 3 DLE`. Then, the sender transmits an "
"additional `DLE` character followed by `STX 4` and the `DLE ETX` marker."
msgstr ""

#: ../../principles/reliability.rst:260
msgid "**1** **2** **3** **4**"
msgstr ""

#: ../../principles/reliability.rst:260
msgid "`DLE STX` **1** **2** **3** **4** `DLE ETX`"
msgstr ""

#: ../../principles/reliability.rst:261
msgid "**1** **2** **3** **DLE** **STX** **4**"
msgstr ""

#: ../../principles/reliability.rst:261
msgid "`DLE STX` **1** **2** **3** **DLE** `DLE` **STX** `4` `DLE ETX`"
msgstr ""

#: ../../principles/reliability.rst:262
msgid "**DLE STX DLE ETX**"
msgstr ""

#: ../../principles/reliability.rst:262
msgid "`DLE STX` **DLE** `DLE` **STX** **DLE** `DLE` ETX** `DLE ETX`"
msgstr ""

#: ../../principles/reliability.rst:265
msgid ""
"`Character stuffing` , like bit stuffing, increases the length of the "
"transmitted frames. For `character stuffing`, the worst frame is a frame "
"containing many `DLE` characters. When transmission errors occur, the "
"receiver may incorrectly decode one or two frames (e.g. if the errors "
"occur in the markers). However, it will be able to resynchronize itself "
"with the next correctly received markers."
msgstr ""

#: ../../principles/reliability.rst:269
msgid ""
"Bit stuffing and character stuffing allow to recover frames from a stream"
" of bits or bytes. This framing mechanism provides a richer service than "
"the physical layer. Through the framing service, one can send and receive"
" complete frames. This framing service can also be represented by using "
"the `DATA.request` and `DATA.indication` primitives. This is illustrated "
"in the figure below, assuming hypothetical frames containing four useful "
"bits and one bit of framing for graphical reasons."
msgstr ""

#: ../../principles/reliability.rst:297
msgid ""
"We can now build upon the framing mechanism to allow the hosts to "
"exchange frames containing an integer number of bits or bytes. Once the "
"framing problem has been solved, we can focus on designing a technique "
"that allows to reliably exchange frames."
msgstr ""

#: ../../principles/reliability.rst:304
msgid "Recovering from transmission errors"
msgstr ""

#: ../../principles/reliability.rst:306
msgid ""
"In this section, we develop a reliable datalink protocol running above "
"the physical layer service. To design this protocol, we first assume that"
" the physical layer provides a perfect service. We will then develop "
"solutions to recover from the transmission errors."
msgstr ""

#: ../../principles/reliability.rst:308
msgid ""
"The datalink layer is designed to send and receive frames on behalf of a "
"user. We model these interactions by using the `DATA.req` and `DATA.ind` "
"primitives. However, to simplify the presentation and to avoid confusion "
"between a `DATA.req` primitive issued by the user of the datalink layer "
"entity, and a `DATA.req` issued by the datalink layer entity itself, we "
"will use the following terminology :"
msgstr ""

#: ../../principles/reliability.rst:310
msgid ""
"the interactions between the user and the datalink layer entity are "
"represented by using the classical `DATA.req` and the `DATA.ind` "
"primitives"
msgstr ""

#: ../../principles/reliability.rst:311
msgid ""
"the interactions between the datalink layer entity and the framing sub-"
"layer are represented by using `send` instead of `DATA.req` and `recvd` "
"instead of `DATA.ind`"
msgstr ""

#: ../../principles/reliability.rst:313
msgid ""
"When running on top of a perfect framing sub-layer, a datalink entity can"
" simply issue a `send(SDU)` upon arrival of a `DATA.req(SDU)` [#fsdu]_ "
".Similarly, the receiver issues a `DATA.ind(SDU)` upon receipt of a "
"`recvd(SDU)`. Such a simple protocol is sufficient when a single SDU is "
"sent. This is illustrated in the figure below."
msgstr ""

#: ../../principles/reliability.rst:332
msgid ""
"Unfortunately, this is not always sufficient to ensure a reliable "
"delivery of the SDUs. Consider the case where a client sends tens of SDUs"
" to a server. If the server is faster that the client, it will be able to"
" receive and process all the segments sent by the client and deliver "
"their content to its user. However, if the server is slower than the "
"client, problems may arise. The datalink entity contains buffers to store"
" SDUs that have been received as a `Data.request` but have not yet been "
"sent. If the application is faster than the physical link, the buffer may"
" become full. At this point, the operating system suspends the "
"application to let the datalink entity empty its transmission queue. The "
"datalink entity also uses a buffer to store the received frames that have"
" not yet been processed by the application. If the application is slow to"
" process the data, this buffer may overflow and the datalink entity will "
"not able to accept any additional frame. The buffers of the datalink "
"entity have a limited size and if they overflow, the arriving frames will"
" be discarded, even if they are correct."
msgstr ""

#: ../../principles/reliability.rst:334
msgid ""
"To solve this problem, a reliable protocol must include a feedback "
"mechanism that allows the receiver to inform the sender that it has "
"processed a frame and that another one can be sent. This feedback is "
"required even though there are no transmission errors. To include such a "
"feedback, our reliable protocol must process two types of frames :"
msgstr ""

#: ../../principles/reliability.rst:336
msgid "data frames carrying a SDU"
msgstr ""

#: ../../principles/reliability.rst:337
msgid ""
"control frames carrying an acknowledgment indicating that the previous "
"frames was processed correctly"
msgstr ""

#: ../../principles/reliability.rst:339
msgid ""
"These two types of frames can be distinguished by dividing the frame in "
"two parts :"
msgstr ""

#: ../../principles/reliability.rst:341
msgid ""
"the `header` that contains one bit set to `0` in data frames and set to "
"`1` in control frames"
msgstr ""

#: ../../principles/reliability.rst:342
msgid "the payload that contains the SDU supplied by the application"
msgstr ""

#: ../../principles/reliability.rst:344
msgid ""
"The datalink entity can then be modeled as a finite state machine, "
"containing two states for the receiver and two states for the sender. The"
" figure below provides a graphical representation of this state machine "
"with the sender above and the receiver below."
msgstr ""

#: ../../principles/reliability.rst:351
msgid "Finite state machine of the simplest reliable protocol"
msgstr ""

#: ../../principles/reliability.rst:353
msgid ""
"The above FSM shows that the sender has to wait for an acknowledgment "
"from the receiver before being able to transmit the next SDU.  The figure"
" below illustrates the exchange of a few frames between two hosts."
msgstr ""

#: ../../principles/reliability.rst:372
msgid "Services and protocols"
msgstr ""

#: ../../principles/reliability.rst:374
msgid ""
"An important aspect to understand before studying computer networks is "
"the difference between a *service* and a *protocol*. In order to "
"understand the difference between the two, it is useful to start with "
"real world examples. The traditional Post provides a service where a "
"postman delivers letters to recipients. The Post defines precisely which "
"types of letters (size, weight, etc) can be delivered by using the "
"Standard Mail service. Furthermore, the format of the envelope is "
"specified (position of the sender and recipient addresses, position of "
"the stamp). Someone who wants to send a letter must either place the "
"letter at a Post Office or inside one of the dedicated mailboxes. The "
"letter will then be collected and delivered to its final recipient. Note "
"that for the regular service the Post usually does not guarantee the "
"delivery of each particular letter, some letters may be lost, and some "
"letters are delivered to the wrong mailbox. If a letter is important, "
"then the sender can use the registered service to ensure that the letter "
"will be delivered to its recipient. Some Post services also provide an "
"acknowledged service or an express mail service that is faster than the "
"regular service."
msgstr ""

#: ../../principles/reliability.rst:389
msgid "Reliable data transfer on top of an imperfect link"
msgstr ""

#: ../../principles/reliability.rst:391
msgid ""
"The datalink layer must deal with the transmission errors. In practice, "
"we mainly have to deal with two types of errors in the datalink layer :"
msgstr ""

#: ../../principles/reliability.rst:393
msgid "Frames can be corrupted by transmission errors"
msgstr ""

#: ../../principles/reliability.rst:394
msgid "Frames can be lost or unexpected frames can appear"
msgstr ""

#: ../../principles/reliability.rst:397
msgid ""
"A first glance, loosing frames might seem strange on single link. "
"However, if we take framing into account, transmission errors can affect "
"the frame delineation mechanism and make the frame unreadable. For the "
"same reason, a receiver could receive two (likely invalid) frames after a"
" sender has transmitted a single frame."
msgstr ""

#: ../../principles/reliability.rst:399
msgid ""
"To deal with these types of imperfections, reliable protocols rely on "
"different types of mechanisms. The first problem is transmission errors. "
"Data transmission on a physical link can be affected by the following "
"errors :"
msgstr ""

#: ../../principles/reliability.rst:401
msgid ""
"random isolated errors where the value of a single bit has been modified "
"due to a transmission error"
msgstr ""

#: ../../principles/reliability.rst:402
msgid ""
"random burst errors where the values of `n` consecutive bits have been "
"changed due to transmission errors"
msgstr ""

#: ../../principles/reliability.rst:403
msgid ""
"random bit creations and random bit removals where bits have been added "
"or removed due to transmission errors"
msgstr ""

#: ../../principles/reliability.rst:405
msgid ""
"The only solution to protect against transmission errors is to add "
"redundancy to the frames that are sent. `Information Theory` defines two "
"mechanisms that can be used to transmit information over a transmission "
"channel affected by random errors. These two mechanisms add redundancy to"
" the transmitted information, to allow the receiver to detect or "
"sometimes even correct transmission errors. A detailed discussion of "
"these mechanisms is outside the scope of this chapter, but it is useful "
"to consider a simple mechanism to understand its operation and its "
"limitations."
msgstr ""

#: ../../principles/reliability.rst:407
msgid ""
"`Information theory` defines `coding schemes`. There are different types "
"of coding schemes, but let us focus on coding schemes that operate on "
"binary strings. A coding scheme is a function that maps information "
"encoded as a string of `m` bits into a string of `n` bits. The simplest "
"coding scheme is the (even) parity coding. This coding scheme takes an "
"`m` bits source string and produces an `m+1` bits coded string where the "
"first `m` bits of the coded string are the bits of the source string and "
"the last bit of the coded string is chosen such that the coded string "
"will always contain an even number of bits set to `1`. For example :"
msgstr ""

#: ../../principles/reliability.rst:409
msgid "`1001` is encoded as `10010`"
msgstr ""

#: ../../principles/reliability.rst:410
msgid "`1101` is encoded as `11011`"
msgstr ""

#: ../../principles/reliability.rst:412
msgid ""
"This parity scheme has been used in some RAMs as well as to encode "
"characters sent over a serial line. It is easy to show that this coding "
"scheme allows the receiver to detect a single transmission error, but it "
"cannot correct it. However, if two or more bits are in error, the "
"receiver may not always be able to detect the error."
msgstr ""

#: ../../principles/reliability.rst:414
msgid ""
"Some coding schemes allow the receiver to correct some transmission "
"errors. For example, consider the coding scheme that encodes each source "
"bit as follows :"
msgstr ""

#: ../../principles/reliability.rst:416
msgid "`1` is encoded as `111`"
msgstr ""

#: ../../principles/reliability.rst:417
msgid "`0` is encoded as `000`"
msgstr ""

#: ../../principles/reliability.rst:419
msgid ""
"For example, consider a sender that sends `111`. If there is one bit in "
"error, the receiver could receive `011` or `101` or `110`. In these three"
" cases, the receiver will decode the received bit pattern as a `1` since "
"it contains a majority of bits set to `1`. If there are two bits in "
"error, the receiver will not be able anymore to recover from the "
"transmission error."
msgstr ""

#: ../../principles/reliability.rst:421
msgid ""
"This simple coding scheme forces the sender to transmit three bits for "
"each source bit. However, it allows the receiver to correct single bit "
"errors. More advanced coding systems that allow to recover from errors "
"are used in several types of physical layers."
msgstr ""

#: ../../principles/reliability.rst:424
msgid ""
"Besides framing, datalink layers also include mechanisms to detect and "
"sometimes even recover from transmission errors. To allow a receiver to "
"detect transmission errors, a sender must add some redundant information "
"as an `error detection` code to the frame sent. This `error detection` "
"code is computed by the sender on the frame that it transmits. When the "
"receiver receives a frame with an error detection code, it recomputes it "
"and verifies whether the received `error detection code` matches the "
"computer `error detection code`. If they match, the frame is considered "
"to be valid. Many error detection schemes exist and entire books have "
"been written on the subject. A detailed discussion of these techniques is"
" outside the scope of this book, and we will only discuss some examples "
"to illustrate the key principles."
msgstr ""

#: ../../principles/reliability.rst:426
msgid ""
"To understand `error detection codes`, let us consider two devices that "
"exchange bit strings containing `N` bits. To allow the receiver to detect"
" a transmission error, the sender converts each string of `N` bits into a"
" string of `N+r` bits. Usually, the `r` redundant bits are added at the "
"beginning or the end of the transmitted bit string, but some techniques "
"interleave redundant bits with the original bits. An `error detection "
"code` can be defined as a function that computes the `r` redundant bits "
"corresponding to each string of `N` bits. The simplest error detection "
"code is the parity bit. There are two types of parity schemes : even and "
"odd parity. With the `even` (resp. `odd`) parity scheme, the redundant "
"bit is chosen so that an even (resp. odd) number of bits are set to `1` "
"in the transmitted bit string of `N+r` bits. The receiver can easily "
"recompute the parity of each received bit string and discard the strings "
"with an invalid parity. The parity scheme is often used when 7-bit "
"characters are exchanged. In this case, the eighth bit is often a parity "
"bit. The table below shows the parity bits that are computed for bit "
"strings containing three bits."
msgstr ""

#: ../../principles/reliability.rst:429
msgid "3 bits string"
msgstr ""

#: ../../principles/reliability.rst:429
msgid "Odd parity"
msgstr ""

#: ../../principles/reliability.rst:429
msgid "Even parity"
msgstr ""

#: ../../principles/reliability.rst:431 ../../principles/reliability.rst:448
msgid "000"
msgstr ""

#: ../../principles/reliability.rst:431 ../../principles/reliability.rst:432
#: ../../principles/reliability.rst:433 ../../principles/reliability.rst:434
#: ../../principles/reliability.rst:435 ../../principles/reliability.rst:436
#: ../../principles/reliability.rst:437 ../../principles/reliability.rst:438
#: ../../principles/reliability.rst:452 ../../principles/reliability.rst:453
#: ../../principles/reliability.rst:454 ../../principles/reliability.rst:455
msgid "1"
msgstr ""

#: ../../principles/reliability.rst:431 ../../principles/reliability.rst:432
#: ../../principles/reliability.rst:433 ../../principles/reliability.rst:434
#: ../../principles/reliability.rst:435 ../../principles/reliability.rst:436
#: ../../principles/reliability.rst:437 ../../principles/reliability.rst:438
#: ../../principles/reliability.rst:448 ../../principles/reliability.rst:449
#: ../../principles/reliability.rst:450 ../../principles/reliability.rst:451
msgid "0"
msgstr "0"

#: ../../principles/reliability.rst:432 ../../principles/reliability.rst:449
msgid "001"
msgstr ""

#: ../../principles/reliability.rst:433 ../../principles/reliability.rst:450
msgid "010"
msgstr ""

#: ../../principles/reliability.rst:434 ../../principles/reliability.rst:451
msgid "100"
msgstr ""

#: ../../principles/reliability.rst:435 ../../principles/reliability.rst:452
msgid "111"
msgstr ""

#: ../../principles/reliability.rst:436 ../../principles/reliability.rst:453
msgid "110"
msgstr ""

#: ../../principles/reliability.rst:437 ../../principles/reliability.rst:454
msgid "101"
msgstr ""

#: ../../principles/reliability.rst:438 ../../principles/reliability.rst:455
msgid "011"
msgstr ""

#: ../../principles/reliability.rst:441
msgid ""
"The parity bit allows a receiver to detect transmission errors that have "
"affected a single bit among the transmitted `N+r` bits. If there are two "
"or more bits in error, the receiver may not necessarily be able to detect"
" the transmission error. More powerful error detection schemes have been "
"defined. The Cyclical Redundancy Checks (CRC) are widely used in datalink"
" layer protocols. An N-bits CRC can detect all transmission errors "
"affecting a burst of less than N bits in the transmitted frame and all "
"transmission errors that affect an odd number of bits. Additional details"
" about CRCs may be found in [Williams1993]_."
msgstr ""

#: ../../principles/reliability.rst:443
msgid ""
"It is also possible to design a code that allows the receiver to correct "
"transmission errors. The simplest `error correction code` is the triple "
"modular redundancy (TMR). To transmit a bit set to `1` (resp. `0`), the "
"sender transmits `111` (resp. `000`). When there are no transmission "
"errors, the receiver can decode `111` as `1`. If transmission errors have"
" affected a single bit, the receiver performs majority voting as shown in"
" the table below. This scheme allows the receiver to correct all "
"transmission errors that affect a single bit."
msgstr ""

#: ../../principles/reliability.rst:446
msgid "Received bits"
msgstr ""

#: ../../principles/reliability.rst:446
msgid "Decoded bit"
msgstr ""

#: ../../principles/reliability.rst:458
msgid ""
"Other more powerful error correction codes have been proposed and are "
"used in some applications. The `Hamming Code "
"<https://en.wikipedia.org/wiki/Hamming_code>`_ is a clever combination of"
" parity bits that provides error detection and correction capabilities."
msgstr ""

#: ../../principles/reliability.rst:461
msgid ""
"Reliable protocols use error detection schemes, but none of the widely "
"used reliable protocols rely on error correction schemes. To detect "
"errors, a frame is usually divided into two parts :"
msgstr ""

#: ../../principles/reliability.rst:463
msgid ""
"a `header` that contains the fields used by the reliable protocol to "
"ensure reliable delivery. The header contains a checksum or Cyclical "
"Redundancy Check (CRC) [Williams1993]_ that is used to detect "
"transmission errors"
msgstr ""

#: ../../principles/reliability.rst:464
msgid "a `payload` that contains the user data"
msgstr ""

#: ../../principles/reliability.rst:466
msgid ""
"Some headers also include a `length` field, which indicates the total "
"length of the frame or the length of the payload."
msgstr ""

#: ../../principles/reliability.rst:468
msgid ""
"The simplest error detection scheme is the checksum. A checksum is "
"basically an arithmetic sum of all the bytes that a frame is composed of."
" There are different types of checksums. For example, an eight bit "
"checksum can be computed as the arithmetic sum of all the bytes of (both "
"the header and trailer of) the frame. The checksum is computed by the "
"sender before sending the frame and the receiver verifies the checksum "
"upon frame reception. The receiver discards frames received with an "
"invalid checksum. Checksums can be easily implemented in software, but "
"their error detection capabilities are limited. Cyclical Redundancy "
"Checks (CRC) have better error detection capabilities [SGP98]_, but "
"require more CPU when implemented in software."
msgstr ""

#: ../../principles/reliability.rst:474
msgid "checksums, CRCs, ..."
msgstr ""

#: ../../principles/reliability.rst:476
msgid ""
"Most of the protocols in the TCP/IP protocol suite rely on the simple "
"Internet checksum in order to verify that a received packet has not been "
"affected by transmission errors. Despite its popularity and ease of "
"implementation, the Internet checksum is not the only available checksum "
"mechanism. Cyclical Redundancy Checks (CRC_) are very powerful error "
"detection schemes that are used notably on disks, by many datalink layer "
"protocols and file formats such as ``zip`` or ``png``. They can easily be"
" implemented efficiently in hardware and have better error-detection "
"capabilities than the Internet checksum [SGP98]_ . However, CRCs are "
"sometimes considered to be too CPU-intensive for software implementations"
" and other checksum mechanisms are preferred. The TCP/IP community chose "
"the Internet checksum, the OSI community chose the Fletcher checksum "
"[Sklower89]_ . Nowadays there are efficient techniques to quickly compute"
" CRCs in software [Feldmeier95]_"
msgstr ""

#: ../../principles/reliability.rst:490
msgid ""
"Since the receiver sends an acknowledgment after having received each "
"data frame, the simplest solution to deal with losses is to use a "
"retransmission timer. When the sender sends a frame, it starts a "
"retransmission timer. The value of this retransmission timer should be "
"larger than the `round-trip-time`, i.e. the delay between the "
"transmission of a data frame and the reception of the corresponding "
"acknowledgment. When the retransmission timer expires, the sender assumes"
" that the data segment has been lost and retransmits it. This is "
"illustrated in the figure below."
msgstr ""

#: ../../principles/reliability.rst:521
msgid ""
"Unfortunately, retransmission timers alone are not sufficient to recover "
"from losses. Let us consider, as an example, the situation depicted below"
" where an acknowledgment is lost. In this case, the sender retransmits "
"the data segment that has not been acknowledged. Unfortunately, as "
"illustrated in the figure below, the receiver considers the "
"retransmission as a new segment whose payload must be delivered to its "
"user."
msgstr ""

#: ../../principles/reliability.rst:552
msgid ""
"To solve this problem, datalink protocols associate a `sequence number` "
"to each data frame. This `sequence number` is one of the fields found in "
"the header of data frames. We use the notation `D(x,...)` to indicate a "
"data frame whose sequence number field is set to value `x`. The "
"acknowledgments also contain a sequence number indicating the data frames"
" that it is acknowledging. We use `OKx` to indicate an acknowledgment "
"frame that confirms the reception of `D(x,...)`. The sequence number is "
"encoded as a bit string of fixed length. The simplest reliable protocol "
"is the Alternating Bit Protocol (ABP)."
msgstr ""

#: ../../principles/reliability.rst:556
msgid ""
"The Alternating Bit Protocol uses a single bit to encode the sequence "
"number. It can be implemented easily. The sender and the receiver only "
"require a four-state Finite State Machine."
msgstr ""

#: ../../principles/reliability.rst:564
msgid "Alternating bit protocol : Sender FSM"
msgstr ""

#: ../../principles/reliability.rst:567
msgid ""
"The initial state of the sender is `Wait for D(0,...)`. In this state, "
"the sender waits for a `Data.request`. The first data frame that it sends"
" uses sequence number `0`. After having sent this frame, the sender waits"
" for an `OK0` acknowledgment. A frame is retransmitted upon expiration of"
" the retransmission timer or if an acknowledgment with an incorrect "
"sequence number has been received."
msgstr ""

#: ../../principles/reliability.rst:569
msgid ""
"The receiver first waits for `D(0,...)`. If the frame contains a correct "
"`CRC`, it passes the SDU to its user and sends `OK0`. If the frame "
"contains an invalid CRC, it is immediately discarded. Then, the receiver "
"waits for `D(1,...)`. In this state, it may receive a duplicate "
"`D(0,...)` or a data frame with an invalid CRC. In both cases, it returns"
" an `OK0` frame to allow the sender to recover from the possible loss of "
"the previous `OK0` frame."
msgstr ""

#: ../../principles/reliability.rst:576
msgid "Alternating bit protocol : Receiver FSM"
msgstr ""

#: ../../principles/reliability.rst:579
msgid "Dealing with corrupted frames"
msgstr ""

#: ../../principles/reliability.rst:581
msgid ""
"The receiver FSM of the Alternating bit protocol discards all frames that"
" contain an invalid CRC. This is the safest approach since the received "
"frame can be completely different from the frame sent by the remote host."
" A receiver should not attempt at extracting information from a corrupted"
" frame because it cannot know which portion of the frame has been "
"affected by the error."
msgstr ""

#: ../../principles/reliability.rst:584
msgid ""
"The figure below illustrates the operation of the alternating bit "
"protocol."
msgstr ""

#: ../../principles/reliability.rst:614
msgid ""
"The Alternating Bit Protocol can recover from the losses of data or "
"control frames. This is illustrated in the two figures below. The first "
"figure shows the loss of one data segment."
msgstr ""

#: ../../principles/reliability.rst:640
msgid "And the loss of one control frame."
msgstr ""

#: ../../principles/reliability.rst:675
msgid ""
"The Alternating Bit Protocol can recover from transmission errors and "
"frame losses. However, it has one important drawback. Consider two hosts "
"that are directly connected by a 50 Kbits/sec satellite link that has a "
"250 milliseconds propagation delay. If these hosts send 1000 bits frames,"
" then the maximum throughput that can be achieved by the alternating bit "
"protocol is one frame every :math:`20+250+250=520` milliseconds if we "
"ignore the transmission time of the acknowledgment. This is less than 2 "
"Kbits/sec !"
msgstr ""

#: ../../principles/reliability.rst:685
msgid "Go-back-n and selective repeat"
msgstr ""

#: ../../principles/reliability.rst:687
msgid ""
"To overcome the performance limitations of the alternating bit protocol, "
"reliable protocols rely on `pipelining`. This technique allows a sender "
"to transmit several consecutive frames without being forced to wait for "
"an acknowledgment after each frame. Each data frame contains a sequence "
"number encoded in an `n` bits field."
msgstr ""

#: ../../principles/reliability.rst:693
msgid "Pipelining improves the performance of reliable protocols"
msgstr ""

#: ../../principles/reliability.rst:695
msgid ""
"`Pipelining` allows the sender to transmit frames at a higher rate. "
"However this higher transmission rate may overload the receiver. In this "
"case, the frames sent by the sender will not be correctly received by "
"their final destination. The reliable protocols that rely on pipelining "
"allow the sender to transmit `W` unacknowledged frames before being "
"forced to wait for an acknowledgment from the receiving entity."
msgstr ""

#: ../../principles/reliability.rst:697
msgid ""
"This is implemented by using a `sliding window`. The sliding window is "
"the set of consecutive sequence numbers that the sender can use when "
"transmitting frames without being forced to wait for an acknowledgment. "
"The figure below shows a sliding window containing five segments "
"(`6,7,8,9` and `10`). Two of these sequence numbers (`6` and `7`) have "
"been used to send frames and only three sequence numbers (`8`, `9` and "
"`10`) remain in the sliding window. The sliding window is said to be "
"closed once all sequence numbers contained in the sliding window have "
"been used."
msgstr ""

#: ../../principles/reliability.rst:703
msgid "The sliding window"
msgstr ""

#: ../../principles/reliability.rst:705
msgid ""
"The figure below illustrates the operation of the sliding window. It uses"
" a sliding window of three frames. The sender can thus transmit three "
"frames before being forced to wait for an acknowledgment. The sliding "
"window moves to the higher sequence numbers upon the reception of each "
"acknowledgment. When the first acknowledgment (`OK0`) is received, it "
"allows the sender to move its sliding window to the right and sequence "
"number `3` becomes available. This sequence number is used later to "
"transmit the frame containing `d`."
msgstr ""

#: ../../principles/reliability.rst:712
msgid "Sliding window example"
msgstr ""

#: ../../principles/reliability.rst:715
msgid ""
"In practice, as the frame header includes an `n` bits field to encode the"
" sequence number, only the sequence numbers between :math:`0` and "
":math:`2^{n}-1` can be used. This implies that, during a long transfer, "
"the same sequence number will be used for different frames and the "
"sliding window will wrap. This is illustrated in the figure below "
"assuming that `2` bits are used to encode the sequence number in the "
"frame header. Note that upon reception of `OK1`, the sender slides its "
"window and can use sequence number `0` again."
msgstr ""

#: ../../principles/reliability.rst:722
msgid "Utilisation of the sliding window with modulo arithmetic"
msgstr ""

#: ../../principles/reliability.rst:727
msgid ""
"Unfortunately, frame losses do not disappear because a reliable protocol "
"uses a sliding window. To recover from losses, a sliding window protocol "
"must define :"
msgstr ""

#: ../../principles/reliability.rst:729
msgid "a heuristic to detect frame losses"
msgstr ""

#: ../../principles/reliability.rst:730
msgid "a `retransmission strategy` to retransmit the lost frames"
msgstr ""

#: ../../principles/reliability.rst:735
msgid ""
"The simplest sliding window protocol uses the `go-back-n` recovery. "
"Intuitively, `go-back-n` operates as follows. A `go-back-n` receiver is "
"as simple as possible. It only accepts the frames that arrive in-"
"sequence. A `go-back-n` receiver discards any out-of-sequence frame that "
"it receives. When `go-back-n` receives a data frame, it always returns an"
" acknowledgment containing the sequence number of the last in-sequence "
"frame that it has received. This acknowledgment is said to be "
"`cumulative`. When a `go-back-n` receiver sends an acknowledgment for "
"sequence number `x`, it implicitly acknowledges the reception of all "
"frames whose sequence number is earlier than `x`. A key advantage of "
"these cumulative acknowledgments is that it is easy to recover from the "
"loss of an acknowledgment. Consider for example a `go-back-n` receiver "
"that received frames `1`, `2` and `3`. It sent `OK1`, `OK2` and `OK3`. "
"Unfortunately, `OK1` and `OK2` were lost. Thanks to the cumulative "
"acknowledgments, when the receiver receives `OK3`, it knows that all "
"three frames have been correctly received."
msgstr ""

#: ../../principles/reliability.rst:737
msgid ""
"The figure below shows the FSM of a simple `go-back-n` receiver. This "
"receiver uses two variables : `lastack` and `next`. `next` is the next "
"expected sequence number and `lastack` the sequence number of the last "
"data frame that has been acknowledged. The receiver only accepts the "
"frame that are received in sequence. `maxseq` is the number of different "
"sequence numbers (:math:`2^n`)."
msgstr ""

#: ../../principles/reliability.rst:744
msgid "Go-back-n : receiver FSM"
msgstr ""

#: ../../principles/reliability.rst:747
msgid ""
"A `go-back-n` sender is also very simple. It uses a sending buffer that "
"can store an entire sliding window of frames [#fsizesliding]_ . The "
"frames are sent with increasing sequence numbers (modulo `maxseq`). The "
"sender must wait for an acknowledgment once its sending buffer is full. "
"When a `go-back-n` sender receives an acknowledgment, it removes from the"
" sending buffer all the acknowledged frames and uses a retransmission "
"timer to detect frame losses. A simple `go-back-n` sender maintains one "
"retransmission timer per connection. This timer is started when the first"
" frame is sent. When the `go-back-n sender` receives an acknowledgment, "
"it restarts the retransmission timer only if there are still "
"unacknowledged frames in its sending buffer. When the retransmission "
"timer expires, the `go-back-n` sender assumes that all the unacknowledged"
" frames currently stored in its sending buffer have been lost. It thus "
"retransmits all the unacknowledged frames in the buffer and restarts its "
"retransmission timer."
msgstr ""

#: ../../principles/reliability.rst:754
msgid "Go-back-n : sender FSM"
msgstr ""

#: ../../principles/reliability.rst:757
msgid ""
"The operation of `go-back-n` is illustrated in the figure below. In this "
"figure, note that upon reception of the out-of-sequence frame `D(2,c)`, "
"the receiver returns a cumulative acknowledgment `C(OK,0)` that "
"acknowledges all the frames that have been received in sequence. The lost"
" frame is retransmitted upon the expiration of the retransmission timer."
msgstr ""

#: ../../principles/reliability.rst:763
msgid "Go-back-n : example"
msgstr ""

#: ../../principles/reliability.rst:766
msgid ""
"The main advantage of `go-back-n` is that it can be easily implemented, "
"and it can also provide good performance when only a few frames are lost."
" However, when there are many losses, the performance of `go-back-n` "
"quickly drops for two reasons :"
msgstr ""

#: ../../principles/reliability.rst:768
msgid "the `go-back-n` receiver does not accept out-of-sequence frames"
msgstr ""

#: ../../principles/reliability.rst:769
msgid ""
"the `go-back-n` sender retransmits all unacknowledged frames once it has "
"detected a loss"
msgstr ""

#: ../../principles/reliability.rst:776
msgid ""
"`Selective repeat` is a better strategy to recover from losses. "
"Intuitively, `selective repeat` allows the receiver to accept out-of-"
"sequence frames. Furthermore, when a `selective repeat` sender detects "
"losses, it only retransmits the frames that have been lost and not the "
"frames that have already been correctly received."
msgstr ""

#: ../../principles/reliability.rst:778
msgid ""
"A `selective repeat` receiver maintains a sliding window of `W` frames "
"and stores in a buffer the out-of-sequence frames that it receives. The "
"figure below shows a five-frame receive window on a receiver that has "
"already received frames `7` and `9`."
msgstr ""

#: ../../principles/reliability.rst:784
msgid "The receiving window with selective repeat"
msgstr ""

#: ../../principles/reliability.rst:786
msgid ""
"A `selective repeat` receiver discards all frames having an invalid CRC, "
"and maintains the variable `lastack` as the sequence number of the last "
"in-sequence frame that it has received. The receiver always includes the "
"value of `lastack` in the acknowledgments that it sends. Some protocols "
"also allow the `selective repeat` receiver to acknowledge the out-of-"
"sequence frames that it has received. This can be done for example by "
"placing the list of the correctly received, but out-of-sequence frames in"
" the acknowledgments together with the `lastack` value."
msgstr ""

#: ../../principles/reliability.rst:788
msgid ""
"When a `selective repeat` receiver receives a data frame, it first "
"verifies whether the frame is inside its receiving window. If yes, the "
"frame is placed in the receive buffer. If not, the received frame is "
"discarded and an acknowledgment containing `lastack` is sent to the "
"sender. The receiver then removes all consecutive frames starting at "
"`lastack` (if any) from the receive buffer. The payloads of these frames "
"are delivered to the user, `lastack` and the receiving window are "
"updated, and an acknowledgment acknowledging the last frame received in "
"sequence is sent."
msgstr ""

#: ../../principles/reliability.rst:790
msgid ""
"The `selective repeat` sender maintains a sending buffer that can store "
"up to `W` unacknowledged frames. These frames are sent as long as the "
"sending buffer is not full. Several implementations of a `selective "
"repeat` sender are possible. A simple implementation associates one "
"retransmission timer to each frame. The timer is started when the frame "
"is sent and canceled upon reception of an acknowledgment that covers this"
" frame. When a retransmission timer expires, the corresponding frame is "
"retransmitted and this retransmission timer is restarted. When an "
"acknowledgment is received, all the frames that are covered by this "
"acknowledgment are removed from the sending buffer and the sliding window"
" is updated."
msgstr ""

#: ../../principles/reliability.rst:792
msgid ""
"The figure below illustrates the operation of `selective repeat` when "
"frames are lost. In this figure, `C(OK,x)` is used to indicate that all "
"frames, up to and including sequence number `x` have been received "
"correctly."
msgstr ""

#: ../../principles/reliability.rst:798
msgid "Selective repeat : example"
msgstr ""

#: ../../principles/reliability.rst:802
msgid ""
"Pure cumulative acknowledgments work well with the `go-back-n` strategy. "
"However, with only cumulative acknowledgments a `selective repeat` sender"
" cannot easily determine which frames have been correctly received after "
"a data frame has been lost. For example, in the figure above, the second "
"`C(OK,0)` does not inform explicitly the sender of the reception of "
"`D(2,c)` and the sender could retransmit this frame although it has "
"already been received. A possible solution to improve the performance of "
"`selective repeat` is to provide additional information about the "
"received frames in the acknowledgments that are returned by the receiver."
" For example, the receiver could add in the returned acknowledgment the "
"list of the sequence numbers of all frames that have already been "
"received. Such acknowledgments are sometimes called `selective "
"acknowledgments`. This is illustrated in the figure above."
msgstr ""

#: ../../principles/reliability.rst:811
msgid ""
"In the figure above, when the sender receives `C(OK,0,[2])`, it knows "
"that all frames up to and including `D(0,...)` have been correctly "
"received. It also knows that frame `D(2,...)` has been received and can "
"cancel the retransmission timer associated to this frame. However, this "
"frame should not be removed from the sending buffer before the reception "
"of a cumulative acknowledgment (`C(OK,2)` in the figure above) that "
"covers this frame."
msgstr ""

#: ../../principles/reliability.rst:815
msgid "Maximum window size with `go-back-n` and `selective repeat`"
msgstr "Taille maximale de fenêtre avec le `go-back-n` et `selective repeat`"

#: ../../principles/reliability.rst:817
msgid ""
"A reliable protocol that uses `n` bits to encode its sequence number can "
"send up to :math:`2^n` successive frames. However, to ensure a reliable "
"delivery of the frames, `go-back-n` and `selective repeat` cannot use a "
"sending window of :math:`2^n` frames. Consider first `go-back-n` and "
"assume that a sender sends :math:`2^n` frames. These frames are received "
"in-sequence by the destination, but all the returned acknowledgments are "
"lost. The sender will retransmit all frames. These frames will all be "
"accepted by the receiver and delivered a second time to the user. It is "
"easy to see that this problem can be avoided if the maximum size of the "
"sending window is :math:`{2^n}-1` frames. A similar problem occurs with "
"`selective repeat`. However, as the receiver accepts out-of-sequence "
"frames, a sending window of :math:`{2^n}-1` frames is not sufficient to "
"ensure a reliable delivery. It can be easily shown that to avoid this "
"problem, a `selective repeat` sender cannot use a window that is larger "
"than :math:`\\frac{2^n}{2}` frames."
msgstr ""

#: ../../principles/reliability.rst:863
msgid ""
"Reliable protocols often need to send data in both directions. To reduce "
"the overhead caused by the acknowledgments, most reliable protocols use "
"`piggybacking`. Thanks to this technique, a datalink entity can place the"
" acknowledgments and the receive window that it advertises for the "
"opposite direction of the data flow inside the header of the data frames "
"that it sends. The main advantage of piggybacking is that it reduces the "
"overhead as it is not necessary to send a complete frame to carry an "
"acknowledgment. This is illustrated in the figure below where the "
"acknowledgment number is underlined in the data frames. Piggybacking is "
"only used when data flows in both directions. A receiver will generate a "
"pure acknowledgment when it does not send data in the opposite direction "
"as shown in the bottom of the figure."
msgstr ""

#: ../../principles/reliability.rst:869
msgid "Piggybacking example"
msgstr ""

#: ../../principles/reliability.rst:877
msgid ""
"SDU is the acronym of Service Data Unit. We use it as a generic term to "
"represent the data that is transported by a protocol."
msgstr ""
"SDU est l'acronyme de Service Data Unit. On l'utilise comme terme générique "
"pour désigner les données qui sont transmises par un protocole."

#: ../../principles/reliability.rst:879
msgid ""
"The size of the sliding window can be either fixed for a given protocol "
"or negotiated during the connection establishment phase. Some protocols "
"allow to change the maximum window size during the data transfer. We will"
" explain these techniques with real protocols later."
msgstr ""

#~ msgid ""
#~ "This is an unpolished draft of the"
#~ " third edition of this ebook. If "
#~ "you find any error or have "
#~ "suggestions to improve the text, please"
#~ " create an issue via "
#~ "https://github.com/CNP3/ebook/issues?milestone=1"
#~ msgstr ""

#~ msgid ""
#~ "`optical fiber`. Optical fibers are "
#~ "frequently used in public and enterprise"
#~ " networks when the distance between "
#~ "the communication devices is larger than"
#~ " one kilometer. There are two main"
#~ " types of optical fibers : multimode"
#~ " and monomode. Multimode is much "
#~ "cheaper than monomode fiber because a"
#~ " LED can be used to send a "
#~ "signal over a multimode fiber while "
#~ "a monomode fiber must be driven by"
#~ " a laser. Due to the different "
#~ "modes of propagation of light, monomode"
#~ " fibers are limited to distances of"
#~ " a few kilometers while multimode "
#~ "fibers can be used over distances "
#~ "greater than several tens of kilometers."
#~ " In both cases, repeaters can be "
#~ "used to regenerate the optical signal"
#~ " at one endpoint of a fiber to"
#~ " send it over another fiber."
#~ msgstr ""

#~ msgid ""
#~ "`wireless`. In this case, a radio "
#~ "signal is used to encode the "
#~ "information exchanged between the "
#~ "communicating devices. Many types of "
#~ "modulation techniques are used to send"
#~ " information over a wireless channel "
#~ "and there is lot of innovation in"
#~ " this field with new techniques "
#~ "appearing every year. While most "
#~ "wireless networks rely on radio signals,"
#~ " some use a laser that sends "
#~ "light pulses to a remote detector. "
#~ "These optical techniques allow to create"
#~ " point-to-point links while radio-"
#~ "based techniques, depending on the "
#~ "directionality of the antennas, can be"
#~ " used to build networks containing "
#~ "devices spread over a small geographical"
#~ " area."
#~ msgstr ""

#~ msgid ""
#~ "Time-sequence diagrams are usual when"
#~ " trying to understand the characteristics"
#~ " of a given communication scheme. "
#~ "When considering the above transmission "
#~ "scheme, is it useful to evaluate "
#~ "whether this scheme allows the two "
#~ "communicating hosts to reliably exchange "
#~ "information ? A digital transmission "
#~ "will be considered as reliable when "
#~ "a sequence of bits that is "
#~ "transmitted by a host is received "
#~ "correctly at the other end of the"
#~ " wire. In practice, achieving perfect "
#~ "reliability when transmitting information "
#~ "using the above scheme is difficult. "
#~ "Several problems can occur with such "
#~ "a transmission scheme."
#~ msgstr ""

#~ msgid ""
#~ "The first problem is that electrical "
#~ "transmission can be affected by "
#~ "electromagnetic interferences. These interferences"
#~ " can have various sources including "
#~ "natural phenomenons like thunderstorms, "
#~ "variations of the magnetic field, but"
#~ " also can be caused by interference"
#~ " with other electrical signals such "
#~ "as interference from neighboring cables, "
#~ "interferences from neighboring antennas, ..."
#~ " Due to all these interferences, "
#~ "there is unfortunately no guarantee that"
#~ " when a host transmit one bit "
#~ "on a wire, the same bit is "
#~ "received at the other end. This is"
#~ " illustrated in the figure below "
#~ "where a `DATA.request(0)` on the left"
#~ " host leads to a `Data.indication(1)` "
#~ "on the right host."
#~ msgstr ""

#~ msgid ""
#~ "With the above transmission scheme, a"
#~ " bit is transmitted by setting the"
#~ " voltage on the electrical cable to"
#~ " a specific value during some period"
#~ " of time. We have seen that due"
#~ " to electromagnetic interferences, the "
#~ "voltage measured by the receiver can "
#~ "differ from the voltage set by the"
#~ " transmitter. This is the main cause"
#~ " of transmission errors. However, this "
#~ "is not the only type of problem"
#~ " that can occur. Besides defining the"
#~ " voltages for bits `0` and `1`, "
#~ "the above transmission scheme also "
#~ "specifies the duration of each bit. "
#~ "If one million bits are sent every"
#~ " second, then each bit lasts 1 "
#~ "microsecond. On each host, the "
#~ "transmission (resp. the reception) of "
#~ "each bit is triggered by a local"
#~ " clock having a 1 MHz frequency. "
#~ "These clocks are the second source "
#~ "of problems when transmitting bits over"
#~ " a wire. Although the two clocks "
#~ "have the same specification, they run"
#~ " on different hosts, possibly at a"
#~ " different temperature and with a "
#~ "different source of energy. In practice,"
#~ " it is possible that the two "
#~ "clocks do not operate at exactly "
#~ "the same frequency. Assume that the "
#~ "clock of the transmitting host operates"
#~ " at exactly 1000000 Hz while the "
#~ "receiving clock operates at 999999 Hz."
#~ " This is a very small difference "
#~ "between the two clocks. However, when"
#~ " using the clock to transmit bits,"
#~ " this difference is important. With "
#~ "its 1000000 Hz clock, the transmitting"
#~ " host will generate one million bits"
#~ " during a period of one second. "
#~ "During the same period, the receiving"
#~ " host will sense the wire 999999 "
#~ "times and thus will receive one "
#~ "bit less than the bits originally "
#~ "transmitted. This small difference in "
#~ "clock frequencies implies that bits can"
#~ " \"disappear\" during their transmission on"
#~ " an electrical cable. This is "
#~ "illustrated in the figure below."
#~ msgstr ""

#~ msgid ""
#~ "the `Physical layer service` may change,"
#~ " e.g. due to electromagnetic interferences,"
#~ " the value of a bit being "
#~ "transmitted"
#~ msgstr ""

#~ msgid ""
#~ "Many other types of encodings have "
#~ "been defined to transmit information "
#~ "over an electrical cable. All physical"
#~ " layers are able to send and "
#~ "receive physical symbols that represent "
#~ "values `0` and `1`. However, for "
#~ "various reasons that are outside the "
#~ "scope of this chapter, several physical"
#~ " layers exchange other physical symbols "
#~ "as well. For example, the Manchester "
#~ "encoding used in several physical layers"
#~ " can send four different symbols. The"
#~ " Manchester encoding is a differential "
#~ "encoding scheme in which time is "
#~ "divided into fixed-length periods. Each"
#~ " period is divided in two halves "
#~ "and two different voltage levels can"
#~ "  be applied. To send a symbol, "
#~ "the sender must set one of these"
#~ " two voltage levels during each half"
#~ " period. To send a `1` (resp. "
#~ "`0`), the sender must set a high"
#~ " (resp. low) voltage during the first"
#~ " half of the period and a low"
#~ " (resp. high) voltage during the "
#~ "second half. This encoding ensures that"
#~ " there will be a transition at "
#~ "the middle of each period and "
#~ "allows the receiver to synchronise its"
#~ " clock to the sender's clock. Apart"
#~ " from the encodings for `0` and "
#~ "`1`, the Manchester encoding also "
#~ "supports two additional symbols : `InvH`"
#~ " and `InvB`  where the same voltage"
#~ " level is used for the two half"
#~ " periods. By definition, these two "
#~ "symbols cannot appear inside a frame "
#~ "which is only composed of `0` and"
#~ " `1`. Some technologies use these "
#~ "special symbols as markers for the "
#~ "beginning or end of frames."
#~ msgstr ""

#~ msgid ""
#~ "Bit rate and bandwidth are often "
#~ "used to characterize the transmission "
#~ "capacity of the physical service. The"
#~ " original definition of `bandwidth "
#~ "<http://www.merriam-webster.com/dictionary/bandwidth>`_, "
#~ "as listed in the `Webster dictionary "
#~ "<http://www.merriam-webster.com/dictionary>`_ is `a"
#~ " range of radio frequencies which is"
#~ " occupied by a modulated carrier "
#~ "wave, which is assigned to a "
#~ "service, or over which a device "
#~ "can operate`. This definition corresponds "
#~ "to the characteristics of a given "
#~ "transmission medium or receiver. For "
#~ "example, the human ear is able to"
#~ " decode sounds in roughly the 0-20"
#~ " KHz frequency range. By extension, "
#~ "bandwidth is also used to represent "
#~ "the capacity of a communication system"
#~ " in bits per second. For example, "
#~ "a Gigabit Ethernet link is theoretically"
#~ " capable of transporting one billion "
#~ "bits per second."
#~ msgstr ""

#~ msgid ""
#~ "`Character stuffing` , like bit "
#~ "stuffing, increases the length of the"
#~ " transmitted frames. For `character "
#~ "stuffing`, the worst frame is a "
#~ "frame containing many `DLE` characters. "
#~ "When transmission errors occur, the "
#~ "receiver may incorrectly decode one or"
#~ " two frames (e.g. if the errors "
#~ "occur in the markers). However, it "
#~ "will be able to resynchronise itself "
#~ "with the next correctly received "
#~ "markers."
#~ msgstr ""

#~ msgid ""
#~ "Bit stuffing and character stuffing "
#~ "allow to recover frames from a "
#~ "stream of bits or bytes. This "
#~ "framing mechanism provides a richer "
#~ "service than the physical layer. Through"
#~ " the framing service, one can send"
#~ " and receive complete frames. This "
#~ "framing service can also be represented"
#~ " by using the `DATA.request` and "
#~ "`DATA.indication` primitives. This is "
#~ "illustrated in the figure below, "
#~ "assuming hypothetical frames containing four"
#~ " useful bit and one bit of "
#~ "framing for graphical reasons."
#~ msgstr ""

#~ msgid ""
#~ "the interactions between the datalink "
#~ "layer entity and the framing sublayer"
#~ " are represented by using `send` "
#~ "instead of `DATA.req` and `recvd` "
#~ "instead of `DATA.ind`"
#~ msgstr ""

#~ msgid ""
#~ "When running on top of a perfect"
#~ " framing sublayer, a datalink entity "
#~ "can simply issue a `send(SDU)` upon "
#~ "arrival of a `DATA.req(SDU)` [#fsdu]_ "
#~ ".Similarly, the receiver issues a "
#~ "`DATA.ind(SDU)` upon receipt of a "
#~ "`recvd(SDU)`. Such a simple protocol is"
#~ " sufficient when a single SDU is "
#~ "sent. This is illustrated in the "
#~ "figure below."
#~ msgstr ""

#~ msgid ""
#~ "The datalink entity can then be "
#~ "modelled as a finite state machine, "
#~ "containing two states for the receiver"
#~ " and two states for the sender. "
#~ "The figure below provides a graphical"
#~ " representation of this state machine "
#~ "with the sender above and the "
#~ "receiver below."
#~ msgstr ""

#~ msgid ""
#~ "The above FSM shows that the "
#~ "sender has to wait for an "
#~ "acknowledgement from the receiver before "
#~ "being able to transmit the next "
#~ "SDU.  The figure below illustrates the"
#~ " exchange of a few frames between "
#~ "two hosts."
#~ msgstr ""

#~ msgid ""
#~ "Other more powerful error correction "
#~ "codes have been proposed and are "
#~ "used in some applications. The `Hamming"
#~ " Code <http://en.wikipedia.org/wiki/Hamming_code>`_ is"
#~ " a clever combination of parity bits"
#~ " that provides error detection and "
#~ "correction capabilities."
#~ msgstr ""

#~ msgid "Checksums, CRCs, ..."
#~ msgstr ""

#~ msgid ""
#~ "Most of the protocols in the "
#~ "TCP/IP protocol suite rely on the "
#~ "simple Internet checksum in order to "
#~ "verify that a received packet has "
#~ "not been affected by transmission "
#~ "errors. Despite its popularity and ease"
#~ " of implementation, the Internet checksum"
#~ " is not the only available checksum"
#~ " mechanism. Cyclical Redundancy Checks "
#~ "(CRC_) are very powerful error detection"
#~ " schemes that are used notably on "
#~ "disks, by many datalink layer protocols"
#~ " and file formats such as zip "
#~ "or png. They can easily be "
#~ "implemented efficiently in hardware and "
#~ "have better error-detection capabilities "
#~ "than the Internet checksum [SGP98]_ ."
#~ " However, CRCs are sometimes considered "
#~ "to be too CPU-intensive for "
#~ "software implementations and other checksum"
#~ " mechanisms are preferred. The TCP/IP "
#~ "community chose the Internet checksum, "
#~ "the OSI community chose the Fletcher "
#~ "checksum [Sklower89]_ . Nowadays there "
#~ "are efficient techniques to quickly "
#~ "compute CRCs in software [Feldmeier95]_"
#~ msgstr ""

#~ msgid ""
#~ "Since the receiver sends an "
#~ "acknowledgement after having received each "
#~ "data frame, the simplest solution to "
#~ "deal with losses is to use a "
#~ "retransmission timer. When the sender "
#~ "sends a frame, it starts a "
#~ "retransmission timer. The value of this"
#~ " retransmission timer should be larger "
#~ "than the `round-trip-time`, i.e. "
#~ "the delay between the transmission of"
#~ " a data frame and the reception "
#~ "of the corresponding acknowledgement. When "
#~ "the retransmission timer expires, the "
#~ "sender assumes that the data segment "
#~ "has been lost and retransmits it. "
#~ "This is illustrated in the figure "
#~ "below."
#~ msgstr ""

#~ msgid ""
#~ "Unfortunately, retransmission timers alone are"
#~ " not sufficient to recover from "
#~ "losses. Let us consider, as an "
#~ "example, the situation depicted below "
#~ "where an acknowledgement is lost. In "
#~ "this case, the sender retransmits the"
#~ " data segment that has not been "
#~ "acknowledged. Unfortunately, as illustrated in"
#~ " the figure below, the receiver "
#~ "considers the retransmission as a new"
#~ " segment whose payload must be "
#~ "delivered to its user."
#~ msgstr ""

#~ msgid ""
#~ "To solve this problem, datalink "
#~ "protocols associate a `sequence number` "
#~ "to each data frame. This `sequence "
#~ "number` is one of the fields found"
#~ " in the header of data frames. "
#~ "We use the notation `D(x,...)` to "
#~ "indicate a data frame whose sequence "
#~ "number field is set to value `x`."
#~ " The acknowledgements also contain a "
#~ "sequence number indicating the data "
#~ "frames that it is acknowledging. We "
#~ "use `OKx` to indicate an acknowledgement"
#~ " frame that confirms the reception of"
#~ " `D(x,...)`. The sequence number is "
#~ "encoded as a bit string of fixed"
#~ " length. The simplest reliable protocol "
#~ "is the Alternating Bit Protocol (ABP)."
#~ msgstr ""

#~ msgid ""
#~ "The initial state of the sender is"
#~ " `Wait for D(0,...)`. In this state,"
#~ " the sender waits for a "
#~ "`Data.request`. The first data frame "
#~ "that it sends uses sequence number "
#~ "`0`. After having sent this frame, "
#~ "the sender waits for an `OK0` "
#~ "acknowledgement. A frame is retransmitted "
#~ "upon expiration of the retransmission "
#~ "timer or if an acknowledgement with "
#~ "an incorrect sequence number has been"
#~ " received."
#~ msgstr ""

#~ msgid ""
#~ "The Alternating Bit Protocol can recover"
#~ " from transmission errors and frame "
#~ "losses. However, it has one important"
#~ " drawback. Consider two hosts that "
#~ "are directly connected by a 50 "
#~ "Kbits/sec satellite link that has a "
#~ "250 milliseconds propagation delay. If "
#~ "these hosts send 1000 bits frames, "
#~ "then the maximum throughput that can "
#~ "be achieved by the alternating bit "
#~ "protocol is one frame every "
#~ ":math:`20+250+250=520` milliseconds if we "
#~ "ignore the transmission time of the "
#~ "acknowledgement. This is less than 2 "
#~ "Kbits/sec !"
#~ msgstr ""

#~ msgid ""
#~ "To overcome the performance limitations "
#~ "of the alternating bit protocol, "
#~ "reliable protocols rely on `pipelining`. "
#~ "This technique allows a sender to "
#~ "transmit several consecutive frames without"
#~ " being forced to wait for an "
#~ "acknowledgement after each frame. Each "
#~ "data frame contains a sequence number"
#~ " encoded in an `n` bits field."
#~ msgstr ""

#~ msgid ""
#~ "`Pipelining` allows the sender to "
#~ "transmit frames at a higher rate. "
#~ "However this higher transmission rate "
#~ "may overload the receiver. In this "
#~ "case, the frames sent by the "
#~ "sender will not be correctly received"
#~ " by their final destination. The "
#~ "reliable protocols that rely on "
#~ "pipelining allow the sender to transmit"
#~ " `W` unacknowledged frames before being "
#~ "forced to wait for an acknowledgement"
#~ " from the receiving entity."
#~ msgstr ""

#~ msgid ""
#~ "This is implemented by using a "
#~ "`sliding window`. The sliding window is"
#~ " the set of consecutive sequence "
#~ "numbers that the sender can use "
#~ "when transmitting frames without being "
#~ "forced to wait for an acknowledgement."
#~ " The figure below shows a sliding "
#~ "window containing five segments (`6,7,8,9` "
#~ "and `10`). Two of these sequence "
#~ "numbers (`6` and `7`) have been "
#~ "used to send frames and only three"
#~ " sequence numbers (`8`, `9` and `10`)"
#~ " remain in the sliding window. The"
#~ " sliding window is said to be "
#~ "closed once all sequence numbers "
#~ "contained in the sliding window have "
#~ "been used."
#~ msgstr ""

#~ msgid ""
#~ "The figure below illustrates the "
#~ "operation of the sliding window. It "
#~ "uses a sliding window of three "
#~ "frames. The sender can thus transmit "
#~ "three frames before being forced to "
#~ "wait for an acknowledgement. The sliding"
#~ " window moves to the higher sequence"
#~ " numbers upon the reception of each"
#~ " acknowledgement. When the first "
#~ "acknowledgement (`OK0`) is received, it "
#~ "allows the sender to move its "
#~ "sliding window to the right and "
#~ "sequence number `3` becomes available. "
#~ "This sequence number is used later "
#~ "to transmit the frame containing `d`."
#~ msgstr ""

#~ msgid ""
#~ "The simplest sliding window protocol "
#~ "uses the `go-back-n` recovery. "
#~ "Intuitively, `go-back-n` operates as "
#~ "follows. A `go-back-n` receiver is "
#~ "as simple as possible. It only "
#~ "accepts the frames that arrive in-"
#~ "sequence. A `go-back-n` receiver "
#~ "discards any out-of-sequence frame "
#~ "that it receives. When `go-back-n` "
#~ "receives a data frame, it always "
#~ "returns an acknowledgement containing the "
#~ "sequence number of the last in-"
#~ "sequence frame that it has received. "
#~ "This acknowledgement is said to be "
#~ "`cumulative`. When a `go-back-n` "
#~ "receiver sends an acknowledgement for "
#~ "sequence number `x`, it implicitly "
#~ "acknowledges the reception of all frames"
#~ " whose sequence number is earlier "
#~ "than `x`. A key advantage of these"
#~ " cumulative acknowledgements is that it "
#~ "is easy to recover from the loss"
#~ " of an acknowledgement. Consider for "
#~ "example a `go-back-n` receiver that "
#~ "received frames `1`, `2` and `3`. "
#~ "It sent `OK1`, `OK2` and `OK3`. "
#~ "Unfortunately, `OK1` and `OK2` were "
#~ "lost. Thanks to the cumulative "
#~ "acknowledgements, when the receiver receives"
#~ " `OK3`, it knows that all three "
#~ "frames have been correctly received."
#~ msgstr ""

#~ msgid ""
#~ "A `go-back-n` sender is also very"
#~ " simple. It uses a sending buffer "
#~ "that can store an entire sliding "
#~ "window of frames [#fsizesliding]_ . The"
#~ " frames are sent with increasing "
#~ "sequence numbers (modulo `maxseq`). The "
#~ "sender must wait for an acknowledgement"
#~ " once its sending buffer is full. "
#~ "When a `go-back-n` sender receives "
#~ "an acknowledgement, it removes from the"
#~ " sending buffer all the acknowledged "
#~ "frames and uses a retransmission timer"
#~ " to detect frame losses. A simple "
#~ "`go-back-n` sender maintains one "
#~ "retransmission timer per connection. This "
#~ "timer is started when the first "
#~ "frame is sent. When the `go-back-n"
#~ " sender` receives an acknowledgement, it"
#~ " restarts the retransmission timer only "
#~ "if there are still unacknowledged frames"
#~ " in its sending buffer. When the "
#~ "retransmission timer expires, the `go-"
#~ "back-n` sender assumes that all the "
#~ "unacknowledged frames currently stored in "
#~ "its sending buffer have been lost. "
#~ "It thus retransmits all the "
#~ "unacknowledged frames in the buffer and"
#~ " restarts its retransmission timer."
#~ msgstr ""

#~ msgid ""
#~ "The operation of `go-back-n` is "
#~ "illustrated in the figure below. In "
#~ "this figure, note that upon reception"
#~ " of the out-of-sequence frame "
#~ "`D(2,c)`, the receiver returns a "
#~ "cumulative acknowledgement `C(OK,0)` that "
#~ "acknowledges all the frames that have"
#~ " been received in sequence. The lost"
#~ " frame is retransmitted upon the "
#~ "expiration of the retransmission timer."
#~ msgstr ""

#~ msgid ""
#~ "A `selective repeat` receiver discards "
#~ "all frames having an invalid CRC, "
#~ "and maintains the variable `lastack` as"
#~ " the sequence number of the last "
#~ "in-sequence frame that it has "
#~ "received. The receiver always includes "
#~ "the value of `lastack` in the "
#~ "acknowledgements that it sends. Some "
#~ "protocols also allow the `selective "
#~ "repeat` receiver to acknowledge the "
#~ "out-of-sequence frames that it has"
#~ " received. This can be done for "
#~ "example by placing the list of the"
#~ " correctly received, but out-of-"
#~ "sequence frames in the acknowledgements "
#~ "together with the `lastack` value."
#~ msgstr ""

#~ msgid ""
#~ "When a `selective repeat` receiver "
#~ "receives a data frame, it first "
#~ "verifies whether the frame is inside "
#~ "its receiving window. If yes, the "
#~ "frame is placed in the receive "
#~ "buffer. If not, the received frame "
#~ "is discarded and an acknowledgement "
#~ "containing `lastack` is sent to the "
#~ "sender. The receiver then removes all"
#~ " consecutive frames starting at `lastack`"
#~ " (if any) from the receive buffer."
#~ " The payloads of these frames are "
#~ "delivered to the user, `lastack` and "
#~ "the receiving window are updated, and"
#~ " an acknowledgement acknowledging the last"
#~ " frame received in sequence is sent."
#~ msgstr ""

#~ msgid ""
#~ "The `selective repeat` sender maintains "
#~ "a sending buffer that can store up"
#~ " to `W` unacknowledged frames. These "
#~ "frames are sent as long as the "
#~ "sending buffer is not full. Several "
#~ "implementations of a `selective repeat` "
#~ "sender are possible. A simple "
#~ "implementation associates one retransmission "
#~ "timer to each frame. The timer is"
#~ " started when the frame is sent "
#~ "and cancelled upon reception of an "
#~ "acknowledgement that covers this frame. "
#~ "When a retransmission timer expires, the"
#~ " corresponding frame is retransmitted and"
#~ " this retransmission timer is restarted."
#~ " When an acknowledgement is received, "
#~ "all the frames that are covered by"
#~ " this acknowledgement are removed from "
#~ "the sending buffer and the sliding "
#~ "window is updated."
#~ msgstr ""

#~ msgid ""
#~ "Pure cumulative acknowledgements work well "
#~ "with the `go-back-n` strategy. However,"
#~ " with only cumulative acknowledgements a"
#~ " `selective repeat` sender cannot easily"
#~ " determine which frames have been "
#~ "correctly received after a data frame"
#~ " has been lost. For example, in "
#~ "the figure above, the second `C(OK,0)`"
#~ " does not inform explicitly the "
#~ "sender of the reception of `D(2,c)` "
#~ "and the sender could retransmit this "
#~ "frame although it has already been "
#~ "received. A possible solution to improve"
#~ " the performance of `selective repeat` "
#~ "is to provide additional information "
#~ "about the received frames in the "
#~ "acknowledgements that are returned by "
#~ "the receiver. For example, the receiver"
#~ " could add in the returned "
#~ "acknowledgement the list of the sequence"
#~ " numbers of all frames that have "
#~ "already been received. Such acknowledgements"
#~ " are sometimes called `selective "
#~ "acknowledgements`. This is illustrated in "
#~ "the figure above."
#~ msgstr ""

#~ msgid ""
#~ "In the figure above, when the "
#~ "sender receives `C(OK,0,[2])`, it knows "
#~ "that all frames up to and "
#~ "including `D(0,...)` have been correctly "
#~ "received. It also knows that frame "
#~ "`D(2,...)` has been received and can "
#~ "cancel the retransmission timer associated "
#~ "to this frame. However, this frame "
#~ "should not be removed from the "
#~ "sending buffer before the reception of"
#~ " a cumulative acknowledgement (`C(OK,2)` in"
#~ " the figure above) that covers this"
#~ " frame."
#~ msgstr ""

#~ msgid ""
#~ "A reliable protocol that uses `n` "
#~ "bits to encode its sequence number "
#~ "can send up to :math:`2^n` successive"
#~ " frames. However, to ensure a "
#~ "reliable delivery of the frames, `go-"
#~ "back-n` and `selective repeat` cannot "
#~ "use a sending window of :math:`2^n` "
#~ "frames. Consider first `go-back-n` and"
#~ " assume that a sender sends "
#~ ":math:`2^n` frames. These frames are "
#~ "received in-sequence by the destination,"
#~ " but all the returned acknowledgements "
#~ "are lost. The sender will retransmit "
#~ "all frames. These frames will all "
#~ "be accepted by the receiver and "
#~ "delivered a second time to the "
#~ "user. It is easy to see that "
#~ "this problem can be avoided if the"
#~ " maximum size of the sending window"
#~ " is :math:`{2^n}-1` frames. A similar "
#~ "problem occurs with `selective repeat`. "
#~ "However, as the receiver accepts out-"
#~ "of-sequence frames, a sending window "
#~ "of :math:`{2^n}-1` frames is not "
#~ "sufficient to ensure a reliable "
#~ "delivery. It can be easily shown "
#~ "that to avoid this problem, a "
#~ "`selective repeat` sender cannot use a"
#~ " window that is larger than "
#~ ":math:`\\frac{2^n}{2}` frames."
#~ msgstr ""

#~ msgid ""
#~ "Reliable protocols often need to send"
#~ " data in both directions. To reduce"
#~ " the overhead caused by the "
#~ "acknowledgements, most reliable protocols use"
#~ " `piggybacking`. Thanks to this technique,"
#~ " a datalink entity can place the "
#~ "acknowledgements and the receive window "
#~ "that it advertises for the opposite "
#~ "direction of the data flow inside "
#~ "the header of the data frames that"
#~ " it sends. The main advantage of "
#~ "piggybacking is that it reduces the "
#~ "overhead as it is not necessary to"
#~ " send a complete frame to carry "
#~ "an acknowledgement. This is illustrated "
#~ "in the figure below where the "
#~ "acknowledgement number is underlined in "
#~ "the data frames. Piggybacking is only"
#~ " used when data flows in both "
#~ "directions. A receiver will generate a"
#~ " pure acknowledgement when it does "
#~ "not send data in the opposite "
#~ "direction as shown in the bottom "
#~ "of the figure."
#~ msgstr ""

#~ msgid ""
#~ "The size of the sliding window can"
#~ " be either fixed for a given "
#~ "protocol or negotiated during the "
#~ "connection establishment phase. Some protocols"
#~ " allow to change the maximum window"
#~ " size during the data transfert. We"
#~ " will explain these techniques with "
#~ "real protocols later."
#~ msgstr ""
