Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : Division Binaire pour CRC [ Algorithme / Maths ] (raph004)

vendredi 2 mai 2008 à 09:53:04 | Division Binaire pour CRC

raph004

Bonjour,

Je recherche le code d'un fonction qui renverrais le reste d'une division binaire en C.
C'est pour gérer du contrôle CRC.
Pourriez-vous me donner un code simple qui effectue cette division ou une méthode "codable" facilement en C.

Merci

vendredi 2 mai 2008 à 15:27:18 | Re : Division Binaire pour CRC

raph004

ReBonjour,

Après quelques heures de recherche, j'ai compris dans les grande ligne le fonctionnement du CRC et je pense savoir comment faire tourner le programme à la main.
Mon problème maintenant c'est de récupérer le binaire d'une chaine de caractère.

C'est à dire que j'ai mes données qui sont sous forme d'une chaine de caractère et si je veux y appliquer mon CRC je doit la voir comme une suite de chiffres binaires et non plus comme une suite de caractères.

Donc si quelqu'un sais comment on manipule du binaire en C, ça m'aiderais grandement dans ma tâche.

Merci

vendredi 2 mai 2008 à 16:16:20 | Re : Division Binaire pour CRC

jfrancois

Bonjour,

C'est à dire ? La chaîne "ABC" devient :
la chaîne "414243" ("41" = code de "A", ...)
ou
la chaîne "010000010100001001000011" ("01000001" = code de "A", ...)
ou autre ?

Jean-François


lundi 5 mai 2008 à 08:34:04 | Re : Division Binaire pour CRC

raph004

Bonjour,

Oui en effet c'est comme cela que je l'entend.
Mais donc y a t-il un moyen de travailler sur ce binaire sachant que ma chaine de caractère risque d'avoir quelques dizaine de caractère. Je désire utiliser ce binaire pour faire un calcule de CRC afin de vérifier qu'une transmission s'est effectué sans problème.

Merci

lundi 5 mai 2008 à 09:44:21 | Re : Division Binaire pour CRC

jfrancois

Bonjour,

Et ce calcul ne peut pas être fait directement sur le code ASCII des caractères ?
Pourquoi le convertir lui-même en ASCII ?

Jean-François


lundi 5 mai 2008 à 10:53:11 | Re : Division Binaire pour CRC

raph004

Hey bien en fait le principe du CRC (Cyclic Redundancy Check) consiste à faire une division binaire(par un polynome définie) des informations à envoyer. Ensuite le reste de cette division est ajouté à la trame qui est envoyée.
De l'autre coté le recepteur effectue cette même division binaire, puis compare son reste à celui de la trame reçu, si il sont différent, c'est qu'une erreur de transmission s'est produite.

Donc je pense que cela n'est faisable que sur le binaire. C'est pourquoi je cherche à manipuler du binaire.

Merci


lundi 5 mai 2008 à 23:58:27 | Re : Division Binaire pour CRC

jfrancois

Voilà l'un des calculs de CRC (CRC16 CCITT) que j'ai trouvé sur Internet. Le code des caractères (ou autres données) est utilisé directement !

#define unsignd __int16 uint16

uint16 GetCRC16
(
    const char* pData// E:data à traiter
   ,int         iSize// E:taille des data
)                     // S:CRC16
{
   uint16 uiCRC = 0;
   for (int i=0 ; i<iSize ; ++i)
   {
      uiCRC ^= ((uint16)pData[i]) << 8;
      for (int index=0 ; index<8 ; ++index)
      {
         if (uiCRC & 0x8000)
            uiCRC = (uiCRC << 1) ^ 0x1021;
         else
            uiCRC <<= 1;
      }
   }
   return uiCRC;
}


Jean-François


mardi 6 mai 2008 à 09:50:22 | Re : Division Binaire pour CRC

raph004

Bonjour,

Merci pour  ce code, il semble interesant et semble également correspondre à mes attentes.
Cependant, je n'arrive pas à le faire fonctionner. Il me met plusieurs erreur bizares  quelques erreur qui n'ont aucun sens et pas lieu d'être (il y a notamment quelques" syntax error"). :-s
Je pense qu'il me manque la librairie (cela reglera peut-être tout les problème d'un coup) cependant je ne la trouve pas sur le net.
Si vous pouviez me donner l'endroit ou vous avez trouver ce code et/ou la librairie, cela pourrait m'aider dans mes recherche et/ou compréhension du code ainsi que son utilisation.

Merci

mardi 6 mai 2008 à 10:12:50 | Re : Division Binaire pour CRC

raph004

reBonjour,

Tout d'abord je pense que ce code est du C++.
J'ai donc esseyer de changer certaines chose pour l'adapter à du C et m'affranchir de la librairie. Voila ce que j'ai fait pour l'instant :

unisgned int GetCRC16
(
    const char* pData// E:data à traiter
   ,int         iSize// E:taille des data
)                     // S:CRC16
{
  
unisgned int uiCRC = 0;
   
int i;
    int index;
   for (i=0 ; i<iSize ; ++i)
   {
      uiCRC ^= ((uint16)pData[i]) << 8;
      for (index=0 ; index<8 ; ++index)
      {
         if (uiCRC & 0x8000)
            uiCRC = (uiCRC << 1) ^ 0x1021;
         else
            uiCRC <<= 1;
      }
   }
   return uiCRC;
}


Ca me donne un résultat cependant j'ai du mal à le vérifier.
Il me reste néanmoins un question, à quoi correspond un uint16 ?
Est un unsigned ind de 16 bits?
Donc je suis toujours prenneur de l'endroit d'où ce code proviens

Merci



mardi 6 mai 2008 à 10:12:55 | Re : Division Binaire pour CRC

jfrancois

Réponse acceptée !
Bonjour,

1) #define unsigned __int16 uint16
2) __int16 est un type spécifique Microsoft ! unsigned __int16 = unsigned short

Sinon ce code est très banal et ne nécessite aucune librairie spécifique.

Je l'ai trouvé ici : [ Lien ]
sous la réponse : Implémentation en C (loop drive). J'ai testé aussi l'implémentation suivante (table drive) qui donne les mêmes résultats (ce qui n'est pas le cas avec d'autres implémentations trouvées qui utilisent la même valeur d'initialisation et le même polynôme !).

Jean-François



1 2

Cette discussion est classé dans : code, binaire, division, crc


Répondre à ce message

Sujets en rapport avec ce message

CRC + affichage/conversion binaire [ par Ferrari01 ] Bonjour...Est-ce que quelqu'un aurait un petit programme de CRC et/ou un petit programme qui permet d'afficher 4 caractères en binaire (ex.: abcd -> e Executer du code binaire en C/C++ [ par Kstor4ever ] Bonjour, je programme une application en C++. Je charge en mémoire un code binaire (assembleur x86 koi), comment puis-je faire pour l'executer une foi Type de CheckSum CRC 32, CRC8 , CRC 64 dans un fichier binaire [ par seas ] Bonsoir a tous , Je vais faire trés simple pour permettre aux membres de cérner le probléme sur mon projet . Je dois calculer le Checksum d'un fichier HELP !!! Après plantage fichiers cpp transformés en binaire : code perdu !!!!! [ par ngryman ] J'y crois pas ! J'ai lancé mon progrmme, il a planté, une erreur windows s'est produite et j'ai redémarré mon pc, et après le fichier cpp principal de Le code binaire d'une variable [ par tybow ] Hello, Petite question: Existe-t-il une fonction qui permette d'obtenir le code binaire d'une variable? Petit exemple pour me faire comprendre: So convertir un caractères en binaire [ par BAHROUNRABII ] bonjours tous,  Je  suis débutant en Programmation et je veut créer en langage C un prog qui permet de convertir un message txt en binaire... en p CRC en caractères alphanumériques [ par genetin ] Bonjour,Je voudrais vérifier qu'une saisie au clavier d'un texte ne contient pas d'erreur, en ajoutant un code de contrôle de 2 caractères. Mais ces d MultiByteToWideChar et tous ce qui va avec [ par BEAUBRIUS ] BonjourJe suis sous windows et j'utilise VS2005Je voudrai lister les fichiers et sous repertoire d'un dossier.Apres quelque recherche a ce sujet , j'a (win32) compatibilite [ par mogwai93 ] BonjourJ'ai du code en win32 (trop long pour etre poste ici) qui fonctionne sur certaines machines et par sur d'autresj'ai testé : win98SE, Win2000, W Pb avec graphe en C++ [ par gargourifahmi ] Salut à tous,Je suis en train d'implémenter un graphe basé sur les listes d'adjacence.En première étape, j'ai essayé d'initialiser le tableau de point


Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,468 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.