Size: 13627
Comment:
|
Size: 13951
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 67: | Line 67: |
Vertical location is not known with many systems, and is much worse than the horizontal accuracy even with GPS/AGPS. Consider this in your design if users in buildings or even just multi-level roadways are likely to be encountered. Technology may not reveal the vertical position with sufficient fidelity for the system to respond usefully. | Vertical location is not known with many systems, and is much worse than the horizontal accuracy even with GPS/AGPS. Consider this in your design if users in buildings or even just multi-level roadways are likely to be encountered. Technology may not reveal the vertical position with sufficient fidelity for the system to respond usefully. But if you can derive vertical location, start thinking about using it. A person 120 feet off the ground does not a coupon for the Starbucks across the street; he's probably in a meeting or at his desk in a building. Eventually, map data should account for this, and multi-level roadways navigation will also become easier. |
The most important thing for understanding location technology on mobile devices is to never, ever, ever conflate "GPS" with "location." There are numerous technologies available.
The following are key guidelines to keep in mind when designing location services on mobile devices:
- Every phone is location enabled. GPS or not, working or not, there's some location available. And if you are giving something like a weather report or local news, a few thousand yards is practically pinpoint precision.
- All the available location technologies must be addressed when designing your application or service. Don't shut off the service because the GPS is off.
- Precision and accuracy must be understood by designers, and correctly exploited by the product. When the GPS is off, or doing badly, show that circle so it's clear that we don't know /exactly/ where you are. Say "turn right in about 1/4 mile" and so on.
- If you work for a carrier, exploiting the network like this should be a snap. If not, your devices or software may or may not be able to be talk to the phone enough, and you might need to negotiate with the carrier or find a third party provider.
- Consider what to store locally. Does the handset really need to be on the network, or should you give some functionality when the connection is bad or unavailable?
- Look useful without acting creepy. And don't just follow the letter of the law. Be careful with your user's data, share only what is needed, and store only what you really have to. Often, these last two are answered as "nothing." If that is the decision, make sure it's implemented as such, and no one gets lazy with the development or doesn't get the memo.
Location Technologies
This lists location-finding technologies by (approximately) least to most precise:
Cell
Mobile telephony is based on communications and handoff between cells, each of which is (generally) controlled by a single tower with multiple antennas. The tower location is well-known, and its ID is attached to the CDR, so it can be detected.
This is a fallback, when other things are not available. Better technologies are generally not available when roaming, and the data is not or cannot (technology or politics) shared at more precision with your home network or because you are from another operator.
Precision will vary widely by the size of the cell, and there is no (good, universally-accepted) method to determine and communicate precision and accuracy. A good rule of thumb – and something similar is generally used by devices – is a circle 3000 yds (m) across.
Sector
Recall that each tower has multiple antennas. Those three (or four, rarely anything else, depends on the carrier) antennas point different directions. Each of those is an independent mobile radio sector; just like signals are handed off between cells, they are handed off between sectors, and the data is generally known to the handset and can sometimes be shared with services or providers. However, since the direction the sector faces is really only known to the company that installed it, and the network operator, they are the only ones that can use the data well. Precision will vary widely by the size of the cell, and by the antennas used, the number on the cell, the down-angle, and so on. There are some semi-useful ways of determining precision and accuracy for a single read, but they are not univerally implemented and there is no way to send the data to the information providers (e.g. the map program). A good rule of thumb – and something similar is generally used by devices – is a circle 1200 yds (m) across, co-located with the radio centroid of the sector. Yes, sectors are not circles, but it's also hard to communicate shape and orientation, so this works.
Triangulation
Generally, triangulation is the practice of determining the location of a point by measuring the angle and/or distance from several known locations. More points give more precision. It can get more complex when you try to find points in 3D space, but all mobile triangulation systems mostly assume the earth is locally perfectly flat, and simply find the location on the geoid. Methods of triangulating get really complex and vary by network type and equipment available; multilateration and signal interpolation are some of those. The math can get pretty harrowing. Precision varies mostly by the number of sectors being used, the distance between them and other variables of the network. There may be a method of communicating to services employing it an approximation of the precision available. In any remotely built-up area, where it most often has enough sectors to work, a circle 50 yds (m) across is typical. 12 yd precision is possible, with good accuracy.
GPS Telemetry
The Global Positioning System consists of a ground based control system, a series of satellites and any number of anonymous receivers. So, reading that alone dismisses many misconceptions; its one-way, it's a system, and the signal is from satellites and has nothing to do with mobile networks.
Telemetry means data sent from a remote (usually mobile) site like a rocket, back to base. Here, it means the device figures out where it is by listening to the satellites, then tells the network or website or whatever where it is.
Ignoring SA, GPS can give precision to fractions of an inch at least. But those are large, complex devices used for special surveying and scientific tasks. Portable, hand-held receivers like those in mobile handsets can generally be assumed to give precision of 20-50 ft, though antenna and signal processing improves constantly and precision can be in single digit feet.
There are other systems, like Galileo, GLONASS, and COMPASS but none of these are really fully-active, and there are few or no receivers in mobiles as yet. In theory, eventually, using multiple unrelated systems will give better accuracy yet, and give better coverage when in touchy situations like in dense cities.
WAAS
GPS uses radios, and the atmosphere and earth are imperfect and can displace or distort the signals. WAAS is a satellite based augmentation system based in North America (others exist in the rest of the world, but are less well-established) that sends additional signals via another set of satellites to allow GPS receivers to adjust for those inaccuracies. I know of no mobile phones that have a built-in WAAS receiver, but it's a location technology that does exist, and is employed on cell towers using AGPS.
AGPS
Assisted GPS requires the use of mobile networks, so only works when in data communication range. The cell tower has its own GPS (which many use anyway to get precise time codes), and usually a WAAS receiver. This provides a bit more precision, assures it of more accuracy, but mostly helps speed up cold or warm starts. Briefly, for a GPS to work, the receiver has to download data about all the satellites before it can calculate the position. AGPS caches this info for the phone, and sends over just the relevant bits, cutting minutes to a second or two.
This is a reason you may not see WAAS, and might see some benefits from other GNSS (say, GLONASS) before the receivers are added to the handsets. AGPS generally gives precision, even in dense areas and on the move, of 10 ft or better. Two foot indicated precision has been observed.
AGPS is not generally selectable as a separate service; when the user chooses to turn on or off "GPS," and has a network connection (and an AGPS compliant phone, etc.) they get the advantages of AGPS.
WLANs & PANs
Local networks like WiFi and Bluetooth are not exactly more precise,but are at the bottom of this list because they are local, and can add another layer of location, so could increase precision. They can also be used instead of other technologies when there is no GPS signal, or a bad mobile signal so triangulation cannot be used.
Both of these currently use the "cell" (or network identifier) and triangulation methods described above. There are no sectors, and no universally-adopted AGPS system to work with device telemetry. Naturally, a handset getting good GPS data can send that telemetry to anyone over any network, including WiFi, but that's not the same thing.
They are both relatively more rare, and often are supported by third party software or individual services (which may have specific capabilities), and are not universally implemented on the handset. There are no reliable, independently verified numbers on the real-world precision, but tests of WiFi triangulation alone have gone down to inches. On the other hand, poor network identification has led to placing users on the wrong continent. There's room to improve here.
Ask
People often know where they are. If you cannot get any location, or there's a reason they might want to over-ride it (even as simple as the data is bad) let them enter a location. If you do this, allow lots of methods. Only accepting ZIP or postal code is not useful for e.g. travellers, who do not generally know the ZIP where they are.
Key Topics in Implementing Location Services
Location is Not Just GPS
All the above is pretty well known by network engineers, and chip-makers and various low-level handset software guys. But it is often missed a bit by various software implementations (and certainly by marketing). All too often GPS is navigation, such that turning it off kills all location services. Certain systems are becoming aware of this, and (e.g.) just give poorer precision when you turn the GPS off, but it do allow location services to work.
Vertical Accuracy
Vertical location is not known with many systems, and is much worse than the horizontal accuracy even with GPS/AGPS. Consider this in your design if users in buildings or even just multi-level roadways are likely to be encountered. Technology may not reveal the vertical position with sufficient fidelity for the system to respond usefully. But if you can derive vertical location, start thinking about using it. A person 120 feet off the ground does not a coupon for the Starbucks across the street; he's probably in a meeting or at his desk in a building. Eventually, map data should account for this, and multi-level roadways navigation will also become easier.
Precision vs. Accuracy
Precision vs. accuracy is often confused. A quick primer: precision is the number of decimal places you measure something to; accuracy is how correct it is. The less accurate a measurement is, the less precisely it should be reported. Practically every location system gives location to the same degree of precision (e.g. 1 meter, using full UTM precision) at all times, and presumes the accuracy measure will be considered as well.
Visual representations are similar. The moving arrow (or car, or person icon) is the centroid of the current location precision circle. Even when that accuracy circle is displayed, the centroid marker implies much higher precision than is actually being achieved. Consider better ways to represent location to avoid user confusion.
Appropriateness of Information
Display of information services should be related to the current accuracy. For example, turn-by-turn directions always assume perfect location precision (using the centroid of the current location accuracy circle), and say "you have arrived" instead of "it's the big, white building on the north side of the street." What if the location is vague and the target or turn is 30 yards behind you, or 50 in front? The user is confused. Close roads (in dense cities), multi-tier highways and other situations can exacerbate the effect of this behavior.
Design to accommodate imperfect location instead.
Data Integrity and Reliability
If your map might be wrong, or imprecise or inaccurate (and they all might be) then think about this when planning the interaction. Don't assume your data is perfect, and give contextually-helpful information. Let users note problems, and do something with the problem reports.
Local vs. Network Storage
Handheld dedicated GPS units and most in-car units store map data locally, so when a GPS fix is found a map can be displayed immediately. Mobiles generally assume functionality only when on the network, even when a GPS is included. If your service is usable when out of network range (e.g. it's just for navigation, not for social media or communications), consider placing enough information locally for the device to work when out of network coverage.