IWETHEY v. 0.3.0 | TODO
1,095 registered users | 0 active users | 0 LpH | Statistics
Login | Create New User
IWETHEY Banner

Welcome to IWETHEY!

New It doesn't take much to be bad
Let's see. Without looking hard, no strict, uses cgi-lib.pl, makequote reinvents DBI's quote method (badly - and if you did this in Oracle then you'd want to use placeholders, really), there is a horrible parsing technique, no indentation, method calls inside of strings (that won't work very well), the aforementioned zip code issues and his formula for distance is computationally unstable at low distances (which is ironically where you care most about accuracy). I also think that the formula should be documented in the code...

But other than the fact that every detail sucks, the general idea is workable.

If you want a better calculation, then I'd suggest using Haversine's formula (faster for computers to calculate, more numerically stable):
\ndlon = lon2 - lon1\ndlat = lat2 - lat1\na = (sin(dlat/2))^2 + cos(lat1) * cos(lat2) * (sin(dlon/2))^2\nc = 2 * atan2(sqrt(a), sqrt(1-a))\nd = R * c\n


where R should be the radius of the earth, aka 3,959 miles (on average - it varies). You can find a derivation at [link|http://mathforum.org/library/drmath/view/51879.html|http://mathforum.org...h/view/51879.html].

Also given how many services (Google, mapquest, etc) do accurate geocoding, I'd suggest that today the zip code approximation is not good enough. Sure, use it as a fallback. But go negotiate a contract with someone like mapquest allowing you to geocode lots of addresses. I don't know what it costs, but I don't think it is that much. And take your program and add an artificial limit, such as "closest 3 within 20 miles". (Or reorganize it about that limit) Who's going to drive more than that just to get to a dealer? That limit will let you use a "bounding box" of latitude/longitude combinations allowing you to significantly reduce how many dealers you have to do the expensive calculation for.

Have I explained my response sufficiently? The idea works. The approach is inefficient. The code is crap.

Cheers,
Ben
I have come to believe that idealism without discipline is a quick road to disaster, while discipline without idealism is pointless. -- Aaron Ward (my brother)
Collapse Edited by ben_tilly Jan. 7, 2005, 01:53:56 PM EST
It doesn't take much to be bad
Let's see. Without looking hard, no strict, uses cgi-lib.pl, makequote reinvents DBI's quote method (badly - and if you did this in Oracle then you'd want to use placeholders, really), there is a horrible parsing technique, no indentation, method calls inside of strings (that won't work very well), the aforementioned zip code issues and his formula for distance isn't computationally stable at low distances (which is ironically where you care most about accuracy). I also think that the formula should be documented in the code...

But other than the fact that every detail sucks, the general idea is workable.

If you want a better calculation, then I'd suggest using Haversine's formula (faster for computers to calculate, more numerically stable):
  dlon = lon2 - lon1
  dlat = lat2 - lat1
  a = (sin(dlat/2))^2 + cos(lat1) * cos(lat2) * (sin(dlon/2))^2
  c = 2 * atan2(sqrt(a), sqrt(1-a)) 
  d = R * c


where R should be the radius of the earth, aka 3,959 (on average - it varies). You can find a derivation at [link|http://mathforum.org/library/drmath/view/51879.html|http://mathforum.org...h/view/51879.html].

Also given how many services (Google, mapquest, etc) do accurate geocoding, I'd suggest that today the zip code approximation is not good enough. Sure, use it as a fallback. But go negotiate a contract with someone like mapquest allowing you to geocode lots of addresses. I don't know what it costs, but I don't think it is that much. And take your program and add an artificial limit, such as "closest 3 within 20 miles". (Or reorganize it about that limit) Who's going to drive more than that just to get to a dealer? That limit will let you use a "bounding box" of latitude/longitude combinations allowing you to significantly reduce how many dealers you have to do the expensive calculation for.

Have I explained my response sufficiently? The idea works. The approach is inefficient. The code is crap.

Cheers,
Ben
I have come to believe that idealism without discipline is a quick road to disaster, while discipline without idealism is pointless. -- Aaron Ward (my brother)
New Nice. It's things like this that make zIWeThey a great read.
New 20 is nothing
"closest 3 within 20 miles". (Or reorganize it about that limit) Who's going to drive more than that just to get to a dealer?
distince is relative. When I lived in Corpus Christi, it was "forever" to drive anywere that was over 15 miles away. Now that I live in a large city, I think nothing about driving someplace that's 40 miles away(Fry's Electronics comes to mind).

I'd say just list the closest 3 or 5, regardless of how far they actually are.
Darrell Spice, Jr.                      [link|http://www.spiceware.org/cgi-bin/spa.pl?album=./Artistic%20Overpass|Artistic Overpass]\n[link|http://www.spiceware.org/|SpiceWare] - We don't do Windows, it's too much of a chore
New I may be biased
I work for a company where people do a lot of searching. It has critical for us to find ways to optimize them.

If your volume is low and performance needs are not critical, then sure. Go with the obvious dumb approach. But if you need to optimize later...

Cheers,
Ben
I have come to believe that idealism without discipline is a quick road to disaster, while discipline without idealism is pointless. -- Aaron Ward (my brother)
New no disagreement about the code
just the limit of < 20 miles.
Darrell Spice, Jr.                      [link|http://www.spiceware.org/cgi-bin/spa.pl?album=./Artistic%20Overpass|Artistic Overpass]\n[link|http://www.spiceware.org/|SpiceWare] - We don't do Windows, it's too much of a chore
New Thanks
     Any obvious pitfalls in using this? - (broomberg) - (18)
         expensive aint it? - (daemon) - (3)
             Huh? - (broomberg) - (1)
                 isnt that what mapquest and grep comes in? -NT - (daemon)
             Well, I see the L pseudo scripting language is catching on. -NT - (ChrisR)
         Possible distance quirk. - (static) - (5)
             Yep, thought of that - (broomberg) - (4)
                 Consider natural barriers like rivers too... - (Another Scott) - (3)
                     As the bird flies - (broomberg) - (2)
                         You do something clever with the number of results. - (static) - (1)
                             Too confusing - (broomberg)
         Well the code is crap... - (ben_tilly) - (7)
             Not much code there to be THAT bad. - (broomberg) - (6)
                 It doesn't take much to be bad - (ben_tilly) - (5)
                     Nice. It's things like this that make zIWeThey a great read. -NT - (Another Scott)
                     20 is nothing - (SpiceWare) - (2)
                         I may be biased - (ben_tilly) - (1)
                             no disagreement about the code - (SpiceWare)
                     Thanks -NT - (broomberg)

Hey, the gutters are mine now.
74 ms