Untitled
unknown
dart
a year ago
1.5 kB
9
Indexable
double haversine(double lat1, double lon1, double lat2, double lon2) {
print('Calculating distance from ($lat1, $lon1) to ($lat2, $lon2)');
double dlon = _degreesToRadians(lon2 - lon1);
double dlat = _degreesToRadians(lat2 - lat1);
double a = pow(sin(dlat / 2), 2) + cos(_degreesToRadians(lat1)) * cos(_degreesToRadians(lat2)) * pow(sin(dlon / 2), 2);
double c = 2 * atan2(sqrt(a), sqrt(1 - a));
double r = 6371.0; // Radius of the Earth in kilometers
double distance = c * r * 1000; // Convert to meters
print('Computed distance: $distance meters');
return distance;
}
List<Alert> sortAlertsBySeverityAndDistance(List<Alert> alerts, double userLatitude, double userLongitude) {
// Calculate distance once and store it in a map to avoid recalculating
Map<Alert, double> distanceMap = {};
for (var alert in alerts) {
distanceMap[alert] = haversine(alert.latitude, alert.longitude, userLatitude, userLongitude);
}
// Sort by severity
alerts.sort((a, b) => compareAlertLevels(a.severity, b.severity));
// Further sort each severity level by distance using precomputed distances
Map<String, List<Alert>> groupedBySeverity = {};
for (var alert in alerts) {
groupedBySeverity.putIfAbsent(alert.severity, () => []).add(alert);
}
List<Alert> sortedAlerts = [];
groupedBySeverity.forEach((severity, group) {
group.sort((a, b) => distanceMap[a].compareTo(distanceMap[b]));
sortedAlerts.addAll(group);
});
return sortedAlerts;
}
Editor is loading...
Leave a Comment