FR2908203A1 - Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel. - Google Patents

Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel. Download PDF

Info

Publication number
FR2908203A1
FR2908203A1 FR0609611A FR0609611A FR2908203A1 FR 2908203 A1 FR2908203 A1 FR 2908203A1 FR 0609611 A FR0609611 A FR 0609611A FR 0609611 A FR0609611 A FR 0609611A FR 2908203 A1 FR2908203 A1 FR 2908203A1
Authority
FR
France
Prior art keywords
dimensional code
areas
code
product
dark
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.)
Granted
Application number
FR0609611A
Other languages
English (en)
Other versions
FR2908203B1 (fr
Inventor
Suanez Patricia Etienne
Roger Suanez
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.)
Individual
Original Assignee
Individual
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 Individual filed Critical Individual
Priority to FR0609611A priority Critical patent/FR2908203B1/fr
Priority to PCT/FR2007/001811 priority patent/WO2008065267A1/fr
Priority to EP07866479A priority patent/EP2084648A1/fr
Priority to US12/513,431 priority patent/US20110053639A1/en
Publication of FR2908203A1 publication Critical patent/FR2908203A1/fr
Application granted granted Critical
Publication of FR2908203B1 publication Critical patent/FR2908203B1/fr
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/14Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation using light without selection of wavelength, e.g. sensing reflected white light

Landscapes

  • Physics & Mathematics (AREA)
  • Engineering & Computer Science (AREA)
  • Health & Medical Sciences (AREA)
  • Electromagnetism (AREA)
  • General Health & Medical Sciences (AREA)
  • Toxicology (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Credit Cards Or The Like (AREA)
  • Image Processing (AREA)

Abstract

La présente invention concerne un procédé d'authentification d'un produit à partir d'une analyse de la clarté de blocs translucides présents dans un code bidimensionnel (1), un procédé d'authentification d'un code bidimensionnel (1) et les dispositifs permettant la mise en oeuvre de ces procédés. Le code bidimensionnel (1), apposé sur un produit, est authentifié en analysant le niveau de clarté d'aires translucides (11, 12, 14) inclues dans le code bidimensionnel (1), et en comparant le résultat de cette analyse avec une référence dans une base de données pré-établi. L'authentification du code bidimensionnel (1) est assurée en marquant sélectivement certaines aires sombres du code bidimensionnel (1), en fonction de la chaîne de caractères qui est encodée, lors d'une étape d'encodage, et en comparant la position des aires sombres marquées et la position définie par la chaîne de caractères lors d'une étape de décodage. La présente invention concerne aussi une application nouvelle des codes bidimensionnels (1).

Description

1 Procédés et dispositifs d'authentification d'un produit et d'un code
bidimensionnel et application nouvelle d'un code bidimensionnel. La présente invention concerne un procédé d'authentification d'un produit, à partir de l'analyse de la clarté d'aires translucides inclues dans un code bidimensionnel appliqué sur le produit, un procédé d'authentification d'un code bidimensionnel par marquage et analyse de certaines zones du code bidimensionnel, et les dispositifs permettant la mise en oeuvre de ces procédés. La présente invention concerne aussi une application nouvelle d'un code bidimensionnel.
La plupart des produits manufacturés possèdent un marquage afin de garantir leur traçabilité, notamment lors de leur passage par des frontières. En particulier, afin de se prémunir de la réalisation de contrefaçons et de pouvoir identifier les faux lors d'un contrôle ou d'une saisie, la plupart des produits manufacturés possède une immatriculation unique, et, si possible, difficilement reproductible. L'immatriculation est généralement de petite taille afin d'être discrète sur le support, et, pour complexifier la reproduction illicite de l'immatriculation du produit, l'immatriculation est généralement non séquentielle. II existe dans l'art antérieur différents systèmes de codage et d'immatriculation de produits connus de l'homme du métier. Les codes bidimensionnels sont notamment fréquemment utilisés. Ceux-ci se présentent généralement sous la forme d'une matrice composée de carrés sombres et de carrés blancs ou translucides, dont la position relative permet de coder une chaîne de caractères spécifique sur le produit. La chaîne de caractères peut être un mot clé, ou une concaténation de différents mots clés, qui font références à des données comprises dans une base de données. Dans cette famille de système de codage bidimensionnel, le QR- Code (marque déposée) est l'un des plus répandu, notamment dans l'industrie japonaise. Il est notamment utilisé pour saisir rapidement des 2908203 2 informations personnelles sur un téléphone portable, les informations personnelles étant apposées par exemple sur une carte de visite, à partir de la photographie du code et un logiciel de traitement d'information. Un autre système de codage fréquemment utilisé est le système de codage public 5 appelé datamatrix (marque déposée). Son application la plus répandue est pour l'industrie électronique, comme le marquage de cartes à puce, mais aussi parfois pour l'immatriculation de bouteilles de vin. La matrice du système de codage datamatrix est constituée d'une zone de codage des données appelée zone de données , présentant une combinaison de 10 carrés sombres et de carrés translucides adjacents, cette zone de données étant entourée sur deux côtés adjacents par deux lignes sombres appelées les barres de déclenchement , et sur les deux autres côtés par deux autres lignes présentant une alternance de carrés sombres et de carrés translucides, et appelées les barres indicatrices de densité . Les carrés 15 sont appelés aires par la suite. Le système de codage matriciel datamatrix fonctionne ainsi : Une chaîne de caractères, représentant une information caractérisant le produit, qui doit être codée dans la matrice, est tout d'abord binarisée selon un protocole de codage pré-défini, par exemple en format ASCII 7 bits dans le 20 protocole ECI (Extended Channel lnterpretation). Ces données binaires sont ensuite représentées sous la forme d'aires translucides et d'aires sombres, représentant généralement respectivement un bit 0 et un bit 1. L'agencement des aires sombres et translucides des différents éléments de la chaîne de caractères dans la zone de données suit un ordre spécifique et connu de 25 l'homme du métier. Les aires translucides permettent de laisser apparaître le support. Les aires sombres, par contre, sont généralement opaques, créées par l'impression d'une encre foncée, et ne permettent pas de voir le support en dessous. En plus de cet encodage de l'information caractérisant le produit, un 30 système de correction d'erreurs de lecture est encodé dans la datamatrix . Celui-ci permet de reconstituer et rectifier des données mal imprimées, effacées, floues ou arrachées. Le mécanisme de correction des erreurs est 2908203 3 basé sur les codes de Reed-Solomon, généralement selon le standard ECC (Error Corrective Code) 200. Le système de codage bidimensionnel datamatrix permet de coder une chaîne de caractères, typiquement d'une dizaine ou de quelques 5 dizaines de caractères, avec des matrices de taille très restreinte, typiquement quelques millimètres ou dizaine de millimètres carrés, ce qui rend ce système de codage discret lorsqu'il est apposé sur le produit. De plus, la lecture des aires translucides et sombres avec un système optique adapté et leur décodage peuvent être effectués même avec un contraste 10 faible entre les aires sombres et les aires translucides. Ce système d'immatriculation souffre cependant de plusieurs défauts. En effet, bien que la taille réduite de la matrice complexifie sa reproduction, le système datamatrix n'est pas infalsifiable dans l'état de l'art antérieur. Un contrefacteur qui aurait réalisé un produit faux peut relativement 15 facilement lui adjoindre un code datamatrix similaire à celui présent sur un produit original. De plus, ce système de codage encode des informations, c'est-à-dire la chaîne de caractères, qui sont prédéfinies et apposées sur le produit. Le système de codage ne donne donc pas, dans l'état de l'art antérieur, d'informations sur le produit en lui-même mais sur la chaîne de 20 caractères qui lui a été encodée. Un autre système d'identification de produits connu dans l'art antérieur consiste à utiliser un système d'imagerie optique à fort grossissement afin d'analyser les variations aléatoires de la structure de la matière du produit. Chaque produit manufacturé possède une empreinte spécifique, une 25 structure aléatoire, liées à la façon dont il a été réalisé et/ou à la nature même du matériau qui constitue l'e produit. En comparant la structure de surface du matériau analysé avec celle d'un étalon de référence, il est alors possible de déterminer selon des critères prédéfinis si le produit saisi est un faux ou non. 30 Cependant, ce système d'authentification nécessite d'utiliser deux systèmes de détection. En plus du système classique de lecture de la chaîne de caractères apposée sous la forme, par exemple, d'un QR-code ou 2908203 4 d'une datamatrix , un second dispositif d'imagerie et de traitement d'information doit être utilisé pour analyser la structure du matériau. La présente invention a pour objet de pallier un ou plusieurs inconvénients de l'art antérieur et notamment de proposer un procédé 5 d'authentification d'un produit à partir d'un système de codage bidimensionnel. La présente invention concerne un procédé d'authentification d'un produit sur lequel est apposé un code bidimensionnel représentant une chaîne de caractères sous la forme d'un agencement d'aires sombres et 10 d'aires non sombres, situées dans une zone de codage des données, et sous la forme d'un agencement d'aires sombres et d'aires non sombres, situées en périphérie de la zone de codage des données, les aires non sombres, appelées par la suite aires translucides , laissant apparaître le substrat du produit, caractérisé en ce qu'il comprend les étapes suivantes : 15 - une étape de lecture et d'enregistrement du code bidimensionnel sous la forme de valeurs codées de signaux électriques associées à l'intensité d'un flux lumineux issu des aires du code bidimensionnel, - une étape de traitement d'image, à partir des valeurs codées enregistrées, consistant à créer une matrice de valeurs dans laquelle chaque élément est 20 associé à une aire du code bidimensionnel, - une étape de décodage de la matrice de valeurs, permettant de décoder la chaîne de caractères et de l'enregistrer, - une étape de détermination d'une valeur moyenne d'intensité de flux lumineux issue d'au moins deux aires translucides situées dans la zone 25 périphérique, par analyse des valeurs codées des signaux électriques, une étape d'inversion / attribution, consistant à créer une matrice binaire dans laquelle chaque élément est associée à une aire du code bidimensionnel, avec la valeur 0 aux éléments associés aux aires sombres et aux aires translucides dont la valeur codée est inférieure à la valeur 30 moyenne de signal électrique, et la valeur 1 aux éléments associés aux aires translucides dont la valeur codée est supérieure à la valeur moyenne de signal électrique, 2908203 5 - une étape de calcul sur la matrice binaire dont le résultat détermine un code testé, - une étape de mise en relation avec une base de données et de comparaison entre le code testé et un code posé prédéterminé, les deux 5 codes étant associés à une référence. Selon une particularité, le procédé est caractérisé en ce que le code bidimensionnel est réalisé à l'aide d'un système de codage datamatrix comprenant une zone de données, deux barres de déclenchement, et deux barres indicatrices de densité, et que la zone de codage de données 10 correspond à la zone de données, et que la zone périphérique correspond aux deux barres indicatrices de densité. Selon une autre particularité, le procédé est caractérisé en ce que le code bidimensionnel est réalisé à l'aide d'un système de codage QRCode , et que la zone de codage de données correspond à la zone de 15 données du code QR-Code, et que la zone périphérique (3) correspond aux trois zones de déclenchement situées sur trois des quatre coins du QRCode . Selon une autre particularité, le procédé est caractérisé en ce que l'étape de traitement d'image comprend une segmentation des aires du code 20 bidimensionnel. Selon une autre particularité, le procédé est caractérisé en ce que l'étape de décodage est réalisée à l'aide d'un protocole de décodage enregistré dans une mémoire à laquelle le logiciel de traitement d'image a accès. 25 Selon une autre particularité, le procédé est caractérisé en ce que l'étape de calcul consiste au calcul d'un polynôme, consistant pour chaque bit d'une matrice binaire ayant la valeur binaire de 1, à multiplier cette valeur par deux, à élever le résultat à une puissance, cette puissance étant déterminée comme le nombre de colonnes présentes dans la matrice binaire 30 auquel est soustrait le numéro de la colonne sur laquelle est situé le bit pour lequel le calcul est effectué, telle que la première colonne est située sur une bordure prédéfinie de la matrice binaire, puis à sommer l'ensemble de ces 2908203 6 résultats, soit P = E E (2x N(1), Ibn i) , avec i le numéro de la ligne de la matrice binaire telle que la première ligne est située sur une bordure prédéfinie de la matrice binaire, j le numéro de la colonne, Nb le nombre de colonnes présentes dans la matrice binaire, N(1)1i la valeur binaire égale à 1 5 de l'aire située sur la ligne i et la colonne j, le terme 1( )signifiant une sommation de tous les termes compris entre les parenthèses pour j variant de 1 à Nb, et le terme 1( )signifiant une sommation de tous les termes compris entre les parenthèses sur toutes les valeurs de i existantes. Selon une autre particularité, le procédé est caractérisé en ce que 10 l'étape de comparaison et de mise en relation définit le produit comme étant un faux si le code testé et le code posé correspondant à la même chaîne de caractères sont différents. Selon une autre particularité, le procédé est caractérisé en ce que le code posé est calculé à partir du code bidimensionnel d'un produit avant sa 15 mise en circulation. Selon une autre particularité, le procédé est caractérisé en ce que la référence commune, utilisée pour l'étape de comparaison, est la chaîne de caractères, ou une partie de la chaîne de caractères. Un autre objet de la présente invention est de proposer une 20 application nouvelle d'un code bidirnensionnel. L'invention concerne une application nouvelle d'un code bidimensionnel apposé sur un produit, le code bidimensionnel représentant une chaîne de caractères codés sous la forme d'un agencement d'aires sombres et d'aires non sombres compris dans une zone de codage de 25 données, et d'autres aires non sombres étant positionnées en périphérie de la zone de codage de données, les aires non sombres permettant de laisser apparaître le substrat du produit et étant appelées aires translucides caractérisée en ce que les aires translucides du code bidimensionnel sont utilisées pour authentifier le produit, par l'analyse de leur clarté. 2908203 7 Un autre objet de la présente invention et de proposer un procédé d'authentification d'un code bidimensionnel. L'invention concerne un procédé d'authentification d'un code bidimensionnel (1) codant une chaîne de caractères (70) à l'aide d'une 5 alternance d'aires sombres (10) et d'aires non sombres (11) situées dans une zone de codage des données, et à l'aide d'autres aires sombres (13) et d'autres aires non sombres (14) situées dans une zone périphérique (3) en périphérie de la zone de codage des données, les aires non sombres (11, 12, 14) étant appelées par la suite aires translucides et laissant 10 apparaître le substrat du produit, caractérisé en ce qu'il comprend une étape de codage et une étape de décodage telle que l'étape de codage comprend : - une première étape de calcul, par un logiciel de codage, permettant de déterminer une valeur numérique représentative (30) du codage de la chaîne de caractères (70), 15 - une première étape d'attribution de densité, par le logiciel de codage, consistant à déterminer la position d'aires sombres marquées (17) sur la zone périphérique (3) par une seconde étape de calcul à partir de la valeur numérique représentative (30), - une étape d'impression et de marquage du code bidimensionnel, 20 consistant à imprimer le code bidimensionnel sur le produit et à adjoindre un marqueur sur les aires sombres marquées (17), et l'étape de décodage comprend : - une étape de lecture et d'enregistrement du code bidimensionnel, avec un dispositif adapté, permettant d'enregistrer des signaux électriques 25 associés à des aires du code bidimensionnel, de déterminer une matrice de valeurs représentative du code bidimensionnel, et de distinguer la position des aires sombres marquées (17) et des aires sombres non marquées (18) de la zone périphérique (3), - une étape de décodage du code bidimensionnel, par un logiciel de 30 traitement d'image, permettant de décoder la chaîne de caractères (70) et de l'enregistrer, 2908203 8 - une troisième étape de calcul, par un logiciel de décodage, à partir du codage de la chaîne de caractères, et selon un même algorithme que dans la première étape de calcul, permettant de déterminer la valeur numérique représentative (30) du codage de la chaîne de caractères (70), 5 - une seconde étape d'attribution de densité, par le logiciel de décodage, selon le même protocole que la première étape d'attribution de densité, permettant de déterminer une position des aires sombres marquées (17) et des aires sombres non marquées (18) à partir d'un calcul sur la valeur numérique représentative (30) du codage de la chaîne de caractères (70), 10 - une étape de comparaison entre les positions des aires sombres marquées (17) et des aires sombres non marquées (18) déterminées d'une part par la seconde étape d'attribution de densité et d'autre part par l'étape de lecture et d'enregistrement. Selon une particularité, le procédé est caractérisé en ce que le code 15 bidimensionnel est réalisé à l'aide d'un système de codage datamatrix comprenant une zone de données, deux barres de déclenchement, et deux barres indicatrices de densité, et que la zone périphérique est associée aux deux barres indicatrices de densité. Selon une autre particularité, le procédé est caractérisé en ce que le 20 code bidimensionnel est réalisé à l'aide d'un système de codage QRCode , et que la zone périphérique correspond à au moins une des trois zones de déclenchement situées sur trois des quatre coins du QR-Code . Selon une autre particularité, le procédé est caractérisé en ce que la première étape de calcul de la valeur numérique représentative du codage 25 de la chaîne de caractères consiste à calculer le reste d'une division d'un premier terme par un second terme, le second terme étant appelé le nombre premier de la chaîne de caractères, le premier terme étant soit un produit des codes ASCII des caractères de la chaîne de caractères, soit le résultat d'une multiplication des restes de divisions d'un produit des codes ASCII des 30 caractères de la chaîne de caractères par le nombre premier de la chaîne de caractères, ou soit toutes autres combinaisons de restes de division de produits des codes ASCII des caractères de la chaîne de caractères par le 2908203 9 nombre premier de la chaîne de caractères et le produit de ces restes de division, de manière à ce que l'intégralité des caractères de la chaîne de caractères interviennent dans l'étape de calcul par leur code ASCII, le nombre premier de la chaîne de caractères étant le nombre premier le plus 5 proche et inférieur au chiffre deux élevé à la puissance du nombre de caractères compris dans la chaîne de caractères. Selon une autre particularité, le procédé est caractérisé en ce que les premières et secondes étapes d'attribution de densité consistent à attribuer la valeur numérique représentative à une aire sombre située à une extrémité 10 en contact avec une barre de déclenchement d'une des barres indicatrices de densité, à diviser successivement la valeur numérique représentative par deux en ne tenant compte que de la partie entière de la division, à attribuer successivement chacun des résultats de cette division à une aire sombre des barres indicatrices de densité en commençant par l'aire sombre le plus 15 proche de l'aire à laquelle est associée la valeur numérique représentative et en terminant par l'aire sombre des barres indicatrices de densité située du côté diagonalement opposé à l'aire sombre à laquelle est attribuée la valeur numérique représentative, à calculer le reste de la division par le chiffre deux de chacun des résultats de la division de la valeur numérique représentative, 20 et à attribuer chacun de ces restes de division à la même aire sombre des barres indicatrices de densité auquel est associé chacun des résultats de la division de la valeur numérique représentative par deux. Selon une autre particularité, le procédé est caractérisé en ce que le marquage consiste à modifier le contraste des aires sombres et/ou à 25 adjoindre aux aires marquées une encre ayant des propriétés physico-chimiques différentes de l'encre utilisée pour les aires non marquées. Un autre objet de la présente invention et de proposer un dispositif permettant la mise en oeuvre du procédé d'authentification d'un produit. L'invention concerne un dispositif d'authentification d'un produit sur 30 lequel est apposé un code bidimensionnel (1) représentant une chaîne de caractères sous la forme d'un agencement d'aires sombres (10) et d'aires non sombres (11, 12), comprenant un dispositif d'imagerie optique (100), un 2908203 10 dispositif de conversion de signal optique en signal électrique analogique (110), un convertisseur analogique / numérique (130), une mémoire (140), un logiciel de traitement d'image (150) commandé par un microprocesseur, et un moyen de mise en relation (160) avec une base de données (170), le 5 dispositif d'imagerie optique (100) étant constitué d'au moins une lentille permettant de réaliser l'imagerie du code bidimensionnel (1) sur le dispositif de conversion de signal optique en signal électrique analogique (110), le dispositif de conversion de signal optique en signal électrique (110) étant constitué d'un ensemble de photodétecteurs permettant de convertir un 10 signal lumineux en un signal électrique analogique qui est converti en signal électrique numérique par le convertisseur analogique / numérique (130) et mémorisé dans la mémoire (140), et caractérisé en ce que le logiciel de traitement d'image (150) inclus des moyens de : - segmenter des aires d'un code bidimensionnel à partir de l'analyse de 15 l'intensité des signaux électriques enregistrés dans la mémoire, - créer une matrice de valeurs en fonction du résultat de la segmentation, - extraire une chaîne de caractères en décodant la matrice de valeurs selon un protocole de décodage prédéterminé, - calculer une valeur moyenne (22) de signal électrique à partir des valeurs 20 des signaux enregistrés dans la mémoire, - créer une matrice binaire dont chaque élément correspond à une aire et dont la valeur de l'élément dépend des valeurs des signaux enregistrés en mémoire et de la valeur moyenne de signal électrique, -calculer, selon un algorithme prédéfini, un code testé qui dépend de la 25 matrice binaire, - utiliser le moyen de mise en relation (160) avec une base de données (170) pour comparer le code testé avec un code posé enregistré dans une base de données (170), et référencé selon une chaîne de caractères. Selon une particularité, le dispositif est caractérisé en ce que le 30 dispositif d'imagerie optique, le dispositif de conversion de signal optique en signal électrique analogique, le convertisseur analogique / numérique, le logiciel de traitement d'image, la mémoire et le moyen de mise en relation 2908203 11 avec une base de données sont compris dans un téléphone - appareil photo numérique. Selon une autre particularité, le dispositif est caractérisé en ce que le logiciel de traitement d'image permet de reconnaître le type de code 5 bidimensionnel apposé sur le produit par la segmentation et l'analyse de zones spécifiques du code bidimensionnel. Selon une autre particularité, le dispositif est caractérisé en ce que le protocole de décodage de la matrice de valeurs est enregistré dans une mémoire à laquelle le logiciel de traitement d'image a accès, et que ce 10 protocole de décodage est adapté au code bidimensionnel. Selon une autre particularité, le dispositif est caractérisé en ce que l'algorithme prédéfini du logiciel de traitement d'image consiste au calcul d'un polynôme consistant pour chaque chiffre ayant la valeur binaire de 1 de la matrice binaire, à multiplier cette valeur par deux, à élever le résultat à une 15 puissance, cette puissance étant déterminée comme le nombre de colonnes présentes dans la matrice binaire auquel est soustrait le numéro de la colonne sur laquelle est situé le chiffre de la matrice binaire pour lequel le calcul est effectué, telle que la première colonne est située sur une bordure prédéfinie de la matrice binaire, puis à sommer l'ensemble de ces résultats, i 20 soit P = E 1(2x N(1)i.)(Nb-') , avec i le numéro de la ligne de la matrice \ binaire telle que la première ligne est située sur une bordure prédéfinie de la matrice binaire, j le numéro de la colonne, Nb le nombre de colonnes présentes dans la matrice binaire, N(1);,1 la valeur binaire égale à 1 du chiffre situé sur la ligne i et la colonne j, le terme E( ) signifiant une sommation de 25 tous les termes compris entre les parenthèses pour j variant de 1 à Nb, et le terme E( ) signifiant une sommation de tous les termes compris entre les parenthèses sur toutes les valeurs de i existantes. Selon une autre particularité, le dispositif est caractérisé en ce que la base de données est enregistrée dans une mémoire supportée par un même 2908203 12 dispositif qui englobe le logiciel de traitement d'image, et que le moyen de mise en relation est une connexion électrique. Selon une autre particularité, le dispositif est caractérisé en ce que la base de données inclue des codes qui ont été posés sur des produits avant 5 leur mise en circulation et référencées selon une chaîne de caractères codée sur les produits. Un autre objet de la présente invention et de proposer un dispositif de codage permettant la mise en oeuvre du procédé d'authentification d'un code bidimensionnel. 10 L'invention concerne un dispositif de codage pour l'authentification d'un code bidimensionnel représentant une chaîne de caractères, comprenant un logiciel de codage connecté à une mémoire et à un moyen d'impression et de marquage, caractérisé en ce que le logiciel de codage peut définir des valeurs binaires de marquages à partir d'un calcul sur la 15 valeur numérique représentative (30), et le moyen d'impression et de marquage permet d'imprimer le code bidimensionnel sur un produit et de marquer certaines aires sombres avec un marqueur en fonction des valeurs binaires de marquage. Selon une particularité, le dispositif est caractérisé en ce que le 20 marqueur est une encre noire, et/ou une combinaison soustractive d'encres de couleurs différentes, et/ou une encre possédant des éléments métalloïdes, et/ou une encre possédant des éléments magnétisés. Un autre objet de la présente invention et de proposer un dispositif de décodage permettant la mise en oeuvre du procédé d'authentification d'un 25 code bidimensionnel. L'invention concerne un dispositif de décodage pour l'authentification d'un code bidimensionnel, représentant une chaîne de caractères, constitués d'aires sombres, d'aires sombres marquées et d'aires non sombres, comprenant un dispositif de lecture et d'enregistrement qui inclue un 30 dispositif d'imagerie optique, un dispositif de conversion de signal optique en signal électrique analogique, un convertisseur analogique / numérique, une mémoire et un logiciel de décodage, le dispositif d'imagerie optique étant 2908203 13 constitué d'au moins une lentille permettant de réaliser l'imagerie du code bidimensionnel sur le dispositif de conversion de signal optique en signal électrique analogique, le dispositif de conversion de signal optique en signal électrique analogique étant constitué d'un ensemble de photodétecteurs 5 permettant de convertir un signal lumineux en un signal électrique analogique qui est converti en signal électrique numérique par le convertisseur analogique / numérique et mémorisé dans la mémoire, caractérisé en ce que le logiciel de décodage peut : - déterminer une matrice de valeurs représentant le code bidimensionnel à 10 partir de l'analyse de l'intensité des signaux électriques enregistrés, - décoder la matrice de valeurs pour déterminer la chaîne de caractères selon un protocole de décodage prédéfini, - calculer selon un algorithme prédéfini, une valeur numérique représentative du codage de la chaîne de caractères, et déterminer par un calcul sur la 15 valeur numérique représentative des positions d'aires sombres marquées et d'aires sombres non marquées, -identifier la position des aires sombres marquées et des aires sombres non marquées par l'analyse des signaux électriques enregistrés, - comparer les positions des d'aires sombres marquées et des aires 20 sombres non marquées obtenues d'une part par l'analyse des signaux électriques enregistrés et d'autre part par le calcul sur la valeur numérique représentative . Selon une particularité, le dispositif est caractérisé en ce que le dispositif d'imagerie optique et d'enregistrement, le dispositif de conversion 25 de signal optique en signal électrique analogique, le convertisseur analogique / numérique, le logiciel de décodage et la mémoire sont compris dans un téléphone portable û appareil photo numérique. Selon une autre particularité, le dispositif est caractérisé en ce que le protocole de décodage de la matrice de valeurs est enregistré dans la 30 mémoire, et que ce protocole de décodage est adapté au codebidimensionnel. 2908203 14 D'autres caractéristiques et avantages de l'invention apparaîtront à la lecture de la description détaillée qui suit, pour la compréhension de laquelle on se reportera aux dessins annexés dans lesquels : La figure 1 représente un exemple de code bidimensionnel 5 datamatrix non posé (appelé code avant pose ), ainsi qu'une étape de calcul d'un code avant pose selon le procédé d'authentification d'un produit de la présente invention. La figure 2 représente un exemple de code datamatrix , posé sur un produit, initialement identique à celui de la figure 1, dont certaines zones 10 translucides sont modifiées compte tenu de la texture du produit, avec une étape de calcul d'un code posé selon le procédé d'authentification d'un produit de la présente invention. La figure 3 représente schématiquement une étape d'analyse selon la présente invention dans laquelle une valeur moyenne d'intensité de certaines 15 zones translucides d'un code bidimensionnel est déterminée. La figure 4 représente schématiquement une étape d'inversion / attribution selon la présente invention, dans laquelle une matrice binaire dont chaque élément représente une aire d'un code bidimensionnel est créée, et dans laquelle la valeur 0 ou 1 est attribuée aux aires selon leur intensité. 20 La figure 5 représente un exemple d'un code datamatrix apposé sur un produit simulant un faux, résultat de la copie d'un code posé, par rapport au produit sur lequel est apposé le code datamatrix de la figure 2, avec une étape de calcul d'un code testé selon le procédé d'authentification d'un produit de la présente invention. 25 La figure 6 présente schématiquement un exemple de chaîne de caractères qui doit être codée dans un code bidimensionnel, ainsi qu'une détermination d'une valeur numérique représentative du codage binaire de la chaîne de caractères selon le procédé d'authentification d'un code bidimensionnel de la présente invention. 30 La figure 7 présente un exemple de procédé d'authentification d'un code bidimensionnel selon la présente invention, le code bidimensionnel 2908203 15 étant un code datamatrix représentant la chaîne de caractères indiquée sur la figure 6 selon un protocole de codage ASCII. La figure 8 représente un exemple de code bidimensionnel QR- code codant une information qui doit être apposée sur un produit. 5 La figure 9 représente schématiquement des étapes selon le procédé d'authentification d'un produit de la présente invention. La figure 10 représente un exemple de dispositif pour la mise en oeuvre du procédé d'authentification d'un produit de la présente invention. La description suivante présente un exemple de mise en oeuvre des 10 procédés d'authentification d'un produit et d'authentification d'un code bidimensionnel selon la présente invention, ainsi qu'une description d'un mode de réalisation envisageable des dispositifs permettant la mise en oeuvre de ces procédés. Cette description est présentée notamment pour le système de codage bidimensionnel datamatrix . Cependant, les procédés 15 et dispositifs de mise en oeuvre des procédés de la présente invention peuvent s'appliquer à toutes autres formes de codes bidimensionnels de type QR-Code ou autres. Notamment, les codes bidirnensionnels se présentent sous la forme d'un agencement d'aires sombres et d'aires non sombres permettant le 20 codage d'une chaîne de caractères. Les aires peuvent être des carrés, mais aussi toutes autres formes dont l'agencement permet de coder une chaîne de caractères. Ainsi, on peut tout aussi bien concevoir que le code bidimensionnel est composé d'un agencement de triangles, ou de losanges, ou autres figures géométriques représentant une répartition variable de 25 densités. Nous allons maintenant décrire un exemple de mise en oeuvre du procédé d'authentification d'un produit et un dispositif adapté à l'aide des figures 1à5et8à10. Le type de code bidimensionnel qui est apposé sur le produit est 30 généralement identifiable par des zones caractéristiques. Par exemple, le code datamatrix , dont la figure 1 représente un exemple, comporte une zone de données entourée par deux barres de déclenchement (2) et deux 2908203 16 barres indicatrices de densité (3). Les deux barres de déclenchement (2) sont opaques. Les barres indicatrices de densité (3) alternent des aires sombres (13) et des aires non sombres (14). Ces aires non sombres permettent de laisser apparaître le substrat du produit, et seront appelées 5 par la suite aires translucides . D'une façon générale, la clarté des aires sombres est inférieure à la clarté des aires translucides. A l'intérieur de la zone de données, l'agencement des aires sombres (10) et des aires translucides (11) permet de coder une information, par exemple en code ASCII, c'est-à-dire de coder une chaîne de caractères, caractérisant un 10 produit. Les numéros de lignes de la zone de données sont associés à la lettre i, et les numéros de colonne de la zone de données sont associés à la lettre j. Dans cet exemple, la zone de données comporte 16 lignes et 16 colonnes. La première ligne et la première colonne, soit i = 1 et j = 1, caractérisent l'aire située dans la zone de données en haut à gauche de la 15 figure selon le sens donné sur la figure 1. Les aires sombres (10, 13) :sont réalisées par impression d'une encre noire sur le produit, de telle façon que les aires sont opaques et ne permettent pas de voir le support en dessous. Les aires translucides (11, 14) sont formées sans modification du support, et en particulier sans impression 20 d'encre, ce qui permet de laisser apparaître la surface du substrat par ces aires. Dans le codage datarnatrix , les aires sombres (10, 13) correspondent généralement à un bit égal à 1, et les aires translucides (11, 14) correspondent généralement à un bit égal à 0. 25 Le procédé d'authentification d'un produit commence par une étape de lecture et d'enregistrement du code bidimensionnel qui est apposée sur un produit. Les différentes étapes du procédé sont représentées sur la figure 9. Le dispositif adapté, dont un exemple est donné sur la figure 10, permettant d'effectuer cette étape de lecture et d'enregistrement (200) du 30 code bidimensionnel comprend un dispositif d'imagerie optique (100), permettant de collecter un flux lumineux (120) issu de la surface du produit sur lequel est apposé le code bidimensionnel, par l'intermédiaire d'une 2908203 17 lentille ou d'un jeu de lentilles. Le dispositif d'imagerie capte l'image de la surface, et en particulier d'une zone sur laquelle se situe le code bidimensionnel, en utilisant un dispositif de conversion de signal optique en signal électrique analogique (110). 5 Le dispositif de conversion de signal optique en signal électrique analogique (110) est constitué d'un ensemble de photodétecteurs. Les photodétecteurs convertissent le flux lumineux (120) en un signal électrique analogique, dont l'intensité est dépendante de l'intensité du flux lumineux. Ainsi, une aire sombre du code bidimensionnel émettra une intensité de flux 10 lumineux faible comparée à celui d'une aire translucide. Les dispositifs d'imagerie optique (100) et de conversion de signal optique en signal électrique analogique (110) permettent de collecter le flux lumineux de chaque aire du code bidimensionnel et d'imager chacune des aires sur au moins un photodétecteur, de manière à pouvoir distinguer 15 spatialement chacune des aires. Les signaux électriques analogiques issus des photodétecteurs sont lus par un dispositif adapté de lecture des photodétecteurs et convertis en signaux électriques numériques par un convertisseur analogique / numérique (130). Le codage de la conversion analogique / numérique dépend de la 20 précision que l'on souhaite obtenir sur les valeurs d'intensité des signaux électriques analogiques. On peut, par exemple et sans restriction, utiliser un codage du signal analogique sur 7 ou 8 bits. Les informations relatives à ce codage numérique sont ensuite mémorisées dans une mémoire (140). La figure 2 présente, dans un carré en traits discontinus, un exemple de valeurs 25 d'intensité de signal associées à quatre aires avec un codage sur 8 bits, c'est-à-dire que le signal représentatif de l'aire peut prendre une valeur comprise entre 1 et 256. Un logiciel de traitement d'image (150), exécuté par un processeur, qui est connecté avec la mémoire (140), va exploiter les informations 30 stockées en mémoire (140), en enregistrer de nouvelles, et les modifier tout au long des étapes du procédé d'authentification de produit décrit ci-après. 2908203 18 Le logiciel de traitement d'image (150) exploite les informations enregistrées et permet de segmenter le code bidimensionnel, c'est-à-dire de distinguer les positions relatives des aires sombres (10) et des aires translucides (11), et donc d'associer à chaque aire du code bidimensionnel 5 un ou plusieurs photodétecteurs sur lesquelles le flux de photons à été imagé. Cette analyse, inclus dans l'étape de traitement d'image du procédé de la présente invention, est réalisée à l'aide d'une ou plusieurs zones caractéristiques des codes bidimensionnel. Dans le cas du code bidimensionnel datamatrix , les barres de déclenchement (2) sont 10 opaques et perpendiculaires. Les valeurs codées et enregistrées correspondant à l'intensité du flux lumineux de ces aires sont donc identifiables, et permettent de déterminer le sens de lecture du code. Les barres indicatrices de densité (3) du code datamatrix présentent une alternance d'aires sombres et d'aires translucides, et les deux barres sont 15 perpendiculaires l'une de l'autre. Ces deux barres sont donc elles-aussi nettement distinguables et permettent de définir notamment la dimension d'une aire. Le logiciel peut ainsi, par l'analyse des valeurs codées, distinguer ces zones caractéristiques, et ainsi la position relative de chaque aire du code 20 bidimensionnel. A partir de cette segmentation, le logiciel de traitement d'image crée une matrice de valeurs, dont chaque élément est associé à une aire de la zone de codage de données. Les valeurs codées correspondant à l'intensité du flux lumineux de chaque aire sont comparées avec une valeur d'intensité 25 seuil. Si la valeur codée est inférieure à la valeur d'intensité seuil, l'aire est associée à une valeur binaire dans la matrice de valeurs, et si la valeur codée associée à une aire possède une valeur supérieure à cette valeur d'intensité seuil, l'aire est associée à la valeur binaire complémentaire dans la matrice de valeurs. 30 Cette valeur d'intensité seuil peut être prédéfinie et pré-enregistrée dans la mémoire, et être proche de l'intensité électrique issue de la collection et de la conversion optique / électrique du flux lumineux d'une aire sombre 2908203 19 connue, tout en étant légèrement supérieure à cette intensité. La valeur d'intensité seuil peut aussi être déterminée par l'analyse spécifique de chaque code bidimensionnel. Ainsi, dans le cas d'un code bidimensionnel du type datamatrix , les barres indicatrices de densité alternent des aires 5 sombres avec des aires translucides selon un ordre connu. La valeur d'intensité seuil peut donc être spécifiquement déterminée sur chaque code bidimensionnel comme étant supérieure à la valeur codée associée à une aire sombre, et inférieure à la valeur codée associée à une aire translucide. Dans le cas d'un code bidimensionnel du type QR-code , dont un 10 exemple est donné sur la figure 8, trois zones identiques, appelées les zones de déclenchement, sont situées sur trois des quatre coins du code bidimensionnel (ici en haut à droite et gauche et en bas à gauche selon le sens de la figure). Dans cet exemple, les trois zones de déclenchement sont constituées d'un carré noir central comportant neuf aires sombres 15 adjacentes, entourées d'aires translucides sur une épaisseur d'une aire, et elles-mêmes entourées d'aires sombres. Une quatrième zone, constituée d'une seule aire sombre, est située dans le quatrième coin. Ces différentes zones sont caractéristiques du code bidimensionnel du type QR-Code . Ces trois zones identiques et cette quatrième zone permettent au logiciel de 20 traitement d'image de déterminer le sens de lecture et la position des différentes aires dans le code. Le logiciel de traitement d'image (150) mémorise la position relative de chaque aire et la valeur codée correspondant à l'intensité du flux lumineux de chaque aire. D'une façon générale, la valeur codée associée à chaque aire 25 peut être une combinaison de l'intensité électrique issue de plusieurs photodétecteurs sur lesquels le dispositif d'imagerie a réalisé l'imagerie d'une aire. Les valeurs des éléments de la matrice qui est créée par le logiciel de traitement d'image sont généralement les suivantes : les aires sombres, pour 30 lesquels la valeur codée est inférieure à la valeur d'intensité seuil, correspondent à une valeur binaire! de 1, et la valeur
complémentaire 0 est donnée pour les autres aires.
2908203 20 Après cette étape de traitement d'image, une étape de décodage (201) est réalisée, permettant d'identifier la chaîne de caractères apposée dans le code bidimensionnel. Le décodage s'effectue à partir de la matrice de valeurs qui a été déterminée au cours de l'étape précédente. Le logiciel 5 de traitement d'image (150) décode le code bidimensionnel (1) à partir d'un protocole de décodage enregistré en mémoire. Eventuellement, plusieurs protocoles de décodage sont préenregistrés, correspondant à plusieurs types de code bidimensionnel. Dans ce cas, une analyse du logiciel de traitement d'image de la matrice de valeurs permet d'identifier les zones 10 caractéristiques du code bidimensionnel, et ainsi de déterminer le type de code bidimensionnel et donc le protocole de décodage approprié. La chaîne de caractères ainsi décodée est enregistrée dans la mémoire (140). L'étape de détermination d'une valeur moyenne (202) consiste à analyser les valeurs codées représentant l'intensité du flux lumineux 15 associées à certaines aires de la zone périphérique (3) du code bidimensionnel. Le logiciel de traitement d'image (150) exploite les valeurs codées enregistrées et réalise une moyenne de ces valeurs codées associées à certaines aires prédéfinies. Par exemple, dans le cas d'un code bidimensionnel datamatix , certaines des aires translucides (14) des 20 barres indicatrices de densité (3) sont utilisées pour l'analyse. Les valeurs codées représentent une intensité de signal électrique, associé à une intensité de flux lumineux. L'analyse consiste donc à déterminer une valeur moyenne de ces intensités électriques (22) associés aux aires translucides (14) analysées, que l'on appellera valeur moyenne de signal électrique .
25 La figure 3 montre ainsi une partie d'une des deux barres indicatrices de densité (3) d'un code bidimensionnel datamatrix . Le diagramme (20) présente schématiquement une comparaison entre les intensités de signaux électrique (A) associés à différentes aires translucides (14) de la partie d'une des deux barres indicatrices (3) de densité analysée. La valeur moyenne de 30 signal électrique (22) est ainsi déterminée en moyennant ces différentes intensités de signaux électriques, ou les codes hexadécimaux, ou autres, représentatifs des intensités. Dans le cas d'un code bidimensionnel du type 2908203 21 QR-Code donné en exemple sur la figure 7, les aires translucides de la zone périphérique sur lesquelles est réalisée l'étape d'analyse peuvent, par exemple, appartenir à une ou plusieurs zones de déclenchement. L'étape d'inversion / attribution (203) consiste à créer une matrice 5 binaire, dans laquelle chaque élément est associé à une aire du code bidimensionnel, et dont la valeur des éléments dépend de l'intensité du signal électrique et de la valeur moyenne de signal électrique. Ainsi, la matrice binaire est créée telles que les aires translucides, dont l'intensité du signal électrique est inférieure à la valeur moyenne, sont associées à la 10 valeur binaire 0, et les aires translucides, dont l'intensité du signal électrique est supérieure à la valeur moyenne, sont associées à la valeur binaire 1. Les aires sombres sont associées à la valeur 0. Cette étape est dite d'inversion dans le sens où les aires sombres ont désormais la valeur 0, contrairement à la matrice de valeurs créée dans l'étape de traitement 15 d'image où elles avaient la valeur 1. La figure 4 montre une ligne (il) quelconque de la zone de données d'un code datamatrix . Cette figure présente l'étape d'inversion / attribution du procédé de la présente invention. Le logiciel de traitement d'image compare l'intensité du signal électrique (A) associée à chaque aire 20 translucide (11, 12) de la zone de données avec la valeur moyenne de signal électrique (22). Le logiciel de traitement d'image attribue alors, à chaque élément d'une ligne (i2) d'une matrice binaire, des valeurs dépendantes du résultat de cette comparaison : la valeur binaire 0 est attribuée aux éléments associés aux aires dont l'intensité du signal électrique est inférieure à la 25 valeur moyenne de signal électrique (22), et la valeur binaire 1 est attribuée aux éléments associés aux aires dont l'intensité du signal électrique est supérieure à la valeur moyenne de signal électrique (22). Les aires translucides (12) pour lesquels l'intensité du signal électrique (A) est inférieure à la valeur moyenne électrique (22) sont appelées les aires 30 translucides altérées. L'étape de calcul est maintenant présentée à l'aide des figures 1, 2 et 5. La figure 2 présente un exemple du même code bidimensionnel que celui 2908203 22 de la figure 1, mais cette fois-ci tel qu'il est visible lorsqu'il est apposé sur un produit. Les aires translucides altérées (12) (aires hachurées) sont moins claires que d'autres aires translucides (11). Cette différence de niveau de clarté provient de la texture du produit, qui n'est pas homogène et qui 5 présente donc, entres autres, des aspérités, des déformations ou des marques propres au matériau utilisé et / ou à la façon dont le produit a été conçu. Sur la figure 1, des valeurs numériques (Ti) représentent les valeurs obtenues par le calcul d'un polynôme P; pour chaque ligne de la matrice 10 binaire associée au code bidimensionnel présenté. Le code bidimensionnel de la figure 1 n'est pas posé sur un produit, et donc il ne présente pas de zones altérées. C'est pourquoi la matrice binaire utilisée dans l'étape de calcul est constituée, pour cette figure, d'éléments ayant la valeur 1 pour les aires translucides et 0 pour les aires sombres. Les lignes i et colonnes j, 15 associées à la zone de codage de données, correspondent identiquement aux lignes et aux colonnes de la matrice binaire, car chaque valeur de la matrice binaire est associée à une aire de la zone de codage de données. Dans cet exemple, P; est défini pour chaque ligne i par : P; =E(2xN(1)j,Mn->> 20 avec Nb le nombre de colonnes dans la zone de données, c'est-à-dire ici Nb = 16, i est le numéro de la ligne sur laquelle est effectué le calcul du polynôme P;, j est le numéro de la colonne considérée lors du calcul, N(1)j est la valeur binaire associée à la ligne i et la colonne j. Le calcul est effectué uniquement pour les aires auquel on associe la valeur binaire de 1, c'est-à- 25 dire les aires translucides, donc N(1)j est forcément égal à 1 dans cet exemple. On peut cependant envisager d'autres polynômes dans un autre mode de mise en oeuvre du procédé. Le terme E( ) signifie que l'on fait la somme des termes inclus entre les parenthèses pour toutes les valeurs de j existantes, soit de j = 1 à j = Nb. Ainsi, selon cet exemple, le calcul du 30 polynôme P; pour la première ligne donne : 2908203 23 P1 =(2x1 15 +(2x1 12 +(2x1)" +(2x1'0 +(2x1)3 +(2x1' =39946. Un code avant pose (P1) est défini par la somme des différentes valeurs (Ti) obtenues par le calcul du polynôme P; pour chaque ligne i. La même étape de calcul est effectuée sur la matrice binaire créée 5 dans l'étape d'inversion / attribution associée au code de la figure 2. Le code bidimensionnel de la figure 2 est posé sur un produit, et il présente donc des aires altérées. La matrice binaire associée au code de la figure 2 est donc différente de celle associée à la figure 1, car l'étape d'inversion / attribution a pris en compte les différences d'intensité lumineuse des aires translucides.
10 Le calcul du polynôme P; sur chacune des lignes de la matrice binaire associée à la zone de données du code de la figure 2 donne donc des valeurs différentes (T2) par rapport aux valeurs obtenues sur la figure 1 (Ti), et la sommation des différentes valeurs P;, c'est-à-dire la sommation des différentes valeurs (T2), qui donne un code testé (P2), montre un résultat 15 différent du code avant pose (P1) obtenue précédemment sur la figure 1. La figure 5 représente un exemple de code datamatrix , initialement identique à celui de la figure 1, mais apposé sur un produit différent de celui sur lequel a été apposé le code datamatrix de la figure 2. Le produit représente ici en l'occurrence un faux, et sa structure de surface est 20 différente de celle du produit sur lequel a été apposé le code datamatrix de la figure 2. Dans cet exemple, le nombre et la position des aires translucides (12) altérées sont différents de ceux présentés sur la figure 2. Ainsi, l'application des étapes de lecture et d'enregistrement, de traitement d'image, de décodage, d'analyse, d'attribution/inversion et de calcul selon le 25 procédé de la présente invention permet d'obtenir la même chaîne de caractères que celle du code bidimensionnel de la figure 2, mais le code testé (P3), issue de la somme des résultats (T3) du calcul du polynôme P; pour chaque ligne i, est différent du code testé (P2) de la figure 2. Dans l'étape de mise en relation avec une base de données, le 30 dispositif contenant le logiciel de traitement d'image (150) peut contenir aussi un moyen de mise en relation (160) avec un serveur (170) (cf. figure 10). La 2908203 24 mise en relation permet au logiciel de traitement d'image (150) de comparer ou de faire comparer par le serveur le code testé qu'il a déterminé avec un code posé contenue dans une base de données (170) à distance. Eventuellement, la base de données (170) est directement englobée dans un 5 même dispositif qui contient le logiciel de traitement d'image (150), et celui-ci possède alors les moyens de mettre à jour cette base de données. Le code posé est un code qui a été déterminé sur un produit selon les étapes du procédé décrites précédemment, et avant la mise en circulation du produit. II représente donc une identification du produit par 10 l'analyse des aires altérées du code bidimensionnel qui lui a été apposé. La base de données (170) contient le code posé de chaque produit sur lequel un code bidimensionnel est apposé. Ce code posé est référencé dans la base de données (170). La référence peut être, par exemple, la chaîne de caractères qui est codée sur le même produit, ou une partie de la chaîne de 15 caractères, ou une donnée qui est obtenue à partir de la chaîne de caractères. Ainsi, l'étape de mise en relation avec la base de données (170) et de comparaison (205) entre le code testé et le code posé permet d'authentifier le produit. Si les deux valeurs sont différentes, pour une même chaîne de 20 caractères, le logiciel peut alors conclure qu'il s'agit d'un faux, et envoyer un message relatif à un utilisateur. Le dispositif comprenant un dispositif d'imagerie optique (100), de conversion de signal optique en signal électrique (110), de conversion analogique / numérique (130) et la mémoire (140) peut être, par exemple, un 25 téléphone portable possédant un appareil photo. Le logiciel de traitement d'image (150) peut être chargé dans le téléphone - appareil photo, ou celui-ci peut se connecter à un serveur possédant le logiciel de traitement d'images (150) et une mémoire et transférer les informations nécessaires pour le procédé. La base de données (170) peut, elle aussi, être soit mémorisée 30 dans le téléphone - appareil photo, soit être positionnée à distance. Le téléphone - appareil photo a alors la possibilité de se connecter avec un serveur possédant la base de données (170).
2908203 25 Eventuellement, si lors de l'étape de comparaison, la chaîne de caractères qui a été décodée n'est pas retrouvée dans la base de données, ou que la chaîne de caractères ne peut pas être déchiffrée car son mode de codage n'est pas correct, le logiciel de traitement d'image peut alors 5 transmettre à un opérateur un message spécifique d'erreur. Ainsi, le code bidimensionnel assure à la fois le codage d'une information caractérisant un produit, mais permet de plus l'authentification du produit sur lequel est apposé le code, par l'analyse de la clarté de certaines zones du code bidimensionnel selon le procédé d'authentification d'un 10 produit de la présente invention. Nous allons maintenant décrire le procédé d'authentification d'un code bidimensionnel et un exemple de dispositif de codage d'un code et un dispositif de décodage d'un code permettant la mise en oeuvre de ce procédé selon la présente invention, à l'aide des figures 6 et 7.
15 La figure 6 présente un exemple d'une chaîne de caractères (70) comportant 18 caractères caractérisant un produit, et que l'on souhaite encoder à l'aide d'un système de codage bidimensionnel. La chaîne de caractères (70) est symboliquement placée dans une matrice (71) qui représente une matrice d'un code bidimensionnel. Chaque caractère de la 20 chaîne de caractères (70) possède un code ASCII connu de l'homme du métier dont les valeurs (T4) sont représentées à côté de la matrice (71). Le codage de cette chaîne de caractères selon un protocole connu définit ainsi une matrice de valeurs, dont chaque valeur de bit sera ensuite associée à une aire du code bidimensionnel.
25 Dans l'étape de codage, une étape de calcul est réalisée par un logiciel de codage sur des valeurs de la chaîne de caractères (70) codée selon un protocole de codage prédéfini, par exemple en ASCII, afin de déterminer une valeur numérique représentative (30) de la chaîne de caractères (70). Dans cet exemple non limitatif, l'étape de calcul est 30 constituée d'une succession de calculs que l'on présente ci-dessous : Tout d'abord, le nombre premier le plus proche et inférieur au chiffre deux élevé à la puissance du nombre de caractères (par exemple 18) 2908203 26 compris dans la chaîne de caractères (70) est déterminé, soit le nombre premier le plus proche et inférieur à 218, soit 262139. Ce nombre premier est appelé par la suite le nombre premier de la chaîne de caractères. Ensuite, la chaîne de caractères (70) est divisée en quatre groupes 5 approximativement égaux. Dans cet exemple, les quatre premiers caractères forment un premier groupe (41), les quatre caractères suivant forment un second groupe (42), les cinq caractères suivants forment un troisième groupe (43), et les cinq derniers caractères forment un quatrième groupe (44).
10 Puis, les codes ASCII (T4) de chaque caractère d'un même groupe sont multipliés entre eux, permettant d'obtenir une seule valeur numérique produit pour chaque groupe (41, 42, 43, 44). Ensuite, la division de la valeur numérique produit de chaque groupe (41, 42, 43, 44) par le nombre premier de la chaîne de caractères produit un reste qui permet d'obtenir une valeur 15 numérique appelée valeur modulo (51, 52, 53, 54) pour chacun des groupes. Les valeurs modulo (51, 52, 53, 54) sont ensuite multipliées entre elles et deux à deux, telle que la valeur modulodu premier groupe (51) est multipliée avec celle du second groupe (52), et la valeur modulo du troisième groupe (53) est multipliée avec celle du quatrième groupe (54), permettant 20 ainsi d'obtenir deux valeurs numériques produit des modulo. Le reste de la division de ces deux valeurs numériques produit des modulo par le nombre premier de la chaîne de caractères est ensuite déterminé, permettant d'obtenir deux nouvelles valeurs numériques modulo (61, 62).
25 Enfin, ces deux nouvelles valeurs numériques modulo (61, 62) sont multipliées entre-elles, et le reste de la division de ce dernier produit par le nombre premier de la chaîne de caractères est déterminé, ce reste étant la valeur numérique représentative (30) de la chaîne de caractères (dans l'exemple de la figure 6 la valeur 131118) 30 Dans l'étape d'attribution de densité, le logiciel de codage attribue, en fonction de la valeur numérique représentative, une valeur binaire de marquage aux éléments de la matrice de valeurs qui représentent des aires 2908203 27 sombres et qui sont situées dans une zone périphérique (3) du code bidimensionnel. La figure 7 représente ainsi schématiquement cette étape d'attribution dans le cas particulier d'un code du type datamatrix codant la chaîne de caractères (70) en format ASCII, et selon un mode d'attribution 5 possible. L'agencement des aires sombres et non sombres du code datamatrix est associé à la matrice de valeurs : les aires sombres représentent par exemple un bit égal à 1, et les aires non sombres représentent un bit égal à 0. La valeur numérique représentative (30) obtenue est mise en relation avec une aire sombre (15) située à une 10 extrémité en contact avec une des barres de déclenchement (2) d'une des barres indicatrices de densité (3), ici en bas à droite selon le sens de la figure 7. La valeur numérique représentative (30) est divisée successivement par deux en ne tenant compte que de la partie entière du résultat de la division, et chaque résultat (T5) de cette division est mise en relation successivement 15 et continuellement avec une aire sombre (13) des barres indicatrices de densité (3), en commençant par l'aire sombre adjacente à l'aire sombre (15) à laquelle est associée la valeur numérique représentative (30), et en terminant par l'aire sombre (16) située à l'extrémité diagonalement opposée, de sorte que toutes les aires sombres (13) des barres indicatrices de densité 20 (3) sont associées à une valeur numérique (T5). Chaque terme du résultat de la division (T5) est divisé par deux, permettant d'obtenir un reste binaire de cette division ayant une valeur égale à 0 ou une valeur égale à 1, appelé valeur binaire de marquage, et chacune de ces valeurs binaires de marquage étant associées à la même aire sombre 25 (13) des barres indicatrices de densité (3) auquel étaient associés les résultats (T5) successifs de la division de la valeur numérique représentative (30) par deux. Dans le cas d'un code bidimensionnel du type QR-Code dont un exemple est donné sur la figure 8, l'attribution de densité est réalisée, par 30 exemple, sur les aires sombres situées sur les zones de déclenchement, ou sur une seule zone de déclenchement.
2908203 28 A la suite de cette étape d'attribution de densité, une étape d'impression et de marquage permet d'imprimer le code bidimensionnel représentatif de la matrice de valeurs sur un produit, et de marquer certaines aires sombres spécifiques. Le dispositif d'impression et de marquage est, par 5 exemple une imprimante. Les aires sombres (13) des barres indicatrices de densité (3) associées à la valeur binaire de marquage 1 sont ainsi marquées avec le dispositif de marquage, créant ainsi des aires marquées (17). Les autres aires sombres qui sont associées à la valeur binaire 0 ne sont pas marquées (18).
10 Le marqueur peut être par exemple et sans restriction une encre noire d'impression, à laquelle on peut joindre des molécules métalloïdes, ou des molécules magnétiques. Le marquage peut aussi être sous la forme d'une modification du contraste des aires sombres (13). Dans l'exemple d'application où le contraste est modifié, les aires sombres (13) des barres 15 indicatrices de densité (3) sont imprimées avec une encre grise. Les aires sombres (17) devant être marquées peuvent être noircies par synthèse soustractive de couleur avec le dispositif d'impression et de marquage. Un exemple d'étape de décodage du procédé de la présente invention est maintenant présenté : 20 L'étape de lecture et d'enregistrement du code bidimensionnel consiste à utiliser un dispositif adapté pour mémoriser le code bidimensionnel (1) dans une mémoire. Par exemple, le dispositif peut être constitué d'un dispositif d'imagerie, d'un dispositif de conversion de signal optique en signal électrique analogique, d'un convertisseur analogique / 25 numérique, et d'une mémoire. Le dispositif permet d'enregistrer dans une mémoire des signaux électriques associés à l'intensité d'un flux lumineux issu des aires du code bidimensionnel, collecté par le dispositif d'imagerie, capté sur le dispositif de conversion de signal optique en signal électrique analogique, et converti en signal numérique.
30 Le dispositif de lecture et d'enregistrement peut aussi être composé d'un capteur à induction, dans le cas où le marquage est réalisé avec une encre créant un champ magnétique, ou d'un capteur sensible dans 2908203 29 l'infrarouge, dans le cas où l'encre de marquage possède des molécules émettant une onde électromagnétique infrarouge. Le dispositif de lecture et d'enregistrement du dispositif de décodage peut être, par exemple, un téléphone portable équipé d'un appareil photo et 5 du logiciel effectuant les traitements correspondants au procédé. L'étape de décodage du code bidimensionnel est similaire à l'étape de décodage du code bidimensionnel suivant le procédé d'authentification d'un produit de la présente invention : Un logiciel de décodage ayant accès à la mémoire sur laquelle sont enregistrés les signaux électriques, segmente les 10 aires par reconnaissance d'aires caractéristiques du code bidimensionnel, crée une matrice de valeurs dont chaque élément est associé à une aire, et décode la matrice de valeurs selon un protocole de décodage préenregistré dans la mémoire. II obtient ainsi la chaîne de caractères qui avait été codée et l'enregistre dans la mémoire.
15 Dans une autre variante de réalisation, le logiciel de décodage peut, par exemple, être situé à distance, sur un serveur. Dans ce cas, le dispositif de lecture et d'enregistrement est en contact avec un moyen de mise en relation, et se met en relation avec le serveur pour lui transmettre les informations mémorisées.
20 L'étape de calcul du logiciel de décodage est identique à l'étape de calcul effectuée par le logiciel de codage. Ainsi, la chaîne de caractères (70) qui avait été obtenue, est codée selon le même protocole prédéfini dans l'étape de marquage (par exemple en ASCII 7 bits), et les valeurs codées sont utilisées pour déterminer une valeur numérique représentative du 25 codage de la chaîne de caractères. De même, l'étape d'attribution de densité effectuée par le logiciel de décodage est identique à l'étape d'attribution de densité effectuée par le logiciel de codage. Cette étape est effectuée à partir de la valeur numérique représentative du codage de la chaîne de caractères et de la matrice de 30 valeurs qui a été déterminée au cours de l'étape de décodage. Le logiciel de décodage mémorise ainsi des valeurs binaires de marquage associées à des aires sombres marquées et des aires sombres non marquées sur la zone 2908203 30 périphérique (3), et enregistre ces valeurs binaires de marquage dans la mémoire. Dans l'étape de comparaison, le logiciel de décodage charge les informations relatives à la position des aires sombres marquées et des aires 5 sombres non marquées qui ont été déterminées par l'étape de lecture et d'enregistrement, et celles qui ont été obtenues lors de l'étape d'attribution. Cette étape permet ainsi de conclure que le produit est un vrai Si les positions sont identiques et un faux Si les positions sont différentes. Le résultat de cette comparaison est enfin transmis à un opérateur, 10 par exemple sous un format booléen vrai ou faux . Il doit être évident pour l'homme du métier que la présente invention permet des modes de mise en oeuvre du procédé sous de nombreuses autres formes spécifiques sans l'éloigner du domaine d'application de l'invention comme revendiquée. Par conséquent, le présent mode de mise en 15 oeuvre doit être considéré à titre d'illustration, mais peut être modifié dans le domaine défini par la portée des revendications jointes, et l'invention ne doit pas être limitée aux détails donnés ci-dessus.

Claims (27)

Revendications
1. Procédé d'authentification d'un produit sur lequel est apposé un code bidimensionnel (1) représentant une chaîne de caractères sous la forme d'un agencement d'aires sombres (10) et d'aires non sombres (11, 12), situées dans une zone de codage des données, et sous la forme d'un agencement d'aires sombres (13) et d'aires non sombres (14), situées en périphérie de la zone de codage des données, les aires non sombres (11, 12, 14), appelées par la suite aires translucides , laissant apparaître le substrat du produit, caractérisé en ce qu'il comprend les étapes suivantes : - une étape de lecture et d'enregistrement (200) du code bidimensionnel sous la forme de valeurs codées de signaux électriques associées à l'intensité d'un flux lumineux issu des aires du code bidimensionnel, - une étape de traitement d'image, à partir des valeurs codées enregistrées, consistant à créer une matrice de valeurs dans laquelle chaque élément est associé à une aire du code bidimensionnel, -une étape de décodage (201) de la matrice de valeurs, permettant de décoder la chaîne de caractères et de l'enregistrer, - une étape de détermination (202) d'une valeur moyenne d'intensité de flux lumineux issue d'au moins deux aires translucides (14) situées dans la zone périphérique (3), par analyse des valeurs codées des signaux électriques, - une étape d'inversion I attribution (203), consistant à créer une matrice binaire dans laquelle chaque élément est associé à une aire du code bidimensionnel, avec la valeur 0 aux éléments associés aux aires sombres et aux aires translucides (12) dont la valeur codée est inférieure à la valeur moyenne de signal électrique (22), et la valeur 1 aux éléments associés aux aires translucides (12) dont la valeur codée est supérieure à la valeur moyenne de signal électrique (22), - une étape de calcul (204) sur la matrice binaire dont le résultat détermine un code testé, 2908203 32 - une étape de mise en relation avec une base de données et de comparaison (205) entre le code testé et un code posé prédéterminé, les deux codes étant associés à une référence.
2. Procédé selon la revendication 1 caractérisé en ce que le code 5 bidimensionnel (1) est réalisé à l'aide d'un système de codage datamatrix comprenant une zone de données, deux barres de déclenchement (2), et deux barres indicatrices de densité (3), et que la zone de codage de données correspond à la zone de données, et que la zone périphérique (3) correspond aux deux barres indicatrices de densité (3). 10
3. Procédé selon la revendication 1 caractérisé en ce que le code bidimensionnel (1) est réalisé à l'aide d'un système de codage QR-Code , et que la zone de codage de données correspond à la zone de données du code QR-Code, et que la zone périphérique (3) correspond aux trois zones de déclenchement situées sur trois des quatre coins du QR-Code . 15
4. Procédé selon la revendication 1 caractérisé en ce que l'étape de traitement d'image comprend une segmentation des aires du code bidimensionnel.
5. Procédé selon la revendication 1 caractérisé en ce que l'étape de décodage (201) est réalisée à l'aide d'un protocole de décodage enregistré 20 dans une mémoire à laquelle le logiciel de traitement d'image a accès.
6. Procédé selon une quelconque des revendications précédentes, caractérisé en ce que l'étape de calcul consiste au calcul d'un polynôme (P), consistant pour chaque bit d'une matrice binaire ayant la valeur binaire de 1, à multiplier cette valeur par deux, à élever le résultat à une puissance, cette 25 puissance étant déterminée comme le nombre de colonnes présentes dans la matrice binaire auquel est soustrait le numéro de la colonne sur laquelle est situé le bit pour lequel le calcul est effectué, telle que la première colonne est située sur une bordure prédéfinie de la matrice binaire, puis à sommer i l'ensemble de ces résultats, soit P = E E(2 x N(1) , avec i le numéro 2908203 33 de la ligne de la matrice binaire telle que la première ligne est située sur une bordure prédéfinie de la matrice binaire, j le numéro de la colonne, Nb le nombre de colonnes présentes dans la matrice binaire, N(1);,j la valeur binaire égale à 1 de l'aire située sur la ligne i et la colonne j, le terme 5 E( )signifiant une sommation de tous les termes compris entre les parenthèses pour j variant de 1 à Nb, et le terme E( ) signifiant une sommation de tous les termes compris entre les parenthèses sur toutes les valeurs de i existantes.
7. Procédé selon une quelconque des revendications précédentes 10 caractérisé en ce que l'étape de comparaison (205) et de mise en relation définit le produit comme étant un faux si le code testé et le code posé correspondant à la même chaîne de caractères sont différents.
8. Procédé selon une quelconque des revendications précédentes caractérisé en ce que le code posé est calculée à partir du code 15 bidimensionnel d'un produit avant sa mise en circulation.
9. Procédé selon une quelconque des revendications précédentes caractérisé en ce que la référence commune, utilisée pour l'étape de comparaison (205), est la chaîne de caractères, ou une partie de la chaîne de caractères. 20
10. Procédé selon la revendication 1 caractérisé en ce que le code bidimensionnel (1) est authentifié par une étape de codage et une étape de décodage telle que l'étape de codage comprend : - une première étape de calcul, par un logiciel de codage, permettant de déterminer une valeur numérique représentative (30) du codage de la 25 chaîne de caractères (70), - une première étape d'attribution de densité, par le logiciel de codage, consistant à déterminer la position d'aires sombres marquées (17) sur la zone périphérique (3) par une seconde étape de calcul à partir de la valeur numérique représentative (30), 2908203 34 - une étape d'impression et de marquage du code bidimensionnel, consistant à imprimer le code bidimensionnel sur le produit et à adjoindre un marqueur sur les aires sombres marquées (17), et l'étape de décodage comprend : 5 - une étape de lecture et d'enregistrement du code bidimensionnel, avec un dispositif adapté, permettant d'enregistrer des signaux électriques associés à des aires du code bidimensionnel, de déterminer une matrice de valeurs représentative du code bidimensionnel, et de distinguer la position des aires sombres marquées (17) et des aires sombres non 10 marquées (18) de la zone périphérique (3), - une étape de décodage du code bidimensionnel, par un logiciel de traitement d'image, permettant de décoder la chaîne de caractères (70) et de l'enregistrer, - une troisième étape de calcul, par un logiciel de décodage, à partir du 15 codage de la chaîne de caractères, et selon un même algorithme que dans la première étape de calcul, permettant de déterminer la valeur numérique représentative (30) du codage de la chaîne de caractères (70), - une seconde étape d'attribution de densité, par le logiciel de décodage, selon le même protocole que la première étape d'attribution de densité, 20 permettant de déterminer une position des aires sombres marquées (17) et des aires sombres non marquées (18) à partir d'un calcul sur la valeur numérique représentative (30) du codage de la chaîne de caractères (70), -une étape de comparaison entre les positions des aires sombres marquées (17) et des aires sombres non marquées (18) déterminées 25 d'une part par la seconde étape d'attribution de densité et d'autre part par l'étape de lecture et d'enregistrement.
11. Procédé selon la revendication 10 caractérisé en ce que le code bidimensionnel (1) est réalisé à l'aide d'un système de codage datamatrix comprenant une zone de données, deux barres de déclenchement (2), et deux barres indicatrices de densité (3), et que la zone périphérique (3) est associée aux deux barres indicatrices de densité (3). 2908203
12. Procédé selon la revendication 10 caractérisé en ce que le code bidimensionnel (1) est réalisé à l'aide d'un système de codage QR-Code , et que la zone périphérique (3) correspond à au moins une des trois zones de déclenchement situées sur trois des quatre coins du QR-Code . 5
13. Procédé selon la revendication 10 caractérisé en ce que la première étape de calcul de la valeur numérique représentative (30) du codage de la chaîne de caractères consiste à calculer le reste d'une division d'un premier terme par un second terme, le second terme étant appelé le nombre premier de la chaîne de caractères, le premier terme étant soit un produit des codes 10 ASCII des caractères de la chaîne de caractères (70), soit le résultat d'une multiplication des restes de divisions d'un produit des codes ASCII des caractères de la chaîne de caractères (70) par le nombre premier de la chaîne de caractères, ou soit toutes autres combinaisons de restes de division de produits des codes ASCII des caractères de la chaîne de 15 caractères (70) par le nombre premier de la chaîne de caractères et le produit de ces restes de division, de manière à ce que l'intégralité des caractères de la chaîne de caractères (70) interviennent dans l'étape de calcul par leur code ASCII, le nombre premier de la chaîne de caractères étant le nombre premier le plus proche et inférieur au chiffre deux élevé à la 20 puissance du nombre de caractères compris dans la chaîne de caractères (70).
14. Procédé selon une quelconque des revendications 10 à 13 caractérisé en ce que les premières et secondes étapes d'attribution de densité consistent à attribuer la valeur numérique représentative (30) à une aire sombre (15) 25 située à une extrémité en contact avec une barre de déclenchement (2) d'une des barres indicatrices de densité (3), à diviser successivement la valeur numérique représentative (30) par deux en ne tenant compte que de la partie entière de la division, à attribuer successivement chacun des résultats de cette division (T5) à une aire sombre (13) des barres indicatrices 30 de densité (3) en commençant par l'aire sombre le plus proche de l'aire (15) à laquelle est associée la valeur numérique représentative (30) et en 2908203 36 terminant par l'aire sombre (16) des barres indicatrices de densité située du côté diagonalement opposé à l'aire sombre (15) à laquelle est attribuée la valeur numérique représentative (30), à calculer le reste de la division par le chiffre deux de chacun des résultats (T5) de la division de la valeur 5 numérique représentative (30), et à attribuer chacun de ces restes de division à la même aire sombre (13) des barres indicatrices de densité (3) auquel est associé chacun des résultats (T5) de la division de la valeur numérique (30) représentative par deux.
15. Procédé selon la revendication 10 caractérisé en ce que le marquage 10 consiste à modifier le contraste des aires sombres et/ou à adjoindre aux aires marquées (17) une encre ayant des propriétés physico-chimiques différentes de l'encre utilisée pour les aires non marquées (18).
16. Dispositif d'authentification d'un produit sur lequel est apposé un code bidimensionnel (1) représentant une chaîne de caractères sous la forme d'un 15 agencement d'aires sombres (10) et d'aires non sombres (11, 12), permettant la mise en oeuvre du procédé selon une des revendications 1 à 9, comprenant un dispositif d'imagerie optique (100), un dispositif de conversion de signal optique en signal électrique analogique (110), un convertisseur analogique / numérique (130), une mémoire (140), un logiciel de traitement 20 d'image (150) commandé par un microprocesseur, et un moyen de mise en relation (160) avec une base de données (170), le dispositif d'imagerie optique (100) étant constitué d'au moins une lentille permettant de réaliser l'imagerie du code bidimensionnel (1) sur le dispositif de conversion de signal optique en signal électrique analogique (110), le dispositif de conversion de 25 signal optique en signal électrique (110) étant constitué d'un ensemble de photodétecteurs permettant de convertir un signal lumineux en un signal électrique analogique qui est converti en signal électrique numérique par le convertisseur analogique I numérique (130) et mémorisé dans la mémoire (140), et caractérisé en ce que le logiciel de traitement d'image (150) inclus 30 des moyens de : û segmenter des aires d'un code bidimensionnel à partir de l'analyse de l'intensité des signaux électriques enregistrés dans la mémoire, 2908203 37 créer une matrice de valeurs en fonction du résultat de la segmentation, extraire une chaîne de caractères en décodant la matrice de valeurs selon un protocole de décodage prédéterminé, calculer une valeur moyenne (22) de signal électrique à partir des valeurs 5 des signaux enregistrés dans la mémoire, créer une matrice binaire dont chaque élément correspond à une aire et dont la valeur de l'élément dépend des valeurs des signaux enregistrés en mémoire et de la valeur moyenne de signal électrique, calculer, selon un algorithme prédéfini, un code testé qui dépend de la 10 matrice binaire, utiliser le moyen de mise en relation (160) avec une base de données (170) pour comparer le code testé avec un code posé enregistré dans une base de données (170), et référencé selon une chaîne de caractères.
17. Dispositif d'authentification d'un produit selon la revendication 16 15 caractérisé en ce que le dispositif d'imagerie optique (100), le dispositif de conversion de signal optique en signal électrique analogique (110), le convertisseur analogique I numérique (130), la mémoire (140), le logiciel de traitement d'image (150) et le moyen de mise en relation (160) avec une base de données sont compris dans un téléphone - appareil photo 20 numérique.
18. Dispositif d'authentification d'un produit selon une quelconque des revendications 16 à 17 caractérisé en ce que le logiciel de traitement d'image (150) permet de reconnaître le type de code bidimensionnel apposé sur le produit par la segmentation et l'analyse de zones spécifiques du code 25 bidimensionnel.
19. Dispositif d'authentification d'un produit selon une quelconque des revendications 16 à 18 caractérisé en ce que le protocole de décodage de la matrice de valeurs est enregistré dans une mémoire à laquelle le logiciel de traitement d'image a accès, et que ce protocole de décodage est adapté au 30 code bidimensionnel. 2908203 38
20. Dispositif d'authentification d'un produit selon une quelconque des revendications 16 à 19 caractérisé en ce que l'algorithme prédéfini du logiciel de traitement d'image consiste au calcul d'un polynôme consistant pour chaque chiffre ayant la valeur binaire de 1 de la matrice binaire, à multiplier 5 cette valeur par deux, à élever le résultat à une puissance, cette puissance étant déterminée comme le nombre de colonnes présentes dans la matrice binaire auquel est soustrait le numéro de la colonne sur laquelle est situé le chiffre de la matrice binaire pour lequel le calcul est effectué, telle que la première colonne est située sur une bordure prédéfinie de la matrice binaire, P=E E(2xN(1),,i)(N'') 10 puis à sommer l'ensemble de ces résultats, soit , avec i le numéro de la ligne de la matrice binaire telle que la première ligne est située sur une bordure prédéfinie de la matrice binaire, j le numéro de la colonne, Nb le nombre de colonnes présentes dans la matrice binaire, N(1)i,j la valeur binaire égale à 1 du chiffre situé sur la ligne i et la colonne j, le E() 15 terme J signifiant une sommation de tous les termes compris entre les E() parenthèses pour j variant de 1 à Nb, et le terme i signifiant une sommation de tous les termes compris entre les parenthèses sur toutes les valeurs de i existantes.
21. Dispositif d'authentification d'un produit selon une quelconque des 20 revendications 16 à 20 caractérisé en ce que la base de données (170) est enregistrée dans une mémoire supportée par un même dispositif qui englobe le logiciel de traitement d'image (150), et que le moyen de mise en relation est une connexion électrique.
22. Dispositif d'authentification d'un produit selon une quelconque des 25 revendications 16 à 21 caractérisé en ce que la base de données (170) inclue des codes qui ont été posés sur des produits avant leur mise en circulation et référencées selon une chaîne de caractères codée sur les produits. 2908203 39
23. Dispositif de codage pour l'authentification d'un code bidimensionnel permettant la mise en oeuvre du procédé selon une des revendications 10 à 15 et représentant une chaîne de caractères, comprenant un logiciel de codage connecté à une mémoire et à un moyen d'impression et de 5 marquage, caractérisé en ce que le logiciel de codage peut définir des valeurs binaires de marquages à partir d'un calcul sur la valeur numérique représentative (30), et le moyen d'impression et de marquage permet d'imprimer le code bidimensionnel sur un produit et de marquer certaines aires sombres avec un marqueur en fonction des valeurs binaires de 10 marquage.
24. Dispositif de codage selon la revendication 23 caractérisé en ce que le marqueur est une encre noire, et/ou une combinaison soustractive d'encres de couleurs différentes, et/ou une encre possédant des éléments métalloïdes, et/ou une encre possédant des éléments magnétisés. 15
25. Dispositif de décodage pour l'authentification d'un code bidimensionnel permettant la mise en oeuvre du procédé selon une des revendications 10 à 15 et représentant une chaîne de caractères, constitués d'aires sombres (10, 18), d'aires sombres marquées (17) et d'aires non sombres (11, 14), comprenant un dispositif de lecture et d'enregistrement qui inclue un 20 dispositif d'imagerie optique, un dispositif de conversion de signal optique en signal électrique analogique, un convertisseur analogique / numérique, une mémoire et un logiciel de décodage, le dispositif d'imagerie optique étant constitué d'au moins une lentille permettant de réaliser l'imagerie du code bidimensionnel sur le dispositif de conversion de signal optique en signal 25 électrique analogique, le dispositif de conversion de signal optique en signal électrique analogique étant constitué d'un ensemble de photodétecteurs permettant de convertir un signal lumineux en un signal électrique analogique qui est converti en signal électrique numérique par le convertisseur analogique / numérique et mémorisé dans la mémoire, 30 caractérisé en ce que le logiciel de décodage peut : 2908203 - déterminer une matrice de valeurs représentant le code bidimensionnel à partir de l'analyse de l'intensité des signaux électriques enregistrés, - décoder la matrice de valeurs pour déterminer la chaîne de caractères selon un protocole de décodage prédéfini, 5 - calculer selon un algorithme prédéfini, une valeur numérique représentative (30) du codage de la chaîne de caractères, et déterminer par un calcul sur la valeur numérique représentative (30) des positions d'aires sombres marquées (17) et d'aires sombres non marquées (18), - identifier la position des aires sombres marquées (17) et des aires 10 sombres non marquées (18) par l'analyse des signaux électriques enregistrés, - comparer les positions des d'aires sombres marquées (17) et des aires sombres non marquées (18) obtenues d'une part par l'analyse des signaux électriques enregistrés et d'autre part par le calcul sur la valeur numérique 15 représentative (30).
26. Dispositif de décodage selon la revendication 25 caractérisé en ce que le dispositif d'imagerie optique et d'enregistrement, le dispositif de conversion de signal optique en signal électrique analogique, le convertisseur analogique I numérique, le logiciel de décodage et la mémoire sont compris 20 dans un téléphone portable û appareil photo numérique.
27. Application nouvelle d'un code bidimensionnel (1) apposé sur un produit, permettant l'utilisation du procédé selon la revendication 1, le code bidimensionnel (1) représentant une chaîne de caractères codés sous la forme d'un agencement d'aires sombres (10) et d'aires non sombres (11, 12) 25 compris dans une zone de codage de données, et d'autres aires non sombres (14) étant positionnées en périphérie (3) de la zone de codage de données, les aires non sombres permettant de laisser apparaître le substrat du produit et étant appelé aires translucides caractérisée en ce que les aires translucides (11, 12, 14) du code bidimensionnel sont utilisées pour 30 authentifier le produit, par l'analyse de leur clarté.
FR0609611A 2006-11-03 2006-11-03 Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel. Expired - Fee Related FR2908203B1 (fr)

Priority Applications (4)

Application Number Priority Date Filing Date Title
FR0609611A FR2908203B1 (fr) 2006-11-03 2006-11-03 Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel.
PCT/FR2007/001811 WO2008065267A1 (fr) 2006-11-03 2007-10-31 Procédés et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel
EP07866479A EP2084648A1 (fr) 2006-11-03 2007-10-31 Procédés et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel
US12/513,431 US20110053639A1 (en) 2006-11-03 2007-10-31 Methods and devices for authenticating a product and a two-dimensional code and novel application of a two-dimensional code

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
FR0609611A FR2908203B1 (fr) 2006-11-03 2006-11-03 Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel.

Publications (2)

Publication Number Publication Date
FR2908203A1 true FR2908203A1 (fr) 2008-05-09
FR2908203B1 FR2908203B1 (fr) 2009-04-24

Family

ID=38256011

Family Applications (1)

Application Number Title Priority Date Filing Date
FR0609611A Expired - Fee Related FR2908203B1 (fr) 2006-11-03 2006-11-03 Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel.

Country Status (4)

Country Link
US (1) US20110053639A1 (fr)
EP (1) EP2084648A1 (fr)
FR (1) FR2908203B1 (fr)
WO (1) WO2008065267A1 (fr)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110275132A (zh) * 2019-06-18 2019-09-24 西京学院 一种基于二维码映射的室内定位方法

Families Citing this family (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10353774B2 (en) * 2015-10-30 2019-07-16 International Business Machines Corporation Utilizing storage unit latency data in a dispersed storage network
US8807421B2 (en) * 2011-04-26 2014-08-19 Michael Alexander Johnson Composite code with dynamic linking to internet addresses
US11907060B2 (en) 2011-09-06 2024-02-20 Pure Storage, Inc. Coding of data streams in a vast storage network
US10235237B2 (en) 2011-09-06 2019-03-19 Intertnational Business Machines Corporation Decoding data streams in a distributed storage network
US8751894B2 (en) * 2011-09-06 2014-06-10 Cleversafe, Inc. Concurrent decoding of data streams
US20190179696A1 (en) 2011-09-06 2019-06-13 International Business Machines Corporation Demultiplexing decoded data streams in a distributed storage network
US8534543B1 (en) * 2012-05-18 2013-09-17 Sri International System and method for authenticating a manufactured product with a mobile device
US8534544B1 (en) * 2012-05-18 2013-09-17 Sri International System and method for authenticating a manufactured product with a mobile device
US20150356803A1 (en) * 2014-06-04 2015-12-10 David Jarrett Collins Item authentication
RU2015139057A (ru) 2015-09-14 2017-03-17 ИЭмСи КОРПОРЕЙШН Способ и система распределенного хранения данных
US9483718B1 (en) * 2015-12-14 2016-11-01 International Business Machines Corporation Encoding and decoding data in two-dimensional symbology
US10061697B2 (en) 2015-12-16 2018-08-28 EMC IP Holding Company LLC Garbage collection scope detection for distributed storage
US10133770B2 (en) 2015-12-16 2018-11-20 EMC IP Holding Company LLC Copying garbage collector for B+ trees under multi-version concurrency control
US10146600B2 (en) 2015-12-16 2018-12-04 EMC IP Holding Company LLC Mutable data objects content verification tool
US10067696B2 (en) 2015-12-18 2018-09-04 Emc Corporation Capacity exhaustion prevention for distributed storage
US10379780B2 (en) 2015-12-21 2019-08-13 EMC IP Holding Company LLC Statistics management for scale-out storage
US10291265B2 (en) 2015-12-25 2019-05-14 EMC IP Holding Company LLC Accelerated Galois field coding for storage systems
US10152248B2 (en) 2015-12-25 2018-12-11 EMC IP Holding Company LLC Erasure coding for elastic cloud storage
US10110258B2 (en) 2016-03-30 2018-10-23 EMC IP Holding Company LLC Accelerated erasure coding for storage systems
US10248326B2 (en) 2016-06-29 2019-04-02 EMC IP Holding Company LLC Incremental erasure coding for storage systems
US10152376B2 (en) * 2016-06-29 2018-12-11 EMC IP Holding Company LLC Data object recovery for storage systems
US10795872B2 (en) 2016-06-29 2020-10-06 EMC IP Holding Company LLC Incremental bloom filter rebuild for B+ trees under multi-version concurrency control
WO2018090192A1 (fr) * 2016-11-15 2018-05-24 深圳大学 Procédé et appareil de chiffrement et de déchiffrement d'image basés sur une technique de chiffrement et de déchiffrement optique
US10831742B2 (en) 2016-12-09 2020-11-10 EMC IP Holding Company LLC Data set verification
US10564883B2 (en) 2016-12-13 2020-02-18 EMC IP Holding Company LLC Efficient migration to distributed storage
US10776322B2 (en) 2016-12-13 2020-09-15 EMC IP Holding Company LLC Transformation processing for objects between storage systems
US10453221B2 (en) 2017-04-10 2019-10-22 Intel Corporation Region based processing
EP3687319B1 (fr) * 2017-12-29 2020-12-02 JT International SA Inhalateur avec reconnaissance optique et son consommable
US10783022B2 (en) 2018-08-03 2020-09-22 EMC IP Holding Company LLC Immediate replication for dedicated data blocks
CN112884105B (zh) * 2021-03-25 2022-07-05 南通大学 一种基于移位加密的商品防伪二维码生成方法
CN114254719B (zh) * 2021-12-17 2022-11-22 广州市宝绅科技应用有限公司 一种防伪二维码的生成方法及装置

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0572989A2 (fr) * 1992-06-01 1993-12-08 Symbol Technologies, Inc. Enregistrement avec données codées
US6606396B1 (en) * 1999-06-18 2003-08-12 Denso Corporation Method and apparatus for detecting forgery

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5452379A (en) * 1991-09-13 1995-09-19 Meadowbrook Industries, Ltd. Image capture and storage techniques in association with optical mark reading
US5717195A (en) * 1996-03-05 1998-02-10 Metanetics Corporation Imaging based slot dataform reader
KR100414524B1 (ko) * 2002-10-31 2004-01-16 주식회사 아이콘랩 복호 특성이 우수하며 단계별 에러레벨조정이 가능한2차원 코드 및 그 코드의 인코딩 디코딩 방법
CN100481117C (zh) * 2004-03-15 2009-04-22 武汉矽感科技有限公司 一种二维条码编解码方法
JP2007279786A (ja) * 2006-04-03 2007-10-25 Fuji Xerox Co Ltd 情報端末装置及びプログラム

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0572989A2 (fr) * 1992-06-01 1993-12-08 Symbol Technologies, Inc. Enregistrement avec données codées
US6606396B1 (en) * 1999-06-18 2003-08-12 Denso Corporation Method and apparatus for detecting forgery

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110275132A (zh) * 2019-06-18 2019-09-24 西京学院 一种基于二维码映射的室内定位方法
CN110275132B (zh) * 2019-06-18 2023-03-28 西京学院 一种基于二维码映射的室内定位方法

Also Published As

Publication number Publication date
EP2084648A1 (fr) 2009-08-05
FR2908203B1 (fr) 2009-04-24
WO2008065267A1 (fr) 2008-06-05
US20110053639A1 (en) 2011-03-03

Similar Documents

Publication Publication Date Title
FR2908203A1 (fr) Procedes et dispositifs d'authentification d'un produit et d'un code bidimensionnel et application nouvelle d'un code bidimensionnel.
EP2054836B1 (fr) Procedes et dispositifs de securisation et d'authentification de documents
US10373033B2 (en) Two dimensional barcode and method of authentication of such barcode
EP2036002B1 (fr) Procede et dispositif de securisation de documents
US9406010B2 (en) Producing, capturing and using visual identification tags for moving objects
CN101167084B (zh) 使用了点图案的信息输入输出方法
EP2150923B1 (fr) Procède et dispositif de sécurisation de documents
CN109190736B (zh) 防伪二维码及其生成方法和生成应用系统
EP2294558B1 (fr) Procédé et dispositif d'identification d'une plaque d'impression d'un document
FR2631182A1 (fr) Code binaire dynamiquement variable lisible par une machine et procede pour sa lecture et sa production
EP2596479A1 (fr) Procédés et dispositifs de marquage et d'authentification d'un produit par un consommateur
CN113313225B (zh) 基于稀疏点阵码的防伪方法
FR2904130A1 (fr) Procedes et dispositifs de securisation et d'authentification de documents
EP2909817A1 (fr) Procédés, dispositifs et document d'identification d'une personne ou d'un animal
CN113761407A (zh) 一种农产品溯源二维码编码及过程识别终端应用系统
Weng et al. Design and implementation of barcode management information system
CN109344937A (zh) 一种图形编码的生成、识别方法及装置
CN109299770B (zh) 防伪二维码及其激光全息图加密方法和生产应用系统
FR2910158A1 (fr) Procede de lecture de codes visuels
FR2957705A1 (fr) Procede et dispositif de securisation de carte a microcircuit et carte le comportant
FR2662527A1 (fr) Dispositif pour executer des operations sur un code binaire et procede pour former ce code binaire optiquement lisible par une machine.

Legal Events

Date Code Title Description
TP Transmission of property
ST Notification of lapse

Effective date: 20120731