<div dir="ltr">Ce n'est pas tout à fait la même formule, celle en Python tient compte de l'applatissement de la Terre sur le géoïde de référence (alors que la première formule en PHP la modélise comme une sphère, avec un rayon moyen arrondi en kilomètres, et non les deux rayons arrondis en mètres).<div>Cependant les deux formules ne tiennent pas compte de l'altitude (il faudrait des données supplémentaires sur le modèle de terrain pour estimer l'altitude des deux points)</div></div><div class="gmail_extra"><br><div class="gmail_quote">Le 30 juin 2016 à 07:52, <a href="mailto:pepilepioux@ovh.fr">pepilepioux@ovh.fr</a> <span dir="ltr"><<a href="mailto:pepilepioux@ovh.fr" target="_blank">pepilepioux@ovh.fr</a>></span> a écrit :<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
  
    
  
  <div bgcolor="#FFFFFF" text="#000000"><span class="">
    <div>Le 29/06/2016 à 23:20, François Lacombe
      a écrit :<br>
    </div>
    </span><span class=""><blockquote type="cite">
      <div dir="ltr">
        <div>
          <div>
            <div>
              <div>
                <div>Bonjour Adrien,<br>
                  <br>
                </div>
                A mon sens c'est un calcul de distance loxodromique
                entre chaque nœud, de chaque portion de véloroute qui
                composent le chemin à parcourir.<br>
                <a href="https://fr.wikipedia.org/wiki/Loxodromie" target="_blank">https://fr.wikipedia.org/wiki/Loxodromie</a><br>
                <br>
              </div>
              Concrètement, voici un bout de PHP qui te donne la
              distance entre deux points dont tu connais le lat/lon<br>
            </div>
            Tu n'as plus qu'à faire la somme de tous tes segments pour
            avoir la distance totale<br>
            <br>
            $l = 6366 * 2 * asin(<br>
                                    sqrt(<br>
                                        pow(
            sin((deg2rad($lat)-deg2rad($ll[1]))/2) , 2) +
            cos(deg2rad($lat))*cos(deg2rad($ll[1]))* pow(
            sin((deg2rad($lng)-deg2rad($ll[0]))/2) , 2)<br>
                                    )<br>
                                );<br>
          </div>
        </div>
      </div>
    </blockquote>
    <br>
    <br></span>
    Pour ceux que ça peut intéresser la même chose en Python :<br>
    <br>
    <font face="Lucida Console">import    math<br>
      <br>
      def    distance    ( lat1 , lon1 , lat2 , lon2 , alt1 , alt2 )   
      :<br>
          rEquat    = 6378137<br>
          rPole    = 6356752<br>
          rLat    = rEquat - ( ( rEquat - rPole ) * abs( lat1 / 90 ) ) +
      alt1<br>
      <br>
          distParallele    = abs ( rLat * math.cos( (( lat1 + lat2 ) / 2
      ) * math.pi / 180 ) * ( ( lon2 - lon1 ) * math.pi / 180 ) )<br>
          distMeridien    = abs ( rLat * ( lat2 - lat1 )  * math.pi /
      180  )<br>
          distVerticale    = abs ( alt2 - alt1 )<br>
          distTotale        = math.sqrt ( ( distParallele *
      distParallele ) + ( distMeridien * distMeridien ) + (
      distVerticale * distVerticale ) )<br>
          <br>
          return    distTotale<br>
      <br>
    </font>(distance en mètres)<div><div class="h5"><br>
    <br>
    <br>
    <br>
    <br>
    <blockquote type="cite">
      <div dir="ltr">
        <div>
          <div><br>
          </div>
          Où $lat et $lng sont les coordonnées de ton point B et $ll[0]
          et $ll[1] celles de ton point A.<br>
        </div>
        Cette formule a un défaut : elle ne tient pas compte de
        l'altitude des points, réputée négligeable ici.<br>
        <div>
          <div><br>
            <br>
          </div>
          <div>A+<br>
          </div>
        </div>
      </div>
      <div class="gmail_extra"><br clear="all">
        <div>
          <div data-smartmail="gmail_signature">
            <div dir="ltr"><b>François Lacombe</b><br>
              <br>
              fl dot infosreseaux At gmail dot com<br>
              <a href="http://www.infos-reseaux.com" target="_blank">www.infos-reseaux.com</a><br>
              <a href="http://www.twitter.com/InfosReseaux" target="_blank">@InfosReseaux</a></div>
          </div>
        </div>
        <br>
        <div class="gmail_quote">Le 29 juin 2016 à 20:46, adrien <span dir="ltr"><<a href="mailto:perso@adrieng.fr" target="_blank">perso@adrieng.fr</a>></span>
          a écrit :<br>
          <blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Bonjour,<br>
            <br>
            J'aimerais connaître la distance entre deux points sur une
            relation<br>
            route=bicycle,en l'occurence la distance entre Nantes et
            Blain sur la<br>
            Vélodyssée.<br>
            <br>
            Je suppose que c'est facilement faisable, mais je sèche
            complètement sur<br>
            comment faire, et quel outils utiliser…<br>
            <br>
            Si vous avez des pistes, je vous en serait reconnaissant.<br>
            <br>
            Bonne soirée<br>
            <br>
            Adrien<br>
            <br>
            <br>
            _______________________________________________<br>
            Talk-fr mailing list<br>
            <a href="mailto:Talk-fr@openstreetmap.org" target="_blank">Talk-fr@openstreetmap.org</a><br>
            <a href="https://lists.openstreetmap.org/listinfo/talk-fr" rel="noreferrer" target="_blank">https://lists.openstreetmap.org/listinfo/talk-fr</a><br>
          </blockquote>
        </div>
        <br>
      </div>
      <br>
      <fieldset></fieldset>
      <br>
      <pre>_______________________________________________
Talk-fr mailing list
<a href="mailto:Talk-fr@openstreetmap.org" target="_blank">Talk-fr@openstreetmap.org</a>
<a href="https://lists.openstreetmap.org/listinfo/talk-fr" target="_blank">https://lists.openstreetmap.org/listinfo/talk-fr</a>
</pre>
    </blockquote>
    <p><br>
    </p>
  </div></div></div>

<br>_______________________________________________<br>
Talk-fr mailing list<br>
<a href="mailto:Talk-fr@openstreetmap.org">Talk-fr@openstreetmap.org</a><br>
<a href="https://lists.openstreetmap.org/listinfo/talk-fr" rel="noreferrer" target="_blank">https://lists.openstreetmap.org/listinfo/talk-fr</a><br>
<br></blockquote></div><br></div>