45 lines
2.0 KiB
C
45 lines
2.0 KiB
C
#include "Asser_Moteurs.h"
|
|
#include "Geometrie_robot.h"
|
|
#include "Commande_vitesse.h"
|
|
|
|
|
|
|
|
/// @brief Commande une rotation autour d'un point dans le référentiel du robot.
|
|
/// Cette fonction déplace le torseur cinétique du centre de rotation vers le centre du robot
|
|
/// pour obtenir la vitesse de ce dernier.
|
|
/// @param rotation_rad_s : Rotation en rad/s
|
|
/// @param centre_x : centre de rotation (coordonnée X)
|
|
/// @param centre_y : centre de rotation (coordonnée Y)
|
|
void commande_rotation(float rotation_rad_s, float centre_x, float centre_y){
|
|
float vitesse_x_mm_s, vitesse_y_mm_s;
|
|
vitesse_x_mm_s = centre_y * rotation_rad_s;
|
|
vitesse_y_mm_s = -centre_x * rotation_rad_s;
|
|
|
|
commande_vitesse(vitesse_x_mm_s, vitesse_y_mm_s, rotation_rad_s);
|
|
}
|
|
|
|
|
|
/// @brief Commande de la vitesse dans le référentiel du robot
|
|
/// tel que décrit ici : http://poivron-robotique.fr/Robot-holonome-lois-de-commande.html
|
|
/// @param vitesse_x_mm_s : Vitesse x en mm/s dans le référentiel du robot
|
|
/// @param vitesse_y_mm_s : Vitesse y en mm/s dans le référentiel du robot
|
|
/// @param orientation_radian_s : Rotation en radian/s dans le référentiel du robot
|
|
void commande_vitesse(float vitesse_x_mm_s, float vitesse_y_mm_s, float orientation_radian_s){
|
|
float vitesse_roue_a, vitesse_roue_b, vitesse_roue_c;
|
|
|
|
vitesse_roue_a = vitesse_x_mm_s / 2.0 - vitesse_y_mm_s * RACINE_DE_3 / 2.0 - DISTANCE_ROUES_CENTRE_MM * orientation_radian_s;
|
|
vitesse_roue_b = vitesse_x_mm_s / 2.0 + vitesse_y_mm_s * RACINE_DE_3 / 2.0 - DISTANCE_ROUES_CENTRE_MM * orientation_radian_s;
|
|
vitesse_roue_c = -vitesse_x_mm_s - DISTANCE_ROUES_CENTRE_MM * orientation_radian_s;
|
|
|
|
AsserMoteur_setConsigne_mm_s(MOTEUR_A, vitesse_roue_a);
|
|
AsserMoteur_setConsigne_mm_s(MOTEUR_B, vitesse_roue_b);
|
|
AsserMoteur_setConsigne_mm_s(MOTEUR_C, vitesse_roue_c);
|
|
|
|
}
|
|
|
|
/// @brief Arrête le robot.
|
|
void commande_vitesse_stop(){
|
|
AsserMoteur_setConsigne_mm_s(MOTEUR_A, 0);
|
|
AsserMoteur_setConsigne_mm_s(MOTEUR_B, 0);
|
|
AsserMoteur_setConsigne_mm_s(MOTEUR_C, 0);
|
|
} |