Check your eligibility for this 50% exam voucher offer and join us for free live learning sessions to get prepared for Exam DP-700.
Get StartedDon't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.
Hello!
I'm having a problem with an assignment and I thought maybe some of you had already dealt with something similar.
I have a database of about 10,000 POIs with addresses, lat/lon and a specific value assigned to each point.
The task is to find a point on the map which has the POI with the highest total value within a radius of 500m.
So far, the closest I have come to a solution is taking the minimum and maximum values of lat/lon from the city limits and creating a table based on them containing combinations of all longitudes and latitudes every ~100m.
The resulting table has about 100,000 rows.
For each of these rows the distance to each POI is calculated and if it is <= 500m then the value is summed.
And it works. At least in theory.
Of course, the problem turned out to be system resources. Additionally, intervals every 100m are not ideal in terms of measurement accuracy.
There must be a more sensible way to solve this, but I can't think of it...
Solved! Go to Solution.
Can you translate 500m into lat / long degress? If so, you could add & subtract them to your starting point giving you minimum and maximum values for lat / long. Filter your POIs to only those which fall inside the range, then do your distance calculations on those. Sum the values for any which fall inside 500m.
This is a difficult problem to solve efficiently. I've tried to read up on the literature but most of the papers on it are behind paywalls, so I'm not able to do much more than point you at this question on StackOverflow:
Can you translate 500m into lat / long degress? If so, you could add & subtract them to your starting point giving you minimum and maximum values for lat / long. Filter your POIs to only those which fall inside the range, then do your distance calculations on those. Sum the values for any which fall inside 500m.
Yeah!
As always - when looking for complex solutions the easiest ones are hard to find.
The 500m into lat/long translation is not as easy as it seems. But i figured out a rough estimate would do the job with drastically impoving the performance and it did!
Thanks!
User | Count |
---|---|
119 | |
78 | |
58 | |
52 | |
46 |
User | Count |
---|---|
170 | |
117 | |
63 | |
58 | |
51 |