Différences entre versions de « MicroPython-Hack-deparasitage »

De MCHobby - Wiki
Sauter à la navigation Sauter à la recherche
Ligne 47 : Ligne 47 :
  
 
== A la méthode Arduino ==
 
== A la méthode Arduino ==
xxx
+
Si vous êtes bien attentif au point précédent, votre programme est arrêté aussi longtemps que l'utilisateur ne presse pas le bouton.
 +
 
 +
Si cela conviendra à certaines utilisation, ce ne sera pas le cas de la plupart des programmes qui cycles en vérifiant régulièrement l'état des boutons pour savoir ce que le programme doit faire.
  
 
{{MicroPython-Hack-deparasitage-TRAILER}}
 
{{MicroPython-Hack-deparasitage-TRAILER}}

Version du 14 mai 2015 à 15:11


MCHobby investit du temps et de l'argent dans la réalisation de traduction et/ou documentation. C'est un travail long et fastidieux réalisé dans l'esprit Open-Source... donc gratuit et librement accessible.
SI vous aimez nos traductions et documentations ALORS aidez nous à en produire plus en achetant vos produits chez MCHobby.

Une broche utilisée comme entrée pour lire un bouton poussoir ou un interrupteur mécanique peut recevoir beaucoup de parasites. En effet, durant un très court laps de temps, juste avant le contact franc, le signal peut rapidement passer de niveau haut à bas et inversement.

Switchbounce.jpg

Ce "bruit" peut être éliminé en utilisant une capacité (un circuit de déparasitage... debouncing circuit en anglais).

Ce "bruit" peut également être éliminé en utilisant une simple fonction qui s'assure que la valeur de la broche est bien stable.

Attendre que la valeur change

C'est justement ce que fait la fonction ci-dessous. Elle prend la valeur actuelle de la broche puis attend que la valeur change et s'assure que la valeur reste stable pendant 20ms.


Le code s'utilise avec le montage suivant.

MicroPython-Hack-deboucing.jpg

La nouvelle valeur doit être stable pendant un temps continu de 20ms puis enregistre le modification d'état. Vous pouvez ajuster le temps (par exemple, à 50ms) si le bruit est important.

import pyb

def wait_pin_change(pin):
    # attendre que la broche change de valeur
    cur_value = pin.value()
    # Elle doit être stable pendant un temps continu de 20ms
    active = 0
    while active < 20:
        if pin.value() != cur_value:
            active += 1
        else:
            active = 0
        pyb.delay(1)

Vous pouvez l'utiliser comme ceci:

import pyb

pin_x1 = pyb.Pin('X1', pyb.Pin.IN, pyb.Pin.PULL_DOWN)
while True:
    wait_pin_change(pin_x1)
    pyb.LED(4).toggle()

Au passage, vous noterez que la broches est configurée en PULL_DOWN, ce qui signifie que le niveau reste à LOW/BAS aussi longtemps qu'une intervention extérieur ne place pas le potentiel de la broche au niveau HIGH/HAUT.

A la méthode Arduino

Si vous êtes bien attentif au point précédent, votre programme est arrêté aussi longtemps que l'utilisateur ne presse pas le bouton.

Si cela conviendra à certaines utilisation, ce ne sera pas le cas de la plupart des programmes qui cycles en vérifiant régulièrement l'état des boutons pour savoir ce que le programme doit faire.



Source: Debouncing a pin input écrit par/written by Damien P.George

Traduit par Meurisse D. pour MCHobby.be - Translated by Meurisse D. for MCHobby.be

Traduit avec l'autorisation de micropython.org - Translated with the authorisation of micropython.org

Toute référence, mention ou extrait de cette traduction doit être explicitement accompagné du texte suivant : «  Traduction par MCHobby (www.MCHobby.be) - Vente de kit et composants » avec un lien vers la source (donc cette page) et ce quelque soit le média utilisé.

L'utilisation commercial de la traduction (texte) et/ou réalisation, même partielle, pourrait être soumis à redevance. Dans tous les cas de figures, vous devez également obtenir l'accord du(des) détenteur initial des droits. Celui de MC Hobby s'arrêtant au travail de traduction proprement dit.