|Publication number||US7392017 B2|
|Application number||US 11/172,377|
|Publication date||Jun 24, 2008|
|Filing date||Jun 30, 2005|
|Priority date||Jun 30, 2005|
|Also published as||US20070004394, WO2007005877A2, WO2007005877A3|
|Publication number||11172377, 172377, US 7392017 B2, US 7392017B2, US-B2-7392017, US7392017 B2, US7392017B2|
|Inventors||Michael Chu, Mark Crady, Shumeet Baluja|
|Original Assignee||Google Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (27), Referenced by (58), Classifications (18), Legal Events (3)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This disclosure relates to assessing quality, at a large number of locations, of one or more wireless networks; more particularly, the disclosure relates to aggregating and analyzing the quality assessments from a small number of locations, such as, for example, at facilities associated with an information provider.
As the number of features available in wireless communication devices has increased, user expectations have increased that wireless access will be available wherever they may be. People now expect to have access on the road, in coffee shops, at home and in the office, through wireless communication devices, to information previously available only from a personal computer that was physically connected to an appropriately provisioned network. They want stock quotes, weather reports and directions to the nearest seafood restaurant from their cell phones, email from their personal digital assistants (PDAs), up-to-date documents from their smartphones, and timely, accurate search results from all their devices. They may also want networked, real-time, interactive, multi-user gaming. They also want voice communications with a high level of service quality.
To keep up with wireless device users' insatiable appetite for more features in more locations, wireless service providers continually assess their wireless service performance and quality and regularly expand their wireless coverage to new areas or improve their coverage within their current network. To assess performance, a wireless service provider may regularly analyze quality from a number of test units. The test units could be fixed or mobile. For example, use of mobile test units to assess wireless service performance is reflected in one carrier's “Can you hear me now?” marketing campaign, showing a technician touring the countryside. A wireless service provider may also assess performance by simulating wireless signal quality or coverage based on, for example, geography, atmospheric conditions, volume of wireless service traffic, or other parameters.
These techniques for assessing performance may be cumbersome and expensive. They may only capture information for a small number of locations at particular times. Moreover, they may only capture information for a single wireless service provider or a small number of wireless service providers. The information that is captured may only be available to the entity that collected it, even though other entities, such as other wireless service providers or consumers, may benefit from the information.
Therefore, there is need for a method of assessing quality of wireless service of a plurality of wireless service provider networks in a more convenient and more flexible manner that also can provide additional helpful information to wireless users, carriers, and others.
This document discloses methods and systems that aggregate and analyze information indicative of network coverage by one or more wireless service providers over a geographic area.
In certain embodiments, systems may measure coverage quality, not directly at the user device (such as by drive testing with active handsets), but from a location or locations external to the normal receiver and transmitter locations in a network. As one example, the performance can be measured by an information provider that is accessed by wireless devices that are part of a network or networks. The information provider may comprise, for example a typical search engine or other Internet data provider. Such a system may provide one or more advantages. For example, such a system may enable simple aggregation of quality of service information by a single entity. Such a system may also permit collection of such information outside a carrier's traditional network infrastructure, and outside the carrier organization itself. In addition, such information may also be collected easily across multiple carriers, without requiring coordination of the carriers, so that comparative information may be made available for analysis.
With such coverage analysis information available, various reports and services may also be provided. For example, the service provider or another company may use the information to let consumers comparison shop for carriers—much like a Froogle™ for wireless carriers. The reports, which may be generated in real-time in response to specific requests from users, may include, for example, maps showing coverage for a carrier or comparing carriers in a certain geography at a point in time, animations of coverage over time, coverage over a path at a certain time range (e.g., during a commute or commutes), graphs of coverage at a certain point over time, and indications of coverage at multiple locations at different times (e.g., over a commute path in during drive time, at the office during work hours, and at home over night). Other appropriate reports and displays may also be generated from the collected data.
In some embodiments, a method of providing information indicative of network coverage by one or more wireless service providers in a geographic area may include obtaining, at an information provider, performance indicators for a plurality of accesses to the information provider by a plurality of wireless devices. The performance indicators may be correlated with one or more network service areas. Related performance indicators may be aggregated to produce one or more aggregated performance indicators. A human-discernible representation of network performance for one or more network service areas may be produced.
A wireless device may be, for example, a wireless personal digital assistant. The information provider may not be affiliated with the one or more wireless service providers. The method may further include obtaining location information associated with the wireless devices. The location information may be obtained from a number of different technologies including a global positioning system (GPS), base-station triangulation technologies, cell identification, etc. In the case that a precise location is not available, location information can also be predicted based on previously received heading, speed and geographical (latitude and longitude) location of a wireless device. The location information can be made available to the information provider through many different means including an HTTP request, a proprietary message from a software client running on the wireless device, or even a request for the user's location that is originated from the information provider. In addition, location information can also be obtained if the device initiates a request for information that includes a specific location (i.e., a search for pizza restaurants in Mountain View, Calif.).
In some embodiments, a system for providing information indicative of network coverage by one or more wireless providers over a geographic area may include a service performance monitor, a performance correlation, and a report generator. The service performance monitor may obtain performance indicators for a plurality of accesses to an information provider by a plurality of wireless devices located over the entire geographical area of interest. The performance correlator may correlate the performance indicators with one or more network service areas and aggregate related performance indicators to produce one or more aggregated performance indicators. The report generator may produce, from the aggregated performance indicators, a representation of network performance for the one or more network service areas.
The systems and techniques described herein may provide one or more of the following advantages. Information about quality of network coverage provided by one or more wireless service providers may be collected from a single location or from a small number of locations. The collected information may include information about a large number of locations, at a variety of different times and for various wireless service providers and various wireless devices.
The details of one or more embodiments are set forth in the accompanying drawings and in the description below. Other features, objects and advantages will be apparent from the description and drawings, and from the claims.
These and other aspects will now be described in detail with reference to the following drawings.
Like reference symbols in the various drawings indicate like elements.
The systems and methods described herein relate to assessing quality of one or more wireless networks. The methods may be implemented, for example, by an information provider such as a search engine service or other information provider that distributes information in response to requests received from a plurality of wireless devices.
A wireless service provider network 101 may include a wireless network 116 comprising various network equipment and a series of wireless towers 119A, 119B and 119C, through which data and voice communications and services may be transmitted or received. As shown, the wireless network connects to the public switched telephone network (PSTN) 125 and to the Internet 128. The PSTN 125 may also connect to the Internet 128. Other networks may be accessible from either the PSTN 125 or from the Internet 128. For example, an information provider 131 may be accessible from the Internet 128 to users of the wireless service provider network 101, such as, for example, the wireless PDA 110. In any given environment, more than one wireless service provider network may exist. For example, as shown, both the wireless service provider 101 and the wireless service provider 104 coexist in the exemplary environment.
The exemplary environment 100 may further include a system for identifying the location of a device. For example, the system may include a global positioning system (GPS) 134. The global positioning system may include a plurality of satellites, such as satellites 137A and 137B, which may continuously transmit signals that devices can use to determine precise locations. For example, the vehicle wireless device 113 may receive a plurality of GPS signals, and from them, it may determine a precise location of the vehicle. Based on the plurality of location determinations, the vehicle communication system may also be able to predict a future location of the vehicle. For example, based on a location determination at time t1, the vehicle communication system may be able to determine a vehicle heading and speed from which it can predict the location of the vehicle at a time t2. Other wireless devices may also receive GPS signals from which they can determine precise location. For example, the wireless PDA 110 may receive GPS signals from which it can determine its precise location. A GPS-enabled wireless phone, such as the wireless phone 107, may also receive GPS signals from which it can determine a precise location at any given time. Any of these devices may also have a determined heading and speed. Each device may transmit determined location coordinates with other transmissions. For example, along with a request for data sent to an information provider, such as the information provider 131, the wireless PDA 110 may transmit GPS location coordinates. GPS provides just one method for obtaining location information. Location information may be obtained through other means, such as, for example, base-station triangulation technologies; base station location information; cell identification; explicit requests of the user to provide location information; inferences drawn from user data, such as location-specific requests; and location identification software running on a wireless device.
The arrows labeled with letters in
This exemplary communication path may represent, for example, a search request to an information provider such as the well-known Google™ search engine. The user of the wireless PDA may request, for example, information from the Google Local™ service or another appropriate service. The transmission from the user's wireless PDA may include the search request in addition to information about the user's geographic location. The information provider 131 may receive the search request in a conventional manner and provide its response in a known manner, such as using results from the Google PageRank™ system and process. The information provider 131 may also use the location information and other information that it is able to determine about the communication process, as described in more detail below, to determine information about the quality of the wireless network on which the user's request and the resulting response were transmitted.
The information provider 131 is connected to the Internet 128 to communicate with users who may be interested in accessing the services provided by the information provider. The information provider 131 could also be connected to other networks (not shown), such as, for example, an internal company network, or a local wireless communication network. The information provider 131 may be divided into separate systems to allow for scalability, data integrity, or data security, and it may be connected to the Internet 128 or to another network in any of a variety of ways, as is commonly known.
The information provider 131 includes an index database 143 and system storage 146. The index database 143 contains data that represents information that the information provider 131 provides to users. For example, the information provider 131 may comprise a typical Internet search engine, and the index database 143 may contain links to information stored on the Internet (outside of the information provider 131). When a user selects a link, the information to which the link points may be provided. As another example, some information to which entries in the index database 143 point may be stored in the system storage 146. For example, the system storage 146 may “mirror” information for which search reports are regularly received—such as, for example, breaking news stories or weather or traffic information. The system storage 146 may also store various components needed for general operation of the information provider 131, such as applications, system parameters and information about users who access the system.
In some embodiments, the index database 143 and the system storage 146 may be included in the data store 140 that is shown in
The information provider 131 communicates through an external interface 152 and an internal interface 155. Through the external interface 152, the information provider 131 receives requests and transmits responses. Through the internal interface 155, the information provider 131 internally routes information to and from the index database 143 and system storage 146. These interfaces are shown as distinct interfaces, but they may be partially or fully combined, or they may include additional interfaces. As an example, the internal interface 155 may comprise interface devices for a high-speed, high-bandwidth network such as SONET, Infiniband or Ethernet, or any suitable communication hardware operating under an appropriate protocol such that the information provider 131 can respond to a large number of distinct requests simultaneously. The external interface may 152 comprise network interface cards (NICs) or other communication devices and may similarly include components or interfaces of a high-speed, high-bandwidth network. The precise design of the information provider 131 is not critical to this disclosure and could take any suitable form.
The information in the index database 143 may be gathered by an automated information gatherer 158, such as, for example, a crawler. The information gatherer 158 may continuously or almost continuously obtain new information from sources connected to the Internet 128 or to other network(s) connected to the information provider 131. The index database 143 may index information that is stored in the system storage 146, or it may index data that is accessible from the Internet 128 or from another network. In addition to being added to the index database 143 or system storage 146 in an automated fashion, information may also be manually loaded in or retrieved from the index database 143 or the system storage 146 through a maintenance interface 161. The maintenance interface 161 may allow an information provider 131 administrator to manually add bulk data to the index database 143 or to the system storage 146.
Data requests, such as data requests from users, may be received through the external interface 152 and handled by a request processor (not shown in the figures). For example, the request processor 164 may parse the requests and reformat from, for example, HTML (hypertext markup language) or text format, to search terms or strings that are compatible with the search engine 149. The information generated by the search engine 149 in response to a request may be converted to another format by a response formatter 167 in a manner that allows it to be used by the requesting device. For example, the response formatter 167 may convert data that is in an internal format to HTML, WAP, XML, VoiceXML, etc. After formatting the response, the information provider 131 may transmit it to the requesting user via its external interface 152.
Information may be extracted and captured from incoming data requests by a service performance monitor 170. The monitor 170 may, for example, read a copy of the stream of data coming in through external interface 152, or a sub-set of that data, such as only data identified as related to mobile devices. This extracted information may be stored in a performance database 173. For example, data requests may include a header that includes information about a user making the data request. More particularly, in the case of a search request received from the Internet, the header information may include a date and time stamp and an Internet Protocol (IP) address that identifies the device from which the request originated. As another example, in the case of an information request originating from a wireless device, the header may include a date and time stamp, and information about the wireless service provider, the wireless device model, a user associated with the wireless device, location coordinates of the device, or other information. In addition, the system may have previously stored information about a device (such as information entered by a user as part of a registration process), and may refer to that information by using an identifier received from a device (e.g., like a “cookie”).
The external interface 152 may include a message tracker 176 that extracts additional information from incoming data requests or outgoing data responses. For example, in some embodiments, the information provider 131 and the device from which a data request originates may communicate with a guaranteed delivery protocol, such as, for example, TCP/IP. In such a system, the message tracker 176 may track outgoing response messages and corresponding incoming handshake messages to determine whether a response message is actually delivered. The message tracker 176 may be configured to resend a response message whose receipt has not been confirmed within a specific period of time. The message tracker 176 may be further configured to resend a response message a specific number of times, after which it no longer tracks the message.
The message tracker 176 may store information about any messages it resends. For example, the message tracker 176 may store a number in a “Retries” field in the performance database 173 corresponding to the number of times it resends a message. The message tracker 176 may further store information about whether it stops tracking a message in, for example, a “Dropped” field in the performance database 173. Similar functionality may be provided in a mobile device and the device may be programmed to send similar information to information provider 131.
As another example, the information provider 131 and the device from which the data request originates may, in some embodiments, communicate with an unguaranteed protocol, such as UDP. Even in embodiments that utilize a guaranteed protocol, the information provider 131 and the device from which the requests originates may communicate through an intermediate device (not shown) that prevents the information provider 131 from determining whether a response message has been ultimately delivered to the requesting device. For example, a wireless service provider may act as an intermediary between a wireless device and the information provider 131. More particularly, a wireless service provider may receive from the wireless device a data request, such as, for example, a search request for a specific restaurant near a specific location. The wireless service provider may forward the search request to the information provider 131 and may subsequently receive the corresponding information response. The wireless service provider may then forward the information response to the wireless device after confirming its receipt of the information response to the information provider 131. The wireless service provider may subsequently fail to deliver the information response to the requesting device.
In either of the above examples—where the information provider 131 uses an unguaranteed protocol, or where the information provider 131 and requesting device are separated by an intermediary device that prevents the information provider 131 from confirming ultimate deliver of the information response—the message tracker 176 may still be able to identify retried data requests. For example, the message tracker 176 may identify a first and second identical data request, originating from the same wireless device, within a short period of time. The message tracker 176 may determine that the second data request was a resend by the requesting device after it did not receive a response to the first data request. The message tracker 176 may then record, in the performance database 173, the second data request as a retry or a drop associated with the first data request.
In some embodiments, an intermediary device between the information provider 131 and the device may be configured to transmit information about dropped or retried information responses, and the message tracker 176 may store this information in the performance database 173. Also, the mobile device may track response time from its end, submit that time to information provider 131, and the submitted time may be compared to the response time in other parts of the path to determine or estimate the response time of the wireless network.
Information in the performance database 173 may be manipulated and analyzed by a performance data correlator 179. The performance data correlator 179 may identify data sets in the performance database 173 that include related performance data and may subsequently compile and analyze the identified data sets. For example, the performance data correlator 179 may identify data sets related to data requests from, for example, a specific time of day, a specific wireless service provider, a particular wireless device model, a specific location, or a combination or combinations of such factors. From fields that store information about retries or dropped information responses or about other relevant performance indicators, the performance data correlator 179 may generate inferences about signal quality associated with the requests from the specific time of day, the specific wireless provider, or the specific location. For example, if the performance data correlator 179 identifies a set of data from a specific time of day and location that is associated with a large number or retries or drops, the performance data correlator 179 may generate an inference that signal quality for that specific time of day and location is poor.
Analyzed data may be formatted for presentation to a user by a report generator 182. The report generator 182 may format the analyzed data in a way that effectively communicates performance data to a user. For example, the report generator 182 may generate a report that presents performance data as a function of wireless service provider, location, time, or other parameter, or that compares performance data for two or more wireless service providers, locations, times, devices, etc.
The wireless networks illustrated in
The location of buildings may also impact the shape of various regions. For example, tall office buildings may block or reflect wireless signals from particular wireless towers. As a result, regions near the tall office buildings may be shaped to accommodate natural areas of continuous wireless reception from nearby wireless towers. Approximate boundaries of the regions may be identified by a range of GPS coordinates, or by some other means. For example, approximate boundaries may be identified by distances from one or more wireless towers. To assess quality of wireless service in a specific region, certain information may be stored for a plurality of wireless communications originating from that region. The information may be stored in a database and analyzed periodically.
The method 300 includes receiving (301) a data request from a user. For example, the request processor, via the external interface 152, may receive a data request from a user connected to the information provider 131 via the Internet 128.
The method 300 determines (304) whether the data request is from a wireless device. For example, the service performance monitor 170 may scan a header that is included in the data request for information that indicates that the request originated at a wireless device. If the data request did not originate from a wireless device, the service performance monitor 170 may ignore the data request and wait to receive another data request in action 301. If the data request did originate from a wireless device, the service performance monitor 170 may continue processing the data request by performing the actions below.
In an action 307, the method 300 extracts information about the data request. For example, the service performance monitor 170 may extract information from the header included in the data request. Specifically, the service performance monitor may extract information related to at least one of: a) a wireless device ID; b) a time and date stamp; c) location information; d) the wireless service provider associated with the data request; and e) a wireless device model.
In an action 310, the method 300 may obtain certain information associated with the data request by looking it up in another data source. For example, the header may include a numeric wireless device ID, such as an alphanumeric manufacturer model code. The information provider 131 may look up the model code to identify a device name for storage in the performance database 173. In some embodiments, the service performance monitor 170 may simply store the alphanumeric model code. As another example, a header for one data request may include GPS coordinate data associated with the device sending the data request. A header for another data request may include a location code associated with the wireless service provider or with particular cells or wireless towers within the wireless service provider's network. The information provider 131 may, for example, look up both the GPS coordinate data and the location code to obtain a region with which to associate the data request.
In an action 313, the method 300 adds the information to the database. For example, the service performance monitor 170 may store the information obtained in actions 307 and/or 310 in the performance database 173. More particularly, the service performance monitor 170 may store different kinds of information in different fields of a table in the performance database 173, is further explained with reference to
In an action 317, the method 300 determines whether to receive additional data. For example, in some embodiments, the service performance monitor 170 may only collect and store certain amounts of data, or data at certain times. In some embodiments, the service performance monitor 170 may continue to receive data in action 301 as the information provider 131 receives data requests.
In an action 401, the method 400 receives input to generate a report. For example, the report generator 182 may receive input from a user connected to the information provider 131 to generate a report that summarizes performance of a specific wireless service provider. The user requesting the report may be connected to the information provider 131 by a private network (not shown in
In an action 404, the method 400 may authenticate the user requesting the report. For example, the report generator 182 may be configured to generate reports only for certain users. Specifically, in some embodiments, reports may not be available to the general public, but rather may only be accessible to certain users associated with the information provider 131.
In an action 407, the method 400 may receive parameter selection input that determines the type of report. For example, the report generator 182 may receive input that specifies parameters that include at least one of: a) a wireless service provider; b) a time period; c) a location identifier; d) a wireless device identifier; and e) other parameters.
In an action 410, the method 400 may retrieve database entries that correspond to the parameter selection input. For example, the performance data correlator 179 may retrieve entries from the performance database 173 that correspond to the wireless service provider, or time period, or location identifier, or wireless device identifier, or other parameters, or any combination of the foregoing that were received in the action 407.
In an action 413, the method 400 may determine whether there are enough retrieved database entries to process. For example, in some embodiments, the report generator 182 may be configured to only generate a report if the number of retrieved database entries from which the report is to be generated exceeds a threshold number. Such a limitation may ensure, for example, that the report draws from enough database entries to permit statistically significant inferences about service performance to be drawn.
If the method 400 determines that there are not enough database entries in the action 413, it may prompt the user for different parameters in an action 416. For example, the report generator 182 may indicate to the user that specific parameter selection input was not acceptable, and it may further suggest that the user enter other parameter selection input in the action 407. In some embodiments, the report generator 182 may suggest specific parameter selection input that is similar to the originally entered parameter selection input and for which there are sufficient database entries from which to generate a report.
In an action 419, the method 400 formats the database entries that were retrieved in the action 410. For example, the report generator 182 may sort database entries that the performance data correlator 179 retrieved from the performance database, and it may further generate a report that includes a graphical or a pictorial representation of the retrieved data.
In an action 422, the method 400 transmits the report to the user. For example, in some embodiments, the report generator 182 may send the report to the user who requested it via the external interface 152 and the Internet 128.
In the database 500, each row corresponds to a distinct wireless communication sent over a wireless network (a “data point”). Each column in the table corresponds to different information related to the data communication. As shown in the exemplary database 500, the stored information includes a unique Communication ID 501, a Device ID 504, a Date/Time Stamp 507, location information in the form of either or both of a GPS coordinate 510 or a Cell Location 513, the Wireless Service Provider 516, the Wireless Device Model 519, any Retries 522 necessary to send or resend any data, and whether the data access request was fulfilled, or whether the access was terminated (“Dropped” 525) prior to fulfillment.
In some embodiments, actual performance of a wireless network or of a wireless device may be inferred from any Retries 522 that are necessary to fulfill a data request or a Dropout 525 that occurs in the process of fulfilling a data request. For example, if one or more retries are necessary to fulfill a request for data, a low signal quality may be inferred. Retries may be necessary for other reasons, but when a large number of wireless communications are considered, low signal quality at a particular location may primarily be manifested by either retries or by dropped wireless communications by a relatively large number of devices in the relevant geographic area. Other data indicating network quality may also be stored, such as elapsed time to fulfill a request over a network.
Data in the other columns of the database 500 may be used with data on Retries 522 and Dropouts 525 to correlate quality with time, location, provider, device, or any combination thereof. The Communication ID 501 may store a unique number associated with a specific wireless communication. As shown, each value in the Communication ID field 301 is a reference numeral that corresponds to a location point 228, 231A, 231B, 231C, 234, 237, 240, 243, 246, 249 or 252 that is shown in
A Device ID 504 may store an identifier that associates a discrete wireless communication with a particular wireless device. The Device ID 504 may facilitate analysis of wireless communications over time by the same wireless device. For example, as shown, the rows corresponding to Communication IDs 231A, 231B and 231C capture wireless communications by the same device over a relatively short period of time. These wireless communications could be, for example, periodic requests for real-time traffic information from a vehicle wireless device, such as the vehicle communication device 113 as it travels along the highway 201C. Sequences of wireless communications such as 231A, 231B and 231C may be analyzed to track wireless signal quality at a particular time and by a particular device as a function of location. For example, since the wireless device is common, and the time is relatively fixed, variation in inferred signal quality for the data points 231A, 231B and 231C at the corresponding location may highlight variation as a function of location in the wireless signal quality of the network 219. More specifically, although none of the wireless communications 231A, 231B or 231C were dropped, wireless communication 231A required three retries. Given that other variables are relatively fixed, the retries could support an inference that signal quality is low at the location corresponding to data point 231A. In aggregate, many such sequences could be used to identify “dead zones,” or zones of poor wireless service coverage, as will be further described with reference to
The Date/Time Stamp 507 may be used to identify sequences such as the sequence comprising communication 231A, 231B and 231C described above. For example, a series of data points having a Date/Time Stamp 507 that are very close in time and that originate from the same device (as indicated by the Device ID 504) could be identified as a sequence. Quality information that varies as a function of location could be extracted from such sequences.
The Date/Time Stamp 507 field could also be used to group data points from many different days, but at the same general time of day. Such groupings may be useful for determining average wireless service assessments at a particular location, as a function of time, or as a function of wireless service provider. For example, wireless service quality at a particular location may generally be high at one point in the day, but generally low at another point in the day. Wireless service quality may be low, for example, if the wireless network is congested and unable to accept all network requests. As another example, a wireless service provider may maintain a number of adaptive or directional antennae along several major highways leading into the central business district of a large city. During a typical morning or afternoon commute, the antennae might be focused more on the highways and less on the central business district, in order to support commuters who may be using wireless devices while commuting. Between peak commute times, the antennae may be more focused on the central business district to support use of more wireless devices there. This change in focus of the antennae may result in variations in wireless signal quality as a function of time and location. Variation in signal quality may be intended by the wireless service providers in order to maximize capacity of wireless network equipment and to match capacity to needs of wireless device users. But the variation may not be advertised to consumers or to other wireless service providers. Variation in quality may also be a factor of the demand or load placed on certain portions of a network. Analysis of certain sets of data points may identify the regular variations in quality of wireless service over time or location. From the analysis, reports may be generated such as a report 900 that is shown in
Location information may take different forms. In some embodiments, wireless devices may have GPS capabilities, and these devices may transmit GPS location coordinates along with requests for data. When such GPS location information is received, it may be stored in the database 500. For example, as shown, the data requests associated with wireless communications 231A, 231B, 231C, 240, 243 and 246 all have GPS location information stored in the database 500. In some embodiments, location of wireless devices may be determined even when the wireless device is not equipped with GPS functionality. Wireless devices may receive signals from several different wireless towers. The devices may transmit a time of arrival for a synchronized signal from each tower. From the time-of-arrival transmissions, the wireless service provider may be able to calculate a relatively precise location using, for example, a technique such as Advanced Forward Link Trilateration (AFLT). The location—whether a GPS location, an AFLT location, or a location determined in some other manner—may be assigned to a Region 513. The Region 513 may be used as a reference point for data storage and analysis, as was described with reference to
Identification of the wireless service provider from whose network the data request originated is stored in the database 500 in the Wireless Service Provider 516 field. This information may be used to identify data points that correspond to a particular network. From these data points, a system may generate location-time assessments of quality for a particular network (see
The specific model of wireless device is also stored in the database table 500. This information may be used to compare quality of particular wireless devices. For example, the communications 237 and 240 occurred at roughly the same time and from nearby locations. If quality of the actual signal from the closest wireless tower is assumed to be relatively fixed, the wireless device itself may impact the inferred quality of the wireless service at the location from which the data request was made. For example, differences in fulfillment of data requests at different wireless devices, as evidenced by retries or dropped wireless communications, may point to differences in the wireless devices themselves. More particularly, the fact that the data request took three retries to be fulfilled for communication 240 when the data request was fulfilled without any retries for communication 237 may imply that the wireless devices themselves are of different quality. Conclusions about quality of wireless devices may be drawn relative to a “baseline” for the locations corresponding to wireless devices under comparison. For example, analysis of a large number of data points near the locations associated with communications 237 and 240 around 09:15 A.M. may indicate that network 216 generally provides a high quality wireless service. The fact that the specific wireless device that initiated communication 240 required three retries for the data request to be fulfilled may imply that the quality of the wireless device itself is of lower-than-average quality.
While the data in database 500 and elsewhere in this document is shown in a particular format to assist in understanding a system and its operation, in actual application, the data may taken many different forms and be stored in appropriate manners. For example, the various data may be stored across multiple relational databases or database components. In addition, the data may take a non-readable form, such as to reduce the amount of storage spaced required for the data. In addition, the data may be pre-processed in various manners. For example, multiple data entries may be combined into a single entry, such as to reduce errors in the data or reduce the size of the data. As one example, where a mobile device is constantly transmitting useful information, the information may be stored as discrete averaged information for discrete periods that are longer in length than the periods at which the device is providing data.
Each data point in the database 600 includes a Communication ID 601 that may be used during analysis to distinguish one data point from another. Each data point also includes a number of Retries 607, if any, associated with the data point and another number, 1 or 0, that represents whether that particular wireless communication was dropped (610) or not, respectively. A Score 613 is also shown in the database 600. The Score 613 could be related to the number of Retries 607 and the Dropped 610 field, or to another indicator of network quality or data transmission quality. The Score 613 may permit an inference to be drawn on the signal quality at the corresponding Region 604 for a particular wireless communication. As shown, the Score 613 is equal to the number of Retries 604 plus three if the wireless communication was dropped, or zero if it was not dropped. In this manner, the exemplary Score 613 weights a drop more heavily than a single retry. In other embodiments, the Score 613 may be calculated in another manner.
While the scores are shown graphically in
In addition to graphical representations like the graphical representation 800, numerous other kinds of reports may be generated. The reports may summarize quality associated with one or more wireless networks graphically. For example, a report may comprise a map or a series of maps (e.g., in the form of an animation or animations) depicting coverage of a particular wireless service provider as a function of location or time, as illustrated by
As illustrated in
The maps 904 and 907 may be generated in a similar manner—from hundreds or thousands (or more) of data points corresponding to hundreds or thousands (or more) of wireless communications at other times of the day. In addition to the static maps 901, 904 and 907, more continuous representations of wireless signal quality could be generated. For example, many maps may be generated for many different times throughout the day, and one or more animations may be generated from the many different maps. Data may also be interpolated as needed to smooth out the animation.
A wireless service provider may use this information to improve its wireless service network. For example, it may be desirable for a wireless service provider to vary its coverage over a particular area throughout the day. Rather than adding wireless towers to vary coverage, the wireless service provider may adjust the antennae on existing wireless towers to focus coverage in a particular direction. For example, a wireless service provider may wish to adjust antennae along a major highway to ensure good coverage from the highway during peak commute times. However, such an adjustment may have the effect of lowering the quality of coverage in an adjoining residential neighborhood. Faced with this tradeoff, the wireless service provider may use data compiled from an information provider to assess the volume and locations wireless services requests. In such a situation, adjustments may be made using historical data or even real-time data, particularly in heavily traveled areas.
As illustrated in
The user may also provide, or be provided with, a quality along that route from point A to point B, where point A is shown on the left of the graph point B on the right, a quality as one or more (for multiple carriers) line graphs in between. Landmarks on the trip may also be indicated before points A and B. A wireless service provider may use the maps 1001 and 1004 for strategic planning purposes. For example, Carrier B may plan future wireless tower sites to capture more of the wireless service market among morning commuters along the highway 201C.
As illustrated in
Other appropriate reports, whether graphical or not, may also be generated using the stored data. For example, a user experiencing quality problems with a wireless device may submit a request with the device (such as by pressing a key on the device or selecting an icon on the screen of the device), which may trigger a central system having access to data on network quality in particular locations to generate a visual or aural instruction telling the user which way to move for better coverage. In addition, an organization wishing to purchase time or bandwidth on the physical networks of various wireless carriers may also use the data to generate reports and recommendations about which carriers have the best coverage in particular areas and at particular times. Such an organization may then piece together access agreements that allow for the best coverage at the best costs.
Various implementations of the systems and techniques described here can be realized in digital electronic circuitry, integrated circuitry, specially designed ASICs (application specific integrated circuits), computer hardware, firmware, software, and/or combinations thereof. These various implementations can include implementation in one or more computer programs that are executable and/or interpretable on a programmable system including at least one programmable processor, which may be special or general purpose, coupled to receive data and instructions from, and to transmit data and instructions to, a storage system, at least one input device, and at least one output device.
These computer programs (also known as programs, software, software applications or code) include machine instructions for a programmable processor, and can be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the term “machine-readable medium” refers to any computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory, Programmable Logic Devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine instructions as a machine-readable signal. The term “machine-readable signal” refers to any signal used to provide machine instructions and/or data to a programmable processor.
To provide for interaction with a user, the systems and techniques described here can be implemented on a computer having a display device (e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor) for displaying information to the user and a keyboard and a pointing device (e.g., a mouse or a trackball) by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback (e.g., visual feedback, auditory feedback, or tactile feedback); and input from the user can be received in any form, including acoustic, speech, or tactile input.
The systems and techniques described here can be implemented in a computing system that includes a back-end component (e.g., as a data server), or that includes a middleware component (e.g., an application server), or that includes a front-end component (e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with an implementation of the systems and techniques described here), or any combination of such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication (e.g., a communication network). Examples of communication networks include a local area network (“LAN”), a wide area network (“WAN”), and the Internet.
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
Although a few embodiments have been described in detail above, other modifications are possible. The systems and methods described herein may be implemented in many different wireless networks, including by way of example, cellular voice networks; wide area wireless networks such as TDMA, CDMA, W-CDMA, GSM, satellite-based, or EDGE networks; metro area networks such as WiMAX networks; local area networks such as WiFi networks; and any other wireless networks that can deliver voice, data, information, gaming applications, business or utility applications, or other services over a large or small geographical area. Also, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. Other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Other embodiments may be within the scope of the following claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5490204||Mar 1, 1994||Feb 6, 1996||Safco Corporation||Automated quality assessment system for cellular networks|
|US5644623||Jan 31, 1996||Jul 1, 1997||Safco Technologies, Inc.||Automated quality assessment system for cellular networks by using DTMF signals|
|US5799154||Jun 27, 1996||Aug 25, 1998||Mci Communications Corporation||System and method for the remote monitoring of wireless packet data networks|
|US5983185||Oct 10, 1997||Nov 9, 1999||Telefonaktiebolaget Lm Ericsson (Publ)||Method and device for simultaneously recording and presenting radio quality parameters and associated speech|
|US6157830||May 22, 1997||Dec 5, 2000||Telefonaktiebolaget Lm Ericsson||Speech quality measurement in mobile telecommunication networks based on radio link parameters|
|US6219544||Dec 20, 1996||Apr 17, 2001||Nokia Telecommunications Oy||Telemetric measuring of a mobile telephone network|
|US6236949 *||Oct 7, 1999||May 22, 2001||Power Measurement Ltd.||Digital sensor apparatus and system for protection, control and management of electricity distribution systems|
|US6285875||Jun 28, 1996||Sep 4, 2001||Telefonaktiebolaget Lm Ericsson||Traffic management system for use in mobile communications network|
|US6438373 *||Feb 22, 1999||Aug 20, 2002||Agilent Technologies, Inc.||Time synchronization of human speech samples in quality assessment system for communications system|
|US6516189||Mar 17, 1999||Feb 4, 2003||Telephia, Inc.||System and method for gathering data from wireless communications networks|
|US6603966||Dec 23, 1997||Aug 5, 2003||At&T Wireless Services, Inc.||Method and system for optimizing performance of a mobile communication system|
|US6609001||Feb 5, 2002||Aug 19, 2003||Dynamic Telecommunications, Inc.||Apparatus and method for providing signal quality measurements in drive test systems for wireless networks|
|US6711404||Jul 21, 2000||Mar 23, 2004||Scoreboard, Inc.||Apparatus and method for geostatistical analysis of wireless signal propagation|
|US6721557||Mar 17, 1999||Apr 13, 2004||Swisscom Ag||Method for determining the quality of mobile radiotelephone units in a mobile radiotelephone network|
|US6775549||Oct 8, 2002||Aug 10, 2004||At&T Wireless Services, Inc.||Method for self-calibration of a wireless communication system|
|US6778823||Feb 20, 2002||Aug 17, 2004||T-Mobile Deutschland Gmbh||Method for testing the quality of mobile radio networks|
|US6810246||Oct 23, 2000||Oct 26, 2004||Verizon Laboratories Inc.||Method and system for analyzing digital wireless network performance|
|US6816727 *||Apr 30, 2003||Nov 9, 2004||Metro One Telecommunications, Inc.||Technique for continually providing directional assistance over a communication network to a user|
|US20020177448 *||Mar 20, 2001||Nov 28, 2002||Brian Moran||System and method for wireless data performance monitoring|
|US20030120753 *||Feb 12, 2003||Jun 26, 2003||Sap Aktiengesellschaft||Methods and systems for generating interactive information formatted for a device|
|US20040204063 *||Feb 22, 2003||Oct 14, 2004||Julian Van Erlach||Enhanced telecommunication services|
|US20050064870 *||Sep 23, 2003||Mar 24, 2005||Gabara Thaddeus John||Method and apparatus for automatic determination of optimal user device location in a wireless network|
|US20050080563 *||Sep 8, 2004||Apr 14, 2005||Petrovski Ivan G.||RTK positioning system and positioning method therefor|
|US20050136949 *||Jan 10, 2005||Jun 23, 2005||Barnes Melvin L.Jr.||Portable communications device and method of use|
|US20060223546 *||Mar 31, 2005||Oct 5, 2006||Holger Claussen||Adapting a communications network of wireless access nodes to a changing environment|
|US20060239266 *||Apr 21, 2005||Oct 26, 2006||Babbar Uppinder S||Method and apparatus for supporting wireless data services on a TE2 device using an IP-based interface|
|US20070088819 *||Oct 6, 2006||Apr 19, 2007||Verizon Laboratories Inc.||Service level agreements and management thereof|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US8027266 *||Aug 31, 2007||Sep 27, 2011||Symbol Technologies, Inc.||Optimized RF coverage using AJAX and SVG|
|US8108144||Jan 31, 2012||Apple Inc.||Location based tracking|
|US8112042 *||Feb 7, 2012||Kddi Corporation||Wireless communication device capable of measuring quality of wireless signal at variable time intervals|
|US8175802||May 8, 2012||Apple Inc.||Adaptive route guidance based on preferences|
|US8180379||May 15, 2012||Apple Inc.||Synchronizing mobile and vehicle devices|
|US8204684||Jun 19, 2012||Apple Inc.||Adaptive mobile device navigation|
|US8260320||Nov 13, 2008||Sep 4, 2012||Apple Inc.||Location specific content|
|US8275352||Jan 3, 2008||Sep 25, 2012||Apple Inc.||Location-based emergency information|
|US8290513||Oct 16, 2012||Apple Inc.||Location-based services|
|US8311526||May 27, 2008||Nov 13, 2012||Apple Inc.||Location-based categorical information services|
|US8311741||Nov 4, 2011||Nov 13, 2012||Google Inc.||Method and system for generating travel routes based on wireless coverage|
|US8332402||Dec 11, 2012||Apple Inc.||Location based media items|
|US8351923||Mar 14, 2012||Jan 8, 2013||Root Wireless, Inc.||Mobile device and method for collecting location based user quality data|
|US8355862||Jan 6, 2008||Jan 15, 2013||Apple Inc.||Graphical user interface for presenting location information|
|US8359643||Jan 22, 2013||Apple Inc.||Group formation using anonymous broadcast information|
|US8364089||Sep 30, 2011||Jan 29, 2013||Google Inc.||Network performance server|
|US8379532 *||Feb 19, 2013||Root Wireless, Inc.||Web server and method for hosting a web page for presenting location based user quality data related to a communication network|
|US8423046||Apr 16, 2013||Google Inc.||Network performance server|
|US8509811||Sep 29, 2011||Aug 13, 2013||Google Inc.||Service provider recommendation engine|
|US8548735||Jan 30, 2012||Oct 1, 2013||Apple Inc.||Location based tracking|
|US8644843||May 16, 2008||Feb 4, 2014||Apple Inc.||Location determination|
|US8660530||May 1, 2009||Feb 25, 2014||Apple Inc.||Remotely receiving and communicating commands to a mobile device for execution by the mobile device|
|US8666367||May 1, 2009||Mar 4, 2014||Apple Inc.||Remotely locating and commanding a mobile device|
|US8670748||Mar 30, 2010||Mar 11, 2014||Apple Inc.||Remotely locating and commanding a mobile device|
|US8694026||Oct 15, 2012||Apr 8, 2014||Apple Inc.||Location based services|
|US8711776 *||Jun 17, 2009||Apr 29, 2014||Telefonaktiebolaget L M Ericsson (Publ)||Methods and apparatus for adapting network characteristics in telecommunications systems|
|US8738039||Nov 9, 2012||May 27, 2014||Apple Inc.||Location-based categorical information services|
|US8762056||Feb 6, 2008||Jun 24, 2014||Apple Inc.||Route reference|
|US8774825||Jun 6, 2008||Jul 8, 2014||Apple Inc.||Integration of map services with user applications in a mobile device|
|US8832258||Oct 6, 2009||Sep 9, 2014||Root Wireless, Inc.||Server device and method for directing mobile devices to collect and communicate location based user quality data|
|US8924144||Jan 30, 2012||Dec 30, 2014||Apple Inc.||Location based tracking|
|US8965288||Dec 31, 2012||Feb 24, 2015||Elwha Llc||Cost-effective mobile connectivity protocols|
|US9066199||Jun 27, 2008||Jun 23, 2015||Apple Inc.||Location-aware mobile device|
|US9083610 *||Jan 18, 2013||Jul 14, 2015||Root Wireless, Inc.||Web server and method for hosting a web page for presenting location based user quality data related to a communication network|
|US9107180 *||Aug 12, 2013||Aug 11, 2015||Verizon Patent And Licensing Inc.||User device radio activity optimization in dead zones|
|US9109904||Jan 25, 2008||Aug 18, 2015||Apple Inc.||Integration of map services and user applications in a mobile device|
|US9113345 *||Mar 13, 2013||Aug 18, 2015||Root Wireless, Inc.||Web server and method for hosting a web page for presenting location based user quality data related to a communication network|
|US9131342||Apr 30, 2014||Sep 8, 2015||Apple Inc.||Location-based categorical information services|
|US9154984 *||Nov 15, 2011||Oct 6, 2015||Google Inc.||System and method for estimating network performance|
|US9250092||May 12, 2008||Feb 2, 2016||Apple Inc.||Map service with network-based query for search|
|US9310206||Dec 29, 2014||Apr 12, 2016||Apple Inc.||Location based tracking|
|US9340214||Apr 14, 2014||May 17, 2016||Caterpillar Inc.||System for remotely controlling a machine|
|US20090063525 *||Aug 31, 2007||Mar 5, 2009||Symbol Technologies, Inc.||Optimized rf coverage using ajax and svg|
|US20100048224 *||Dec 21, 2007||Feb 25, 2010||Axel Klatt||Method for network identification acquisition by regular users for supporting automated planning and optimization processes in cellular mobile radio networks|
|US20100091677 *||Oct 6, 2009||Apr 15, 2010||Root Wireless, Inc.|
|US20100094930 *||Oct 6, 2009||Apr 15, 2010||Root Wireless, Inc.||Server device and method for directing mobile devices to collect and communicate location based user quality data|
|US20100113006 *||Nov 4, 2008||May 6, 2010||2Wire, Inc.||Cell calibration|
|US20100159843 *||Dec 22, 2009||Jun 24, 2010||Kddi Corporation||Wireless communication device capable of measuring quality of wireless signal at variable time intervals|
|US20110207411 *||Aug 25, 2011||Google Inc.||Network Performance Server|
|US20110208668 *||Apr 9, 2010||Aug 25, 2011||Google Inc.||Server Provider Recommendation Engine|
|US20120093001 *||Jun 17, 2009||Apr 19, 2012||Petter Ljung||Methods and Apparatus for Adapting Network Characteristics in Telecommunications Systems|
|US20130132517 *||May 23, 2013||Root Wireless, Inc.|
|US20130196685 *||Mar 13, 2013||Aug 1, 2013||Root Wireless, Inc.|
|US20130331126 *||Aug 12, 2013||Dec 12, 2013||Verizon Patent And Licensing Inc.||User device radio activity optimization in dead zones|
|EP2385728A1||May 4, 2011||Nov 9, 2011||Vodafone IP Licensing limited||Method and apparatus to determine radio coverage of telecommunications networks|
|WO2010053873A1 *||Nov 2, 2009||May 14, 2010||2Wire, Inc.||Cell calibration|
|WO2011103061A2 *||Feb 14, 2011||Aug 25, 2011||Google Inc.||Network performance server|
|WO2011103061A3 *||Feb 14, 2011||Jan 19, 2012||Google Inc.||Network performance server|
|U.S. Classification||455/67.11, 455/456.2, 370/248, 370/253, 455/423, 370/245, 455/434, 455/515, 370/241.1|
|International Classification||H04B17/00, H04W24/00, H04W16/18, H04W24/08|
|Cooperative Classification||H04W16/18, H04W24/00, H04W24/08|
|European Classification||H04W24/08, H04W24/00|
|Oct 26, 2005||AS||Assignment|
Owner name: GOOGLE, INC., CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CHU, MICHAEL;CRADY, MARK;BALUJA, SHUMEET;REEL/FRAME:016942/0870
Effective date: 20051025
|Sep 23, 2011||FPAY||Fee payment|
Year of fee payment: 4
|Dec 24, 2015||FPAY||Fee payment|
Year of fee payment: 8