Positionel notation i aggregering ser ud til stadig ikke at være understøttet, tjek denne billet .
Som @Sammaye siger, skal du enten afvikle arrayet først eller erstatte dit koordinatarray med en indlejret lng
/lat
indlejret doc, hvilket ville gøre dette trivielt.
Givet array-strukturen, kan du slappe af og projicere lat/lng sådan her:
myColl.aggregate([
// unwind the coordinates into separate docs
{$unwind: "$myCoordinates"},
// group back into single docs, projecting the first and last
// coordinates as lng and lat, respectively
{$group: {
_id: "$_id",
lng: {$first: "$myCoordinates"},
lat: {$last: "$myCoordinates"}
}},
// then group as normal for the averaging
{$group: {
_id: 0,
lngAvg: {$avg: "$lng"},
latAvg: {$avg: "$lat"}
}}
]);