File: distance.c

package info (click to toggle)
grass 6.0.2-6
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 40,044 kB
  • ctags: 31,303
  • sloc: ansic: 321,125; tcl: 25,676; sh: 11,176; cpp: 10,098; makefile: 5,025; fortran: 1,846; yacc: 493; lex: 462; perl: 133; sed: 1
file content (35 lines) | stat: -rw-r--r-- 757 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#include "gis.h"

double distance (double east, double west)
{
    double incr;
    double meters;
    double e1, e2;

/* calculate the distance from east edge to west edge at north==0.0
 * for lat-lon this will be along equator. For other databases the
 * north value will make no difference
 *
 * Note, must do lat-lon in 3 pieces, otherwise distance "line" may
 * go the wrong way around the globe
 */
    G_begin_distance_calculations();

    if (east < west)
    {
	double temp;
	temp = east;
	east = west;
	west = temp;
    }

    incr = (east - west) / 3.0 ;
    e1 = west + incr;
    e2 = e1 + incr;

    meters = G_distance (west, 0.0, e1, 0.0) +
	     G_distance (e1, 0.0, e2, 0.0)   +
	     G_distance (e2, 0.0, east, 0.0);

    return meters;
}