FR2888962A1 - Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion - Google Patents

Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion Download PDF

Info

Publication number
FR2888962A1
FR2888962A1 FR0313380A FR0313380A FR2888962A1 FR 2888962 A1 FR2888962 A1 FR 2888962A1 FR 0313380 A FR0313380 A FR 0313380A FR 0313380 A FR0313380 A FR 0313380A FR 2888962 A1 FR2888962 A1 FR 2888962A1
Authority
FR
France
Prior art keywords
animation
client terminal
determining
creating
client
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
FR0313380A
Other languages
French (fr)
Inventor
Xavier Henocq
Franck Denoual
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Canon Inc filed Critical Canon Inc
Priority to FR0313380A priority Critical patent/FR2888962A1/en
Priority to EP04292667.5A priority patent/EP1531428A3/en
Priority to US10/986,381 priority patent/US7423649B2/en
Publication of FR2888962A1 publication Critical patent/FR2888962A1/en
Pending legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/239Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests
    • H04N21/2393Interfacing the upstream path of the transmission network, e.g. prioritizing client content requests involving handling client requests
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/957Browsing optimisation, e.g. caching or content distillation
    • G06F16/9577Optimising the visualization of content, e.g. distillation of HTML documents
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
    • H04N19/132Sampling, masking or truncation of coding units, e.g. adaptive resampling, frame skipping, frame interpolation or high-frequency transform coefficient masking
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/146Data rate or code amount at the encoder output
    • H04N19/147Data rate or code amount at the encoder output according to rate distortion criteria
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/156Availability of hardware or computational resources, e.g. encoding based on power-saving criteria
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/162User input
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
    • H04N19/164Feedback from the receiver or from the transmission channel
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/40Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using video transcoding, i.e. partial or full decoding of a coded input stream followed by re-encoding of the decoded output stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/587Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal sub-sampling or interpolation, e.g. decimation or subsequent interpolation of pictures in a video sequence
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/63Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding using sub-band based transform, e.g. wavelets
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • H04N21/23439Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements for generating different versions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/25Management operations performed by the server for facilitating the content distribution or administrating data related to end-users or client devices, e.g. end-user or client device authentication, learning user preferences for recommending movies
    • H04N21/266Channel or content management, e.g. generation and management of keys and entitlement messages in a conditional access system, merging a VOD unicast channel into a multicast channel
    • H04N21/2662Controlling the complexity of the video stream, e.g. by scaling the resolution or bitrate of the video stream based on the client capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/637Control signals issued by the client directed to the server or network components
    • H04N21/6377Control signals issued by the client directed to the server or network components directed to server
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/65Transmission of management data between client and server
    • H04N21/658Transmission by the client directed to the server

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Databases & Information Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computing Systems (AREA)
  • Processing Or Creating Images (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

The requests for obtaining images from a remote terminal are optimized by determining versions of the animation depending on criterion corresponding to characteristic of client liable to download the animation. A file comprising the optimized requests, and description of different versions of the animation and associated criterion, is created. Independent claims are also included for the following: (1) animation management method; (2) animation downloading method; (3) animation creation device; (4) animation management device; (5) animation downloading device; (6) digital data processing apparatus; and (7) information storage medium storing animation creating program.

Description

La présente invention concerne d'une manière générale les animations, parThe present invention generally relates to animations, for example

exemple construites selon la technique appelée Flash développée par la société Macromedia.  example built according to the technique called Flash developed by the company Macromedia.

Cette technique permet de fabriquer un fichier contenant une animation qui peut être jouée sur un ordinateur.  This technique makes it possible to make a file containing an animation that can be played on a computer.

Il est possible d'inclure une ou des image(s) au format JPEG2000 dans cette animation. Une description de ce format est disponible à l'adresse internet: http:llwww.jpeg.org.  It is possible to include JPEG2000 image (s) in this animation. A description of this format is available at the internet address: http: llwww.jpeg.org.

On s'intéresse plus particulièrement à la création d'une telle animation. La qualité d'affichage de l'animation dépend directement du nombre d'images clés. En effet, plus il y a d'images clés, moins le nombre d'interpolation est grand et par conséquent plus la qualité visuelle de l'animation est grande. Cependant, plus il y a d'images clés à transmettre et plus le débit de transmission est grand et plus le coût calculatoire pour traiter les images clés est grand.  We are particularly interested in the creation of such an animation. The display quality of the animation depends directly on the number of keyframes. Indeed, the more keyframes there are, the less the interpolation number is large and therefore the higher the visual quality of the animation. However, the more key images to transmit, the higher the transmission rate, and the greater the computational cost to process the keyframes.

Il faut donc trouver un compromis entre la qualité de l'animation d'une part et les capacités de calcul et la bande passante du réseau d'autre part.  It is therefore necessary to find a compromise between the quality of the animation on the one hand and the computing capacities and the bandwidth of the network on the other hand.

Dans le document US 6 081 278, deux versions d'une animation sont mémorisées sur un serveur. L'une des versions comporte un plus grand 30 nombre d'images clés que l'autre.  In US 6 081 278, two versions of an animation are stored on a server. One version has a larger number of keyframes than the other.

Lorsqu'un terminal client demande l'animation, il envoie ses caractéristiques au serveur qui détermine quelle version est la mieux adaptée avant d'envoyer cette version.  When a client terminal requests the animation, it sends its characteristics to the server which determines which version is best suited before sending this version.

Si beaucoup de terminaux clients demandent une animation simultanément, la charge de calcul liée à la recherche de la version adaptée à chaque terminal client peut devenir trop importante pour le serveur.  If many client terminals request an animation simultaneously, the compute load related to finding the version adapted to each client terminal may become too important for the server.

Le document US 6 442 603 traite du cas d'un document contenant plusieurs types de contenu tels que texte, audio, image, vidéo. Comme dans le document précédent, lorsqu'un terminal client demande l'animation, il envoie ses caractéristiques au serveur. Ce dernier détermine quels sont les types de données qui sont compatibles avec le terminal client.  US 6,442,603 discusses the case of a document containing several types of content such as text, audio, image, video. As in the previous document, when a client terminal requests the animation, it sends its characteristics to the server. The latter determines which types of data are compatible with the client terminal.

Ce système présente le même inconvénient que celui du document précédent. En outre, il ne permet pas de moduler la qualité dans un même type de données.  This system has the same drawback as that of the previous document. In addition, it does not allow to modulate the quality in the same type of data.

Le document intitulé Low complexity video coding for receiverdriven layered multicast , de S. Mc Canne, Jacobson et M. Vetterli, paru dans IEEE Journal of selected areas in communications, Vol. 15, N 6, août 1997, pages 983-1001, propose un système dans lequel le serveur n'a aucun rôle actif dans le choix du niveau de qualité des données envoyées à un terminal client.  Low complexity video coding for receiver layered multicast, by S. Mc Canne, Jacobson and M. Vetterli, published in IEEE Journal of Selected Areas in Communications, Vol. 15, No. 6, August 1997, pages 983-1001, proposes a system in which the server has no active role in the choice of the quality level of the data sent to a client terminal.

Dans ce système, le serveur envoie plusieurs niveaux de hiérarchie d'un flux vidéo sur des adresses multipoints séparées. Un terminal client est abonné à un certain nombre de niveaux. Il commence par s'abonner au niveau de hiérarchie le plus bas puis tente de s'abonner aux niveaux plus élevés tant qu'il ne constate pas de perte.  In this system, the server sends multiple hierarchy levels of a video stream to separate multipoint addresses. A client terminal subscribes to a number of levels. It starts by subscribing to the lowest hierarchy level and then tries to subscribe to higher levels as long as there is no loss.

Il n'y a pas de surcharge du serveur. En revanche, le trafic lié à la gestion des arbres multipoints est élevé. En outre, il est nécessaire que des routeurs compatibles avec le multipoint existent dans les réseaux de transmission. A l'heure actuelle, très peu de ces routeurs existent sur l'Internet.  There is no server overhead. On the other hand, traffic related to the management of multipoint trees is high. In addition, it is necessary that routers compatible with the multipoint exist in the transmission networks. At present, very few of these routers exist on the Internet.

Enfin, le temps de convergence vers le niveau de qualité optimal est élevé, ce qui est peu compatible avec des animations de type Flash.  Finally, the convergence time to the optimal quality level is high, which is not very compatible with Flash animations.

Le document US 6 185 625 propose une méthode selon laquelle l'utilisateur du terminal client fixe les paramètres de qualité qui seront utilisés pour jouer l'animation.  Document US 6 185 625 proposes a method according to which the user of the client terminal sets the quality parameters that will be used to play the animation.

Ces informations sont transmises au serveur, et l'animation est 5 codée de manière spécifique en fonction des paramètres fixés par l'utilisateur. L'animation codée est ensuite transmise au terminal client.  This information is transmitted to the server, and the animation is coded specifically according to the parameters set by the user. The coded animation is then transmitted to the client terminal.

Cette méthode implique donc un codage spécifique de l'animation avant sa transmission. Cela peut retarder la transmission.  This method therefore involves a specific encoding of the animation before it is transmitted. This can delay the transmission.

En outre, l'utilisateur du terminal client doit posséder des 10 connaissances techniques pour fixer les paramètres de qualité de manière appropriée.  In addition, the client terminal user must have technical knowledge to set the quality parameters appropriately.

Dans le document US 6 442 658, une animation est considérée comme un ensemble de segments. Les segments sont classés selon leur probabilité d'être joués après le segment courant et également selon un coût 15 de transmission estimé.  In US 6,442,658, an animation is considered as a set of segments. The segments are ranked according to their likelihood of being played after the current segment and also at an estimated transmission cost.

Ainsi, un pré chargement est réalisé en fonction de la probabilité et du coût. La mémoire disponible des terminaux clients peut en outre être prise en compte.  Thus, a pre-loading is done according to the probability and the cost. The available memory of the client terminals can also be taken into account.

Le temps de transmission de l'animation est réduit. Cependant, ce document ne propose pas de compromis entre la qualité de l'animation d'une part et les capacités de calcul et la bande passante du réseau d'autre part.  The transmission time of the animation is reduced. However, this document does not propose a compromise between the quality of the animation on the one hand and the computing capacities and the bandwidth of the network on the other hand.

Le guide utilisateur de Flash MX intitulé Flash MX , aux éditions Dunod, décrit le langage ActionScript qui permet à un utilisateur d'interagir dynamiquement avec une animation.  Flash MX's Flash MX user guide, published by Dunod, describes the ActionScript language that allows a user to dynamically interact with an animation.

Le contrôle qui est ainsi possible est indépendant des capacités des terminaux clients ou de la bande passante.  The control that is possible is independent of the capabilities of the client terminals or the bandwidth.

La présente invention vise à remédier aux inconvénients de la technique antérieure, en fournissant un procédé et un dispositif de création d'animation qui permettent un compromis entre la qualité de l'animation d'une part et/ou les capacités de calcul d'un terminal client et la bande passante du réseau de transmission d'autre part.  The present invention aims to overcome the drawbacks of the prior art, by providing a method and an animation creation device that allow a compromise between the quality of the animation on the one hand and / or the computing capabilities of a computer. terminal and the bandwidth of the transmission network on the other hand.

A cette fin, l'invention propose un procédé de création d'une animation comportant des images clés, caractérisé en ce qu'il comporte les étapes de: - détermination d'une pluralité de versions de l'animation en fonction d'au moins un critère correspondant à au moins une caractéristique du client susceptible de télécharger l'animation, - création d'un fichier comportant une description des différentes versions déterminées et leur critère associé.  To this end, the invention proposes a method for creating an animation comprising keyframes, characterized in that it comprises the steps of: determining a plurality of versions of the animation according to at least a criterion corresponding to at least one characteristic of the client able to download the animation, - creating a file comprising a description of the different versions determined and their associated criterion.

L'invention permet une adaptation fine de l'animation aux capacités du terminal client et de la bande passante disponible.  The invention allows a fine adaptation of the animation to the capabilities of the client terminal and the available bandwidth.

La charge de calcul du coté du serveur est réduite, puisque c'est le terminal client qui détermine automatiquement la version qui lui est adaptée.  The computing load on the side of the server is reduced, since it is the client terminal that automatically determines the version that is adapted to it.

Ainsi, il n'y a pas de temps de latence important lors du téléchargement d'une animation. En effet, même s'il y a beaucoup de terminaux clients qui demandent l'animation simultanément, les calculs sont répartis sur les terminaux clients.  Thus, there is no significant latency when downloading an animation. Indeed, even if there are many client terminals that request the animation simultaneously, the calculations are distributed on the client terminals.

Selon un premier mode de réalisation, l'étape de détermination comporte les étapes de: - affectation d'un niveau de priorité à chaque image clé, calcul d'un coût de décodage global des images clés de chaque niveau de priorité.  According to a first embodiment, the determination step comprises the steps of: assigning a priority level to each key image, calculating a global decoding cost of the key images of each priority level.

Dans ce cas, le coût de décodage est adapté aux capacités calculatoires du terminal client qui télécharge l'animation.  In this case, the decoding cost is adapted to the computing capabilities of the client terminal that downloads the animation.

Selon une caractéristique préférée, une version de l'animation comporte des images clés auxquelles un même niveau de priorité a été affecté.  According to a preferred characteristic, a version of the animation comprises keyframes to which the same priority level has been assigned.

Ainsi, le nombre d'images clés à télécharger varie en fonction du 30 niveau de priorité.  Thus, the number of keyframes to download varies depending on the priority level.

Selon un second mode de réalisation, l'étape de détermination comporte les étapes de: - détermination de plusieurs classes de terminaux clients en fonction de leur bande passante, - détermination d'une version de chaque image clé pour chaque classe de terminaux clients.  According to a second embodiment, the determination step comprises the steps of: - determining several classes of client terminals according to their bandwidth, - determining a version of each key image for each class of client terminals.

Dans ce cas, c'est la bande passante qui est prise en compte. Le temps de téléchargement de l'animation est ainsi limité.  In this case, the bandwidth is taken into account. The download time of the animation is thus limited.

Ben entendu, il est possible de tenir compte à la fois des capacités calculatoire des terminaux clients et de la bande passante.  Of course, it is possible to take into account both the computing capacity of the client terminals and the bandwidth.

Selon une caractéristique préférée, l'étape de création comporte la 10 détermination de requêtes pour chaque image clé, destinées à obtenir chaque image clé depuis un terminal distant.  According to a preferred feature, the creation step includes determining requests for each keyframe for obtaining each keyframe from a remote terminal.

Selon une caractéristique préférée, les requêtes sont de type JPIP.  According to a preferred characteristic, the requests are of the JPIP type.

Les requêtes JPIP sont établies selon un protocole en cours de normalisation, dont une description peut être trouvée à l'adresse Internet: 15 http:llwww.jpeg.org.  JPIP requests are established according to a protocol in the process of standardization, a description of which can be found at the Internet address: http: //www.jpeg.org.

L'invention a également trait à un procédé de téléchargement d'une animation depuis un serveur vers un terminal client, l'animation ayant été créée par le procédé de création présenté ci-dessus, caractérisé en ce qu'il comporte les étapes de: - réception de la description des différentes versions de l'animation, - sélection d'une version de l'animation en fonction d'au moins une caractéristique du terminal client, - émission de requêtes en fonction de la version sélectionnée.  The invention also relates to a method of downloading an animation from a server to a client terminal, the animation having been created by the creation method presented above, characterized in that it comprises the steps of: receiving the description of the different versions of the animation, selecting a version of the animation according to at least one characteristic of the client terminal, sending requests according to the version selected.

Selon le premier mode de réalisation, l'étape de sélection comporte les étapes de: - détermination d'un niveau de priorité de l'animation en fonction du coût de décodage global des images clés de chaque niveau de priorité et des capacités de traitement du terminal client, - sélection des images clés appartenant au niveau de priorité déterminé.  According to the first embodiment, the selection step comprises the steps of: determining a priority level of the animation according to the global decoding cost of the key images of each priority level and the processing capabilities of the client terminal, - selection of keyframes belonging to the determined priority level.

Selon le second mode de réalisation, l'étape de sélection comporte les étapes de: - détermination de la bande passante effective du terminal client, - identification de la classe du terminal client en fonction de sa bande 5 passante effective, - sélection des versions des images clés correspondant à la classe du terminal client.  According to the second embodiment, the selection step comprises the steps of: determining the effective bandwidth of the client terminal, identifying the class of the client terminal as a function of its effective bandwidth, selecting versions of the client terminals; keyframes corresponding to the class of the client terminal.

Corrélativement, l'invention concerne un dispositif de création d'une animation comportant des images clés, caractérisé en ce qu'il comporte: des moyens de détermination d'une pluralité de versions de l'animation en fonction d'au moins un critère correspondant à au moins une caractéristique du client susceptible de télécharger l'animation, - des moyens de création d'un fichier comportant une description 15 des différentes versions déterminées et leur critère associé.  Correlatively, the invention relates to a device for creating an animation comprising keyframes, characterized in that it comprises: means for determining a plurality of versions of the animation according to at least one corresponding criterion at least one characteristic of the client capable of downloading the animation, means for creating a file comprising a description of the different versions determined and their associated criterion.

L'invention concerne aussi un dispositif de téléchargement d'une animation depuis un serveur vers un terminal client, l'animation ayant été créée par le dispositif de création précédent, caractérisé en ce qu'il comporte: des moyens de réception de la description des différentes versions de l'animation, - des moyens de sélection d'une version de l'animation en fonction d'une caractéristique du terminal client, - des moyens d'émission de requêtes en fonction de la version 25 sélectionnée.  The invention also relates to a device for downloading an animation from a server to a client terminal, the animation having been created by the previous authoring device, characterized in that it comprises: means for receiving the description of the different versions of the animation; means for selecting a version of the animation according to a characteristic of the client terminal; means for sending requests according to the selected version.

Les dispositifs selon l'invention comportent des moyens de mise en oeuvre des caractéristiques précédemment exposées.  The devices according to the invention comprise means for implementing the characteristics previously described.

Le dispositif de création, le procédé et le dispositif de 30 téléchargement présentent des avantages analogues à ceux précédemment présentés.  The authoring device, the method and the downloading device have advantages similar to those previously presented.

L'invention concerne aussi un fichier comportant les données de codage d'une animation créée par le procédé de création précédemment présenté, caractérisé en ce qu'il comporte une indexation, une suite de requêtes, une priorité et un instant d'affichage, pour chaque image clé, et en outre le coût calculatoire de chaque niveau de priorité.  The invention also relates to a file comprising the coding data of an animation created by the creation method previously presented, characterized in that it comprises an indexing, a sequence of requests, a priority and a display instant, for each keyframe, and in addition the computational cost of each priority level.

L'invention concerne aussi un fichier comportant les données de codage d'une animation créée par le procédé de création précédemment présenté, caractérisé en ce qu'il comporte une indexation, une suite de requêtes classées en fonction des classes de terminaux clients et un instant d'affichage, pour chaque image clé, et en outre la définition des classes.  The invention also relates to a file comprising the encoding data of an animation created by the creation process previously presented, characterized in that it comprises an indexing, a sequence of queries classified according to the classes of client terminals and a time display, for each keyframe, and further defining the classes.

L'invention concerne aussi un appareil numérique incluant le dispositif selon l'invention ou des moyens de mise en oeuvre du procédé selon l'invention. Cet appareil numérique est par exemple un appareil photographique numérique, un caméscope numérique, un scanner, une imprimante, un photocopieur, un télécopieur. Les avantages du dispositif et de l'appareil numérique sont identiques à ceux précédemment exposés.  The invention also relates to a digital apparatus including the device according to the invention or means for implementing the method according to the invention. This digital camera is for example a digital camera, a digital camcorder, a scanner, a printer, a photocopier, a fax machine. The advantages of the device and the digital device are identical to those previously exposed.

Un moyen de stockage d'information, lisible par un ordinateur ou par un microprocesseur, intégré ou non au dispositif, éventuellement amovible, mémorise un programme mettant en oeuvre le procédé selon l'invention.  An information storage means, readable by a computer or by a microprocessor, integrated or not to the device, possibly removable, stores a program implementing the method according to the invention.

Un programme d'ordinateur lisible par un microprocesseur et comportant une ou plusieurs séquence d'instructions est apte à mettre en oeuvre les procédés selon l'invention.  A computer program readable by a microprocessor and comprising one or more sequences of instructions is able to implement the methods according to the invention.

Les caractéristiques et avantages de la présente invention 25 apparaîtront plus clairement à la lecture d'un mode préféré de réalisation illustré par les dessins ci-joints, dans lesquels: - la figure 1 est un mode de réalisation d'un dispositif mettant en oeuvre l'invention, - la figure 2 représente un dispositif selon l'invention, - la figure 3 représente un premier mode de réalisation de procédé de création d'animation selon l'invention, - la figure 4 représente une interface graphique utilisée dans le procédé de la figure 3, - la figure 5 représente un fichier contenant une animation selon l'invention, - la figure 6 représente un mode de réalisation de calcul d'un coût calculatoire inclus dans le procédé de la figure 3, - la figure 7 représente un premier mode de réalisation de procédé de téléchargement d'animation selon l'invention, la figure 8 représente un mode de réalisation de détermination 10 niveaux de priorité, incluse dans le procédé de la figure 7, - la figure 9 représente un second mode de réalisation de procédé de création d'animation selon l'invention, - la figure 10 représente un fichier contenant une animation selon l'invention, - la figure 11 représente un mode de réalisation de détection d'images posant un problème de transmission, incluse dans le procédé de la figure 9, - la figure 12 représente une structure de liste d'images, - la figure 13 représente un mode de réalisation de détermination de 20 différentes versions d'une image respectant une bande passante prédéterminée, - la figure 14 représente un second mode de réalisation de procédé de téléchargement d'animation selon l'invention.  The features and advantages of the present invention will become more apparent upon reading a preferred embodiment illustrated by the accompanying drawings, in which: FIG. 1 is an embodiment of a device implementing FIG. invention, - figure 2 represents a device according to the invention, - figure 3 represents a first embodiment of animation creation method according to the invention, - figure 4 represents a graphical interface used in the method of FIG. 5 represents a file containing an animation according to the invention; FIG. 6 represents an embodiment of calculation of a computational cost included in the method of FIG. 3; FIG. first embodiment of an animation download method according to the invention, FIG. 8 represents an embodiment of determining priority levels, included in the method of FIG. 9 shows a second embodiment of an animation creation method according to the invention; FIG. 10 represents a file containing an animation according to the invention; FIG. 11 represents an embodiment 1 is a picture transmission pattern included in the method of FIG. 9, FIG. 12 represents an image list structure, FIG. 13 shows an embodiment of determination of different versions of an image respecting a predetermined bandwidth, - Figure 14 shows a second embodiment of animation download method according to the invention.

Selon le mode de réalisation choisi et représenté à la figure 1, un serveur 1 est relié à des terminaux clients 2, dont un seul est représenté, par l'intermédiaire d'un réseau de communication 3.  According to the embodiment chosen and represented in FIG. 1, a server 1 is connected to client terminals 2, only one of which is represented, via a communication network 3.

Le serveur 1 et le terminal client 2 sont des ordinateurs dont un exemple d'architecture est décrit dans la suite.  The server 1 and the client terminal 2 are computers, an exemplary architecture of which is described below.

La connexion entre les deux dispositifs est classique et ne sera pas décrite ici. Elle est par exemple de type http. On suppose que la transmission de données est effectuée sans perte.  The connection between the two devices is conventional and will not be described here. It is for example of type http. It is assumed that the data transmission is performed without loss.

Le serveur 1 comporte une unité 10 de réception de requêtes provenant du terminal client 2. II comporte également une unité 11 d'émission de données numériques à destination du terminal client 2.  The server 1 comprises a unit 10 for receiving requests from the client terminal 2. It also comprises a unit 11 for transmitting digital data to the client terminal 2.

L'unité 10 de réception de requêtes transmet les requêtes reçues à l'unité 12 de traitement. Le traitement comporte l'identification des données requises, leur formatage et leur transmission par l'intermédiaire de l'unité 11.  The request receiving unit 10 transmits the received requests to the processing unit 12. The processing includes the identification of the required data, their formatting and their transmission through the unit 11.

Le serveur 1 comporte également une mémoire 13 dans laquelle sont mémorisées des données. Une unité de commande 14 contrôle le fonctionnement des unités du serveur 1.  The server 1 also comprises a memory 13 in which data are stored. A control unit 14 controls the operation of the units of the server 1.

Selon l'invention, le serveur 1 comporte une unité 15 de création d'une animation, qui comporte: - des moyens de détermination d'une pluralité de versions de l'animation en fonction d'au moins un critère correspondant à au moins une caractéristique du client susceptible de télécharger l'animation, - des moyens de création d'un fichier comportant une description des différentes versions déterminées et leur critère associé.  According to the invention, the server 1 comprises a unit 15 for creating an animation, which comprises: means for determining a plurality of versions of the animation according to at least one criterion corresponding to at least one characteristic of the client likely to download the animation, means for creating a file comprising a description of the different versions determined and their associated criterion.

Le terminal client 2 comporte une unité 20 d'envoi de requêtes vers le serveur 1. II comporte également une unité 21 de réception de données numériques provenant du serveur 1.  The client terminal 2 comprises a unit 20 sending requests to the server 1. It also comprises a unit 21 for receiving digital data from the server 1.

L'unité 21 transmet les données reçues à l'unité 22 de traitement. Le traitement, objet de la présente invention, est détaillé dans la suite à l'aide d'algorithmes.  The unit 21 transmits the received data to the processing unit 22. The treatment, object of the present invention, is detailed in the following using algorithms.

Selon l'invention, l'unité 21 reçoit la description des différentes versions de l'animation. L'unité 22 sélectionne une version de l'animation en fonction d'au moins une caractéristique du terminal client. Enfin l'unité 20 émet des requêtes en fonction de la version sélectionnée.  According to the invention, the unit 21 receives the description of the different versions of the animation. The unit 22 selects a version of the animation according to at least one characteristic of the client terminal. Finally, unit 20 issues requests based on the selected version.

Le terminal client 2 comporte également une mémoire 23 dans laquelle sont mémorisées des données. Une unité de commande 24 contrôle le fonctionnement des unités du terminal client 2.  The client terminal 2 also includes a memory 23 in which data are stored. A control unit 24 controls the operation of the units of the client terminal 2.

Selon le mode de réalisation choisi et représenté à la figure 2, un dispositif mettant en oeuvre l'invention est par exemple un microordinateur 10 connecté à différents périphériques, par exemple une caméra numérique 107 (ou un scanner, ou tout moyen d'acquisition ou de stockage d'image) reliée à une carte graphique et fournissant des informations à traiter selon l'invention.  According to the embodiment chosen and shown in FIG. 2, a device embodying the invention is for example a microcomputer 10 connected to different peripherals, for example a digital camera 107 (or a scanner, or any means of acquisition or image storage) connected to a graphics card and providing information to be processed according to the invention.

Le dispositif 10 comporte une interface de communication 112 reliée à un réseau 113 apte à transmettre des données numériques à traiter ou inversement à transmettre des données traitées par le dispositif. Le dispositif 10 comporte également un moyen de stockage 108 tel que par exemple un disque dur. II comporte aussi un lecteur 109 de disque 110. Ce disque 110 peut être une disquette, un CD-ROM ou un DVD-ROM, par exemple. Le disque 110 comme le disque 108 peuvent contenir des données traitées selon l'invention ainsi que le ou les programmes mettant en oeuvre l'invention qui, une fois lu par le dispositif 10, sera stocké dans le disque dur 108. Selon une variante, le programme permettant au dispositif de mettre en oeuvre l'invention, pourra être stocké en mémoire morte 102 (appelée ROM sur le dessin). En seconde variante, le programme pourra être reçu pour être stocké de façon identique à celle décrite précédemment par l'intermédiaire du réseau de communication 113.  The device 10 comprises a communication interface 112 connected to a network 113 able to transmit digital data to be processed or conversely to transmit data processed by the device. The device 10 also comprises a storage means 108 such as for example a hard disk. It also comprises a disk drive 110 110. This disk 110 may be a diskette, a CD-ROM or a DVD-ROM, for example. The disk 110 as the disk 108 may contain data processed according to the invention as well as the program or programs implementing the invention which, once read by the device 10, will be stored in the hard disk 108. According to a variant, the program allowing the device to implement the invention, can be stored in ROM 102 (called ROM in the drawing). In the second variant, the program can be received to be stored in a manner identical to that previously described via the communication network 113.

Le dispositif 10 est relié à un microphone 111. Les données à traiter selon l'invention seront dans ce cas du signal audio.  The device 10 is connected to a microphone 111. The data to be processed according to the invention will in this case be an audio signal.

Ce même dispositif possède un écran 104 permettant de visualiser les données à traiter ou de servir d'interface avec l'utilisateur qui peut ainsi paramétrer certains modes de traitement, à l'aide du clavier 114 ou de tout autre moyen (souris par exemple).  This same device has a screen 104 making it possible to display the data to be processed or to interface with the user who can thus set up certain modes of treatment, using the keyboard 114 or by any other means (mouse for example) .

L'unité centrale 100 (appelée CPU sur le dessin) exécute les instructions relatives à la mise en oeuvre de l'invention, instructions stockées dans la mémoire morte 102 ou dans les autres éléments de stockage. Lors de la mise sous tension, les programmes de traitement stockés dans une mémoire non volatile, par exemple la ROM 102, sont transférés dans la mémoire vive RAM 103 qui contiendra alors le code exécutable de l'invention ainsi que des registres pour mémoriser les variables nécessaires à la mise en oeuvre de l'invention.  The CPU 100 (called the CPU in the drawing) executes the instructions relating to the implementation of the invention, instructions stored in the read-only memory 102 or in the other storage elements. When powering up, the processing programs stored in a non-volatile memory, for example the ROM 102, are transferred into the RAM RAM 103 which will then contain the executable code of the invention as well as registers for storing the variables. necessary for the implementation of the invention.

De manière plus générale, un moyen de stockage d'information, lisible par un ordinateur ou par un microprocesseur, intégré ou non au dispositif, éventuellement amovible, mémorise un programme mettant en oeuvre le procédé selon l'invention.  More generally, an information storage means, readable by a computer or by a microprocessor, integrated or not into the device, possibly removable, stores a program implementing the method according to the invention.

Le bus de communication 101 permet la communication entre les différents éléments inclus dans le micro-ordinateur 10 ou reliés à lui. La représentation du bus 101 n'est pas limitative et notamment l'unité centrale 100 est susceptible de communiquer des instructions à tout élément du micro-ordinateur 10 directement ou par l'intermédiaire d'un autre élément du micro- ordinateur 10.  The communication bus 101 allows communication between the various elements included in the microcomputer 10 or connected to it. The representation of the bus 101 is not limiting and in particular the central unit 100 is able to communicate instructions to any element of the microcomputer 10 directly or via another element of the microcomputer 10.

La figure 3 représente un premier mode de réalisation de procédé de création d'une animation, selon l'invention. Ce procédé est mis en oeuvre dans le dispositif de création et comporte des étapes El à E8.  FIG. 3 represents a first embodiment of a method for creating an animation, according to the invention. This method is implemented in the authoring device and comprises steps E1 to E8.

Le procédé est réalisé sous la forme d'un algorithme qui peut être mémorisé en totalité ou en partie dans tout moyen de stockage d'information capable de coopérer avec le microprocesseur. Ce moyen de stockage est lisible par un ordinateur ou par un microprocesseur. Ce moyen de stockage est intégré ou non au dispositif, et peut être amovible. Par exemple, il peut comporter une bande magnétique, une disquette ou un CD-ROM (disque compact à mémoire figée).  The method is embodied in the form of an algorithm that can be stored in whole or in part in any information storage means capable of cooperating with the microprocessor. This storage means is readable by a computer or a microprocessor. This storage means is integrated or not to the device, and can be removable. For example, it may comprise a magnetic tape, a floppy disk or a CD-ROM (compact disk with frozen memory).

L'étape El est la sélection d'une image IM pour servir de base à l'animation. L'image est codée selon la norme JPEG 2000 qui permet un accès rapide et facile à différentes résolutions, qualités et régions d'intérêt de l'image.  Step El is the selection of an IM image to serve as a basis for the animation. The image is coded according to the JPEG 2000 standard which allows quick and easy access to different resolutions, qualities and regions of interest of the image.

L'animation est créée à partir de cette seule image. En variante, l'animation est créée à partir de plusieurs images.  The animation is created from this single image. Alternatively, the animation is created from several images.

L'étape suivante E2 est la définition des images clés IMn de l'animation, avec n un entier variant entre 1 et un entier N. Pour cela, l'utilisateur utilise une interface graphique. Cette interface est par exemple générée en utilisant la bibliothèque C++ de conception d'interface graphique QT proposée par la société TrollTech, disponible à l'adresse internet: http:l/www.trolltech.coml.  The next step E2 is the definition of the keyframes IMn of the animation, with n an integer varying between 1 and an integer N. For this, the user uses a graphical interface. This interface is for example generated by using the C ++ QT GUI design library proposed by the company TrollTech, available at the Internet address: http: / / www.trolltech.com.

Cette interface comporte plusieurs fenêtres. Comme représenté à la figure 4, la fenêtre A affiche la taille originale de l'image. La fenêtre B affiche la taille de l'image après modification. Les fenêtres C et D permettent de modifier la taille de l'image. Une nouvelle taille exprimée en pixels peut être définie dans la fenêtre C ou une nouvelle taille exprimée en pourcentage de la taille de l'image initiale peut être définie dans la fenêtre D. Il est à noter que dans le mode préféré de l'invention, seules des tailles correspondant aux résolutions définies dans l'image originale peuvent être choisies.  This interface has several windows. As shown in Figure 4, window A displays the original size of the image. Window B displays the size of the image after modification. Windows C and D allow you to change the size of the image. A new size expressed in pixels can be defined in the window C or a new size expressed as a percentage of the size of the initial image can be defined in the window D. It should be noted that in the preferred embodiment of the invention, only sizes corresponding to the resolutions defined in the original image can be chosen.

La fenêtre E permet de choisir la qualité de l'image. Par exemple, les images possèdent neuf niveaux de qualité.  Window E allows you to choose the quality of the image. For example, the images have nine levels of quality.

La fenêtre F permet d'indiquer qu'une zone rectangulaire H de l'image IM va être sélectionnée.  The window F makes it possible to indicate that a rectangular area H of the image IM will be selected.

La fenêtre J permet de fixer l'instant d'affichage de l'image.  The window J makes it possible to fix the instant of display of the image.

L'étape suivante E3 est la définition d'un niveau de priorité Pn pour chaque image clé IMn. Le niveau de priorité d'une image clé dépend de son importance. Une image qui peut être approximée par interpolation entre deux autres images reçoit un niveau de priorité faible. Une image qui serait dégradée par une approximation par interpolation reçoit une priorité plus élevée. Une image qui ne peut pas être interpolée reçoit une priorité encore plus élevée.  The next step E3 is the definition of a priority level Pn for each key image IMn. The priority level of a keyframe depends on its importance. An image that can be approximated by interpolation between two other images receives a low priority level. An image that would be degraded by an interpolation approximation receives a higher priority. An image that can not be interpolated receives an even higher priority.

Huit niveaux de priorité PI à P8 sont par exemple disponibles. Le niveau 1 est le niveau de priorité le plus élevé. Les priorités sont décroissantes jusqu'au niveau 8. L'utilisateur définit le niveau de priorité de l'image grâce à la fenêtre G (figure 4).  Eight levels of priority PI to P8 are for example available. Level 1 is the highest priority level. The priorities are decreasing to level 8. The user sets the priority level of the image through the window G (Figure 4).

L'étape suivante E4 est le calcul pour chaque image clé IMn de requêtes Rn1, Rn2, ... selon le protocole JPIP. Le protocole JPIP de transmission de données codées selon la norme JPEG2000 permet à un terminal distant de rapatrier une image.  The next step E4 is the calculation for each key image IMn of requests Rn1, Rn2, ... according to the JPIP protocol. The JPIP protocol for transmitting data coded according to the JPEG2000 standard enables a remote terminal to repatriate an image.

Une liste de requêtes JPIP est ainsi formée et mémorisée dans un fichier destiné à être téléchargé, interprété puis joué sur un terminal client. Ce fichier, ou script d'animation, est par exemple au format SWF. Les requêtes JPIP sont établies selon un protocole en cours de normalisation, dont une description peut être trouvée à l'adresse internet: http:llwww. jpeg.org.  A list of JPIP requests is thus formed and stored in a file intended to be downloaded, interpreted and played on a client terminal. This file, or animation script, is for example in SWF format. JPIP requests are established according to a protocol in the process of standardization, a description of which can be found at the Internet address: http: llwww. jpeg.org.

Pour chaque image clé, des informations relatives à la taille, la résolution, la qualité, la zone sélectionnée, qui ont été définies à l'étape E2 sont insérées dans les requêtes JPIP.  For each keyframe, information relating to the size, resolution, quality, selected area, which were defined in step E2 are inserted in the JPIP queries.

L'étape suivante E5 est la définition, à l'aide de la fenêtre J, d'un instant d'affichage Tn pour chaque image clé IM,. Un instant d'affichage est un temps en secondes, déterminé à partir du début de l'animation. Lors de l'exécution ultérieure de l'animation, chaque image est affichée à l'instant défini.  The next step E5 is the definition, using the window J, of a display time Tn for each key image IM. An instant of display is a time in seconds, determined from the beginning of the animation. During the subsequent execution of the animation, each image is displayed at the defined time.

L'étape suivante E6 est le calcul du coût de décodage global cck de chaque niveau de priorité Pk avec k un entier variant entre 1 et 8. Le coût de décodage global cck d'un niveau de priorité Pk est le coût de décodage des images clé du niveau de priorité donné, et d'interpolation des autres images à partir de ces images clés.  The next step E6 is the calculation of the global decoding cost cck of each priority level Pk with k an integer varying between 1 and 8. The global decoding cost cck of a priority level Pk is the decoding cost of the images key of the given priority level, and interpolation of the other images from these keyframes.

Pour cela, un outil informatique d'analyse de programme, tel que celui nommé Quantify de la société Rational Software Corporation, décrit à l'adresse Internet http:l/www.rational.comlproductslquantify ntl, détermine le nombre d'opérations élémentaires effectuées lors de l'exécution du programme et le temps d'exécution du programme.  For this, a computer program analysis tool, such as the one called Quantify from Rational Software Corporation, described on the Internet address http: / / www.rational.comlproductslquantify ntl, determines the number of elementary operations performed during the execution of the program and the execution time of the program.

Le nombre d'opérations élémentaires effectuées par seconde est alors calculé en divisant le premier résultat par le second.  The number of elementary operations performed per second is then calculated by dividing the first result by the second.

En variante, la commande Time dans les systèmes d'exploitation Unix et Linux permet de déterminer le coût calculatoire d'un programme.  Alternatively, the Time command in Unix and Linux operating systems can determine the computational cost of a program.

Un mode de réalisation de l'étape E6 est détaillé dans la suite.  An embodiment of step E6 is detailed below.

L'étape suivante E7 est la mémorisation des données relatives à l'animation dans un fichier FIM représenté à la figure 5. Ce fichier comporte, pour chaque image clé IM,, l'indexation n, la suite de requêtes JPIP la priorité Pr, et l'instant d'affichage Tn.  The next step E7 is the storage of the data relating to the animation in a FIM file represented in FIG. 5. This file comprises, for each key image IM ,, the indexing n, the sequence of requests JPIP the priority Pr, and the instant of display Tn.

Il comporte en outre le coût calculatoire cck de chaque niveau de priorité.  It also includes the computational cost cck of each priority level.

L'étape suivante E8 est la mémorisation du fichier précédent sur le serveur.  The next step E8 is the storage of the previous file on the server.

L'étape E6 de détermination d'un coût calculatoire pour chaque niveau de priorité d'une animation est maintenant détaillée en référence à la figure 6, sous la forme d'un algorithme comportant des étapes E60 à E64.  The step E6 of determining a computational cost for each priority level of an animation is now detailed with reference to FIG. 6, in the form of an algorithm comprising steps E60 to E64.

L'étape E60 est une initialisation à laquelle une variable k est initialisé à la valeur un. La variable k représente le niveau de priorité courant.  Step E60 is an initialization to which a variable k is initialized to the value one. The variable k represents the current priority level.

L'étape suivante E61 est un test pour déterminer si la variable k est inférieure ou égale au nombre de niveaux de priorité. Si la réponse est positive, Cette étape est suivie de l'étape E62 à laquelle le coût calculatoire Ck de décodage de l'animation en ne considérant que les niveaux de priorité de 1 à k est calculé. Comme précédemment exposé, ce coût est calculé avec un outil d'analyse de programme connu en soit.  The next step E61 is a test to determine if the variable k is less than or equal to the number of priority levels. If the answer is positive, this step is followed by the step E62 at which the computational cost Ck of decoding the animation by considering only the priority levels from 1 to k is calculated. As previously stated, this cost is calculated with a program analysis tool known in itself.

L'étape suivante E63 est le calcul du coût calculatoire cck du niveau courant. Pour cela, le coût calculatoire Ck calculé à l'étape précédente est diminué du coût calculatoire Ck-1 calculé lors de l'itération précédente. Bien entendu, lors du premier passage par cette étape (k=1), la quantité Ck_1 est nulle.  The next step E63 is the calculation of the computational cost cck of the current level. For this, the computational cost Ck calculated in the previous step is reduced by the computational cost Ck-1 calculated during the previous iteration. Of course, during the first pass through this step (k = 1), the quantity Ck_1 is zero.

A l'étape suivante E64, la variable k est incrémentée de une unité. Cette étape est suivie de l'étape E61 précédemment décrite.  In the next step E64, the variable k is incremented by one unit. This step is followed by step E61 previously described.

Lorsque la réponse est négative à l'étape E61, les coûts calculatoire de tous les niveaux de priorité de l'animation ont été déterminés.  When the answer is negative in step E61, the computational costs of all the priority levels of the animation have been determined.

La figure 7 représente un premier mode de réalisation de procédé de téléchargement d'une animation, selon l'invention. Ce procédé est mis en oeuvre dans le terminal client 2 et comporte des étapes E10 à E19.  FIG. 7 represents a first embodiment of a method of downloading an animation, according to the invention. This method is implemented in the client terminal 2 and comprises steps E10 to E19.

Le procédé est réalisé sous la forme d'un algorithme qui peut être mémorisé en totalité ou en partie dans tout moyen de stockage d'information capable de coopérer avec le microprocesseur. Ce moyen de stockage est lisible par un ordinateur ou par un microprocesseur. Ce moyen de stockage est intégré ou non au dispositif, et peut être amovible. Par exemple, il peut comporter une bande magnétique, une disquette ou un CD-ROM (disque compact à mémoire figée).  The method is embodied in the form of an algorithm that can be stored in whole or in part in any information storage means capable of cooperating with the microprocessor. This storage means is readable by a computer or a microprocessor. This storage means is integrated or not to the device, and can be removable. For example, it may comprise a magnetic tape, a floppy disk or a CD-ROM (compact disk with frozen memory).

L'étape El0 est l'envoi d'une requête au serveur pour obtenir le fichier de description de l'animation.  Step El0 is sending a request to the server to obtain the description file of the animation.

L'étape suivante El 1 est la réception du fichier de description.  The next step El 1 is the reception of the description file.

L'étape suivante E12 est la recherche du niveau de priorité le plus élevé possible en fonction du coût de décodage de chaque niveau de priorité et des capacités de traitement du terminal client. Cette étape est détaillée dans la suite.  The next step E12 is the search for the highest priority level possible according to the decoding cost of each priority level and the processing capabilities of the client terminal. This step is detailed below.

L'étape suivante E13 est un test de compatibilité de l'animation avec le terminal client. Si aucun niveau de priorité n'est compatible avec le terminal client, une variable logique COMP est mise à la valeur faux . Sinon, cette variable est mise à la valeur vrai .  The next step E13 is a compatibility test of the animation with the client terminal. If no priority level is compatible with the client terminal, a logical variable COMP is set to false. Otherwise, this variable is set to true.

L'étape suivante E14 est un test sur la valeur de la variable logique 15 COMP.  The next step E14 is a test on the value of the logical variable COMP.

Si elle indique une incompatibilité, cette étape est suivie de l'étape El 5 qui est l'affichage d'un message d'erreur.  If it indicates an incompatibility, this step is followed by step El 5 which is the display of an error message.

S'il y a compatibilité à l'étape E14, cette étape est suivie de l'étape E16 qui est l'émission des requêtes JPIP correspondant au niveau de priorité 20 précédemment déterminé. L'étape suivante E17 est la réception et le décodage des données reçues en  If there is compatibility in step E14, this step is followed by step E16 which is the sending of JPIP requests corresponding to the level of priority 20 previously determined. The next step E17 is the reception and decoding of the data received in

réponse aux requêtes émises.response to queries issued.

L'étape suivante E18 est une interpolation entre les images clés reçues, si elle est nécessaire pour pouvoir jouer l'animation à 25 images par seconde. L'interpolation est classique. Elle est pondérée en fonction de la distance entre l'image interpolée et les images clés utilisée pour l'interpolation.  The next step E18 is an interpolation between the received keyframes, if it is necessary to be able to play the animation at 25 frames per second. The interpolation is classic. It is weighted according to the distance between the interpolated image and the keyframes used for the interpolation.

L'étape suivante E19 est l'affichage de l'animation à une fréquence de 25 images par seconde sur le terminal client.  The next step E19 is the display of the animation at a rate of 25 frames per second on the client terminal.

L'étape E12 de recherche du niveau de priorité le plus élevé possible en fonction du coût de décodage de chaque niveau de priorité et des capacités de traitement du terminal client est maintenant détaillée en référence à la figure 8, sous la forme d'un algorithme comportant des étapes E120 à E126.  The search step E12 of the highest priority level possible according to the decoding cost of each priority level and the processing capabilities of the client terminal is now detailed with reference to FIG. 8, in the form of an algorithm having steps E120 to E126.

L'étape E120 est une initialisation à laquelle le nombre K de niveaux de priorités définis dans l'animation est lu. Une variable k est initialisée à un. La variable k représente un niveau de priorité courant. Une variable C est aussi initialisée à la valeur zéro. La variable C représente le cumul des coûts calculatoires des différents niveaux.  Step E120 is an initialization at which the number K of priority levels defined in the animation is read. A variable k is initialized to one. The variable k represents a current priority level. A variable C is also initialized to the value zero. Variable C represents the cumulative computational costs of the different levels.

La capacité de calcul CPU du terminal client exprimée en nombre d'opérations élémentaires par secondes est lue dans la mémoire 112.  The CPU calculation capacity of the client terminal expressed as the number of elementary operations per second is read in the memory 112.

L'étape suivante E121 est un test pour déterminer s'il reste au moins un niveau de priorité à considérer. Si la réponse est positive, cette étape est suivie de l'étape E122 à laquelle le cumul C des coûts calculatoires est augmenté du coût calculatoire du niveau de priorité courant.  The next step E121 is a test to determine if there is still at least one priority level to consider. If the answer is positive, this step is followed by the step E122 in which the cumulation C of the computational costs is increased by the computational cost of the current priority level.

L'étape suivante E123 est un test pour déterminer si le coût calculatoire C est inférieur à la capacité de calcul CPU du terminal client. Si la réponse est positive, cela signifie que le terminal client a une capacité supérieure au coût calculatoire déterminé. Cette étape est alors suivie de l'étape E124 à laquelle la variable k est incrémentée de une unité pour considérer un niveau de priorité suivant.  The next step E123 is a test to determine whether the computational cost C is less than the CPU capacity of the client terminal. If the answer is positive, it means that the client terminal has a capacity greater than the determined computational cost. This step is then followed by the step E124 at which the variable k is incremented by one unit to consider a next priority level.

L'étape E124 est suivie de l'étape E121 précédemment décrite.  Step E124 is followed by step E121 previously described.

Lorsque la réponse est négative à l'étape E123, cela signifie que la capacité de calcul du terminal client est inférieure au coût calculatoire déterminé. Dans ce cas, l'étape E123 est suivie de l'étape E125, à laquelle les requêtes JPIP correspondant aux niveaux de priorité de rangs inférieurs à celui du niveau courant Pk sont transmises à l'interface de communication du terminal client.  When the answer is negative in step E123, this means that the computing capacity of the client terminal is lower than the computed cost determined. In this case, the step E123 is followed by the step E125, in which the JPIP requests corresponding to the priority levels of ranks lower than that of the current level Pk are transmitted to the communication interface of the client terminal.

Lorsque la réponse est négative à l'étape E121 cela signifie que la capacité de calcul du terminal client est supérieure au coût calculatoire de tous les niveaux de priorités de l'animation. Dans ce cas, l'étape E121 est suivie de l'étape E126, à laquelle les requêtes JPIP correspondant à tous les niveaux de priorité de l'animation sont transmises à l'interface de communication du terminal client.  When the answer is negative in step E121, this means that the computing capacity of the client terminal is greater than the computational cost of all the priority levels of the animation. In this case, the step E121 is followed by the step E126, to which the JPIP requests corresponding to all the priority levels of the animation are transmitted to the communication interface of the client terminal.

La figure 9 représente un second mode de réalisation de procédé de création d'une animation, selon l'invention. Ce procédé est mis en oeuvre dans le dispositif de création et comporte des étapes E20 à E28.  FIG. 9 represents a second embodiment of a method for creating an animation, according to the invention. This method is implemented in the creation device and comprises steps E20 to E28.

Le procédé est réalisé sous la forme d'un algorithme qui peut être mémorisé en totalité ou en partie dans tout moyen de stockage d'information capable de coopérer avec le microprocesseur. Ce moyen de stockage est lisible par un ordinateur ou par un microprocesseur. Ce moyen de stockage est intégré ou non au dispositif, et peut être amovible. Par exemple, il peut comporter une bande magnétique, une disquette ou un CD-ROM (disque compact à mémoire figée).  The method is embodied in the form of an algorithm that can be stored in whole or in part in any information storage means capable of cooperating with the microprocessor. This storage means is readable by a computer or a microprocessor. This storage means is integrated or not to the device, and can be removable. For example, it may comprise a magnetic tape, a floppy disk or a CD-ROM (compact disk with frozen memory).

L'étape E20 est la définition de plusieurs classes de terminaux clients. L'utilisateur dispose d'une interface graphique pour sélectionner différentes valeurs de bandes passantes représentant le débit effectif entre le serveur et un terminal client. Par exemple, trois classes CL1, CL2 et CL3 sont créées.  Step E20 is the definition of several classes of client terminals. The user has a graphical interface to select different bandwidth values representing the actual throughput between the server and a client terminal. For example, three classes CL1, CL2 and CL3 are created.

L'étape suivante E21 est la mémorisation des seuils de bande passante définissant les classes de terminaux clients.  The next step E21 is the storage of the bandwidth thresholds defining the client terminal classes.

L'étape suivante E22 est la sélection et la définition des images clés IMn de l'animation. Une ou plusieurs images codées selon la norme JPEG2000 sont sélectionnées, et des images clés sont formées. La construction des images clés peut être faite avec une interface graphique du type de celle présentée dans le premier mode de réalisation. En variante, la construction des images clés peut être faite grâce à un outil de création de contenu tel que le logiciel Flash MX de création de contenu au format flash de la société Macromedia. Cet outil est disponible via Internet à l'adresse: http://www.macromedia. com/software/flash/.  The next step E22 is the selection and definition of the IMn keyframes of the animation. One or more images encoded according to the JPEG2000 standard are selected, and keyframes are formed. The construction of the keyframes can be done with a graphical interface of the type of that presented in the first embodiment. Alternatively, the construction of the keyframes can be done through a content authoring tool such as Macromedia Flash content creation software Flash MX. This tool is available via the Internet at: http: //www.macromedia. com / software / flash /.

Le livre intitulé Flash MX de Guylaine Monnier, aux éditions Dunod, Paris, 2002, décrit ce logiciel.  The book entitled Flash MX by Guylaine Monnier, published by Dunod, Paris, 2002, describes this software.

Un instant d'affichage Tn pour chaque image clé est déterminé. Un instant d'affichage est un temps en secondes, déterminé à partir du début de l'animation.  A display time Tn for each keyframe is determined. An instant of display is a time in seconds, determined from the beginning of the animation.

L'étape suivante E23 est le calcul du coût de transmission de chaque image clé 1Mn. Le coût de transmission d'une image clé IMn est le débit Dn nécessaire à la transmission. Le débit Dn est égal à FxSn, où F est la résolution temporelle de l'animation, exprimée en s"' et Sn est la taille de l'image clé considérée, exprimée en bits.  The next step E23 is the calculation of the transmission cost of each key image 1Mn. The transmission cost of a key image IMn is the Dn rate required for transmission. The rate Dn is equal to FxSn, where F is the temporal resolution of the animation, expressed in s "and Sn is the size of the key image considered, expressed in bits.

Les coûts de transmission sont mémorisés à cette étape.  Transmission costs are stored in this step.

L'étape suivante E24 est une détection des éventuelles images clés posant un problème de transmission.  The next step E24 is a detection of any key images posing a transmission problem.

Pour chaque classe de clients, correspondant à une bande passante maximale, on recherche s'il existe des images qui dépassent la bande passante maximale de sorte que le temps de transmission entre le serveur et un terminal client soit incompatible avec un affichage de bonne qualité de l'animation sur le terminal client.  For each class of clients, corresponding to a maximum bandwidth, it is investigated whether there are images that exceed the maximum bandwidth so that the transmission time between the server and a client terminal is incompatible with a display of good quality. the animation on the client terminal.

Cette étape est détaillée dans la suite. Elle a pour résultat une liste L 15 d'images non compatibles avec les bandes passantes maximales des différentes classes.  This step is detailed below. It results in a list L15 of images not compatible with the maximum bandwidths of the different classes.

L'étape suivante E25 est le calcul, pour chaque image de la liste L, d'un ensemble de couples (débit, distorsion) pour chaque version (résolution, qualité) de l'image. Cette étape est détaillée dans la suite.  The next step E25 is the calculation, for each image in the list L, of a set of couples (bit rate, distortion) for each version (resolution, quality) of the image. This step is detailed below.

L'étape suivante E26 est le calcul des requêtes JPIP de chaque image clé IMn, qui permettront à chaque classe CL1 à CL3 de clients d'obtenir la version de l'image clé adaptée à la bande passante dont il dispose.  The next step E26 is the calculation of the JPIP requests of each key image IMn, which will allow each class CL1 to CL3 of clients to obtain the version of the keyframe adapted to the bandwidth which it has.

Pour une image clé donnée, il faut récupérer les informations relatives à la taille, la résolution, la qualité, et la zone éventuellement sélectionnée dans l'image clé. II faut ensuite vérifier si cette image clé appartient à la liste L des images clés posant un problème de transmission.  For a given keyframe, it is necessary to retrieve the information relating to the size, the resolution, the quality, and the zone possibly selected in the keyframe. It is then necessary to check if this key image belongs to the list L of the key images posing a transmission problem.

Si l'image clé courante n'appartient pas à la liste L, les informations précédentes sont insérées dans les champs de données des requêtes JPIP.  If the current keyframe does not belong to the list L, the previous information is inserted into the data fields of the JPIP queries.

Si l'image clé courante appartient à la liste L, alors les requêtes JPIP associées portent sur une version dégradée de l'image clé, et non sur l'image clé initiale.  If the current keyframe belongs to the list L, then the associated JPIP queries concern a degraded version of the keyframe, and not the initial keyframe.

On considère les classes les unes après les autres. Pour une classe donnée correspondant à une bande passante donnée, et pour une image clé donnée, on considère la version (résolution et qualité) de cette image dont le débit est compatible avec la bande passante et dont la distorsion est minimale.  Classes are considered one after the other. For a given class corresponding to a given bandwidth, and for a given keyframe, consider the version (resolution and quality) of this image whose bit rate is compatible with the bandwidth and whose distortion is minimal.

Cette version est obtenue en résultat de l'étape précédente E25.  This version is obtained as a result of the previous step E25.

La requête JPIP de cette version est formée et mémorisée dans le fichier de description.  The JPIP request of this version is formed and stored in the description file.

L'étape suivante E27 est la mémorisation des données relatives à l'animation dans un fichier FF représenté à la figure 10. Ce fichier comporte, pour chaque image clé IMn, l'indexation n, la suite de requêtes JPIP Rn1, Rn2,... classées en fonction des classes de terminaux clients et l'instant d'affichage Tn.  The next step E27 is the storage of the data relating to the animation in an FF file represented in FIG. 10. This file comprises, for each key image IMn, indexing n, the sequence of JPIP requests Rn1, Rn2 ,. .. classified according to the client terminal classes and the display time Tn.

Il comporte en outre la définition des classes CL1 à CL3.  It further includes the definition of classes CL1 to CL3.

L'étape suivante E28 est la mémorisation du fichier FF sur le serveur.  The next step E28 is the storage of the FF file on the server.

Un mode de réalisation de l'étape E24 de détermination des images qui ne respectent pas la bande passante est décrit en référence à la figure 11, sous la forme d'un algorithme comportant des étapes E240 à E250.  An embodiment of step E24 for determining images that do not respect the bandwidth is described with reference to FIG. 11, in the form of an algorithm comprising steps E240 to E250.

L'étape E240 est la lecture de la valeur de la fréquence F d'affichage des images de l'animation.  Step E240 is the reading of the value of the frequency F of display of the images of the animation.

L'étape suivante E241 est la création d'une liste L vide. La liste L est associée à un tableau T illustré à la figure 12, contenant des données sur chaque image dépassant l'une des bandes passantes maximales des classes de clients.  The next step E241 is the creation of an empty L list. The list L is associated with a table T illustrated in FIG. 12, containing data on each image exceeding one of the maximum bandwidths of the client classes.

Pour chaque image de la liste L, les données suivantes sont mémorisées dans le tableau T: - l'indice temporel de l'image, - l'indice de la classe de client de bande passante la plus faible possible pour laquelle l'image ne pose pas de problème, - sa taille en octets, - la taille à laquelle le créateur de l'animation souhaite afficher l'image dans l'animation, 2888962 20 - le niveau de qualité Qumax fixé par le créateur.  For each image in the list L, the following data are stored in the table T: the time index of the image, the index of the lowest possible bandwidth client class for which the image is not poses no problem, - its size in bytes, - the size at which the creator of the animation wishes to display the image in the animation, 2888962 20 - the quality level Qumax set by the creator.

Une variable i est initialisée à la valeur un. La variable i représente l'indice de la classe de clients courante CL;. On considère tout d'abord la classe correspondant à la bande passante la plus faible, puis les classes par bande passante croissante.  A variable i is initialized to the value one. The variable i represents the index of the current CL client class ;. We first consider the class corresponding to the lowest bandwidth, then the classes with increasing bandwidth.

L'étape suivante E242 est la lecture de la valeur de la bande passante maximale BPmax associée à la classe courante CL;. En outre, une bande passante disponible LBP est due au faible coût de transmission des paramètres d'interpolation entre deux images clés. La bande passante disponible ABP dépend de la bande passante maximale BPmax courante, du nombre d'images interpolées entre deux images clés, du nombre de bits nécessaire pour représenter les paramètres d'interpolation et de la fréquence de l'animation.  The next step E242 is the reading of the value of the maximum bandwidth BPmax associated with the current class CL; In addition, an available bandwidth LBP is due to the low cost of transmitting the interpolation parameters between two keyframes. The available bandwidth ABP depends on the current maximum bandwidth BPmax, the number of interpolated images between two keyframes, the number of bits needed to represent the interpolation parameters and the frequency of the animation.

L'étape suivante E243 est une initialisation à laquelle un paramètre m est initialisé pour considérer la première image clé IMm posant un problème de transmission pour la classe traitée à l'itération précédente. Lors du premier passage par cette étape, on considère la première image clé de l'animation.  The next step E243 is an initialization at which a parameter m is initialized to consider the first key image IMm posing a transmission problem for the class processed at the previous iteration. During the first pass through this step, we consider the first keyframe of the animation.

L'étape suivante E244 est la lecture de la taille Dm en octets de l'image courante.  The next step E244 is reading the size Dm in bytes of the current image.

L'étape suivante E245 est un test pour déterminer si l'image courante respecte la bande passante BPmax. Il s'agit de vérifier si l'image peut être transmise en un temps inférieur à 11F. Pour cela, on vérifie si l'inégalité : F.Dm < BPmax + L1sP est vérifiée.  The next step E245 is a test to determine if the current image respects the BPmax bandwidth. This is to check if the image can be transmitted in less than 11F. For this, we check if the inequality: F.Dm <BPmax + L1sP is checked.

Si la réponse est négative, cela signifie que l'image courante IMm ne respecte pas la bande passante. Dans ce cas, l'étape E245 est suivie de l'étape E246 à laquelle l'image courante IMm est inscrite dans la liste L, avec les données énoncées précédemment.  If the answer is negative, it means that the IMm current image does not respect the bandwidth. In this case, the step E245 is followed by the step E246 in which the current image IMm is entered in the list L, with the data previously stated.

Si la réponse est positive à l'étape E245, cela signifie que l'image courante IMm respecte la bande passante. Dans ce cas, l'étape E245 est suivie 30 de l'étape E247 qui est un test pour vérifier s'il reste au moins une image clé de l'animation à traiter.  If the answer is positive in step E245, this means that the current image IMm respects the bandwidth. In this case, step E245 is followed by step E247 which is a test to check if there is at least one keyframe of the animation to be processed.

Si la réponse est positive, alors cette étape est suivie de l'étape E248 pour considérer l'image clé suivante. L'étape E248 est suivie de l'étape E244 précédemment décrite.  If the answer is positive, then this step is followed by step E248 to consider the next keyframe. Step E248 is followed by step E244 previously described.

Si la réponse est négative à l'étape E247, alors cette étape est suivie 5 de l'étape E249 qui est un test pour déterminer si la liste L est vide pour la classe courante et s'il reste au moins une classe à traiter.  If the answer is negative in step E247, then this step is followed by step E249 which is a test to determine if the list L is empty for the current class and if there is still at least one class to be processed.

Tant que la réponse est négative à ces deux tests, l'étape E249 est suivie de l'étape E250 pour considérer la classe suivante.  As long as the answer is negative to these two tests, step E249 is followed by step E250 to consider the next class.

L'étape E250 est suivie de l'étape E242 précédemment décrite.  Step E250 is followed by step E242 previously described.

Lorsque la réponse est positive à au moins l'un des deux tests de l'étape E249, le traitement est terminé.  When the response is positive to at least one of the two tests of step E249, the processing is complete.

Un mode de réalisation de l'étape E25 d'estimation de la qualité de différentes versions d'une image de la liste L est décrit en référence à la figure 15 13, sous la forme d'un algorithme comportant des étapes E300 à E315.  An embodiment of step E25 for estimating the quality of different versions of an image of list L is described with reference to FIG. 13, in the form of an algorithm comprising steps E300 to E315.

On considère ici une image de la liste L. L'étape E300 est la lecture de l'indice temporel de cette image. L'étape suivante E301 est la lecture de l'image codée. Un décodeur JPEG2000 récupère alors des informations haut niveau relatives à cette image.  An image of the list L is considered here. The step E300 is the reading of the temporal index of this image. The next step E301 is the reading of the coded picture. A JPEG2000 decoder then retrieves high level information relating to this image.

Ces informations sont: - la résolution spatiale maximale de l'image HxW, où H et W sont la hauteur et la largeur de l'image exprimées en nombre de pixels.  This information is: - the maximum spatial resolution of the image HxW, where H and W are the height and the width of the image expressed in number of pixels.

- le nombre de niveau de résolution Rmax utilisés pour représenter l'image.  the number of Rmax resolution level used to represent the image.

L'étape suivante E302 est le calcul de la taille de l'image et du nombre de niveaux de résolution qui sont utilisés dans le traitement suivant. La taille est fournie par les formules: h = min(H, hu) w = min(W, wu) où hu et wu sont la hauteur et la largeur de l'image exprimées en nombre de pixels, fixées par le créateur de l'animation.  The next step E302 is the calculation of the image size and the number of resolution levels that are used in the next processing. The size is given by the formulas: h = min (H, hu) w = min (W, wu) where hu and wu are the height and the width of the image expressed in number of pixels, fixed by the creator of the 'animation.

Le nombre de niveaux de résolution est fourni par les formules: Rumax = min(R(h, w), Rmax), Où R(h, w) est le niveau de résolution pour lequel l'image a une hauteur et une largeur respectivement inférieure ou égale à la hauteur h et à la 5 largeur w.  The number of levels of resolution is provided by the formulas: Rumax = min (R (h, w), Rmax), where R (h, w) is the level of resolution for which the image has a height and a width respectively less than or equal to the height h and the width w.

L'étape suivante E303 est le décodage de l'image à la résolution Rumax et au niveau de qualité Qumax.  The next step E303 is the decoding of the image at the Rumax resolution and the Qumax quality level.

L'étape suivante E304 est la mémorisation de l'image ainsi décodée et reconstruite Iv(Rumax, Qumax) pour servir d'image de référence.  The next step E304 is the storage of the image thus decoded and reconstructed Iv (Rumax, Qumax) to serve as a reference image.

L'étape suivante E305 est une initialisation à laquelle deux variables R et Q sont initialisées à la valeur zéro. La variable R représente le niveau de résolution courant et la variable Q représente le niveau de qualité courant. La valeur zéro pour ces deux variables correspond aux niveaux de résolution et de qualité les plus bas.  The next step E305 is an initialization in which two variables R and Q are initialized to the value zero. The variable R represents the current resolution level and the variable Q represents the current quality level. The zero value for these two variables corresponds to the lowest resolution and quality levels.

L'étape suivante E306 est l'obtention de l'image Iv(R, Q) correspondant au niveau de résolution courant R et au niveau de qualité courant Q. L'image Iv(R, Q) est obtenue par une requête JPIP.  The next step E306 is obtaining the image Iv (R, Q) corresponding to the current resolution level R and to the current quality level Q. The image Iv (R, Q) is obtained by a JPIP request.

L'étape suivante E307 est la mémorisation de données 20 correspondant à l'image Iv(R, Q) dans le tableau T associé à la liste L (figure 12).  The next step E307 is the data storage 20 corresponding to the image Iv (R, Q) in the table T associated with the list L (FIG. 12).

Ces données sont: - la taille D(Iv(R, Q)) de l'image Iv(R, Q), exprimée en octets, - le niveau de résolution courant R, - le niveau de qualité courant Q. L'étape suivante E308 est le décodage de l'image courante Iv(R, Q). L'étape suivante E309 est un agrandissement de l'image courante décodée pour former une image agrandie Iv(Rumax, Q) à la résolution Rumax.  These data are: - the size D (Iv (R, Q)) of the image Iv (R, Q), expressed in bytes, - the current resolution level R, - the current quality level Q. The step next E308 is the decoding of the current image Iv (R, Q). The next step E309 is an enlargement of the decoded current image to form an enlarged image Iv (Rumax, Q) at the Rumax resolution.

Bien entendu, si les résolutions R et Rumax sont égales, il n'y a pas d'agrandissement.  Of course, if the R and Rumax resolutions are equal, there is no magnification.

L'étape suivante E310 est une comparaison de l'image agrandie Iv(Rumax, Q) avec l'image de référence Iv(Rumax, Qumax). Ainsi, la dégradation de qualité de l'animation est estimée, dans le cas du remplacement de l'image de référence par l'image agrandie Iv(Rumax, Q).  The next step E310 is a comparison of the enlarged image Iv (Rumax, Q) with the reference image Iv (Rumax, Qumax). Thus, the quality degradation of the animation is estimated, in the case of the replacement of the reference image by the enlarged image Iv (Rumax, Q).

Cette estimation est par exemple l'écart quadratique moyen entre les deux images. A l'étape E311, le résultat Dist(Iv(R, Q)) de l'estimation est mémorisé dans le tableau T associé à la liste L (figure 12).  This estimate is for example the mean square deviation between the two images. In step E311, the result Dist (Iv (R, Q)) of the estimate is stored in the table T associated with the list L (FIG. 12).

L'étape suivante E312 est un test pour déterminer si la qualité courante Q est strictement inférieure à la valeur Qumax. Si la réponse est positive, alors cette étape est suivie de l'étape E313 à laquelle la qualité Q est incrémentée de une unité. L'étape E313 est suivie de l'étape E306 précédemment décrite.  The next step E312 is a test to determine if the current quality Q is strictly less than the Qumax value. If the answer is positive, then this step is followed by step E313 at which the quality Q is incremented by one. Step E313 is followed by step E306 previously described.

Si la réponse est négative à l'étape E312, alors cette étape est suivie de l'étape E314, qui est un test pour déterminer si la résolution courante R est strictement inférieure à la valeur Rumax. Si la réponse est positive, alors cette étape est suivie de l'étape E315 à laquelle la résolution R est incrémentée de une unité et la qualité courante Q est mise à la valeur zéro. L'étape E315 est suivie de l'étape E306 précédemment décrite.  If the answer is negative in step E312, then this step is followed by step E314, which is a test to determine if the current resolution R is strictly less than the Rumax value. If the answer is positive, then this step is followed by the step E315 at which the resolution R is incremented by one unit and the current quality Q is set to zero. Step E315 is followed by step E306 previously described.

Si la réponse est négative à l'étape E314, alors toutes les versions possibles de l'image considérée de la liste L ont été déterminées.  If the answer is negative in step E314, then all possible versions of the considered image of the list L have been determined.

Ce traitement est répété pour toutes les images de la liste L. 20 La figure 14 représente un second mode de réalisation de procédé de téléchargement d'une animation, selon l'invention. Ce procédé est mis en oeuvre dans le terminal client 2 et comporte des étapes E500 à E510.  This processing is repeated for all the images in the list L. FIG. 14 represents a second embodiment of a method of downloading an animation, according to the invention. This method is implemented in the client terminal 2 and comprises steps E500 to E510.

Le procédé est réalisé sous la forme d'un algorithme qui peut être mémorisé en totalité ou en partie dans tout moyen de stockage d'information capable de coopérer avec le microprocesseur. Ce moyen de stockage est lisible par un ordinateur ou par un microprocesseur. Ce moyen de stockage est intégré ou non au dispositif, et peut être amovible. Par exemple, il peut comporter une bande magnétique, une disquette ou un CD-ROM (disque compact à mémoire figée).  The method is embodied in the form of an algorithm that can be stored in whole or in part in any information storage means capable of cooperating with the microprocessor. This storage means is readable by a computer or a microprocessor. This storage means is integrated or not to the device, and can be removable. For example, it may comprise a magnetic tape, a floppy disk or a CD-ROM (compact disk with frozen memory).

L'étape E500 est l'envoi d'une requête au serveur pour obtenir le fichier de description de l'animation.  Step E500 is sending a request to the server to obtain the description file of the animation.

L'étape suivante E501 est la réception du fichier de description.  The next step E501 is the reception of the description file.

L'étape suivante E502 est la récupération de la bande passante effective du terminal client 2. Cette opération est effectuée soit à partir d'un fichier de configuration, soit par demande à l'utilisateur au moyen d'une interface graphique.  The next step E502 is the recovery of the effective bandwidth of the client terminal 2. This operation is performed either from a configuration file or by request to the user by means of a graphical interface.

L'étape suivante E503 est une identification de la classe du terminal client à partir de la description de l'animation et en fonction de sa bande passante. Les versions des images clés correspondant à la classe du terminal client sont sélectionnées.  The next step E503 is an identification of the class of the client terminal from the description of the animation and according to its bandwidth. The keyframe versions corresponding to the client terminal class are selected.

L'étape suivante E504 est un test de compatibilité de l'animation avec le terminal client. Si le terminal client ne dispose pas d'une bande passante suffisante pour l'animation, une variable logique COMP est mise à la valeur faux . Sinon, cette variable est mise à la valeur vrai .  The next step E504 is a compatibility test of the animation with the client terminal. If the client terminal does not have enough bandwidth for the animation, a logical variable COMP is set to false. Otherwise, this variable is set to true.

L'étape suivante E505 est un test sur la valeur de la variable logique 15 COMP.  The next step E505 is a test on the value of the logical variable COMP.

Si elle indique une incompatibilité, cette étape est suivie de l'étape E506 qui est l'affichage d'un message d'erreur.  If it indicates an incompatibility, this step is followed by the step E506 which is the display of an error message.

S'il y a compatibilité à l'étape E505, cette étape est suivie de l'étape E507 qui est l'émission des requêtes JPIP correspondant à la classe 20 précédemment déterminée.  If there is compatibility in step E505, this step is followed by step E507 which is the issuing of JPIP requests corresponding to the class 20 previously determined.

L'étape suivante E508 est la réception et le décodage des données reçues en réponse aux requêtes émises.  The next step E508 is the reception and decoding of the received data in response to the transmitted requests.

L'étape suivante E509 est une interpolation entre les images clés reçues, si elle est nécessaire pour pouvoir jouer l'animation à 25 images par 25 seconde.  The next step E509 is an interpolation between the received keyframes, if it is necessary to be able to play the animation at 25 frames per 25 seconds.

L'étape suivante E510 est l'affichage de l'animation à une fréquence de 25 images par seconde sur le terminal client.  The next step E510 is the display of animation at a rate of 25 frames per second on the client terminal.

Bien entendu, la présente invention n'est nullement limitée aux 30 modes de réalisation décrits et représentés, mais englobe, bien au contraire, toute variante à la portée de l'homme du métier.  Of course, the present invention is not limited to the embodiments described and shown, but encompasses, on the contrary, any variant within the scope of those skilled in the art.

En particulier, les deux modes de réalisation sont combinables. On tient compte lors de la création de l'animation de la bande passante des terminaux clients puis on affecte un niveau de priorité à chaque image clé.  In particular, the two embodiments are combinable. We take into account when creating the bandwidth animation of the client terminals and assign a priority level to each key image.

Claims (24)

REVENDICATIONS 1. Procédé de création d'une animation comportant des images clés, caractérisé en ce qu'il comporte les étapes de: - détermination (E3, E4, E6) d'une pluralité de versions de l'animation en fonction d'au moins un critère correspondant à au moins une caractéristique du client susceptible de télécharger l'animation, - création (E7) d'un fichier comportant une description des différentes versions déterminées et leur critère associé.  A method of creating an animation comprising keyframes, characterized in that it comprises the steps of: determining (E3, E4, E6) a plurality of versions of the animation according to at least a criterion corresponding to at least one characteristic of the client able to download the animation, - creation (E7) of a file comprising a description of the different versions determined and their associated criterion. 2. Procédé de création d'une animation selon la revendication 1, caractérisé en ce que l'étape de détermination comporte les étapes de: affectation (E3) d'un niveau de priorité à chaque image clé, - calcul (E6) d'un coût de décodage global des images clés de chaque niveau de priorité.  2. A method of creating an animation according to claim 1, characterized in that the determining step comprises the steps of: assigning (E3) a priority level to each keyframe, - calculating (E6) of a global decoding cost of the keyframes of each priority level. 3. Procédé de création d'une animation selon la revendication 2, 20 caractérisé en ce qu'une version de l'animation comporte des images clés auxquelles un même niveau de priorité a été affecté.  3. A method of creating an animation according to claim 2, characterized in that a version of the animation comprises keyframes to which the same level of priority has been assigned. 4. Procédé de création d'une animation selon l'une quelconque des revendications 1 à 3, caractérisé en ce que l'étape de détermination comporte 25 les étapes de: - détermination (E20) de plusieurs classes de terminaux clients en fonction de leur bande passante, - détermination (E24, E25) d'une version de chaque image clé pour chaque classe de terminaux clients.  4. A method of creating an animation according to any one of claims 1 to 3, characterized in that the determining step comprises the steps of: - determining (E20) of several classes of client terminals according to their bandwidth, - determining (E24, E25) a version of each keyframe for each class of client terminals. 5. Procédé de création d'une animation selon l'une quelconque des revendications 1 à 4, caractérisé en ce que l'étape de création (E4, E26) comporte la détermination de requêtes pour chaque image clé, destinées à obtenir chaque image clé depuis un terminal distant.  5. A method of creating an animation according to any one of claims 1 to 4, characterized in that the creation step (E4, E26) comprises the determination of requests for each keyframe, intended to obtain each key image from a remote terminal. 6. Procédé selon la revendication 5, caractérisé en ce que les 5 requêtes sont de type JPIP.  6. Method according to claim 5, characterized in that the 5 requests are JPIP type. 7. Procédé de téléchargement d'une animation depuis un serveur vers un terminal client, l'animation ayant été créée par le procédé de création selon l'une quelconque des revendications 1 à 6, caractérisé en ce qu'il comporte les étapes de: - réception (E11, E501) de la description des différentes versions de l'animation, - sélection (E12, E503) d'une version de l'animation en fonction d'au moins une caractéristique du terminal client, - émission ((E16, E507) de requêtes en fonction de la version sélectionnée.  7. A method of downloading an animation from a server to a client terminal, the animation having been created by the creation method according to any one of claims 1 to 6, characterized in that it comprises the steps of: - reception (E11, E501) of the description of the different versions of the animation, - selection (E12, E503) of a version of the animation according to at least one characteristic of the client terminal, - transmission ((E16 , E507) of requests based on the selected version. 8. Procédé de téléchargement selon la revendication 7, caractérisé en ce que l'étape de sélection (E12) comporte les étapes de: -détermination d'un niveau de priorité de l'animation en fonction du coût de décodage global des images clés de chaque niveau de priorité et des capacités de traitement du terminal client, - sélection des images clés appartenant au niveau de priorité déterminé.  8. The downloading method as claimed in claim 7, characterized in that the selection step (E12) comprises the steps of: determining a priority level of the animation as a function of the overall decoding cost of the key images of each priority level and processing capabilities of the client terminal, - selecting the keyframes belonging to the determined priority level. 9. Procédé de téléchargement selon la revendication 7 ou 8, caractérisé en ce que l'étape de sélection comporte les étapes de: -détermination (E502) de la bande passante effective du terminal client, -identification (E503) de la classe du terminal client en fonction de sa bande passante effective, - sélection (E503) des versions des images clés correspondant à la classe du terminal client.  9. Download method according to claim 7 or 8, characterized in that the selection step comprises the steps of: -determination (E502) of the effective bandwidth of the client terminal, -identification (E503) of the class of the terminal client according to its effective bandwidth, - selection (E503) of the keyframe versions corresponding to the class of the client terminal. 10. Dispositif de création d'une animation comportant des images 5 clés, caractérisé en ce qu'il comporte: - des moyens (15) de détermination d'une pluralité de versions de l'animation en fonction d'au moins un critère correspondant à au moins une caractéristique du client susceptible de télécharger l'animation, - des moyens (15) de création d'un fichier comportant une 10 description des différentes versions déterminées et leur critère associé.  10. Device for creating an animation comprising key images, characterized in that it comprises: means (15) for determining a plurality of versions of the animation according to at least one corresponding criterion at least one characteristic of the client capable of downloading the animation; means (15) for creating a file comprising a description of the different versions determined and their associated criterion. 11. Dispositif de création d'une animation selon la revendication 10, caractérisé en ce que les moyens de détermination comportent: - des moyens d'affectation d'un niveau de priorité à chaque image 15 clé, - des moyens de calcul d'un coût de décodage global des images clés de chaque niveau de priorité.  11. Device for creating an animation according to claim 10, characterized in that the determining means comprise: means for assigning a priority level to each key image, means for calculating a global decoding cost of the keyframes of each priority level. 12. Dispositif de création d'une animation selon la revendication 11, 20 caractérisé en ce que les moyens de détermination sont adaptés à former une version de l'animation comportant des images clés auxquelles un même niveau de priorité a été affecté.  12. Device for creating an animation according to claim 11, characterized in that the determination means are adapted to form a version of the animation comprising keyframes to which the same level of priority has been assigned. 13. Dispositif de création d'une animation selon l'une quelconque 25 des revendications 10 à 12, caractérisé en ce que les moyens de détermination comportent: - des moyens de détermination de plusieurs classes de terminaux clients en fonction de leur bande passante, - des moyens de détermination d'une version de chaque image clé 30 pour chaque classe de terminaux clients.  13. Device for creating an animation according to any one of claims 10 to 12, characterized in that the determination means comprise: means for determining several classes of client terminals as a function of their bandwidth; means for determining a version of each keyframe 30 for each class of client terminals. 14. Dispositif de création d'une animation selon l'une quelconque des revendications 10 à 13, caractérisé en ce que les moyens de création comportent des moyens de détermination de requêtes pour chaque image clé, destinées à obtenir chaque image clé depuis un terminal distant.  14. Device for creating an animation according to any one of claims 10 to 13, characterized in that the creation means comprise means for determining requests for each key image, intended to obtain each keyframe from a remote terminal. . 15. Dispositif selon la revendication 14, caractérisé en ce que les moyens de détermination de requêtes sont adaptés à former des requêtes de type JPIP.  15. Device according to claim 14, characterized in that the means for determining requests are adapted to form queries JPIP type. 16. Dispositif de téléchargement d'une animation depuis un serveur vers un terminal client, l'animation ayant été créée par le dispositif de création selon l'une quelconque des revendications 10 à 15, caractérisé en ce qu'il comporte: - des moyens (21) de réception de la description des différentes 15 versions de l'animation, - des moyens (22) de sélection d'une version de l'animation en fonction d'au moins une caractéristique du terminal client, - des moyens (20) d'émission de requêtes en fonction de la version sélectionnée.  16. Device for downloading an animation from a server to a client terminal, the animation having been created by the authoring device according to any one of claims 10 to 15, characterized in that it comprises: - means (21) receiving the description of the different versions of the animation, - means (22) for selecting a version of the animation according to at least one characteristic of the client terminal, - means (20) ) to issue requests based on the selected version. 17. Dispositif de téléchargement selon la revendication 16, caractérisé en ce que les moyens (22) de sélection comportent: - des moyens de détermination d'un niveau de priorité de l'animation en fonction du coût de décodage global des images clés de chaque niveau de 25 priorité et des capacités de traitement du terminal client, - des moyens de sélection des images clés appartenant au niveau de priorité déterminé.  17. Download device according to claim 16, characterized in that the selection means (22) comprise: means for determining a priority level of the animation as a function of the overall decoding cost of the key images of each level of priority and processing capabilities of the client terminal; - means for selecting keyframes belonging to the determined priority level. 18. Dispositif de téléchargement selon la revendication 16 ou 17, 30 caractérisé en ce que les moyens (22) de sélection comportent: - des moyens de détermination de la bande passante effective du terminal client, - des moyens d'identification de la classe du terminal client en fonction de sa bande passante effective, - des moyens de sélection des versions des images clés correspondant à la classe du terminal client.  18. Download device according to claim 16, characterized in that the selection means (22) comprise: means for determining the effective bandwidth of the client terminal; means for identifying the class of the client; client terminal according to its effective bandwidth; means for selecting versions of the keyframes corresponding to the class of the client terminal. 19. Dispositif de création d'une animation selon l'une quelconque des revendications 10 à 15, caractérisé en ce que les moyens de détermination et création sont incorporés dans: - un microprocesseur (100), - une mémoire morte (102) comportant un programme pour traiter les données, et une mémoire vive (103) comportant des registres adaptés à enregistrer des variables modifiées au cours de l'exécution dudit programme.  19. Apparatus for creating an animation according to any one of claims 10 to 15, characterized in that the determination and creation means are incorporated in: - a microprocessor (100), - a read-only memory (102) comprising a program for processing the data, and a random access memory (103) having registers adapted to record modified variables during the execution of said program. 20. Dispositif de téléchargement, selon l'une quelconque des revendications 16 à 18, caractérisé en ce que les moyens de réception, sélection et émission sont incorporés dans: - un microprocesseur (100), une mémoire morte (102) comportant un programme pour traiter 20 les données, et - une mémoire vive (103) comportant des registres adaptés à enregistrer des variables modifiées au cours de l'exécution dudit programme.  20. Download device according to any one of claims 16 to 18, characterized in that the receiving means, selection and transmission are incorporated in: - a microprocessor (100), a read-only memory (102) comprising a program for processing the data, and - a RAM (103) having registers adapted to record modified variables during the execution of said program. 21. Appareil de traitement (10) de données numériques, caractérisé 25 en ce qu'il comporte des moyens adaptés à mettre en oeuvre le procédé selon l'une quelconque des revendications 1 à 9.  21. Apparatus for processing (10) digital data, characterized in that it comprises means adapted to implement the method according to any one of claims 1 to 9. 22. Appareil de traitement (10) de données numériques, caractérisé en ce qu'il comporte le dispositif selon l'une quelconque des revendications 10 30 à 20.  22. Apparatus for processing (10) digital data, characterized in that it comprises the device according to any one of claims 10 to 20. 23. Fichier comportant les données de codage d'une animation créée par le procédé de création selon la revendication 2 ou 3, caractérisé en ce qu'il comporte une indexation (n), une suite de requêtes (Rn1, Ri2), une priorité (Pn) et un instant d'affichage (Tn), pour chaque image clé (IMn), et en outre le coût calculatoire (cck) de chaque niveau de priorité.  23. File containing the encoding data of an animation created by the creation method according to claim 2 or 3, characterized in that it comprises an indexing (n), a sequence of requests (Rn1, Ri2), a priority (Pn) and a display instant (Tn), for each key image (IMn), and further the computational cost (cck) of each priority level. 24. Fichier comportant les données de codage d'une animation créée par le procédé de création selon la revendication 4, caractérisé en ce qu'il comporte une indexation (n), une suite de requêtes (Rn1, Rn2) classées en fonction des classes de terminaux clients et un instant d'affichage (Tn), pour chaque image clé Mn), et en outre la définition des classes (CL, à CL3).  24. File comprising the coding data of an animation created by the creation method according to claim 4, characterized in that it comprises an indexing (n), a sequence of requests (Rn1, Rn2) classified according to the classes. client terminals and a display instant (Tn), for each key image Mn), and further defining the classes (CL, CL3).
FR0313380A 2003-11-14 2003-11-14 Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion Pending FR2888962A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
FR0313380A FR2888962A1 (en) 2003-11-14 2003-11-14 Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion
EP04292667.5A EP1531428A3 (en) 2003-11-14 2004-11-10 Methods and devices for creating, downloading and managing an animation
US10/986,381 US7423649B2 (en) 2003-11-14 2004-11-12 Methods and devices for creating, downloading and managing an animation

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
FR0313380A FR2888962A1 (en) 2003-11-14 2003-11-14 Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion

Publications (1)

Publication Number Publication Date
FR2888962A1 true FR2888962A1 (en) 2007-01-26

Family

ID=34943958

Family Applications (1)

Application Number Title Priority Date Filing Date
FR0313380A Pending FR2888962A1 (en) 2003-11-14 2003-11-14 Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion

Country Status (1)

Country Link
FR (1) FR2888962A1 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020118224A1 (en) * 2000-12-27 2002-08-29 Isaac Levanon System and methods for network image delivery with dynamic viewing frustum optimized for limited bandwidth communication channels
US6476802B1 (en) * 1998-12-24 2002-11-05 B3D, Inc. Dynamic replacement of 3D objects in a 3D object library

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6476802B1 (en) * 1998-12-24 2002-11-05 B3D, Inc. Dynamic replacement of 3D objects in a 3D object library
US20020118224A1 (en) * 2000-12-27 2002-08-29 Isaac Levanon System and methods for network image delivery with dynamic viewing frustum optimized for limited bandwidth communication channels

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
HOUCHIN J S ET AL: "File format technology in JPEG 2000 enables flexible use of still and motion sequences", SIGNAL PROCESSING. IMAGE COMMUNICATION, ELSEVIER SCIENCE PUBLISHERS, AMSTERDAM, NL, vol. 17, no. 1, January 2002 (2002-01-01), pages 131 - 144, XP004326803, ISSN: 0923-5965 *
TAUBMAN D ET AL: "Architecture, philosophy, and performance of JPIP: internet protocol standard for JPEG2000", PROCEEDINGS OF THE SPIE, SPIE, BELLINGHAM, VA, US, vol. 5150, no. 1, 2003, pages 791 - 805, XP002282186, ISSN: 0277-786X *
TAUBMAN D: "Proposal and Implementation of JPIP (Jpeg2000 Internet Protocol) in Kakadu v3.3", ., 9 August 2002 (2002-08-09), XP002260543 *

Similar Documents

Publication Publication Date Title
FR2831688A1 (en) Multimedia digital data request processing method for television, involves considering request being processed similar to earlier request, when two requests have only certain request descriptors in common
FR2909241A1 (en) METHODS AND DEVICES FOR DYNAMICALLY MANAGING TRANSMISSION ERRORS THROUGH NETWORK INTERCONNECTION POINTS.
FR2894421A1 (en) METHOD AND DEVICE FOR DECODING A VIDEO STREAM CODE FOLLOWING A HIERARCHICAL CODING
FR2840495A1 (en) METHOD AND DEVICE FOR SELECTING A TRANSCODING METHOD AMONG A SET OF TRANSCODING METHODS
FR2870022A1 (en) METHOD AND DEVICE FOR DISTRIBUTING DIGITAL DATA, IN PARTICULAR FOR A PAIR-A-PAIR NETWORK
FR2857198A1 (en) Digital data e.g. audio, stream distribution method, involves selecting code conversion method admissible for each client from set of predetermined code conversion methods based on calculated flow and classification of client
FR2842057A1 (en) METHOD AND DEVICE FOR PROCESSING DATA IN A COMMUNICATION NETWORK
FR2851389A1 (en) Multimedia queries managing process for use in client server type architecture, involves dynamically allocating priority at every valid query, and making decision based on priority allocated to query for transmitting valid query
FR2959636A1 (en) Method for accessing spatio-temporal part of video image sequence in e.g. mobile telephone of Internet, involves obtaining selection zone updating information, where information is decoding function of data corresponding to selection zone
EP2947888A1 (en) Adaptive method for downloading digital content for a plurality of screens
FR2849982A1 (en) Coded digital image decoding method, involves decoding image to preset resolution based on determined preset resolution quantity of data, and selecting decoded image based on relation between selected and preset resolutions
FR2893470A1 (en) METHOD AND DEVICE FOR CREATING A VIDEO SEQUENCE REPRESENTATIVE OF A DIGITAL VIDEO SEQUENCE AND METHODS AND DEVICES FOR TRANSMITTING AND RECEIVING VIDEO DATA THEREOF
FR2888962A1 (en) Animation creation method involves creating file comprising optimized requests for obtaining images from remote terminal, and description of different versions of animation and associated criterion
EP2559218B1 (en) Reception of a digital content in trick mode
FR2923970A1 (en) METHOD AND DEVICE FOR FORMING, TRANSFERING AND RECEIVING TRANSPORT PACKETS ENCAPSULATING DATA REPRESENTATIVE OF A SEQUENCE OF IMAGES
WO2013144531A1 (en) Watermarking method with adaptive streaming
FR2860665A1 (en) Digital image decoding process for client terminal, involves transmitting request towards remote terminal to receive key frame based on time limit associated to frame, and determining interpolation mode based on frames received in response
EP3926929B1 (en) Process for managing the playback of digital content within a multimedia content player terminal connected to a restitution device
EP3675505B1 (en) Method and system for distributing audiovisual content
EP2083554A1 (en) Method for direct transmission of content intended to be recovered later in P2P mode after being split, and associated control device and equipment
FR2853788A1 (en) METHOD AND DEVICE FOR ACCESSING A DIGITAL DOCUMENT IN A PEER-TO-PEER COMMUNICATION NETWORK
FR2857123A1 (en) Flash animation creation assisting method for use in e.g. printer, involves writing selected animation mode by user in file containing animation data and writing data for implementing animation in file
FR3128084A1 (en) method for managing the playback of multimedia content.
WO2021209706A1 (en) Management of access to digital content available via progressive and adaptive streaming and encoded using a variable bit rate encoding method, depending on a network load
FR3114719A1 (en) Method for managing the reading of digital content within a multimedia content player terminal connected to a rendering device