RPiPico-Holonome2023/Commande_vitesse.c

36 lines
1.8 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(double rotation_rad_s, double centre_x, double centre_y){
double 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(double vitesse_x_mm_s, double vitesse_y_mm_s, double orientation_radian_s){
double 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);
}