Last change
on this file since 8488 was
8488,
checked in by spimming, 12 years ago
|
#1894:
- introduced weight property in Edge
- new data source implementation for DIMACS graphs
- lightweight data source implementation for osm graphs
- cost calculator interface and implementations added
|
File size:
1.2 KB
|
Rev | Line | |
---|
[8488] | 1 | using System;
|
---|
| 2 |
|
---|
| 3 | namespace HeuristicLab.Problems.RoutePlanning.Graph {
|
---|
| 4 | public class EarthDistanceCostCalculator : ICostCalculator {
|
---|
| 5 | private const double earthMeanRadius = 6371.0 * 1000.0;
|
---|
| 6 |
|
---|
| 7 | #region ICostCalculator Members
|
---|
| 8 |
|
---|
| 9 | public float Costs(Edge<Vertex> edge) {
|
---|
| 10 | return edge.Weight;
|
---|
| 11 | }
|
---|
| 12 |
|
---|
| 13 | public float EstimatedCosts(Vertex source, Vertex destination) {
|
---|
| 14 | return (float)EarthDistance(source.Logitude, source.Latitude, destination.Logitude, destination.Latitude);
|
---|
| 15 | }
|
---|
| 16 |
|
---|
| 17 | #endregion
|
---|
| 18 |
|
---|
| 19 | private double DegToRad(double alpha) {
|
---|
| 20 | return alpha * Math.PI / 180;
|
---|
| 21 | }
|
---|
| 22 |
|
---|
| 23 | private double AngularDistance(double startLon, double startLat, double endLon, double endLat) {
|
---|
| 24 | double lat1 = DegToRad(startLat);
|
---|
| 25 | double lat2 = DegToRad(endLat);
|
---|
| 26 | double long1 = DegToRad(startLon);
|
---|
| 27 | double long2 = DegToRad(endLat);
|
---|
| 28 |
|
---|
| 29 | double x = Math.Sin(lat1) * Math.Sin(lat2) + Math.Cos(lat1) * Math.Cos(lat2) * Math.Cos(long1 - long2);
|
---|
| 30 | x = Math.Min(1, Math.Max(0, x));
|
---|
| 31 |
|
---|
| 32 | return Math.Acos(x);
|
---|
| 33 | }
|
---|
| 34 |
|
---|
| 35 | private double EarthDistance(double startLon, double startLat, double endLon, double endLat) {
|
---|
| 36 | return earthMeanRadius * AngularDistance(startLon, startLat, endLon, endLat);
|
---|
| 37 | }
|
---|
| 38 | }
|
---|
| 39 | }
|
---|
Note: See
TracBrowser
for help on using the repository browser.