2023-01-18 18:21:12 +01:00
from montchg_lib import * # Bibliothèque utilisateur du monte-charge
2022-12-18 17:33:23 +01:00
###############################################################################
2024-01-18 04:35:49 +01:00
# montchg_cmd.py
# @title: Commandes du monte-charge
2022-12-18 17:33:23 +01:00
###############################################################################
###############################################################################
# Instructions élémentaires pour le monte-charge
#
# Actions (ordre = True ou False) :
2022-12-23 14:30:13 +01:00
# - Monter le monte-charge (moteur sens trigo) : mot_m(True | False)
# - Descendre le monte-charge (moteur sens horaire) : mot_d(True | False)
2024-01-18 04:35:49 +01:00
# - Définir la vitesse du moteur jumeau numérique : mot_vitesse (vitesse) , vitesse en rad / s, si vitesse est omis la valeur par défaut est 125.6 rad /s ( 20 tr / s ))
# - Définir la vitesse du moteur jumeau réel : mot_vitesse_r (vitesse) , vitesse de 0 à 255, la valeur par défaut est 255 (uniquement sur la maquette Grove)
2022-12-18 17:33:23 +01:00
#
# Capteurs (valeur retournée = True ou False) :
# - Capteur présence cabine niveau 0 : pc_0()
# - Capteur présence cabine niveau 1 : pc_1()
#
2022-12-23 14:30:13 +01:00
# Consignes du pupitre (valeur retournée = True ou False) :
2022-12-18 17:33:23 +01:00
# - Bouton poussoir appel niveau 0 : ba_0()
# - Bouton poussoir appel niveau 1 : ba_1()
#
2022-12-23 14:30:13 +01:00
# Retours d'information du pupitre (allumer = True ou False) :
# - Voyant témoin d'étage niveau 0 : voy_0(True | False)
# - Voyant témoin d'étage niveau 1 : voy_1(True | False)
2022-12-22 05:02:33 +01:00
#
2022-12-18 17:33:23 +01:00
# Gestion du temps :
# - Temporisation en seconde : tempo(duree)
2024-01-18 04:35:49 +01:00
# - Réinitialisation de la valeur du temp (t) : reset_t()
#
# Acquisition de données :
# - Retourne la valeur de la variable à l'instant : get(variable)
# - Lancer l'enregistrement : daq([variable1, variable2, ... ])
# - Afficher les graphiques : plot([variable1, variable2, ... ])
#
# Jumelage :
# - Démarrer le jumelage : jumeau({brochage})
# - Arrêter le jumelage : jumeau_stop({brochage})
# - Définir les règles d'activation : jumeau_mode({brochage})
2022-12-18 17:33:23 +01:00
#
###############################################################################
2023-02-15 17:56:49 +01:00
# Brochage du monte-charge (Grove)
brochage = {
' pc_0 ' : [ ' d ' , 7 , ' i ' ] , ' pc_1 ' : [ ' d ' , 8 , ' i ' ] ,
' ba_0 ' : [ ' a ' , 0 , ' i ' ] , ' ba_1 ' : [ ' a ' , 1 , ' i ' ] ,
2024-01-18 04:35:49 +01:00
' voy_0 ' : [ ' d ' , 5 , ' o ' ] , ' voy_1 ' : [ ' d ' , 6 , ' o ' ] ,
' mot_v ' : [ ' d ' , 3 , ' p ' ] , ' mot_s ' : [ ' d ' , 4 , ' o ' ] }
2023-02-15 17:56:49 +01:00
2022-12-18 17:33:23 +01:00
###############################################################################
# Fonctions
###############################################################################
###############################################################################
# Commandes
###############################################################################
def commandes ( ) :
2023-01-01 14:48:27 +01:00
2023-02-15 17:56:49 +01:00
# daq(['mot_angle', 'mot_vitesse', 'cabine_z', 'cabine_vitesse'])
# plot(['mot_angle', 'mot_vitesse'])
jumeau ( brochage )
2023-02-03 05:58:20 +01:00
jumeau_mode ( True , True , True , True )
2023-02-15 17:56:49 +01:00
# Mise en place : Aller au niveau 0
print ( " Monte-charge sans la mémorisation des appels " )
print ( " Mise en place : Aller au niveau 0 ... " )
while pc_0 ( ) == False :
2023-01-19 15:35:57 +01:00
mot_m ( False )
mot_d ( True )
2023-02-15 17:56:49 +01:00
tempo ( 0.1 )
2023-01-19 15:35:57 +01:00
mot_d ( False )
2023-02-15 17:56:49 +01:00
print ( " Mise en place : Aller au niveau 0 : Ok " )
2023-01-19 15:35:57 +01:00
2023-02-15 17:56:49 +01:00
# Fonctionnement normal
print ( " Attente " )
while True :
# Aller au niveau 0
if ba_0 ( ) and pc_0 ( ) == False :
print ( " Déplacement pour le niveau 0 ... " )
voy_0 ( True )
while pc_0 ( ) == False :
mot_m ( False )
mot_d ( True )
tempo ( 0.1 )
mot_d ( False )
tempo ( 2 ) # Temporisation 2s
voy_0 ( False )
print ( " Déplacement pour le niveau 0 : Ok " )
print ( " Attente " )
2023-01-21 06:56:54 +01:00
2023-02-15 17:56:49 +01:00
# Aller au niveau 1
if ba_1 ( ) and pc_1 ( ) == False :
print ( " Déplacement pour le niveau 1 ... " )
voy_1 ( True )
while pc_1 ( ) == False :
mot_d ( False )
mot_m ( True )
tempo ( 0.1 )
mot_m ( False )
tempo ( 2 ) # Temporisation 2s
voy_1 ( False )
print ( " Déplacement pour le niveau 1 : Ok " )
print ( " Attente " )
2023-01-19 15:35:57 +01:00
2023-02-15 17:56:49 +01:00
tempo ( 0.1 )
2023-01-19 15:35:57 +01:00
2022-12-18 17:33:23 +01:00
###############################################################################
# En: External call << DONT CHANGE THIS SECTION >>
# Fr: Appel externe << NE PAS MODIFIER CETTE SECTION >>
###############################################################################
2024-01-18 04:08:18 +01:00
###
# Variante 1 : Maquette Grove
# - Maquette Grove : la carte moteur est le shield moteur Arduino CC 4 x 1,2 A DRI0039 (DFROBOT)
# Variante 2 : Maquette AutoProg
# - Maquette AutoProg (A4 Technologie) : la carte moteur est le module AutoProg K-AP-MMOT-KIT
###
2024-01-06 10:19:56 +01:00
def cycle ( ) :
commandes ( )
fin ( )
2022-12-18 17:33:23 +01:00
if __name__ == ' start ' :
2024-01-06 10:19:56 +01:00
start ( cycle )
2022-12-18 17:33:23 +01:00
if __name__ == ' stop ' :
2023-01-07 10:42:19 +01:00
stop ( )
2024-01-18 04:08:18 +01:00
if __name__ == ' init ' :
variant ( 1 ) # Variante maquette Grove