MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Jak obliczyć odległość trasy między wieloma punktami GeoJSON w MongoDB?

Jak wskazano w komentarzach, spróbuję narysować podobny obraz tutaj za pomocą Javy. Zakładając nazwę bazy danych db i nazwę kolekcji jako col a typ dokumentu to GeoData który można wymodelować jako :

public class GeoData {
    String tracerId;
    Location loc;
    Date date;
    Integer speed;
    ...getters, setters and other overrides
}

public class Location {
    String type;
    Coordinate coordinates;
}

public class Coordinate {
    double x;
    double y;
}

Postąpiłoby to w następujący sposób:

  1. Sortuj elementy według pola daty (powiedzmy w porządku rosnącym)

    MongoDatabase database = getDatabase("db");
    MongoCollection<GeoData> collection = database.getCollection("col", GeoData.class);
    Bson sortFilter = Filters.eq("date", "1"); //sort ascending
    List<GeoData> geoData = Lists.newArrayList(collection.find().sort(sortFilter));
    
  2. Oblicz odległość między punktami, używając c = square root of [(xA-xB)^2+(yA-yB)^2]

    private static double distanceBetweenCoordinates(Coordinate a, Coordinate b) {
        return Math.sqrt(Math.pow(b.getX() - a.getX(), 2) + Math.pow(b.getY() - a.getY(),2));
    }
    
  3. Zsumuj je wszystkie, aby obliczyć odległość trasy

    double routeDist = 0.0;
    for (int i = 0; i < geoData.size()-1; i++) {
        routeDist += distanceBetweenCoordinates(geoData.get(i+1).getLoc().getCoordinates(), geoData.get(i+1).getLoc().getCoordinates());
    } 
    



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Czy powinienem używać opcji allowDiskUse w środowisku produktu?

  2. Jak posortować kolekcję według daty w MongoDB?

  3. Jak skonfigurować klaster MongoDB obsługujący sesje?

  4. Co to jest $min MongoDB? Czym to się różni od find().sort({the_field:1}).limit(1)?

  5. Jak I i NIE w wyszukiwaniu $text w MongoDB