Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/LocalSettings.php on line 193

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/LocalSettings.php on line 197

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/includes/parser/Parser.php on line 2338

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/includes/parser/Parser.php on line 2338

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/includes/parser/Parser.php on line 2338

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/includes/parser/Parser.php on line 2338

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/includes/parser/Parser.php on line 2338

Warning: putenv() has been disabled for security reasons in /home/users4/d/debrouilloweb/www/wikidebrouillard/includes/parser/Parser.php on line 2338
[ Wikidébrouillard ] Arduino : Le cahier de programmation

Arduino : Le cahier de programmation

De Wikidebrouillard.

Ligne 460 : Ligne 460 :
</pre>
</pre>
-
<b>Note :</b> Un "if" test si la condition entre parenthèse est vraie ou fausse.  
+
<b>Note :</b> Un "if" test si la condition entre parenthèse est vraie ou fausse. Ainsi, le premier exemple ne vérifiera que si la variable vaut HIGH (ou +5V) mais pas il n'est pas possible d'avoir un autre état différent de vrai ou faux.
 +
 
 +
===switch... case===
 +
La structure switch... case (commutateur de cas) permet de dresser une lister de test ou de cas (comme le "if") et d'exécuté le code correspondant si un des cas du test est vrai. La principale différence entre le switch... case et le if... else est que le switch... case permet de continuer les tests même si un des cas est vrai, contrairement au if...else qui quittera dans le même cas.
 +
 
 +
<pre>
 +
switch (someVariable)
 +
{
 +
  case A : doSomething;
 +
  case B : doOtherSomething;
 +
}
 +
</pre>
 +
 
 +
someVariable sera comparée à A, si le test est vrai, doSomething sera exécuté. Une fois le code exécuté (ou si le test est faux), "someVariable" sera comparé à B et ainsi de suite. Dans le cas où on voudrait s'arrêter à un des cas, on ajoutera l'instruction <i>break;</i>. De plus, si aucun des cas n'est vérifié, on peut ajouter le cas <i>default</i> qui sera exécuté si aucun test n'est vrai.
 +
 
 +
<pre>
 +
switch (someVariable)
 +
{
 +
  case A : doSomethingA;      //si someVariable vaut A, doSomethingA est exécuté
 +
              break;                //une fois le code exécuté, on sort de la structure
 +
  case B : doSomethingB;    //en l'absence de "break", si someVariable est égale à B puis à C
 +
  case C: doSomethingC;    //doSomethingB et doSomethingC seront exécutés
 +
 
 +
default : doSomethingByDefault  //dans le cas où aucun cas ne serait vérifié,
 +
                                                  //doSomethingByDefault sera exécuté puis on sortira de la structure
 +
}
 +
</pre>
 +
 
 +
<b>Note :</b> Il n'est pas nécessaire que les cas soit dans l'ordre chronologique ou du plus petit au plus grand.
 +
 
===for===
===for===
 +
La structure for (pour) est utilisée afin de répéter une série d'instructions (comprise entre les accolades) le nombre de fois voulu. Un compteur à incrémenter est souvent utilisé afin de sortir de la boucle une fois le nombre de tour fait. Cette structure est composée de trois parties séparées par un point-virgule (;) dans l'entête de la boucle :
 +
 +
<pre>
 +
for (initialisation; condition; expression d'incrémentation)
 +
{
 +
  doSomething;
 +
}
 +
</pre>
 +
 +
L'initialisation d'une variable locale, ou compteur d'incrémentation, permet d'avoir une variable ne servant qu'une fois dans le programme. A chaque tour de boucle, la condition de l'entête est testée. Si cette condition est vraie, doSomething est exécuté ainsi que l'expression d'incrémentation et la condition est de nouveau testée. Quand la condition devient fausse, la boucle prend fin.
 +
 +
L'exemple suivant commande avec un entier i à 0, on vérifie s'il est inférieur à 20 et si c'est vrai, on l'incrémente de 1 et on exécute le programme contenu dans les accolades :
 +
 +
<pre>
 +
for (int i = 0; i<20; i++)
 +
{
 +
  digitalWrite(13, HIGH);
 +
  delay(250);
 +
  digitalWrite(13,LOW);
 +
  delay(250);
 +
}
 +
</pre>
 +
 +
<b>Note :</b> Dans le langage C (d'où découle arduino), la boucle for est beaucoup plus flexible que dans les autres langages (par exemple le Basic). Certains (voire tous) éléments parmi les 3 de l'entête peuvent être oublié, seuls les points-virgules sont indispensables. Chacune des expressions (initialiation, condition et incrémentation) peut être une expression en C avec des variables différentes. Ce genre de cas rares peut être la solution pour certains problèmes de programmations également rares.
 +
===while===
===while===
 +
La boucle "while" (tant que) continuera infiniment tant que l'expression entre parenthèse est vraie. Quelque chose doit changer afin de modifier la condition sinon le programme ne sortira jamais de la boucle while. Cela peut être dans le code, comme l'incrémentation d'une variable, ou une condition extérieur, comme le test d'un capteur.
 +
 +
<pre>
 +
while (someVariable ?? valeur)
 +
{
 +
  doSomething;
 +
}
 +
</pre>
 +
 +
L'exemple suivant test si "someVariable" est inférieur à 200 et si c'est vrai, le code entre les accolades est exécuté et la boucle continue tant que "someVariable" est inférieur à 200.
 +
 +
<pre>
 +
while (someVariable < 200)    //test si "someVariable" est inférieur à 200
 +
{
 +
  doSomething;            //exécution du code
 +
  someVariable++      //incrémentation de "someVariable" par 1
 +
}
 +
</pre>
 +
===do... while===
===do... while===
 +
La boucle do... while (faire... tant que) fonctionne de la même façon que la boucle while, à la seule exception que la condition est testée à la fin de la boucle, de ce fait le code dans la boucle s'exécute toujours au moins une fois.
 +
 +
<pre>
 +
do
 +
{
 +
  doSomething;
 +
} while (someVariable ?? valeur);
 +
</pre>
 +
 +
L'exemple suivant assigne à la variable "x" la valeur lireCapteur() (readSensors() ), puis fait une pause de 50 milli-secondes et continue infiniment tant que x est plus petit que 100.
 +
 +
<pre>
 +
do
 +
{
 +
  x = lireCapteur();    //assignation de la valeur de lireCapteur à x
 +
  delay(50);              //pause durant 50 milli-secondes
 +
} while (x < 100);    //on recommence la boucle si x est inférieur à 100
 +
</pre>
 +
==Entrées et Sorties numériques (digital i/o)==
==Entrées et Sorties numériques (digital i/o)==
===pinMode(pin, mode)===
===pinMode(pin, mode)===

Version du 2 juin 2015 à 11:29

Traduction par Antony Auffret du "Arduino Programming Notebook", écrit et compilé par Brian W. Evans

Ce cahier est une référence de programmation pratique, facile a utiliser pour la structure des programmes et les bases de la syntaxe du microcontroleur Arduino.

Pour le garder simple, certaines exclusions ont été faites pour faire de ce cahier une référence, pour les débutants. Il est très utile comme source complémentaire de d'autres sites web, livres, ateliers ou classes.

Cette décision a conduit à une sélection d'utilisations autonomes d'Arduino ce qui, par exemple, exclue les usages les plus complexes des tableaux ou des formes avancées de communication série.

Ce livre débute avec les structure de base du langage de programme Arduino dérivé du C. Il se poursuit en décrivant la syntaxe des éléments les plus commun, et illustre leurs utilisations avec des exemples et morceaux de programmes. Cela inclue plusieurs fonctions de la bibliothèque principale, suivie par un appendice avec des schémas et des débuts de programmes.

Sommaire

Structure

La structure de base du langage de programmation Arduino est assez simple et comprend au moins deux parties. Ces deux parties, ou fonctions, contiennent des blocs d'instructions.

void setup()
{
blocs d'instructions;
}

void loop()
{
blocs d'instructions;
}

Setup() est la préparation, l'initialisation du programme et loop est l'exécution du programme. Ces deux fonctions sont impérativement requises pour que le programme fonctionne.

La fonction setup() doit suivre la déclaration des variable au tout début du programme. Il s'agit de la première fonction à exécuter dans le programme. Elle est exécutée une seule fois et sert à établir le mode d'une broche (pinMode) ou à initialiser la communication série.

La fonction loop() suit immédiatement et comprend le code à exécuter en continue - lisant les capteurs en entrée et déclenchant les actionneurs en sortie, etc. Cette fonction est le noyau de tout programme Arduino et réalise l'essentiel du travail.

initialisation du programme : setup()

La fonction setup() n'est appelée qu'une fois au démarrage du programme. Utilisez-là pour initialiser le mode des broches ou fixer le débit de communication série. Il doit être dans tout les programmes même si il n'y a aucune instruction à jouer.

void setup()
{
pinMode(broche, OUTPUT); //met la "broche" comme sortie
}

Boucle du programme : loop()

Après avoir appelé la fonction void setup(), la fonction void loop() fait une boucle (loop en anglais) infinie permettant de contrôler la carte arduino, tant que le programme ne change pas.

void loop() 
{
digitalWrite(broche, HIGH);  //met la broche en "ON"
delay(1000);                        //pause pendant une seconde
digitalWrite(broche, LOW);   //met la broche en "OFF"
delay(1000);                        //pause pendant une seconde
}

Les fonctions : blocs de code particuliers

Une fonction est un bloc de code possédant un nom et exécutant ses instructions à chaque appel. Les fonctions void setup() et void loop() sont les 2 fonctions obligatoires en arduino, mais d'autres peuvent être créées.

Il est possible de créer des fonctions afin d'améliorer des programmes répétitifs et pour rendre plus compréhensif un programme. On commence par donner un type aux fonctions. Il s'agit du type de valeur qui sera renvoyée par la fonction, par exemple un "int" donnera une fonction de type entier (integer). Si aucune valeur n'est renvoyée, le type est void (void setup()/void loop() ). Après le type, on attribue un nom à la fonction puis, dans les parenthèses, on donne les paramètres passées à la fonction.

type nomFonction(paramètres)
{
instructions;
}

La fonction entière (int) suivante, delayVal(), va permettre de changer l'intervalle de la valeur lue sur le potentiomètre. On commence par déclarer une variable locale v, elle contient la valeur du potentiomètre, c'est à dire entre 0 et 1023. On divise cette valeur par 4 afin de passer à une valeur comprise entre 0 et 255 puis on renvoie cette valeur au programme.

int delayVal()
{
int v;      //création de la variable locale "v"
v = analogRead(pot);      //lecture de la valeur du potentiomètre
v /= 4;      //conversion de 0-1023 à 0-255
return v;      //renvoie de la valeur finale
}

Les accolades : {}

Les accolades (ouvrantes ou fermantes) définissent le début et la fin d'une fonction ou d'un bloc d'instructions, comme pour la fonction void loop() ou les instructions if et for.

type fonction()
{
instructions;
}

Une accolade ouvrante { est toujours suivie par une accolade fermante }. Une accolade non fermée donne des erreurs ou des programmes lors de la compilation mais peut être dure à corriger en cas de programmes très longs.

L'environnement arduino inclue un système de vérification des accolades. Il suffit de cliquer sur une accolade pour voir sa "paire" se sur-ligner.

Le point-virgule : ;

Le point-virgule est utilisé pour finir une instruction et séparer les éléments d'un programme. On l'utilise, par exemple, pour séparer les éléments de la boucle for.

int x = 13;     //on déclare la variable x comme un entier valant 13

Note : Oublier le point-virgule à la fin d'une ligne donne une erreur de compilation. Le message d'erreur peut parfois faire référence au point-virgule oublié, mais pas toujours. Si le message d'erreur est illogique et incompréhensible, une des premières choses à faire est de vérifier s'il n'y a pas un point-virgule manquant.

Les paragraphes de commentaire/*...*/

Un commentaire (sur une ligne ou sur plusieurs) est une zone de texte qui est ignoré par le programme lors de la compilation et qui est utilisé afin de décrire le code ou pour le commenter pour faciliter sa compréhension auprès de personnes tiers. Un commentaire commence par /* et fini avec */ et peut faire plusieurs ligne.

/*  ceci est un paragraphe de commentaire commencé
     ne pas oublier de le refermer
*/

De par le fait que les commentaires soient ignorés et qu'ils ne prennent pas d'espace mémoire, ils peuvent être utilisés généreusement, par exemple pour débuger une partie du code.

Note : Il est possible de faire un paragraphe d'une seule ligne avec /* */ mais on ne peut pas inclure un second bloc dans le premier.

Les lignes de commentaires : //

Une seule ligne de commentaire commence par // et fini à la fin de la ligne de code. Tout comme le paragraphe de commentaires, la ligne est ignorée lors de la compilation et ne prend pas de mémoire.

//ceci est une ligne de commentaires

La ligne de commentaire est souvent utilisée pour donner des informations ou pour rappeler quelque chose à propos d'une ligne.

Variables

Les variables

Une variable est une façon de nommer et de stocker une information/valer afin de l'utiliser plus tard dans le programme. Comme leur nom l'indique, une variable est une valeur qui peut être continuellement modifiée à l'opposé d'une constante qui ne change jamais de valeur. Une variable a besoin d'être déclarée et on peut lui assigner une valeur que l'on veut stocker, mais cela est optionnel. Le code suivant déclare une variable nommé inputVariable et lui assigne une valeur lue via analogRead sur la broche 2.

int inputVariable = 0;   //déclare la variable et lui assigne la valeur 0

inputVariable = analogRead(2);   //assigne la valeur de la broche analogique 2 à la variable

"inputVariable" est une variable. La première ligne donne le type de la valeur contenue : int (diminutif de integer, entier). La seconde ligne assigne la valeur de la broche analogique 2 à cette variable. Cela permet de rendre accessible dans le code la valeur de la broche analogique 2.

Une fois que la variable a été assignée ou ré-assignée, il est possible de la tester pour voir si elle remplie certaines conditions ou de l'utiliser directement. Afin d'illustrer 3 opérations habituelles sur les variables, le code suivant vérifie si inputVariable est plus petit que 100, si oui elle lui assigne la valeur 100 et le programme marque une pause de inputVariable millisecondes, au minimum 100 donc.

if (inputVariable < 100)     //on vérifie si la variable est plus petite que 100
{
   inputVariable = 100;      //si oui, on lui attribue la valeur 100
}
delay(inputVariable);        //on utilise la variable comme temps de pause (fonction delay() )

Note : Pour rendre le code plus lisible, on peut donner aux variable un nom explicatif. Les noms de variables tels que boutonAppuie (pushButton) ou mouvementCapteur (tiltSensor) aident le programmateur ainsi que les personnes lisant le code afin de savoir ce que représentent les variables. Les noms de variables tels que var (pour variable) ou valeur (value) ne rendent pas vraiment le code plus lisible et ne sont utilisés que dans les exemples. Une variable peut avoir n'importe quel mot comme nom tant que celui-ci n'est pas un mot clé du langage arduino.

La déclaration des variables

Toutes les variables doivent être déclarées avant d'être utilisées. La déclaration d'une variable définie son type, tel que int, long, float, ... lui attribue un nom spécifique et peut lui assigner une valeur initiale. Cela ne doit être fait qu'une seule dans le programme, mais on peut modifier la valeur tout au long du programme par des assignations ou des opérations arithmétiques.

L'exemple suivant déclare inputVariable comme un int, ou type entier (integer) et lui assigne 0 comme valeur initiale. C'est ce qu'on appelle une simple assignation.

int inputVariable = 0;

Une variable peut être déclarée à de nombreux endroits dans le programme, l'emplacement de sa déclaration détermine quelles parties du programme auront accès à cette variable.

Visibilité des variables pour le programme

Une variable peut être déclarée au début du programme avant l'initialisation (Void setup() ), à l'intérieur de fonctions et parfois au sein d'un bloc d'instruction comme les boucles. La zone où la variable est déclarée détermine la "visibilité" de celle-ci, autrement dit la possibilité pour certaines parties d'un programme à utiliser cette variable.

Une variable globale est une variable qui peut être vue et utilisée par l'ensemble du programme. Cette variable doit être déclarée au début du programme, avant la fonction void setup().

Une variable locale est une variable définie à l'intérieur d'une fonction ou dans une partie d'une boucle for. Elle est uniquement visible et utilisable à l'intérieur de la fonction où elle a été déclarée. Il est de ce fait possible d'avoir 2 variables ou plus ayant le même nom dans différentes parties du programme avec des valeurs différentes. Permettre à une seule fonction d'avoir accès à ses variables permet de réduire les erreurs potentielles de programmation.

L'exemple suivant montre comment déclarer les différents types de variables et expliquent leur visibilité :

int value;           //"value" est visible par toutes les fonctions

void setup()
{
   //no setup needed
}

void loop()
{
  for (int i=0 ; i<20 ;)   //"i" est uniquement visible à l'intérieur de la boucle for
  {
     i++;
  }
  float f;   //"f" est uniquement visible dans la fonction void loop()
}

type de données

byte

Byte permet de stocker une valeur entière sur 8 bits (pas de chiffre à virgule donc). Cela permet d'aller de 0 à 255.

byte someVariable = 180;    //déclare "someVariable" en tant que byte

int

Int (pour integers, entier) est le type de base pour les chiffres (sans virgule) des variables. Le stockage se fait sur 16 bits, permettant d'aller de 32 767 à - 32 768.

int someVariable = 1500;  //déclare "someVariable" en tant que int

Note : Si la valeur maximale ou minimale est passée pour le type int, sa valeur sera reportée. C'est à dire, si x = 32767 et que l'on y ajoute 1, x = x + 1 ou x ++, x vaudra alors - 32768.

long

Il s'agit d'un type de variable de grande taille : la donnée (chiffre sans virgule) est stockée sur 32 bits. Cela permet d'aller de 2 147 483 647 à - 2 147 483 648.

long someVariable = 90000;   //déclare "someVariable" en tant que long

float

Ce type permet de stocker les chiffre "flottant" ou chiffre à virgule. Les float bénéfice d'une meilleure résolution que les entiers (int) : ils sont stockés sur 32 bits, soit de 3,4028235^38 à - 3,4028235^38.

float someVariable = 3,14;   //déclare "someVariable" en tant que chiffre flottant

Note : Les chiffres flottants ne sont pas exacts et il arrive que des résultats étranges ressortent de leur comparaison. De plus, réaliser des opérations mathématiques dessus est plus lents que sur des entiers, il est conseillé d'éviter si possible.

bool

Le type bool prend 2 valeurs : Vrai (true) ou Faux (false). Il est stocké sur 8 bits et se comporte ainsi :

  • si la valeur est 0, il sera vu comme Faux
  • si la valeur est 1 ou plus, il sera vu comme Vrai
bool someVariable = false;  //la valeur est 0 donc false (faux)

char

Le type char est utilisé pour stocker une lettre. Le stockage se fait sur 8 bits et permet de stocker une seule lettre.

char someVariable = 'A';    //déclare someVariable en tant que lettre

Note : Pour assigner une valeur à la variable char, on l'écrira entre '.

unsigned

Il ne s'agit pas d'un type de variable à proprement dit mais d'un ajout permettant de supprimer les chiffres négatifs (on ne garde que les chiffres non-signés, les positifs). Cela permet d'avoir plus de place pour stocker les chiffres positifs. Par exemple :

  • au lieu d'aller de 32 767 à - 32 768, un int couvrira l'intervalle de 0 à 65 535
  • au lieu d'aller de 2 147 483 647 à - 2 147 483 648, un long couvrira l'intervalle de 0 à 4 294 967 295
  • ...
unsigned int someVariable = 65534;  //la variable est un entier non-signé valant 65534

arrays

Un tableau est une collection de valeur dont on accède via un index. Afin d'avoir accès aux valeur contenues dans le tableau, il faut appeler le nom du tableau et le numéro d'index de la valeur. Les tableaux possèdent l'index 0 : il s'agit de la première valeur stockée. Un tableau, comme une variable, a besoin d'être déclaré mais l'assignation est facultative avant son utilisation.

int monTableau[] = {valeur0, valeur1, valeur2, ... };

Il est également possible de déclarer le tableau uniquement en lui donnant un type et une taille et d'assigner plus tard des valeurs aux index.

int monTableau[5];      //déclaration d'un tableau d'entier avec 6 cases
monTableau[3] = 10;    //on assigne à la 4e case la valeur 10

Pour sortir une valeur d'un tableau, on assigne à une case du tableau une variable :

x = monTableau[3];     //x vaut maintenant 10

Les tableaux sont souvent utilisés dans la boucle for, où le compteur est utilisé pour choisir la case du tableau et atteindre la valeur. L'exemple suivant utilise un tableau pour modifier l'éclairage d'une LED. Le compteur, dans la boucle for, commence à 0, écrit la valeur contenu dans la case 0 du tableau eclairage[], c'est à dire 180, à la broche 10. Puis marque une pause de 200ms et continue à la case suivante.

int brocheLED = 10;      //la LED est sur la broche 10
byte eclairage[] = {180, 30, 255, 200, 10, 90, 150, 60};
               //tableau avec 8 cases contenant des valeurs différentes

void setup()
{
  pinMode(brocheLED,OUTPUT);
}

void loop ()
{
  for(int i=0;i<7;i++)   //chaque valeur du tableau
  {                      //est envoyée à la broche où
    analogWrite(brocheLED, eclairage[i]); //est reliée la LED
    delay(200);          //avant de faire une pause de 200 millisecondes
  }          
}

String

Il ne s'agit pas exactement d'un type de variable, il s'agit d'une classe. La classe String est comparable a une variable possédant ses propres fonctions. String permet de stocker une chaîne de caractères, comme pourrait le faire un tableau de caractère.

String someVariable = "Aux sciences, citoyens";    //someVariable contient la chaîne de caractères

String permet de réaliser des opérations sur les chaînes de caractères plus complexes que ce qui se ferait sur un tableau de caractères. Dans l'exemple qui suit, on va passer un nombre en String, compter le nombre de caractère qui le compose et réaliser la comparaison avec un second String.

String chaineDeNombre = String(245);  //chaineDeNombre contient "245"

int nombreCaractère = chaineDeNombre.length();   //nombreCaractère vaut 3

int compare = someVariable.compareTo(chaineDeNombre);
                //compare vaudra :
                //un nombre négatif si someVariable vient avant chaineDeNombre
                //0 si someVariable et chaineDeNombre sont égaux
                //un nombre positif si someVariable vient après chaineDeNombre

Quand on parle de "venir avant", cela est lié à la place de chaque caractère en informatique : les chiffres viennent avant les lettres et les majuscules avant les minuscules.

Note : Les String fonctionnent en allocation dynamique de mémoire : la taille maximale n'est pas définie à la création, il faut donc faire attention à ne pas dépasser la taille maximum de mémoire autorisé par une carte/par une machine.

arithmétique

L'arithmétique

Les opérations d'arithmétique incluent les additions, les soustractions, les multiplications et les divisions. Elles retournent respectivement la somme, la différence, le produit et le quotient des 2 opérants.

y = y + 3;
x = x - 7;
r = r / 5;
i = j * 6;

L'opération est réalisée en utilisant les types de données des opérants, de façon à ce que, par exemple, 9 / 4 donnera 2 plutôt que 2,25 car 9 et 4 sont des entiers (int), or le type "int" ne peut être un chiffre à virgule. Cela veut aussi dire que le résultat peut être trop grand pour le type de variable initiale.

Si les opérants sont de différents types, le type le plus grand est utilisé pour le calcul. Par exemple, si un des nombres (opérant) est de type "float" et l'autre de type "int", c'est le type "float" qui sera utilisé lors de l'opération.

Il faut donc faire bien attention lors du choix des types de variables afin que le résultat ne soit pas trop grand lors du calcul. Il faut donc savoir jusqu'à combien (aussi bien dans les positifs que dans les négatifs) la variable peut aller, par exemple 0 ou 1 ou de 0 à - 32768. Pour réaliser des opérations sur des fractions, on utilisera des "float", l'inconvénient étant que des grandes variables entrainent des calculs lents.

Note : Pour passer d'un type de variable à un autre, on utilisera l'opérateur de cast, c'est à dire (int)monFloat convertira monFloat en int. Par exemple :

i = (int)3,6

fixera i à la valeur 3.

Opérateurs d'incrémentation

Les opérateurs d'incrémentation permettent de réaliser une opération simple, ils sont communément utilisés dans la boucle for, voir plus bas. Il en existe 2 : l'incrémentation et la décrémentation.

x ++    //équivaut à x = x + 1 ou d'incrémenter x par 1
x --     //équivaut  à x = x - 1 ou de décrémenter x par 1

Opérateurs d'assignation

Les opérateurs d'assignations sont la combinaison entre une assignation et une opération, de la même sorte que les opérateurs d'incrémentation.

x += y  //équivaut à x = x + y ou d'incrémenter x par y
x -= y   //équivaut à x = x - y ou de décrémenter x par y
x *= y   //équivaut à x = x * y ou de multiplier x par y
x /= y   //équivaut à x = x / y ou de diviser x par y

Note : Par exemple, x *= 3 va multiplier l'ancienne valeur de x par 3 et ré-assigner la nouvelle valeur à x.

Opérateur de comparaison

La comparaison d'une variable ou d'une constante avec une autre est souvent utilisée afin de tester si une condition spécifique est vraie ou non. Dans les exemples suivants, l'opérateur est utilisé pour indiqué une condition :

x == y  //x est égal à y
x != y   //x n'est pas égal à y
x < y   //x est plus petit que y
x > y   //x est plus grand que y
x <= y //x est plus petit ou égal à y
x >= y //x est plus grand ou égal à y

Opérateurs logiques

Les opérateurs logiques sont utilisés pour comparer deux expressions/conditions. Ils renvoient TRUE (vrai) ou FALSE (faux) selon l'opération. Il y a trois opérateurs logiques : AND (et), OR (ou) et NOT (contraire), ils sont souvent utilisés dans les if (voir plus bas) :

AND :

if (x > 0 && x < 5)    //vrai seulement si les deux conditions sont vraies

OR :

if (x > 0 || y > 0)    //vrai si une des condition est vraie

NOT :

if (!x > 0)    //vrai seulement si la condition est fausse

Constantes

Les constantes

Le langage arduino possède des valeurs prédéfinies; elles sont appelée constantes. Elles sont utilisées pour rendre un programme plus simple à lire. Il en existe différent groupe.

Vrai/faux (true/false)

Il s'agit de variable du type booléen. FALSE signifie que la constante est à 0 alors que TRUE désigne l'état différent de 0 : cela peut être 1 (par convention) mais cela peut aussi être -1, 2, -200, ...

if (b == TRUE)
{
   doSomething;
}

Haut/bas (high/low)

Il s'agit des constantes utilisées pour lire ou pour écrire sur les broches, soit le niveau HIGH (ON, 1, 5 volts) soit le niveau LOW (OFF, 0, 0 volts).

digitalWrite(13,HIGH);

Entrée/sortie (input/output)

Ces constantes sont utilisées avec la fonction pinMode(), elles définissent le type de broche digitale :

  • INPUT pour entrée
  • OUTPUT pour sortie
pinMode(13, OUTPUT);

Structures de contrôle

if

La structure de test "if" (si) vérifie si une certaine condition est atteinte, par exemple si une valeur est égale à un certain nombre, et exécute des instructions contenu dans la structure. Si la condition est fausse, le programme quitte la structure et reprend à la ligne suivante. Le format du if est :

if (someVariable ?? valeur)
{
   doSomething;
}

L'exemple précédent compare someVariable avec une autre valeur pouvant être une variable ou une constante. Si la comparaison, ou la condition entre parenthèse est vraie, les instructions entre les accolades sont exécutées. Sinon, le programme quitte la structure et continue après l'accolade fermante.

Note : Attention à l'utilisation du "=" tel que
if( x = 10 )
, qui est grammaticalement valide, cela assigne la valeur 10 à la variable x et le résultat est toujours vraie. Cependant, il faut utiliser "==" tel que
if( x == 10 )
afin de tester si x est égal à 10. Moyen mémo-technique : "=" est "égale" alors que "==" est "est-il égale à".

if... else

if... else (si...sinon) est utilisé pour dire "sinon fait...". Par exemple, si on veut tester une entrée digitale et faire ne action si elle vaut HIGH et d'autres actions si elle vaut LOW, on écrira :

if (inputPin == HIGH)
{
   doThingA;
}
else
{
   doThingB;
}

else peut précéder un autre test avec un "if", on peut ainsi en mettre une multitude qui seront exécutés les uns après les autres. Il est aussi possible d'avoir un nombre infini de branche "else". Cependant, il faut garder à l'esprit qu'une seule partie des instructions sera exécutée, selon les conditions vérifiées.

if (inputPin < 500)
{
  doThingA;
}
else if (inputPin >= 1000)
{
  doThingB;
}
else
{
  doThingC;
}

Note : Un "if" test si la condition entre parenthèse est vraie ou fausse. Ainsi, le premier exemple ne vérifiera que si la variable vaut HIGH (ou +5V) mais pas il n'est pas possible d'avoir un autre état différent de vrai ou faux.

switch... case

La structure switch... case (commutateur de cas) permet de dresser une lister de test ou de cas (comme le "if") et d'exécuté le code correspondant si un des cas du test est vrai. La principale différence entre le switch... case et le if... else est que le switch... case permet de continuer les tests même si un des cas est vrai, contrairement au if...else qui quittera dans le même cas.

switch (someVariable) 
{
  case A : doSomething;
  case B : doOtherSomething;
}

someVariable sera comparée à A, si le test est vrai, doSomething sera exécuté. Une fois le code exécuté (ou si le test est faux), "someVariable" sera comparé à B et ainsi de suite. Dans le cas où on voudrait s'arrêter à un des cas, on ajoutera l'instruction break;. De plus, si aucun des cas n'est vérifié, on peut ajouter le cas default qui sera exécuté si aucun test n'est vrai.

switch (someVariable)
{
  case A : doSomethingA;      //si someVariable vaut A, doSomethingA est exécuté
               break;                 //une fois le code exécuté, on sort de la structure
  case B : doSomethingB;     //en l'absence de "break", si someVariable est égale à B puis à C
  case C: doSomethingC;     //doSomethingB et doSomethingC seront exécutés

 default : doSomethingByDefault  //dans le cas où aucun cas ne serait vérifié, 
                                                   //doSomethingByDefault sera exécuté puis on sortira de la structure
}

Note : Il n'est pas nécessaire que les cas soit dans l'ordre chronologique ou du plus petit au plus grand.

for

La structure for (pour) est utilisée afin de répéter une série d'instructions (comprise entre les accolades) le nombre de fois voulu. Un compteur à incrémenter est souvent utilisé afin de sortir de la boucle une fois le nombre de tour fait. Cette structure est composée de trois parties séparées par un point-virgule (;) dans l'entête de la boucle :

for (initialisation; condition; expression d'incrémentation)
{
  doSomething;
}

L'initialisation d'une variable locale, ou compteur d'incrémentation, permet d'avoir une variable ne servant qu'une fois dans le programme. A chaque tour de boucle, la condition de l'entête est testée. Si cette condition est vraie, doSomething est exécuté ainsi que l'expression d'incrémentation et la condition est de nouveau testée. Quand la condition devient fausse, la boucle prend fin.

L'exemple suivant commande avec un entier i à 0, on vérifie s'il est inférieur à 20 et si c'est vrai, on l'incrémente de 1 et on exécute le programme contenu dans les accolades :

for (int i = 0; i<20; i++)
{
  digitalWrite(13, HIGH);
  delay(250);
  digitalWrite(13,LOW);
  delay(250);
}

Note : Dans le langage C (d'où découle arduino), la boucle for est beaucoup plus flexible que dans les autres langages (par exemple le Basic). Certains (voire tous) éléments parmi les 3 de l'entête peuvent être oublié, seuls les points-virgules sont indispensables. Chacune des expressions (initialiation, condition et incrémentation) peut être une expression en C avec des variables différentes. Ce genre de cas rares peut être la solution pour certains problèmes de programmations également rares.

while

La boucle "while" (tant que) continuera infiniment tant que l'expression entre parenthèse est vraie. Quelque chose doit changer afin de modifier la condition sinon le programme ne sortira jamais de la boucle while. Cela peut être dans le code, comme l'incrémentation d'une variable, ou une condition extérieur, comme le test d'un capteur.

while (someVariable ?? valeur)
{
  doSomething;
}

L'exemple suivant test si "someVariable" est inférieur à 200 et si c'est vrai, le code entre les accolades est exécuté et la boucle continue tant que "someVariable" est inférieur à 200.

while (someVariable < 200)    //test si "someVariable" est inférieur à 200
{
  doSomething;            //exécution du code
  someVariable++       //incrémentation de "someVariable" par 1
}

do... while

La boucle do... while (faire... tant que) fonctionne de la même façon que la boucle while, à la seule exception que la condition est testée à la fin de la boucle, de ce fait le code dans la boucle s'exécute toujours au moins une fois.

do
{
  doSomething;
} while (someVariable ?? valeur);

L'exemple suivant assigne à la variable "x" la valeur lireCapteur() (readSensors() ), puis fait une pause de 50 milli-secondes et continue infiniment tant que x est plus petit que 100.

do
{
  x = lireCapteur();    //assignation de la valeur de lireCapteur à x
  delay(50);               //pause durant 50 milli-secondes
} while (x < 100);     //on recommence la boucle si x est inférieur à 100

Entrées et Sorties numériques (digital i/o)

pinMode(pin, mode)

digitalRead(pin)

digitalWrite(pin, value)

Entrées et Sorties analogiques (analog i/o)

analogRead(pin)

analogWrite(pin, value)

Gestion de la durée

delay(ms)

millis()

math

min(x,y)

max(x,y)

hasard

randomSeed(seed)

random(min, max)

Communication avec le port série

serial.begin(débit)

serial.println(donnée)

appendice

sortie numérique

Entrée numérique

Courant de sortie haut

Sortie pwm(Pulse Width Modulation - modulation de largeur d'impulsions)

Arduino permet de synthétiser un signal analogique grâce à la modulation de largeur d'impulsions(Pulse Width Modulation ou PWM)

Entrée potentiomètre

Entrée résistance variable

Sortie Servo-moteur

Crédits

Ce livre a été écrit à partir d'inspirations et d'informations tirées des sites web suivants :

Incluant des éléments écrits par :

  • Massimo Banzi
  • Hernando Barragan
  • David Cuartielles
  • Tom Igoe
  • Daniel Jolliffe
  • Todd Kurt
  • David Mellis
  • and others...

Première édition publiée en août 2007 sous licence CC-By-Nc-Sa

AR

Arduino : Le cahier de programmation

Rechercher

Page Discussion Historique
Powered by MediaWiki
Creative Commons - Paternite Partage a l

© Graphisme : Les Petits Débrouillards Grand Ouest (Patrice Guinche - Jessica Romero) | Développement web : Libre Informatique