File:  [local] / rpl / src / fonctions_trigonometriques.c
Revision 1.64: download - view: text, annotated - select for diffs - revision graph
Fri Jan 10 11:15:42 2020 UTC (4 years, 2 months ago) by bertrand
Branches: MAIN
CVS tags: rpl-4_1_32, HEAD
Modification du copyright.

    1: /*
    2: ================================================================================
    3:   RPL/2 (R) version 4.1.32
    4:   Copyright (C) 1989-2020 Dr. BERTRAND Joël
    5: 
    6:   This file is part of RPL/2.
    7: 
    8:   RPL/2 is free software; you can redistribute it and/or modify it
    9:   under the terms of the CeCILL V2 License as published by the french
   10:   CEA, CNRS and INRIA.
   11:  
   12:   RPL/2 is distributed in the hope that it will be useful, but WITHOUT
   13:   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   14:   FITNESS FOR A PARTICULAR PURPOSE.  See the CeCILL V2 License
   15:   for more details.
   16:  
   17:   You should have received a copy of the CeCILL License
   18:   along with RPL/2. If not, write to info@cecill.info.
   19: ================================================================================
   20: */
   21: 
   22: 
   23: #include "rpl-conv.h"
   24: 
   25: 
   26: /*
   27: ================================================================================
   28:   Fonction de conversion d'un angle exprimé en radians en degrés
   29: ================================================================================
   30:   Entrées : pointeur sur l'angle
   31: --------------------------------------------------------------------------------
   32:   Sorties : néant
   33: --------------------------------------------------------------------------------
   34:   Effets de bord : néant
   35: ================================================================================
   36: */
   37: 
   38: void
   39: conversion_radians_vers_degres(real8 *angle)
   40: {
   41:     (*angle) = 45 * (*angle) / atan((real8) 1);
   42: 
   43:     return;
   44: }
   45: 
   46: 
   47: /*
   48: ================================================================================
   49:   Fonction de conversion d'un angle exprimé en degrés en radians
   50: ================================================================================
   51:   Entrées : pointeur sur l'angle
   52: --------------------------------------------------------------------------------
   53:   Sorties : néant
   54: --------------------------------------------------------------------------------
   55:   Effets de bord : néant
   56: ================================================================================
   57: */
   58: 
   59: void
   60: conversion_degres_vers_radians(real8 *angle)
   61: {
   62:     (*angle) = atan((real8) 1) * (*angle) / 45;
   63: 
   64:     return;
   65: }
   66: 
   67: 
   68: /*
   69: ================================================================================
   70:   Fonction de conversion d'un angle exprimé en decimal en HMS
   71: ================================================================================
   72:   Entrées : pointeur sur l'angle
   73: --------------------------------------------------------------------------------
   74:   Sorties : néant
   75: --------------------------------------------------------------------------------
   76:   Effets de bord : néant
   77: ================================================================================
   78: */
   79: 
   80: void
   81: conversion_decimal_vers_hms(real8 *angle)
   82: {
   83:     real8                       heures;
   84:     real8                       minutes;
   85:     real8                       reste;
   86:     real8                       secondes;
   87: 
   88:     integer4                    signe;
   89: 
   90:     signe = ((*angle) >= 0) ? 1 : -1;
   91:     (*angle) *= signe;
   92: 
   93:     reste = (*angle) - (heures = floor(*angle));
   94:     minutes = floor(reste *= 60);
   95:     reste -= minutes;
   96:     secondes = floor(reste = 60 * reste);
   97:     reste -= secondes;
   98: 
   99:     (*angle) = (heures + ((minutes + ((secondes + reste) / 100)) / 100))
  100:             * signe;
  101: 
  102:     return;
  103: }
  104: 
  105: 
  106: /*
  107: ================================================================================
  108:   Fonction de conversion d'un angle exprimé en HMS en décimal
  109: ================================================================================
  110:   Entrées : pointeur sur l'angle
  111: --------------------------------------------------------------------------------
  112:   Sorties : néant
  113: --------------------------------------------------------------------------------
  114:   Effets de bord : néant
  115: ================================================================================
  116: */
  117: 
  118: void
  119: conversion_hms_vers_decimal(real8 *angle)
  120: {
  121:     real8                       minutes;
  122:     real8                       secondes;
  123:     real8                       reste;
  124:     real8                       heures;
  125: 
  126:     integer4                    signe;
  127: 
  128:     signe = ((*angle) >= 0) ? 1 : -1;
  129:     (*angle) *= signe;
  130: 
  131:     reste = (*angle) - (heures = floor(*angle));
  132:     minutes = floor(reste *= 100);
  133:     reste -= minutes;
  134:     secondes = floor(reste = 100 * reste);
  135:     reste -= secondes;
  136: 
  137:     (*angle) = (heures + ((minutes + ((secondes + reste) / 60)) / 60)) * signe;
  138: 
  139:     return;
  140: }
  141: 
  142: // vim: ts=4

CVSweb interface <joel.bertrand@systella.fr>