US20220295218A1 - System And Method For Communication With A Tracking Device - Google Patents
System And Method For Communication With A Tracking Device Download PDFInfo
- Publication number
- US20220295218A1 US20220295218A1 US17/684,089 US202217684089A US2022295218A1 US 20220295218 A1 US20220295218 A1 US 20220295218A1 US 202217684089 A US202217684089 A US 202217684089A US 2022295218 A1 US2022295218 A1 US 2022295218A1
- Authority
- US
- United States
- Prior art keywords
- mobile
- tracking device
- host
- data
- request
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
- H04W4/021—Services related to particular areas, e.g. point of interest [POI] services, venue services or geofences
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/02—Services making use of location information
- H04W4/029—Location-based management or tracking services
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W52/00—Power management, e.g. TPC [Transmission Power Control], power saving or power classes
- H04W52/02—Power saving arrangements
- H04W52/0209—Power saving arrangements in terminal devices
- H04W52/0251—Power saving arrangements in terminal devices using monitoring of local events, e.g. events related to user activity
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W64/00—Locating users or terminals or network equipment for network management purposes, e.g. mobility management
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W4/00—Services specially adapted for wireless communication networks; Facilities therefor
- H04W4/70—Services for machine-to-machine communication [M2M] or machine type communication [MTC]
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D30/00—Reducing energy consumption in communication networks
- Y02D30/70—Reducing energy consumption in communication networks in wireless communication networks
Definitions
- This invention relates generally to a system and method for monitoring location, and more specifically to a system and method for enabling communication with a tracking device.
- systems exist for tracking the location of persons and/or property.
- such systems include a tracking device that transmits the location of the tracking device to a central station, which may then take some action based on the location data.
- Known systems have generally been very limited with respect to the communication capabilities between the tracking device and the central station. For example, communications from a tracking device to a central station have typically been limited to the transmission of a device identifier in combination with location data and, in some cases, a distress signal.
- What is needed is a system and method for providing enhanced communication with tracking devices. What is also needed is a system and method for providing enhanced communication with tracking devices, while minimizing power consumption. What is also needed is a system and method for providing enhanced communication with tracking devices, while minimizing network air time.
- a system and method for providing communication with a tracking device is disclosed.
- the inventor has discovered that several advantages are provided by the communication system and methods disclosed herein. These advantages include the efficient use of network access time and the conservation of tracking device power. Additional advantages include enhanced efficiency and flexibility in the communication of location data from tracking devices. Yet another advantage is that functional access (e.g., setting and/or resetting of functions, parameters, etc.) to the tracking device is provided to the central station.
- a tracking device includes a location detector, a communication device, memory, a processor, and a configuration routine.
- the location detector e.g., a Global Positioning Satellite receiver
- the communication device e.g., a cell phone modem
- the memory stores data and code, the data including location data determined by the location detector and configuration data.
- the processor is operative to execute the code to impart functionality to the tracking device.
- the functionality of the tracking device depends at least in part on the configuration data.
- the configuration routine is operative to modify the configuration data responsive to a communication from the remote system. Thus, functional access to the tracking device is provided to the remote system.
- the tracking device can be configured and reconfigured in many ways.
- the configuration data modifiable responsive to the communication from the remote system at least partially determines an interval for communicating the location data to the remote system.
- the configuration data modifiable responsive to the communication from the remote system at least partially determines an interval for buffering the location data when the communication device is unable to communicate the location data to the remote system (e.g., out of communication range).
- the interval for buffering the location data can be, for example and without limitation, a time interval (e.g., every 30 minutes) or a distance interval (e.g., whenever the tracking device moves 50 yards).
- the configuration data modifiable responsive to the communication from the remote system at least partially determines a power state of the location detector.
- the configuration data modifiable responsive to the communication from the remote system at least partially determines a monitored condition with respect to the location of the tracking device (e.g., a “geofence”).
- the monitored condition can be a geographical area (e.g., circular or polygonal, etc.), a velocity, a distance, a time/distance relationship (e.g., a time the tracking device remains stationary), or any combination of these.
- the configuration data modifiable responsive to the communication from the remote system at least partially determines a threshold distance between one of the locations and subsequent ones of the locations for storing the subsequent ones of the locations (e.g., only buffer location data if the tracking device has moved at least the threshold distance).
- the configuration data modifiable responsive to the communication from the remote system at least partially determines an interval for communicating diagnostic information from the tracking device to the remote system.
- the example tracking device also includes a data transfer routine operative to communicate operational data between the tracking device and the remote system.
- the tracking device includes a battery and the data transfer routine responsive to a request from the server is operative to communicate data indicative of the status of the battery to the remote system.
- the data transfer routine responsive to a request from the server is operative to communicate data indicative of a radio signal strength to the remote system.
- the data transfer routine responsive to a request from the server is operative to communicate data indicative of a status of the location detector to the remote system.
- the data transfer routine responsive to a status of a monitored location condition is operative to communicate data indicative of a violation or satisfaction of the location condition to the remote system.
- a status of a monitored location condition e.g., a geofence definition
- the data transfer routine responsive to a request from the server is operative to communicate diagnostic data to the remote system.
- Another feature of the example tracking device is that when the communication device is unable to establish a connection with the remote system, the location data is accumulated in the memory. Then, when the communication device is able to establish a connection with the remote server, the data transfer routine communicates the accumulated data to the remote system.
- An example method for communicating with a tracking device includes communicating with the tracking device via a wireless network and providing configuration data to the tracking device via the wireless network.
- the configuration data causes the tracking device to operate according to a first configuration.
- the method further includes receiving processed data from the tracking device.
- the processed data is generated by the tracking device in the first configuration.
- the method further includes providing new configuration data to the tracking device via the wireless network.
- the new configuration data changes the first configuration of the tracking device to a different configuration.
- the method further includes receiving additional processed data from the tracking device.
- the additional processed data is generated by the tracking device in the different configuration.
- the configuration data at least partially determines a location data reporting interval. In another example method, the configuration data at least partially determines a location data buffering interval. In yet another example method, the configuration data at least partially determines a power state of the tracking device. In yet another example method, the configuration data at least partially determines a location based condition that if violated or satisfied causes an indication of the violation or satisfaction of the location based condition to be communicated from the tracking device to the remote system. In yet another example method, the configuration data at least partially determines a diagnostic reporting interval. In yet another example method, the configuration data at least partially determines a distance threshold for buffering location data. In yet another example method, the processed data includes data indicative of a battery status of the tracking device. In yet another example method, the processed data includes data indicative of a radio signal strength determined by the tracking device. In yet another example method, the processed data includes data generated by a diagnostic routine of the tracking device.
- FIG. 1 is a block diagram of a tracking system
- FIG. 2 is a block diagram of a server of the tracking system of FIG. 1 ;
- FIG. 3 is a block diagram of a subscriber system of the tracking system of FIG. 1 ;
- FIG. 4 is a block diagram of a tracking device of the tracking system of FIG. 1 ;
- FIG. 5 is a flow chart summarizing an example method of communicating with the tracking device of FIG. 1 and FIG. 4 .
- FIG. 1 is a block diagram of a system 100 for tracking and/or monitoring one or more tracking devices 102 ( 1 - m ).
- System 100 includes one or more servers 104 ( 1 - m ), a subscriber profile database 106 , a vendor information database 108 , a public database cache 110 , and tracking interface 112 , all intercommunicating via an internal network 114 .
- System 100 communicates with remote components including one or more vendors 116 ( 1 - n ), one or more subscribers 118 ( 1 - p ), and one or more public databases 120 ( 1 - q ), all via an internetwork 122 (e.g., the Internet).
- a firewall 124 provides a measure of security for internal network 114 against threats via internetwork 122 .
- Servers 104 host services for subscribers 118 and/or other authorized users that facilitate the tracking and/or monitoring of the location of tracking devices 102 .
- Subscriber profile database 106 stores information associated with particular subscribers 118 and/or other users of system 100 .
- Vendor information database 108 stores information associated with vendors 116 that provide goods and or services that can be made available to subscribers 118 and/or other users of system 100 based on information from subscriber profile database 106 and/or location data received from tracking devices 102 .
- Public database cache 110 provides temporary storage for data retrieved from public databases 120 .
- Tracking interface 112 transmits (via wireless communication) data and commands to tracking devices 102 and receives data (e.g., location data, sensor readings, distress signal, etc.) from tracking devices 102 .
- Vendors 116 offer goods and services that may be offered to subscribers and other users of system 100 as described above.
- information associated with vendors e.g., type of business
- public databases 120 provide information (e.g., sex offender registries, etc.) that can be used as criteria for defining boundaries.
- Subscribers 118 are the primary users of system 100 and interact with servers 104 to define tracking criteria and to obtain information and alerts regarding the tracking of associated tracking devices 102 .
- the primary users are referred to as subscribers, because it is expected that users will be willing to pay for the right to use system 100 .
- system 100 is not limited to a subscription type business model. For example, access to system 100 could be provided to users on a free basis, relying on some other business model to raise revenue.
- the communication methods described herein can be used to provide direct communication between tracking devices 102 and subscribers 118 via a communication link (e.g., mobile phone network), which is not shown in FIG. 1 .
- the communication methods described herein can be used to provide direct communication between tracking devices 102 (e.g., GPS enabled cell phone to GPS enabled cell phone). In that case tracking devices 102 can function as both a tracking device and a subscriber system.
- FIG. 2 is a block diagram of a server 102 of tracking system 100 .
- Server 102 includes non-volatile data storage 202 , one or more processing units 204 , memory 206 , user I/O devices 208 , and a network interface 210 .
- Nonvolatile data storage 202 stores data and code that is retained even when server 104 is powered down.
- Memory 206 stores data and code that when processed by processing unit(s) 204 imparts functionality to server 104 .
- User input/output devices 208 e.g., keyboard, mouse, monitor, etc.
- Network interface 210 provides a communication link to other components on internal network 114 and internetwork 122 .
- memory 206 For the sake of clear explanation data and code are shown in memory 206 as functional blocks. It should be understood, however, that the various functions of server 104 need not be run in any particular location of memory 206 and may grouped in any useful manner. For example, the several application program interfaces (APIs) shown could be grouped into a single API.
- APIs application program interfaces
- Memory 206 includes an operating system 214 , public database API 216 , subscriber API 218 , processing queues 220 , vendor API 222 , control and coordination routines 224 , application programs 226 , and a tracking device communication protocol 228 .
- Operating system 214 provides low level control of server 104 and provides a platform on top of which the other modules can operate.
- Application programs 226 are tracking service programs that receive and process location and/or sensor data from tracking devices 102 , process the received data, communicate with subscribers 118 , read and/or update subscriber profile database 106 , search remote data sources, and so on.
- Public database API 216 , vendor API 222 , and subscriber API 218 provide a means of communication between application programs 226 and public databases 120 , vendors 116 , and subscribers 118 , respectively.
- Control and coordination module 224 provides overall control and coordination of the tracking services provided by server 104 .
- Processing queues 220 provide temporary storage for tracking data that is being processed.
- Tracking device communication protocol 228 defines a protocol for communicating with tracking device 102 . In this particular embodiment, this communication occurs via network 114 , tracking interface 112 , and the wireless connection with tracking devices 102 . It is sometimes, therefore, referred to as the over-the-air protocol. The definitions and functionality of an example tracking device communication protocol 228 is fully described below.
- FIG. 3 is a block diagram of a subscriber system 118 of tracking system 100 .
- Subscriber system 118 includes non-volatile data storage 302 , one or more processing units 304 , memory 306 , user I/O devices 308 , and a network interface 310 , all intercommunicating via a bus 312 .
- Memory 306 includes operating system 314 , application programs 316 , subscriber API 318 , and tracking device communication protocol 320 .
- Application programs 316 provide various tracking based services (e.g., set up tracking account, associate particular tracking devices 102 with user account, receive and/or display real time and/or historical location information associated with particular tracking devices 102 , and so on).
- Subscriber API 318 (in conjunction with subscriber API 218 of server 104 shown in FIG. 2 ) facilitates communication between application programs 316 of subscriber system 118 and application programs 226 of server 104 ( FIG. 2 ).
- Tracking device communication protocol 320 is similar to tracking device communication protocol 228 of server 104 , except that tracking device communication protocol 320 resides on a subscriber system 118 . Therefore, tracking device communication protocol 320 facilitates direct communication between subscriber system 118 and tracking device 102 via a separate communication link (not shown), such as a mobile telephone network.
- FIG. 4 is a block diagram of a tracking device 102 of tracking system 100 .
- Tracking device server 102 includes non-volatile data storage 402 , one or more processing unit(s) 404 , memory 406 , location detector (e.g., GPS receiver) 408 with optional sensors (e.g., temperature sensor, motion sensor, etc.), and a wireless communication device 410 , all intercommunicating via a bus 412 .
- Memory 406 includes an operating system 414 , application programs 416 , a tracking API 418 , location data 420 , tracking device communication protocol 422 , and sensor data 424 .
- Application programs 416 facilitate the processing of location data 420 and/or sensor data 424 , provide alerts and/or updates to server 104 ( FIG.
- Tracking API facilitates communication between application programs 416 and application programs 226 of server 104 , for example, to communicate location data from tracking device 102 to server 104 .
- Sensor data 424 and location data 420 can be accessed by application programs 416 as needed.
- Data indicative of the velocity of tracking device 102 can be characterized as either sensor data or location data.
- Tracking device communication protocol 422 is similar to tracking device communication protocol 228 , except that tracking device protocol 422 operates on the device side of the communication link.
- index values to pass a value measured by or stored at the device.
- the firmware When a data field is defined as a gradient, the firmware will calculate an index value as the number of increments from a defined base value. This value, an integer, will be placed within the structure for transmission.
- That actual measured value is calculated by first retrieving the pre-defined values for base, increment, and unit of measure from a table lookup. These values are stored based on Device Type and Firmware Version, and are applied uniformly for all devices sharing these characteristics.
- the actual measurement value is calculated as
- the server will then store the calculated result as a high-precision value in the database.
- System presentation layers can convert these values to the localized measurement system for display, using the unit of measure field as a helper.
- the suggested base and increment are suggested values only. The developer must decide the actual base and increment to meet the requirements for range and granularity imposed by the specific implementation.
- GPS_NOFIX 0 ⁇ 01 GPS is powered on but could not establish a fix.
- GPS_SEARCHING 0 ⁇ 02 GPS is establishing a fix.
- GPS_LOCALT 0 ⁇ 04 GPS has a full three dimension fix with altitude.
- GPS_POWERDOWN 0 ⁇ 01 Power down the GPS.
- GPS_POWERUP 0 ⁇ 02 Power up the GPS and attempt to obtain a fix.
- GPS_POWERDOWNUNTIL 0 ⁇ 03 Power down until the wake up time.
- ⁇ ⁇ ⁇ GET_DEVICE_ID Request 0x0101 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_CURRENT_LOCATION Request 0x0102 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_BATTERY_STATUS Request 0x0103 ⁇ ⁇ ⁇ ⁇ ⁇ GET_RSSI Request 0x0104 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_GPS_STATUS Request 0x0105 ⁇ ⁇ ⁇ ⁇ ⁇ GET_GEOFENCE_HANDLE Request 0x0106 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_GEOFENCES Request 0x0107 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_CUSTOM_PARAM Request 0x0108 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_DIAGNOSTIC Request 0x0109 ⁇ ⁇ ⁇ ⁇ ⁇ ⁇ GET_SYSTEMTIME Request
- POSITION defines a geographic position.
- CORNER defines a corner of a polygon geofence.
- LOCATE defines complete information about the device location in a moment in time.
- Transport Envelopes contain transport-specific information necessary to ensure reliable deliver of information between host and mobile applications.
- Each transport has a specific transport envelope that all request and response transaction structures are encapsulated within.
- the UDP Transport Envelope is use to encase all UDP transport request and response structures.
- the Reverse HTTP Transport Envelope is use to encase all Reverse HTTP transport request and response structures.
- the Direct HTTP Transport Envelope is use to encase all Direct HTTP transport request and response structures.
- the TCP Transport Envelope is use to encase all TCP transport request and response structures.
- the SMS Transport Envelope is use to encase all SMS transport request and response structures.
- GET request structures can be used to initiate both host-to-mobile and mobile-to-host application-layer transactions. These requests contain a request for data, which is typically acknowledged by a corresponding PUT response structure containing the requested data.
- GET_DEVICE_ID is used by the device during first time initialization to obtain a unique device identifier from the GTX host platform.
- This unique device identifier is the primary method by which the device data is organized within the GTX platform. Most subsequent requests require a valid device identified as a structure member.
- a properly formatted GET_DEVICE_ID request structure will be responded to from the host with a PUT_DEVICE_ID response structure.
- GET_CURRENT_LOCATION is used by the host to request the most recent location coordinates from the mobile.
- a properly formatted GET_CURRENT_LOCATION request structure will be responded to from the mobile with a PUT_CURRENT_LOCATION response structure.
- GET_BATTERY_STATUS is used by the host to request the current battery condition from the mobile.
- a properly formatted GET_BATTERY_STATUS request structure will be responded to from the mobile with a PUT_BATTERY_STATUS response structure.
- GET_RSSI is used by the host to request the current radio signal strength condition from the mobile.
- the mobile actually replies with and index value from 0 to 255 that hashes the actual measured signal quality.
- the host calculates the actual signal quality value by referencing in a table containing domain parameters for this device type.
- the server stores the BASE value, the INCREMENT, an override value for transmitting the signal quality is UNKNOWN, and UNIT of measure field used for formatting the value for display.
- the server received value is equal to UNKNOWN, an undefined or unknown signal quality is calculated, otherwise the server calculates the signal quality value for by multiplying the received index by INCREMENT and adding the product to BASE.
- a properly formatted GET_RSSI request structure will be responded to from the mobile with a PUT_RSSI response structure.
- GET_GPS_STATUS is used by the host to request the current condition of the GPS receiver from the mobile.
- a properly formatted GET_GPS_STATUS request structure will be responded to from the mobile with a PUT_GPS_STATUS response structure.
- GET_GEOFENCE_HANDLE is used by the host to request the handle for the next available geofence parameters storage area.
- the device must respond with a PUT_GEOFENCE_HANDLE transaction containing the handle to the available storage location, or a NACK if storage is full or the geofence type is unsupported.
- GET_GEOFENCES is used by the host to request an iteration of the geofence parameter data currently stored on the device.
- the device must respond iteratively with one PUT_GEOFENCE message for each set of geofence data currently stored.
- the device should NACK if not geofences are stored.
- GET_CUSTOM_PARAM is used to query a custom parameter value, such as a carrier-specific connection parameter.
- GET_DIAGNOSTIC is used to make a one-time request for a complete diagnostic payload.
- a properly formatted GET_DIAGNOSTIC should be acknowledged with a PUT_DIAGNOSTIC structure.
- GET_SYSTEMTIME is used to request the current UTC date and time at the host.
- a properly formatted GET_SYSTEMTIME should be acknowledged with a PUT_SYSTEMTIME structure.
- SET request structures are used to initiate both host-to-mobile and mobile-to-host application-layer transactions. These structures contain a command to alter the system running state or modify an internal parameters or values. SET requests are typically confirmed with a generic acknowledgement.
- SET_REPORTING_INTERVAL is used by the host to set the autonomous location report interval.
- the mobile report automatically transmits asynchronous PUT_LOCATION structures according to the set interval.
- a properly formatted SET_REPORTING_INTERVAL should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_REPORTING_INTERVAL.
- SET_GPS_POWERSTATE is used by the host to set the power state of the GPS receiver.
- a properly formatted SET_GPS_POWERSTATE should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_GPS_POWERSTATE.
- SET_BUFFERING_INTERVAL is used by the host to set the local location buffering interval.
- the buffering interval controls how frequently location records will be stored in the device memory in the event of a temporary out-of-coverage condition.
- the buffer is implemented as a circular queue. When the allocated storage for the buffer is used, new entries overwrite the oldest entry in the buffer.
- Locates will be buffered NOT MORE often then this, regardless of the distance trigger. Max Interval Unsigned Short 2 Maximum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Locates will be buffered AT LEAST this often, if the distance trigger is not met. Linear Distance DISTANCE 2 Distance reporting Trigger trigger gradient. Locates will be buffered when this accumulated distance is traveled. TOTAL 8
- a properly formatted SET_BUFFERING_INTERVAL should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_BUFFERING_INTERVAL.
- SET_START_BUFFER starts a dump of the current location buffer from the mobile to the host.
- the mobile When the mobile receives a request to start sending buffered data, it will begin traversing the circular queue starting with the oldest record, sending each record to the host using a PUT_LOCATION structure. Reporting stops when a SET_END_BUFFER request is received, or when the newest buffered data has been transmitted.
- a properly formatted SET_START_BUFFER structure should be acknowledged with a PUT_LOCATION structure containing the oldest record in the buffer.
- SET_END_BUFFER stops a dump of the location buffer from the mobile.
- a properly formatted SET_END_BUFFER should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_END_BUFFER.
- SET_HEARTBEAT_PARAMETERS is used to set the starting parameters for the HTTP session timeout for the Reverse HTTP Transport.
- a properly formatted SET_HEARTBEAT_INTERVAL should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_HEARTBEAT_INTERVAL.
- SET_INTERACTIVITY_MODE is used to set the toggle between High Interactivity and Low Interactive Mode for Reverse HTTP Transport devices.
- a properly formatted SET_INTERACTIVITY_MODE should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_INTERACTIVITY_MODE.
- SET_CIRCULAR_GEOFENCE is used to create a circular area which the device to generate alerts if the area in entered or exited.
- ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_CIRCULAR_GEOFENCE is used to create a rectangular area which the device will generate alerts if the area in entered or exited.
- ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_CIRCULAR_GEOFENCE is used to create a threshold speed which the device will generate alerts if the threshold is exceeded.
- ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_STATIONARY_GEOFENCE is used to create a threshold period of time which the device will generate alerts if it is stationary for a period of time greater than the threshold.
- ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_DELETE_GEOFENCE is used to delete the parameters associated with a particular geofence and suppress alerting based on those parameters.
- ACK is the geofence could be deleted, NACK if the handle is invalid.
- SET_CUSTOM_PARAM is used to set a custom parameter, such as a carrier-specific connection parameter.
- a properly formatted SET_CUSTOM_PARAM should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_CUSTOM_PARAM.
- SET_REPORTING_GRANULARITY is used to set the threshold distance between internal location samples. When a reporting granularity value is set, the device will not accumulate inter-sample distances below the set distance. This is designed to dampen phantom location “drift” generated by a stationary device.
- a properly formatted SET_REPORTING_GRANULARITY should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_REPORTING_GRANULARITY.
- SET_MOVEMENT_GEOFENCE is used to create a threshold distance which the device to generate alerts if that distance is traveled. This is different than setting reporting based on distance because when a movement geofence is set, the device will report PUT_GEOFENCE_VIOLATION when the distance has been traveled.
- ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_DIAGNOSTIC_INTERVAL is used by the host to set the request periodic diagnostic payload reporting.
- the mobile automatically transmits asynchronous PUT_DIAGNOSTIC structures according to the set interval.
- a properly formatted SET_DIAGNOSTIC_INTERVAL should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_DIAGNOSTIC_INTERVAL.
- SET_DEBUG_LEVEL is used by the host to set the debug reporting level for the device.
- Debug level 0 turns off reporting.
- Other levels are firmware defined. Protocol Usage
- a properly formatted SET_DEBUG_LEVEL should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_DEBUG_LEVEL.
- PUT Request structures are used to acknowledge host-to-mobile and mobile-to-host application-layer transactions. These structures typically contain a response to a GET request.
- PUT requests may also be used to asynchronously deliver event notifications. When delivering an asynchronous notification, they may be confirmed with a generic acknowledgement.
- PUT_CURRENT_LOCATION is used to respond to and acknowledge a GET_CURRENT_LOCATION request.
- PUT_BATTERY_STATUS is used to respond to and acknowledge a GET_BATTERY_STATUS request.
- PUT_RSSI is used to respond to and acknowledge a GET_RSSI request.
- the mobile actually replies with and index value from 0 to 255 that hashes the actual measured signal quality.
- the host calculates the actual signal quality value by referencing in a table containing domain parameters for this device type.
- the server stores the BASE value, the INCREMENT, an override value for transmitting the signal quality is UNKNOWN, and UNIT of measure field used for formatting the value for display.
- the server receives value is equal to UNKNOWN, an undefined or unknown signal quality is calculated, otherwise the server calculates the signal quality value for by multiplying the received index by INCREMENT and adding the product to BASE.
- PUT_GPS_STATUS is used to respond to and acknowledge a GET_GPS_STATUS request.
- the device responds to a GET_GEOFENCE_HANDLE message with PUT_GEOFENCE_HANDLE. After retrieving the handle, the host can set a geofence using the supplied handle.
- the host should transmit a desired geofence message type using the supplied handle.
- PUT GEOFENSE is used by the device to transmit the parameters of a particular geofence.
- PUT_GEFENCE could used in response to a require for a specific geofence's parameters, or PUT_GEOFENCE could be transmitted iteratively for each stored geofence in response to GET_GEOFENSES.
- PUT_CUSTOM_PARAM is used to respond to a GET_CUSTOM_PARAM structure with the value of a custom parameter, such as a carrier-specific connection parameter.
- PUT_LOCATION is used to send an unacknowledged coordinate fix from the mobile to the host.
- This coordinate fix may be initiated by a request from the host to begin autonomous interval reporting, or to stream buffered location data in response to a request from the host to dump the buffer, or may be initiated by the device after a back-in-cellular-coverage condition.
- PUT_GEOFENCE_VIOLATION is used to signal that a geofence boundary has been crossed or a threshold has been exceeded.
- PUT_DEVICE_ID is send by the host in response to a GET_DEVICE_ID request structure.
- PUT_LOCATION_ARRAY is used to send multiple coordinate fixes from the mobile to the host. This may be initiated by a request from the host to begin to stream buffered location data in response to a request from the host to dump the buffer, or may be initiated by the device after a back-in-cellular-coverage condition.
- PUT_LOCATION_ARRAY should be used whenever more than one buffered locate record is being set to the host.
- the maximum number of locates that can be passed in the array is 255, but implementation limitations such as maximum transport payload may significantly limit this number. It is the developer's responsibility to insure that a structure small enough to be supported by the transport layer is created.
- PUT_DIAGNOSTIC is used to respond to and acknowledge a GET_DIAGNOSTIC request and to send periodic diagnostic payloads if requested by SET_DIAGNOSTIC_INTERVAL.
- PUT_SYSTEMTIME is used to respond to and acknowledge a GET_SYSTEMTIME request and to send the current UTC date and time at the host.
- PUT_DEBUG_MESSAGE is used to send debugging messages from the device to the server. This is a firmware defined implementation.
- Acknowledgements are generic positive and negative confirmations of requests and notifications. They are also used to carry “no operation” signaling for some transport models.
- ACK_MOBILE is a generic acknowledgement for requests from the host that do not have a specific response structure.
- ACK_MOBILE is also used as a special purpose structure to open an HTTP transmission channel from the mobile to the host.
- the mobile will keep the HTTP session open for the period of time defined in the Timeout value in the Reverse HTTP Transport Envelope.
- the host If the host desired to send an application-layer request to the mobile, it creates a properly formatted request structure within a Reverse HTTP Transport Envelope, BINHEX encodes the entire payload, transmits the payload through the open socket, and closes the socket.
- ACK_HOST is a generic acknowledgement for requests from the mobile that do not have a specific response structure.
- ACK_HOST is also a special purpose structure used to close an HTTP transmission channel from the when the timeout period is about to expire and the host does not need to submit a command to the mobile.
- ACK_HOST simple tells the mobile that the data session is still active. Typically, the mobile will reestablish a new HTTP session with the host, submitting an ACK_MOBILE structure. In Reverse HTTP High Interactivity mode, this reestablishment will occur immediately, and in Reverse HTTP Low Interactivity mode, the client will wait a defined amount of time before re-polling the host for a command.
- NACK_MOBILE is used to negatively acknowledge a request structure received by the mobile device. NACK should only be used if the envelope fails checksum verification or if an unsupported request is made by the host.
- NACK_HOST is used to negatively acknowledge a request structure received by the host. NACK_HOST should only be used if the envelope fails checksum verification or if an unsupported request is made by the mobile.
- UDP Transactions consist of a properly formatted request structure placed inside a properly formatted UDP transport envelope structure and sent to the GTX platform host address.
- Reverse HTTP Application-layer transactions are coupled with the HTTP transport-layer transaction for mobile-initiated requests and decoupled from the HTTP transport-layer transaction for host-initiated requests.
- Reverse HTTP High Interactivity mode a new HTTP session is established immediately.
- Reverse HTTP Low Interactivity Mode a defined interval elapses before the mobile re-polls the host for a command. If any mobile-initiated events occur during this period, the mobile established an HTTP session immediately and sends the host a structure.
- FIG. 5 is a flow chart summarizing a method 500 for communicating with a tracking device using, for example, the above-described communication protocol.
- a first step 502 communication is established between the tracking device (e.g., tracking device 102 ) and a remote system (e.g., system 104 ) via a wireless network (e.g., a mobile phone network).
- a wireless network e.g., a mobile phone network
- configuration data is provided to the tracking device from the remote server.
- the remote server receives processed data from the tracking device.
- a determination is made whether the configuration of the tracking device should be changed.
- a fifth step 510 different configuration data is provided to the tracking device to reconfigure the tracking device.
- the remote system receives additional processed data from the tracking device, which has been processed and/or provided by the tracking device in the tracking device's new configuration. If in fourth step 508 it is determined that no configuration change is necessary, then method 500 proceeds to sixth step 512 where the remote system receives addition processed data from the tracking device, but the additional processed data will have been processed and/or provided by the tracking device in the tracking device's first configuration.
- tracking devices of the present invention can be embodied in an article of clothing worn by a tracked subject.
- tracking devices 102 and/or subscriber systems 118 can be embodied in GPS enabled mobile telephones or other hand-held position determining devices.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
A system and method for providing communication with a tracking device are disclosed. An example tracking device includes a location detector, a communication device, memory, a processor, and a configuration routine. The location detector is operative to determine locations of the tracking device. The communication device is operative to communicate with a remote system. The memory stores data and code, the data including location data determined by the location detector and configuration data. The processor is operative to execute the code to impart functionality to the tracking device. The functionality of the tracking device depends at least in part on the configuration data. The configuration routine is operative to modify the configuration data responsive to communications from the remote system. Thus, functional access to the tracking device is provided to the remote system.
Description
- This application is a continuation of co-pending U.S. patent application Ser. No. 16/149,990, filed Oct. 2, 2018 by at least one common inventor, which is a continuation of U.S. patent application Ser. No. 15/684,156 (now U.S. Pat. No. 10,129,695), filed Aug. 23, 2017 by at least one common inventor, which is a continuation of U.S. patent application Ser. No. 14/961,556 (now U.S. Pat. No. 9,781,558), filed Dec. 7, 2015 by at least one common inventor, which is a divisional of U.S. patent application Ser. No. 14/313,339 (now U.S. Pat. No. 9,219,978), filed Jun. 24, 2014 by at least one common inventor, which is a divisional of U.S. patent application Ser. No. 13/443,180 (now U.S. Pat. No. 8,760,286), filed Apr. 10, 2012 by at least one common inventor, which is a continuation of U.S. patent application Ser. No. 12/322,941 (now U.S. Pat. No. 8,154,401), filed Feb. 9, 2009 by at least one common inventor, which claims the benefit of U.S. Provisional Patent Application No. 61/065,116 filed Feb. 8, 2008 by at least one common inventor, all of which are incorporated herein by reference in their respective entireties.
- This invention relates generally to a system and method for monitoring location, and more specifically to a system and method for enabling communication with a tracking device.
- Currently, systems exist for tracking the location of persons and/or property. Generally, such systems include a tracking device that transmits the location of the tracking device to a central station, which may then take some action based on the location data.
- Known systems have generally been very limited with respect to the communication capabilities between the tracking device and the central station. For example, communications from a tracking device to a central station have typically been limited to the transmission of a device identifier in combination with location data and, in some cases, a distress signal.
- Perhaps, the limited communication between tracking devices and central stations has evolved due to the disadvantages of prior art tracking systems. For example, in personal tracking devices power consumption is a serious concern, because the devices power storage capacity is a limiting factor with respect to the amount of communication that can take place. Another concern is the cost of network access (e.g., mobile phone air time).
- What is needed is a system and method for providing enhanced communication with tracking devices. What is also needed is a system and method for providing enhanced communication with tracking devices, while minimizing power consumption. What is also needed is a system and method for providing enhanced communication with tracking devices, while minimizing network air time.
- A system and method for providing communication with a tracking device is disclosed. The inventor has discovered that several advantages are provided by the communication system and methods disclosed herein. These advantages include the efficient use of network access time and the conservation of tracking device power. Additional advantages include enhanced efficiency and flexibility in the communication of location data from tracking devices. Yet another advantage is that functional access (e.g., setting and/or resetting of functions, parameters, etc.) to the tracking device is provided to the central station. These and other advantages will be apparent to those skilled in the art in view of the following disclosure.
- In a disclosed example, a tracking device includes a location detector, a communication device, memory, a processor, and a configuration routine. The location detector (e.g., a Global Positioning Satellite receiver) is operative to determine locations of the tracking device. The communication device (e.g., a cell phone modem) is operative to communicate with a remote system (e.g., a central station, subscriber server, etc.). The memory stores data and code, the data including location data determined by the location detector and configuration data. The processor is operative to execute the code to impart functionality to the tracking device. The functionality of the tracking device depends at least in part on the configuration data. The configuration routine is operative to modify the configuration data responsive to a communication from the remote system. Thus, functional access to the tracking device is provided to the remote system.
- The tracking device can be configured and reconfigured in many ways. In one example, the configuration data modifiable responsive to the communication from the remote system at least partially determines an interval for communicating the location data to the remote system. In another example, the configuration data modifiable responsive to the communication from the remote system at least partially determines an interval for buffering the location data when the communication device is unable to communicate the location data to the remote system (e.g., out of communication range). The interval for buffering the location data can be, for example and without limitation, a time interval (e.g., every 30 minutes) or a distance interval (e.g., whenever the tracking device moves 50 yards). In yet another example, the configuration data modifiable responsive to the communication from the remote system at least partially determines a power state of the location detector. In yet another example, the configuration data modifiable responsive to the communication from the remote system at least partially determines a monitored condition with respect to the location of the tracking device (e.g., a “geofence”). For example and without limitation, the monitored condition can be a geographical area (e.g., circular or polygonal, etc.), a velocity, a distance, a time/distance relationship (e.g., a time the tracking device remains stationary), or any combination of these. In yet another example, the configuration data modifiable responsive to the communication from the remote system at least partially determines a threshold distance between one of the locations and subsequent ones of the locations for storing the subsequent ones of the locations (e.g., only buffer location data if the tracking device has moved at least the threshold distance). As even yet another example, the configuration data modifiable responsive to the communication from the remote system at least partially determines an interval for communicating diagnostic information from the tracking device to the remote system.
- The example tracking device also includes a data transfer routine operative to communicate operational data between the tracking device and the remote system. In one example, the tracking device includes a battery and the data transfer routine responsive to a request from the server is operative to communicate data indicative of the status of the battery to the remote system. In another example, the data transfer routine responsive to a request from the server is operative to communicate data indicative of a radio signal strength to the remote system. In yet another example, the data transfer routine responsive to a request from the server is operative to communicate data indicative of a status of the location detector to the remote system. In yet another example, the data transfer routine responsive to a status of a monitored location condition (e.g., a geofence definition) is operative to communicate data indicative of a violation or satisfaction of the location condition to the remote system. As yet another example, the data transfer routine responsive to a request from the server is operative to communicate diagnostic data to the remote system.
- Another feature of the example tracking device is that when the communication device is unable to establish a connection with the remote system, the location data is accumulated in the memory. Then, when the communication device is able to establish a connection with the remote server, the data transfer routine communicates the accumulated data to the remote system.
- An example method for communicating with a tracking device is also disclosed. The method includes communicating with the tracking device via a wireless network and providing configuration data to the tracking device via the wireless network. The configuration data causes the tracking device to operate according to a first configuration. The method further includes receiving processed data from the tracking device. The processed data is generated by the tracking device in the first configuration. The method further includes providing new configuration data to the tracking device via the wireless network. The new configuration data changes the first configuration of the tracking device to a different configuration. The method further includes receiving additional processed data from the tracking device. The additional processed data is generated by the tracking device in the different configuration.
- In the example method, the configuration data at least partially determines a location data reporting interval. In another example method, the configuration data at least partially determines a location data buffering interval. In yet another example method, the configuration data at least partially determines a power state of the tracking device. In yet another example method, the configuration data at least partially determines a location based condition that if violated or satisfied causes an indication of the violation or satisfaction of the location based condition to be communicated from the tracking device to the remote system. In yet another example method, the configuration data at least partially determines a diagnostic reporting interval. In yet another example method, the configuration data at least partially determines a distance threshold for buffering location data. In yet another example method, the processed data includes data indicative of a battery status of the tracking device. In yet another example method, the processed data includes data indicative of a radio signal strength determined by the tracking device. In yet another example method, the processed data includes data generated by a diagnostic routine of the tracking device.
- Many other detailed examples are disclosed in the communication protocol specification set forth below.
- The present invention is described with reference to the following drawings, wherein like reference numbers denote substantially similar elements:
-
FIG. 1 is a block diagram of a tracking system; -
FIG. 2 is a block diagram of a server of the tracking system ofFIG. 1 ; -
FIG. 3 is a block diagram of a subscriber system of the tracking system ofFIG. 1 ; -
FIG. 4 is a block diagram of a tracking device of the tracking system ofFIG. 1 ; and -
FIG. 5 is a flow chart summarizing an example method of communicating with the tracking device ofFIG. 1 andFIG. 4 . -
FIG. 1 is a block diagram of asystem 100 for tracking and/or monitoring one or more tracking devices 102(1-m).System 100 includes one or more servers 104(1-m), asubscriber profile database 106, avendor information database 108, apublic database cache 110, and trackinginterface 112, all intercommunicating via aninternal network 114.System 100 communicates with remote components including one or more vendors 116(1-n), one or more subscribers 118(1-p), and one or more public databases 120(1-q), all via an internetwork 122 (e.g., the Internet). Afirewall 124 provides a measure of security forinternal network 114 against threats viainternetwork 122. -
Servers 104 host services forsubscribers 118 and/or other authorized users that facilitate the tracking and/or monitoring of the location of trackingdevices 102.Subscriber profile database 106 stores information associated withparticular subscribers 118 and/or other users ofsystem 100.Vendor information database 108 stores information associated withvendors 116 that provide goods and or services that can be made available tosubscribers 118 and/or other users ofsystem 100 based on information fromsubscriber profile database 106 and/or location data received from trackingdevices 102.Public database cache 110 provides temporary storage for data retrieved frompublic databases 120.Tracking interface 112 transmits (via wireless communication) data and commands to trackingdevices 102 and receives data (e.g., location data, sensor readings, distress signal, etc.) from trackingdevices 102.Vendors 116 offer goods and services that may be offered to subscribers and other users ofsystem 100 as described above. In addition, information associated with vendors (e.g., type of business) can be used to help define boundaries used to monitortracking devices 102. Similarly,public databases 120 provide information (e.g., sex offender registries, etc.) that can be used as criteria for defining boundaries. -
Subscribers 118 are the primary users ofsystem 100 and interact withservers 104 to define tracking criteria and to obtain information and alerts regarding the tracking of associatedtracking devices 102. In this example, the primary users are referred to as subscribers, because it is expected that users will be willing to pay for the right to usesystem 100. However, it should be understood thatsystem 100 is not limited to a subscription type business model. For example, access tosystem 100 could be provided to users on a free basis, relying on some other business model to raise revenue. - In addition communication between
tracking devices 102 andservers 104, the communication methods described herein can be used to provide direct communication betweentracking devices 102 andsubscribers 118 via a communication link (e.g., mobile phone network), which is not shown inFIG. 1 . Similarly, the communication methods described herein can be used to provide direct communication between tracking devices 102 (e.g., GPS enabled cell phone to GPS enabled cell phone). In thatcase tracking devices 102 can function as both a tracking device and a subscriber system. -
FIG. 2 is a block diagram of aserver 102 oftracking system 100.Server 102 includesnon-volatile data storage 202, one ormore processing units 204,memory 206, user I/O devices 208, and anetwork interface 210.Nonvolatile data storage 202 stores data and code that is retained even whenserver 104 is powered down.Memory 206 stores data and code that when processed by processing unit(s) 204 imparts functionality toserver 104. User input/output devices 208 (e.g., keyboard, mouse, monitor, etc.) provide a means of interaction betweenserver 104 and a local human user.Network interface 210 provides a communication link to other components oninternal network 114 andinternetwork 122. - For the sake of clear explanation data and code are shown in
memory 206 as functional blocks. It should be understood, however, that the various functions ofserver 104 need not be run in any particular location ofmemory 206 and may grouped in any useful manner. For example, the several application program interfaces (APIs) shown could be grouped into a single API. -
Memory 206 includes anoperating system 214,public database API 216,subscriber API 218, processingqueues 220,vendor API 222, control andcoordination routines 224,application programs 226, and a trackingdevice communication protocol 228.Operating system 214 provides low level control ofserver 104 and provides a platform on top of which the other modules can operate.Application programs 226 are tracking service programs that receive and process location and/or sensor data from trackingdevices 102, process the received data, communicate withsubscribers 118, read and/or updatesubscriber profile database 106, search remote data sources, and so on.Public database API 216,vendor API 222, andsubscriber API 218 provide a means of communication betweenapplication programs 226 andpublic databases 120,vendors 116, andsubscribers 118, respectively. Control andcoordination module 224 provides overall control and coordination of the tracking services provided byserver 104. Processingqueues 220 provide temporary storage for tracking data that is being processed. - Tracking
device communication protocol 228 defines a protocol for communicating withtracking device 102. In this particular embodiment, this communication occurs vianetwork 114, trackinginterface 112, and the wireless connection with trackingdevices 102. It is sometimes, therefore, referred to as the over-the-air protocol. The definitions and functionality of an example trackingdevice communication protocol 228 is fully described below. -
FIG. 3 is a block diagram of asubscriber system 118 oftracking system 100.Subscriber system 118 includesnon-volatile data storage 302, one ormore processing units 304,memory 306, user I/O devices 308, and anetwork interface 310, all intercommunicating via abus 312.Memory 306 includesoperating system 314,application programs 316,subscriber API 318, and trackingdevice communication protocol 320.Application programs 316 provide various tracking based services (e.g., set up tracking account, associateparticular tracking devices 102 with user account, receive and/or display real time and/or historical location information associated withparticular tracking devices 102, and so on). Subscriber API 318 (in conjunction withsubscriber API 218 ofserver 104 shown inFIG. 2 ) facilitates communication betweenapplication programs 316 ofsubscriber system 118 andapplication programs 226 of server 104 (FIG. 2 ). - Tracking
device communication protocol 320 is similar to trackingdevice communication protocol 228 ofserver 104, except that trackingdevice communication protocol 320 resides on asubscriber system 118. Therefore, trackingdevice communication protocol 320 facilitates direct communication betweensubscriber system 118 andtracking device 102 via a separate communication link (not shown), such as a mobile telephone network. -
FIG. 4 is a block diagram of atracking device 102 oftracking system 100.Tracking device server 102 includesnon-volatile data storage 402, one or more processing unit(s) 404,memory 406, location detector (e.g., GPS receiver) 408 with optional sensors (e.g., temperature sensor, motion sensor, etc.), and awireless communication device 410, all intercommunicating via abus 412.Memory 406 includes anoperating system 414,application programs 416, a trackingAPI 418,location data 420, trackingdevice communication protocol 422, andsensor data 424.Application programs 416 facilitate the processing oflocation data 420 and/orsensor data 424, provide alerts and/or updates to server 104 (FIG. 1 ), facilitate updates to existing routines or the addition of new routines, and provide any other specified functionality for trackingdevice 102. For example,application programs 416 can be updated or replaced byserver 104 via trackinginterface 112. Tracking API facilitates communication betweenapplication programs 416 andapplication programs 226 ofserver 104, for example, to communicate location data from trackingdevice 102 toserver 104.Sensor data 424 andlocation data 420 can be accessed byapplication programs 416 as needed. Data indicative of the velocity oftracking device 102 can be characterized as either sensor data or location data. Trackingdevice communication protocol 422 is similar to trackingdevice communication protocol 228, except thattracking device protocol 422 operates on the device side of the communication link. - The following is a detailed description of a particular example of a tracking device communication protocol.
- Many of the fields within the structures in this document use index values to pass a value measured by or stored at the device.
- When a data field is defined as a gradient, the firmware will calculate an index value as the number of increments from a defined base value. This value, an integer, will be placed within the structure for transmission.
-
index=(measurement−base)/increment - When the server receives the index value, that actual measured value is calculated by first retrieving the pre-defined values for base, increment, and unit of measure from a table lookup. These values are stored based on Device Type and Firmware Version, and are applied uniformly for all devices sharing these characteristics.
- Once the server has retrieved the conversion values, the actual measurement value is calculated as
-
measurement=base+(index*increment) - The server will can then store the calculated result as a high-precision value in the database. System presentation layers can convert these values to the localized measurement system for display, using the unit of measure field as a helper.
- 1.2 Field List with Suggested Metrics
- The following table lists the structure fields defined as gradient fields. All gradient fields are defined as integer values.
- The suggested base and increment are suggested values only. The developer must decide the actual base and increment to meet the requirements for range and granularity imposed by the specific implementation.
-
Field Type Unit of Range Definition Data Type Base Increment Measure (Rounded) RSSI Byte −113 2 dBm −113 to 397 dBm BATTERY Unsigned 0 1 mV 0 to 65.5 volts Short ALTITUDE Unsigned −4000 1 Decimeter −400 to 6,153 Short meters/ −1312 to 20,188 feet SPEED Unsigned 0 1 Dekameters 0 to 6,553 Short meters per hour/0 to 407 miles per hour BEARING Unsigned 0 1 1/100ths of a 360 degrees Short degree DISTANCE Unsigned 0 1 Hectometers 0 to 6,553 Short kilometers/0 to 4,072 miles DOP Byte 0 0.2 Absolute 0 to 50.8 VDOP Byte 0 0.2 Absolute 0 to 50.8 HDOP Byte 0 0.2 Absolute 0 to 50.8 GPSSNR Byte 0 1 dB 0 to 255 dB - The following data types are referenced in this document.
-
-
Name Byte Length Comment Byte 1 No type checking Short Integer 2 Integer values from −32,768 to 32,767. Little endian. Unsigned Short 2 Integer values from 0 to 65,535. Little endian. Integer 4 Integer values from −2147483648 to 2147483647. Little endian. Unsigned Integer 4 Integer values from 0 to 4,294,967,296. Little endian. Float 4 A single-precision 32-bit IEEE 754 floating point value. -
-
Name Data Type Length Comment DATETIME Byte Array 6 YMDHMS CRC32 Integer 4 Result of CRC-32 hash LATITUDE Float 4 LONGITUDE Float 4 DATETIME Unsigned Integer 4 RSSI Byte 1 Gradient field containing the data transceiver Received Signal Strength Indication BATLEVEL Unsigned Short 2 Gradient field containing battery condition. ALTITUDE Unsigned Short 2 Gradient field containing an altitude value. SPEED Unsigned Short 2 Gradient field containing a speed or velocity value. BEARING Unsigned Short 2 Gradient field containing a compass bearing or course direction value. DISTANCE Unsigned Short 2 Gradient field containing a linear distance value. - The following constant values are referenced in this document.
- See section 5 Structure Summary.
-
-
Name Value Comment DT_HERMES 0 × 01 Use for Hermes hardware specification devices. DT_PPC 0 × 02 Use for Windows Pocket PC devices. -
-
Name Value Comment GPS_NOFIX 0 × 01 GPS is powered on but could not establish a fix. GPS_SEARCHING 0 × 02 GPS is establishing a fix. GPS_LOCONLY 0 × 03 GPS fix two dimensional without altitude. GPS_LOCALT 0 × 04 GPS has a full three dimension fix with altitude. GPS_POWEROFF 0 × 05 GPS is powered off. -
-
Name Value Comment GPS_POWERDOWN 0 × 01 Power down the GPS. GPS_POWERUP 0 × 02 Power up the GPS and attempt to obtain a fix. GPS_POWERDOWNUNTIL 0 × 03 Power down until the wake up time. -
-
Name Value Comment IMODE_HIGN 0 × 01 High Interactivity mode. IMODE_LOW 0 × 02 Low Interactivity mode. -
-
Name Value Comment GFT_INCLUSION 0 × 01 GFT_EXCLUSION 0 × 02 GFT_BOTH 0 × 03 GFT_POLYGON 0 × 04 GPT_CIRCULAR 0 × 05 GFT_VELOCITY 0 × 06 GFT_STATIONARY 0 × 07 GFT_MOVEMENT 0 × 08 -
-
Name Value Comment NACK_UNKNOWN 0 × 01 NACK_NOT_SUPPORTED 0 × 02 NACK_FAIILED_CRC 0 × 03 NACK_INVALID_LENGTH 0 × 04 - Utility structures are not included in the summary.
-
Orientation Manifest Mobile Host to Protocol Usage Structure Name Type Value to host Mobile UDP RHTTP DHTTP TCP SMS UDP_ENVELOPE Transport n.a. ✓ ✓ ✓ RHTTP_ENVELOPE Transport n.a. ✓ ✓ ✓ DHTTP_ENVELOPE Transport n.a. ✓ ✓ ✓ TCP_ENVELOPE Transport n.a. ✓ ✓ ✓ SMS_ENVELOPE Transport n.a. ✓ ✓ ✓ GET_DEVICE_ID Request 0x0101 ✓ ✓ ✓ ✓ ✓ ✓ GET_CURRENT_LOCATION Request 0x0102 ✓ ✓ ✓ ✓ ✓ ✓ GET_BATTERY_STATUS Request 0x0103 ✓ ✓ ✓ ✓ ✓ GET_RSSI Request 0x0104 ✓ ✓ ✓ ✓ ✓ ✓ GET_GPS_STATUS Request 0x0105 ✓ ✓ ✓ ✓ ✓ ✓ GET_GEOFENCE_HANDLE Request 0x0106 ✓ ✓ ✓ ✓ ✓ ✓ GET_GEOFENCES Request 0x0107 ✓ ✓ ✓ ✓ ✓ ✓ ✓ GET_CUSTOM_PARAM Request 0x0108 ✓ ✓ ✓ ✓ ✓ ✓ GET_DIAGNOSTIC Request 0x0109 ✓ ✓ ✓ ✓ ✓ ✓ GET_SYSTEMTIME Request 0x010A ✓ ✓ ✓ ✓ ✓ ✓ SET_REPORTING_INTERVAL Request 0x0201 ✓ ✓ ✓ ✓ ✓ ✓ SET_GPS_POWERSTATE Request 0x0202 ✓ ✓ ✓ ✓ ✓ ✓ SET_BUFFERING_INTERVAL Request 0x0203 ✓ ✓ ✓ ✓ ✓ ✓ SET_START_BUFFER Request 0x0204 ✓ ✓ ✓ ✓ ✓ ✓ SET_END_BUFFER Request 0x0205 ✓ ✓ ✓ ✓ ✓ ✓ SET_HEARTBEAT_PARAMETERS Request 0x0206 ✓ ✓ SET_INTERACTIVITY_MODE Request 0x0207 ✓ ✓ ✓ SET_CIRCULAR_GEOFENCE Request 0x0208 ✓ ✓ ✓ ✓ ✓ ✓ SET_POLYGON_GEOFENCE Request 0x0209 ✓ ✓ ✓ ✓ ✓ ✓ SET_VELOCITY_GEOFENCE Request 0x020A ✓ ✓ ✓ ✓ ✓ ✓ SET_STATIONARY_GEOFENCE Request 0x020B ✓ ✓ ✓ ✓ ✓ ✓ SET_DELETE_GEOFENCE Request 0x020C ✓ ✓ ✓ ✓ ✓ ✓ SET_CUSTOM_PARAM Request 0x020D ✓ ✓ ✓ ✓ ✓ ✓ SET_REPORTING_GRANULARITY Request 0x020E ✓ ✓ ✓ ✓ ✓ ✓ SET_MOVEMENT_GEOFENCE Request 0x020F ✓ ✓ ✓ ✓ ✓ ✓ SET_DIAGNOSTIC_INTERVAL Request 0x0210 ✓ ✓ ✓ ✓ ✓ ✓ SET_DEBUG_LEVEL Request 0x0211 ✓ ✓ ✓ ✓ ✓ ✓ PUT_CURRENT_LOCATION Response 0x0301 ✓ ✓ ✓ ✓ ✓ ✓ PUT_BATTERY_STATUS Response 0x0302 ✓ ✓ ✓ ✓ ✓ ✓ PUT_RSSI Response 0x0303 ✓ ✓ ✓ ✓ ✓ ✓ PUT_GPS_STATUS Response 0x0304 ✓ ✓ ✓ ✓ ✓ ✓ PUT_GEOFENCE_HANDLE Response 0x0305 ✓ ✓ ✓ ✓ ✓ ✓ PUT_GEOFENCE Response 0x0306 ✓ ✓ ✓ ✓ ✓ ✓ PUT_CUSTOM_PARAM Response 0x0307 ✓ ✓ ✓ ✓ ✓ ✓ PUT_LOCATION Response 0x0308 ✓ ✓ ✓ ✓ ✓ ✓ PUT_GEOFENCE_VIOLATION Response 0x0309 ✓ ✓ ✓ ✓ ✓ ✓ PUT_DEVICE_ID Response 0x030A ✓ ✓ ✓ ✓ ✓ ✓ PUT_LOCATION_ARRAY Response 0x030B ✓ ✓ ✓ ✓ ✓ ✓ PUT_DIAGNOSTIC Response 0x030C ✓ ✓ ✓ ✓ ✓ ✓ PUT_SYSTEMTEVIE Response 0x030D ✓ ✓ ✓ ✓ ✓ ✓ PUT_DEBUG_MESSAGE Response 0x030E ✓ ✓ ✓ ✓ ✓ ✓ ACK_MOBILE Acknow. 0x0401 ✓ ✓ ✓ ✓ ✓ ✓ ACK_HOST Acknow. 0x0402 ✓ ✓ ✓ ✓ ✓ ✓ NACK_MOBILE Acknow. 0x0403 ✓ ✓ ✓ ✓ ✓ ✓ NACK_HOST Acknow. 0x0404 ✓ ✓ ✓ ✓ ✓ ✓ - POSITION defines a geographic position.
-
Member Name Data Type Bytes Comments Latitude LATITUDE 4 Longitude LONGITUDE 4 TOTAL 8 - CORNER defines a corner of a polygon geofence.
-
Member Name Data Type Bytes Comments Sequence Number Byte 1 The number of the corner in clockwise sequence. Position POSITION 8 The geographic position of the corner. TOTAL 9 - LOCATE defines complete information about the device location in a moment in time.
-
Member Name Data Type Bytes Comments Position POSITION 8 Geographic position of the device. Fix Time DATETIME 6 Byte array [YMDHMS] Fix Type Byte 1 GPS Fix Type Speed SPEED 2 Speed gradient value Bearing BEARING 2 Bearing gradient value Linear Motion DISTANCE 2 Linear distance gradient value Altitude ALTITUDE 2 Altitude gradient value TOTAL 22 - Transport Envelopes contain transport-specific information necessary to ensure reliable deliver of information between host and mobile applications. Each transport has a specific transport envelope that all request and response transaction structures are encapsulated within.
- The UDP Transport Envelope is use to encase all UDP transport request and response structures.
-
Member Name Data Type Bytes Comments Checksum CRC32 4 Checksum of the request/response structure using the CRC- 32 algorithm. SeqNo Byte 1 Sequence Number. Increment with each NEW transmission. No carry. Use same SeqNo for retransmissions. Payload Size Unsigned Short 2 SizeOf(Payload) Payload Array of Byte N Contains the request or response structure being transported. TOTAL N + 8 - The Reverse HTTP Transport Envelope is use to encase all Reverse HTTP transport request and response structures.
-
-
Member Name Data Type Bytes Comments Timeout Unsigned Short 2 The number of seconds the client will maintain the open HTTP request waiting for a response from the host. Checksum CRC32 4 Checksum of the request/response structure using the CRC- 32 algorithm. Payload Size Unsigned Short 2 SizeOf(Payload) Payload Array of Byte N Contains the request or response structure being transported. TOTAL N + 8 - The Direct HTTP Transport Envelope is use to encase all Direct HTTP transport request and response structures.
-
Member Name Data Type Bytes Comments Checksum CRC32 4 Checksum of the request/response structure using the CRC- 32 algorithm. Payload Size Unsigned Short 2 SizeOf(Payload) Payload Array of Byte N Contains the request or response structure being transported. TOTAL N + 6 - The TCP Transport Envelope is use to encase all TCP transport request and response structures.
-
Member Name Data Type Bytes Comments Checksum CRC32 4 Checksum of the request/response structure using the CRC- 32 algorithm. Payload Size Unsigned Short 2 SizeOf(Payload) Payload Array of byte N Contains the request or response structure being transported. TOTAL N + 6 - The SMS Transport Envelope is use to encase all SMS transport request and response structures.
-
Member Name Data Type Bytes Comments Checksum CRC32 4 Checksum of the request/response structure using the CRC- 32 algorithm. Payload Size Unsigned Short 2 SizeOf(Payload) Payload Array of Byte N Contains the request or response structure being transported. TOTAL N + 8 - GET request structures can be used to initiate both host-to-mobile and mobile-to-host application-layer transactions. These requests contain a request for data, which is typically acknowledged by a corresponding PUT response structure containing the requested data.
- GET_DEVICE_ID is used by the device during first time initialization to obtain a unique device identifier from the GTX host platform. This unique device identifier is the primary method by which the device data is organized within the GTX platform. Most subsequent requests require a valid device identified as a structure member.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device SN Array[1..15] of byte 15 Contains a string representation of device IMEI (GSM) or MEID (CDMA). If the IMEI or ESN can not be obtained from the device, it is acceptable to submit the telephone number. This field is padded with nulls. (0 × 00). Firmware Version Float 4 Contains the firmware revision of the device expressed as a major version integer minor version fraction. Device Type Byte 1 Contains the device type constant. TOTAL 22 - A properly formatted GET_DEVICE_ID request structure will be responded to from the host with a PUT_DEVICE_ID response structure.
- GET_CURRENT_LOCATION is used by the host to request the most recent location coordinates from the mobile.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted GET_CURRENT_LOCATION request structure will be responded to from the mobile with a PUT_CURRENT_LOCATION response structure.
- GET_BATTERY_STATUS is used by the host to request the current battery condition from the mobile.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted GET_BATTERY_STATUS request structure will be responded to from the mobile with a PUT_BATTERY_STATUS response structure.
- GET_RSSI is used by the host to request the current radio signal strength condition from the mobile.
- The mobile actually replies with and index value from 0 to 255 that hashes the actual measured signal quality.
- The host calculates the actual signal quality value by referencing in a table containing domain parameters for this device type. The server stores the BASE value, the INCREMENT, an override value for transmitting the signal quality is UNKNOWN, and UNIT of measure field used for formatting the value for display.
- If the server received value is equal to UNKNOWN, an undefined or unknown signal quality is calculated, otherwise the server calculates the signal quality value for by multiplying the received index by INCREMENT and adding the product to BASE.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted GET_RSSI request structure will be responded to from the mobile with a PUT_RSSI response structure.
- GET_GPS_STATUS is used by the host to request the current condition of the GPS receiver from the mobile.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted GET_GPS_STATUS request structure will be responded to from the mobile with a PUT_GPS_STATUS response structure.
- GET_GEOFENCE_HANDLE is used by the host to request the handle for the next available geofence parameters storage area.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Type Byte 1 Geofence type TOTAL 3 - The device must respond with a PUT_GEOFENCE_HANDLE transaction containing the handle to the available storage location, or a NACK if storage is full or the geofence type is unsupported.
- GET_GEOFENCES is used by the host to request an iteration of the geofence parameter data currently stored on the device.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - The device must respond iteratively with one PUT_GEOFENCE message for each set of geofence data currently stored. The device should NACK if not geofences are stored.
- GET_CUSTOM_PARAM is used to query a custom parameter value, such as a carrier-specific connection parameter. The parameter name to query is specified in a variable length field. Up to 255 characters may be sent using this structure, however the response will be formatted as a string in NAME=VALUE format up to 255 bytes in length.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 BufferLen Byte 1 SizeOf(Buffer) Buffer Array[1 . . . N NAME part of BufferLen] of Byte NAME = VALUE parameter format. TOTAL N + 3 - A properly formatted GET_CUSTOM_PARAM should be acknowledged with a PUT_CUSTOM_PARAM structure containing the response in NAME=VALUE format.
- GET_DIAGNOSTIC is used to make a one-time request for a complete diagnostic payload. Use SET_DIAGNOSTIC_INTERVAL to establish periodic reporting of the diagnostics by the device.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted GET_DIAGNOSTIC should be acknowledged with a PUT_DIAGNOSTIC structure.
- GET_SYSTEMTIME is used to request the current UTC date and time at the host.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted GET_SYSTEMTIME should be acknowledged with a PUT_SYSTEMTIME structure.
- SET request structures are used to initiate both host-to-mobile and mobile-to-host application-layer transactions. These structures contain a command to alter the system running state or modify an internal parameters or values. SET requests are typically confirmed with a generic acknowledgement.
- SET_REPORTING_INTERVAL is used by the host to set the autonomous location report interval. When the reporting interval is set to a non-zero value, the mobile report automatically transmits asynchronous PUT_LOCATION structures according to the set interval.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ - Mobile-to-host Host-to-mobile
-
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Min Interval Unsigned Short 2 Minimum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Reports will be sent NOT MORE often then this, regardless of the distance trigger. Max Interval Unsigned Short 2 Maximum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Reports will be sent AT LEAST this often, if the distance trigger is not met. Linear Distance DISTANCE 2 Distance reporting Trigger trigger gradient. Reports will be sent when this accumulated distance is traveled. TOTAL 8 - A properly formatted SET_REPORTING_INTERVAL should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_REPORTING_INTERVAL.
- SET_GPS_POWERSTATE is used by the host to set the power state of the GPS receiver.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 New Power Byte 1 One of the GPS Power State State Constants. Wakeup DATETIME 6 If the power state is being set to GPS_POWERDOWNUNTIL, this field specifies that date and time to power back up. TOTAL 9 - A properly formatted SET_GPS_POWERSTATE should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_GPS_POWERSTATE.
- SET_BUFFERING_INTERVAL is used by the host to set the local location buffering interval. The buffering interval controls how frequently location records will be stored in the device memory in the event of a temporary out-of-coverage condition. The buffer is implemented as a circular queue. When the allocated storage for the buffer is used, new entries overwrite the oldest entry in the buffer.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Min Interval Unsigned Short 2 Minimum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Locates will be buffered NOT MORE often then this, regardless of the distance trigger. Max Interval Unsigned Short 2 Maximum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Locates will be buffered AT LEAST this often, if the distance trigger is not met. Linear Distance DISTANCE 2 Distance reporting Trigger trigger gradient. Locates will be buffered when this accumulated distance is traveled. TOTAL 8 - A properly formatted SET_BUFFERING_INTERVAL should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_BUFFERING_INTERVAL.
- SET_START_BUFFER starts a dump of the current location buffer from the mobile to the host. When the mobile receives a request to start sending buffered data, it will begin traversing the circular queue starting with the oldest record, sending each record to the host using a PUT_LOCATION structure. Reporting stops when a SET_END_BUFFER request is received, or when the newest buffered data has been transmitted.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 3 - A properly formatted SET_START_BUFFER structure should be acknowledged with a PUT_LOCATION structure containing the oldest record in the buffer.
- SET_END_BUFFER stops a dump of the location buffer from the mobile.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 TOTAL 2 - A properly formatted SET_END_BUFFER should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_END_BUFFER.
- SET_HEARTBEAT_PARAMETERS is used to set the starting parameters for the HTTP session timeout for the Reverse HTTP Transport.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Starting Interval Unsigned Short 2 Starting interval in seconds. Step Interval Unsigned Short 2 The amount to add or subtract from the timeout after a successful session or a timeout. Interval Limit Unsigned Short 2 The longest timeout interval the system will seek to, in seconds. TOTAL 8 - A properly formatted SET_HEARTBEAT_INTERVAL should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_HEARTBEAT_INTERVAL.
- SET_INTERACTIVITY_MODE is used to set the toggle between High Interactivity and Low Interactive Mode for Reverse HTTP Transport devices.
- When this command is sent via SMS, it still applies to the devices Reverse HTTP Transport mode. In this case, it is used as an out-of-band signal to switch to High Interactivity mode and force immediate Reverse HTTP session establishment.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Interactivity Mode Byte 1 One of the Interactivity Mode constants. Polling Rate Unsigned Short 2 For Low Interactivity mode, this sets the polling rate in seconds. TOTAL 8 - A properly formatted SET_INTERACTIVITY_MODE should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_INTERACTIVITY_MODE.
- SET_CIRCULAR_GEOFENCE is used to create a circular area which the device to generate alerts if the area in entered or exited.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Handle Byte 1 Center POSITION 8 Radius DISTANCE 2 Distance gradient value Type Byte 1 GFT_INCLUSION GFT_EXCLUSION GFT_BOTH TOTAL 16 - ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_CIRCULAR_GEOFENCE is used to create a rectangular area which the device will generate alerts if the area in entered or exited.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Handle Byte 1 Corner Count Byte 1 Corners Array[ 1. . . Corner Count] N * 8 of CORNER Type Byte 1 GFT_INCLUSION GFT_EXCLUSION GFT_BOTH TOTAL N* 8 + 5 - ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_CIRCULAR_GEOFENCE is used to create a threshold speed which the device will generate alerts if the threshold is exceeded.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Handle Byte 1 Speed SPEED 2 Speed gradient value TOTAL 11 - ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_STATIONARY_GEOFENCE is used to create a threshold period of time which the device will generate alerts if it is stationary for a period of time greater than the threshold.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Handle Byte 1 Trigger Speed SPEED 2 Speed gradient value Time at Rest DATETIME 6 TOTAL 13 - ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_DELETE_GEOFENCE is used to delete the parameters associated with a particular geofence and suppress alerting based on those parameters.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Handle Byte 1 TOTAL 3 - ACK is the geofence could be deleted, NACK if the handle is invalid.
- SET_CUSTOM_PARAM is used to set a custom parameter, such as a carrier-specific connection parameter. The parameter is specified in a variable length field in NAME=VALUE format. Up to 255 characters may be sent using this structure.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 BufferLen Byte 1 SizeOf(Buffer) Buffer Array[1 . . . BufferLen] N Parameter in of Byte NAME = VALUE format. TOTAL N + 3 - A properly formatted SET_CUSTOM_PARAM should be acknowledged with an ACK_MOBILE structure with the Acknowledgement field set to SET_CUSTOM_PARAM.
- SET_REPORTING_GRANULARITY is used to set the threshold distance between internal location samples. When a reporting granularity value is set, the device will not accumulate inter-sample distances below the set distance. This is designed to dampen phantom location “drift” generated by a stationary device.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Distance DISTANCE 2 Distance gradient value TOTAL 4 - A properly formatted SET_REPORTING_GRANULARITY should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_REPORTING_GRANULARITY.
- SET_MOVEMENT_GEOFENCE is used to create a threshold distance which the device to generate alerts if that distance is traveled. This is different than setting reporting based on distance because when a movement geofence is set, the device will report PUT_GEOFENCE_VIOLATION when the distance has been traveled.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Handle Byte 1 Trigger Distance DISTANCE 2 Distance gradient value TOTAL 11 - ACK is the device accepts the geofence, NACK if the handle is invalid or the geofence type is unsupported.
- SET_DIAGNOSTIC_INTERVAL is used by the host to set the request periodic diagnostic payload reporting. When the reporting interval is set to a non-zero value, the mobile automatically transmits asynchronous PUT_DIAGNOSTIC structures according to the set interval.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Min Interval Unsigned Short 2 Minimum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Reports will be sent NOT MORE often then this, regardless of the distance trigger. Max Interval Unsigned Short 2 Maximum reporting interval in seconds. Set to Zero to turn off autonomous reporting. Reports will be sent AT LEAST this often, if the distance trigger is not met. Linear Distance DISTANCE 2 Distance reporting Trigger trigger gradient. Reports will be sent when this accumulated distance is traveled. TOTAL 8 - A properly formatted SET_DIAGNOSTIC_INTERVAL should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_DIAGNOSTIC_INTERVAL.
- SET_DEBUG_LEVEL is used by the host to set the debug reporting level for the device. Debug level 0 turns off reporting. Other levels are firmware defined. Protocol Usage
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Debug Level Byte 1 TOTAL 3 - A properly formatted SET_DEBUG_LEVEL should be acknowledged with a ACK_MOBILE structure with the Acknowledgement field set to SET_DEBUG_LEVEL.
- PUT Request structures are used to acknowledge host-to-mobile and mobile-to-host application-layer transactions. These structures typically contain a response to a GET request.
- PUT requests may also be used to asynchronously deliver event notifications. When delivering an asynchronous notification, they may be confirmed with a generic acknowledgement.
- PUT_CURRENT_LOCATION is used to respond to and acknowledge a GET_CURRENT_LOCATION request.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Location LOCATE 22 TOTAL 28 - PUT_BATTERY_STATUS is used to respond to and acknowledge a GET_BATTERY_STATUS request.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Battery Level BATLEVEL 4 TOTAL 10 - PUT_RSSI is used to respond to and acknowledge a GET_RSSI request.
- The mobile actually replies with and index value from 0 to 255 that hashes the actual measured signal quality.
- The host calculates the actual signal quality value by referencing in a table containing domain parameters for this device type. The server stores the BASE value, the INCREMENT, an override value for transmitting the signal quality is UNKNOWN, and UNIT of measure field used for formatting the value for display.
- If the server receives value is equal to UNKNOWN, an undefined or unknown signal quality is calculated, otherwise the server calculates the signal quality value for by multiplying the received index by INCREMENT and adding the product to BASE.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Radio Signal Strength RSSI 1 TOTAL 7 - PUT_GPS_STATUS is used to respond to and acknowledge a GET_GPS_STATUS request.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Fix Type Byte 1 One of the GPS Fix State constants. Satellites Byte 1 Number of satellites in view of the receiver. DOP Byte 1 Gradient; Dilution of Precision from the GPS, if available. VDOP Byte 1 Gradient; Vertical Dilution of Precision from the GPS, if available. HDOP Byte 1 Gradient; Horizontal Dilution of Precision from the GPS, if available. Accuracy Byte 1 Accuracy in meters. 255 is used for anything greater than 254. TOTAL 11 - The device responds to a GET_GEOFENCE_HANDLE message with PUT_GEOFENCE_HANDLE. After retrieving the handle, the host can set a geofence using the supplied handle.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Handle Byte 1 TOTAL 7 - The host should transmit a desired geofence message type using the supplied handle.
- PUT GEOFENSE is used by the device to transmit the parameters of a particular geofence. PUT_GEFENCE could used in response to a require for a specific geofence's parameters, or PUT_GEOFENCE could be transmitted iteratively for each stored geofence in response to GET_GEOFENSES.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Handle Byte 1 Type Byte 1 Geofence type Radius Unsigned Integer 4 Corner Count Byte 1 Corners Array N * 9 [1..Corner Count] of CORNER TOTAL N * 9 + 13 - PUT_CUSTOM_PARAM is used to respond to a GET_CUSTOM_PARAM structure with the value of a custom parameter, such as a carrier-specific connection parameter. The response is formatted in a variable length field in NAME=VALUE format. Up to 255 characters may be sent using this structure.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. BufferLen Byte 1 SizeOf (Buffer) Buffer Array N Parameter in [1..BufferLen] NAME = VALUE of Byte format. TOTAL N + 7 - PUT_LOCATION is used to send an unacknowledged coordinate fix from the mobile to the host. This coordinate fix may be initiated by a request from the host to begin autonomous interval reporting, or to stream buffered location data in response to a request from the host to dump the buffer, or may be initiated by the device after a back-in-cellular-coverage condition.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response Location LOCATE 22 TOTAL 28 - PUT_GEOFENCE_VIOLATION is used to signal that a geofence boundary has been crossed or a threshold has been exceeded.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Handle Byte 1 Geofence Handle Location LOCATE 22 TOTAL 29 - PUT_DEVICE_ID is send by the host in response to a GET_DEVICE_ID request structure.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 TOTAL 6 - PUT_LOCATION_ARRAY is used to send multiple coordinate fixes from the mobile to the host. This may be initiated by a request from the host to begin to stream buffered location data in response to a request from the host to dump the buffer, or may be initiated by the device after a back-in-cellular-coverage condition.
- PUT_LOCATION_ARRAY should be used whenever more than one buffered locate record is being set to the host. The maximum number of locates that can be passed in the array is 255, but implementation limitations such as maximum transport payload may significantly limit this number. It is the developer's responsibility to insure that a structure small enough to be supported by the transport layer is created.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response Array Size Byte 1 Number of LOCATE elements in the array Locations Array N * 22 [1..Array Size] of LOCATE TOTAL 7 + (N * 22) - Because of the relatively large amount of data carried in a PUT_LOCATION_ARRAY structure, it should be acknowledged with an ACK_HOST structure with the Acknowledgement field set to PUT_LOCATION_ARRAY.
- PUT_DIAGNOSTIC is used to respond to and acknowledge a GET_DIAGNOSTIC request and to send periodic diagnostic payloads if requested by SET_DIAGNOSTIC_INTERVAL.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Location LOCATION 20 GPS SNR Byte 1 GPS Signal to noise ratio in dB Battery Level BATLEVEL 2 Satellites Byte 1 Number of satellites in view of the receiver. Accuracy Byte 1 Accuracy in meters. 255 is used for anything greater than 254. DOP Byte 1 Gradient; Dilution of Precision from the GPS, if available. VDOP Byte 1 Gradient; Vertical Dilution of Precision from the GPS, if available. HDOP Byte 1 Gradient; Horizontal Dilution of Precision from the GPS, if available. Network Status Byte 1 TOTAL 28 - PUT_SYSTEMTIME is used to respond to and acknowledge a GET_SYSTEMTIME request and to send the current UTC date and time at the host.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 System Time DATETIME 6 UTC time at the host. TOTAL 8 - PUT_DEBUG_MESSAGE is used to send debugging messages from the device to the server. This is a firmware defined implementation.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Debug Message Binary Var Variable length field. TOTAL Var - Acknowledgements are generic positive and negative confirmations of requests and notifications. They are also used to carry “no operation” signaling for some transport models.
- ACK_MOBILE is a generic acknowledgement for requests from the host that do not have a specific response structure.
- ACK_MOBILE is also used as a special purpose structure to open an HTTP transmission channel from the mobile to the host. The mobile will keep the HTTP session open for the period of time defined in the Timeout value in the Reverse HTTP Transport Envelope. If the host desired to send an application-layer request to the mobile, it creates a properly formatted request structure within a Reverse HTTP Transport Envelope, BINHEX encodes the entire payload, transmits the payload through the open socket, and closes the socket.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Byte Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response Acknowledgement Unsigned Short 2 The Structure ID of the last transmission to acknowledge. Baggage Unsigned Short 2 Additional acknowledgement information. TOTAL 10 - ACK_HOST is a generic acknowledgement for requests from the mobile that do not have a specific response structure.
- ACK_HOST is also a special purpose structure used to close an HTTP transmission channel from the when the timeout period is about to expire and the host does not need to submit a command to the mobile. ACK_HOST simple tells the mobile that the data session is still active. Typically, the mobile will reestablish a new HTTP session with the host, submitting an ACK_MOBILE structure. In Reverse HTTP High Interactivity mode, this reestablishment will occur immediately, and in Reverse HTTP Low Interactivity mode, the client will wait a defined amount of time before re-polling the host for a command.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Byte Comments Structure ID Unsigned Short 2 Acknowledgement Unsigned Short 2 The Structure ID of the last transmission to acknowledge. Baggage Unsigned Short 2 Additional acknowledgement information. TOTAL 6 - NACK_MOBILE is used to negatively acknowledge a request structure received by the mobile device. NACK should only be used if the envelope fails checksum verification or if an unsupported request is made by the host.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Short 2 Device ID Unsigned Integer 4 Device ID returned in the PUT_DEVICE_ID response. Do not NACK an invalid response to GET_DEVICE_ID. Resend the GET_DEVICE_ID request. Acknowledgement Unsigned Short 2 The Structure ID of the transmission to that generated the error. Baggage Unsigned Short 2 Additional acknowledgement information. Type Byte 1 NACK Type constant TOTAL 11 - NACK_HOST is used to negatively acknowledge a request structure received by the host. NACK_HOST should only be used if the envelope fails checksum verification or if an unsupported request is made by the mobile.
-
-
UDP Reverse HTTP Direct HTTP TCP SMS ✓ ✓ ✓ ✓ ✓ -
-
Mobile-to-host Host-to-mobile ✓ -
-
Member Name Data Type Bytes Comments Structure ID Unsigned Integer 2 Acknowledgement Unsigned Short 2 The Structure ID of the transmission to that generated the error. Baggage Unsigned Short 2 Additional acknowledgement information. Type Byte 1 NACK Type constant TOTAL 7 - UDP Transactions consist of a properly formatted request structure placed inside a properly formatted UDP transport envelope structure and sent to the GTX platform host address.
-
-
Mobile-to-host Host-to-mobile GET_DEVICE_ID PUT_DEVICE_ID -
-
Host-to-mobile Mobile-to-host GET_CURRENT_LOCATION PUT_CURRENT_LOCATION -
-
Host-to-mobile Mobile-to-host SET_REPORTING_INTERVAL ACK_MOBILE - After defined non-zero interval:
-
PUT LOCATION -
-
Host-to-mobile Mobile-to-host GET_BATTERY_LEVEL PUT_BATTERY_LEVEL -
-
Host-to-mobile Mobile-to-host GET_RSSI PUT_RSSI -
-
Host-to-mobile Mobile-to-host GET_GPS_STATUS PUT_GPS_STATUS -
-
Host-to-mobile Mobile-to-host SET_GPS_POWERSTATE ACK_MOBILE -
-
Host-to-mobile Mobile-to-host SET_BUFFERING_INTERVAL ACK_MOBILE -
-
Host-to-mobile Mobile-to-host SET_START_BUFFER PUT_LOCATION - Repeats until a stop buffer transmission request is received or the newest record has been transmitted:
-
PUT LOCATION -
-
Host-to-mobile Mobile-to-host END_BUFFERED_DATA ACK_MOBILE -
-
Host-to-mobile Mobile-to-host GET_GEOFENCE_HANDLE PUT_GEOFENCE_HANDLE SET_CIRCULAR_GEOFENCE ACK_MOBILE -
-
Host-to-mobile Mobile-to-host GET_GEOFENCE_HANDLE PUT_GEOFENCE_HANDLE SET_POLYGON_GEOFENCE ACK_MOBILE -
-
Host-to-mobile Mobile-to-host GET_GEOFENCE_HANDLE PUT_GEOFENCE_HANDLE SET_VELOCITY_GEOFENCE ACK_MOBILE -
-
Host-to-mobile Mobile-to-host GET_GEOFENCE_HANDLE PUT_GEOFENCE_HANDLE SET_STATIONARY_GEOFENCE ACK_MOBILE - Reverse HTTP Application-layer transactions are coupled with the HTTP transport-layer transaction for mobile-initiated requests and decoupled from the HTTP transport-layer transaction for host-initiated requests.
-
-
Mobile-to-host Host-to-mobile GET_DEVICE_ID PUT_DEVICE_ID
12.2 Idle State: Mobile Waiting for Command from Host -
Mobile-to-host Host-to-mobile ACK_MOBILE ACK_HOST - In Reverse HTTP High Interactivity mode, a new HTTP session is established immediately. In Reverse HTTP Low Interactivity Mode, a defined interval elapses before the mobile re-polls the host for a command. If any mobile-initiated events occur during this period, the mobile established an HTTP session immediately and sends the host a structure.
-
ACK_MOBILE ACK_HOST or <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE GET_CURRENT_LOCATION PUT_CURRENT_LOCATION <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE SET_REPORTING_INTERVAL ACK_MOBILE <any valid request> - After defined non-zero interval:
-
PUT_LOCATION <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE GET_BATTERY_LEVEL PUT_BATTERY_LEVEL <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE GET_RSSI PUT_RSSI <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE GET_GPS_STATUS PUT_GPS_STATUS <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE SET_GPS_POWERSTATE ACK_MOBILE <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE SET_BUFFERING_INTERVAL ACK_MOBILE <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE GET_BUFFER PUT_LOCATION <any valid request> - After defined non-zero interval:
-
PUT_LOCATION <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE END_BUFFERED_DATA ACK_MOBILE <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE SET_HEARTBEAT_INTERVAL ACK_MOBILE <any valid request> -
-
Mobile-to-host Host-to-mobile ACK_MOBILE SET_INTERACTIVITY_MODE ACK_MOBILE <any valid request> -
FIG. 5 is a flow chart summarizing amethod 500 for communicating with a tracking device using, for example, the above-described communication protocol. In afirst step 502, communication is established between the tracking device (e.g., tracking device 102) and a remote system (e.g., system 104) via a wireless network (e.g., a mobile phone network). Then, in asecond step 504 configuration data is provided to the tracking device from the remote server. Next, in athird step 506, the remote server receives processed data from the tracking device. Then, in a fourth step 508 a determination is made whether the configuration of the tracking device should be changed. If so, then in afifth step 510, different configuration data is provided to the tracking device to reconfigure the tracking device. Then, in asixth step 512, the remote system receives additional processed data from the tracking device, which has been processed and/or provided by the tracking device in the tracking device's new configuration. If infourth step 508 it is determined that no configuration change is necessary, thenmethod 500 proceeds tosixth step 512 where the remote system receives addition processed data from the tracking device, but the additional processed data will have been processed and/or provided by the tracking device in the tracking device's first configuration. - The description of particular example embodiments of the present invention is now complete. Many of the described features may be substituted, altered or omitted without departing from the scope of the invention. For example, the tracking devices of the present invention can be embodied in an article of clothing worn by a tracked subject. As another example, tracking
devices 102 and/orsubscriber systems 118 can be embodied in GPS enabled mobile telephones or other hand-held position determining devices. These and other deviations from the particular embodiments shown will be apparent to those skilled in the art, particularly in view of the foregoing disclosure.
Claims (12)
1. A tracking device comprising:
a location detector operative to determine locations of said tracking device;
a communication device operative to communicate with a remote system;
memory for storing data and code, said data including location data determined by said location detector and configuration data;
a processor operative to execute said code to impart functionality to said tracking device, said functionality of said tracking device depending at least in part on said configuration data;
a configuration routine operative to modify said configuration data responsive to a communication from said remote system; and
a reporting routine operative to communicate operational data between said tracking device and said remote system.
2. The tracking device of claim 1 , wherein said reporting routine is operative to communicate said operational data to said remote system responsive to a request from said remote system.
3. The tracking device of claim 1 , wherein said operational data is indicative of a radio signal strength.
4. The tracking device of claim 1 , wherein said operational data is indicative of a status of said location detector.
5. The tracking device of claim 4 , wherein said operational data is indicative of a power state of said location detector.
6. The tracking device of claim 1 , wherein said reporting routine, responsive to a request from said remote system, is operative to communicate diagnostic data to said remote system.
7. A method for communicating with a tracking device, said method comprising:
communicating with said tracking device via a wireless network;
providing configuration data to said tracking device via said wireless network, said configuration data causing said tracking device to operate according to a first configuration;
receiving processed data from said tracking device, said processed data being generated by said tracking device in said first configuration; and
providing new configuration data to said tracking device via said wireless network, said new configuration data based at least in part on said processed data and changing said first configuration of said tracking device to a different configuration.
8. The method of claim 7 , wherein said processed data includes data indicative of a radio signal strength determined by said tracking device.
9. The method of claim 7 , wherein said processed data includes data generated by a diagnostic routine of said tracking device.
10. The method of claim 7 , further comprising requesting said processed data from said tracking device.
11. The method of claim 7 , wherein:
said first configuration is associated with a first tracking function; and
said different configuration is associated with a different tracking function.
12. The method of claim 7 , wherein:
said first configuration is associated with a first tracking function; and
said different configuration is associated with a different tracking function.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US17/684,089 US20220295218A1 (en) | 2008-02-08 | 2022-03-01 | System And Method For Communication With A Tracking Device |
Applications Claiming Priority (8)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US6511608P | 2008-02-08 | 2008-02-08 | |
US12/322,941 US8154401B1 (en) | 2008-02-08 | 2009-02-09 | System and method for communication with a tracking device |
US13/443,180 US8760286B2 (en) | 2008-02-08 | 2012-04-10 | System and method for communication with a tracking device |
US14/313,339 US9219978B2 (en) | 2008-02-08 | 2014-06-24 | System and method for communication with a tracking device |
US14/961,556 US9781558B2 (en) | 2008-02-08 | 2015-12-07 | System and method for communication with a tracking device |
US15/684,156 US10129695B2 (en) | 2008-02-08 | 2017-08-23 | System and method for communication with a tracking device |
US16/149,990 US11272313B2 (en) | 2008-02-08 | 2018-10-02 | System and method for communication with a tracking device |
US17/684,089 US20220295218A1 (en) | 2008-02-08 | 2022-03-01 | System And Method For Communication With A Tracking Device |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/149,990 Continuation US11272313B2 (en) | 2008-02-08 | 2018-10-02 | System and method for communication with a tracking device |
Publications (1)
Publication Number | Publication Date |
---|---|
US20220295218A1 true US20220295218A1 (en) | 2022-09-15 |
Family
ID=45922105
Family Applications (7)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/322,941 Expired - Fee Related US8154401B1 (en) | 2008-02-08 | 2009-02-09 | System and method for communication with a tracking device |
US13/443,180 Active US8760286B2 (en) | 2008-02-08 | 2012-04-10 | System and method for communication with a tracking device |
US14/313,339 Active US9219978B2 (en) | 2008-02-08 | 2014-06-24 | System and method for communication with a tracking device |
US14/961,556 Active US9781558B2 (en) | 2008-02-08 | 2015-12-07 | System and method for communication with a tracking device |
US15/684,156 Active US10129695B2 (en) | 2008-02-08 | 2017-08-23 | System and method for communication with a tracking device |
US16/149,990 Active US11272313B2 (en) | 2008-02-08 | 2018-10-02 | System and method for communication with a tracking device |
US17/684,089 Abandoned US20220295218A1 (en) | 2008-02-08 | 2022-03-01 | System And Method For Communication With A Tracking Device |
Family Applications Before (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/322,941 Expired - Fee Related US8154401B1 (en) | 2008-02-08 | 2009-02-09 | System and method for communication with a tracking device |
US13/443,180 Active US8760286B2 (en) | 2008-02-08 | 2012-04-10 | System and method for communication with a tracking device |
US14/313,339 Active US9219978B2 (en) | 2008-02-08 | 2014-06-24 | System and method for communication with a tracking device |
US14/961,556 Active US9781558B2 (en) | 2008-02-08 | 2015-12-07 | System and method for communication with a tracking device |
US15/684,156 Active US10129695B2 (en) | 2008-02-08 | 2017-08-23 | System and method for communication with a tracking device |
US16/149,990 Active US11272313B2 (en) | 2008-02-08 | 2018-10-02 | System and method for communication with a tracking device |
Country Status (1)
Country | Link |
---|---|
US (7) | US8154401B1 (en) |
Families Citing this family (24)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8154401B1 (en) * | 2008-02-08 | 2012-04-10 | Global Trek Xploration Corp. | System and method for communication with a tracking device |
US20110099507A1 (en) * | 2009-10-28 | 2011-04-28 | Google Inc. | Displaying a collection of interactive elements that trigger actions directed to an item |
WO2013028388A1 (en) * | 2011-08-19 | 2013-02-28 | 30 Second Software | Geo-fence entry and exit notification system |
US11184448B2 (en) | 2012-08-11 | 2021-11-23 | Federico Fraccaroli | Method, system and apparatus for interacting with a digital work |
US10419556B2 (en) | 2012-08-11 | 2019-09-17 | Federico Fraccaroli | Method, system and apparatus for interacting with a digital work that is performed in a predetermined location |
US8880101B2 (en) * | 2012-12-16 | 2014-11-04 | Federico Fraccaroli | Method and apparatus for managing attributes and functionalities of predetermined geographical areas |
US9591601B2 (en) | 2012-12-20 | 2017-03-07 | Telefonaktiebolaget L M Ericsson (Publ) | Method, control node, gateway and computer program for enabling communication with a newly detected device |
US9007202B1 (en) | 2013-02-27 | 2015-04-14 | Neil Michael Rego | Human being tracking and monitoring system |
US9565584B2 (en) * | 2013-06-24 | 2017-02-07 | Cisco Technology, Inc. | Human mobility rule-based device location tracking |
US9894476B2 (en) | 2013-10-02 | 2018-02-13 | Federico Fraccaroli | Method, system and apparatus for location-based machine-assisted interactions |
US10244362B2 (en) | 2013-10-08 | 2019-03-26 | Gozio Inc. | Use of RF-based fingerprinting for indoor positioning by mobile technology platforms |
US9807724B2 (en) | 2013-10-08 | 2017-10-31 | Gozio Inc. | Use of RF-based fingerprinting for indoor positioning by mobile technology platforms |
US9788153B1 (en) * | 2014-03-28 | 2017-10-10 | Symantec Corporation | Techniques for mobile geofencing |
EP4220993B1 (en) * | 2014-05-22 | 2024-09-25 | Kyocera Corporation | Assignment of communication resources in an unlicensed frequency band to equipment operating in a licensed frequency band |
US9990823B2 (en) * | 2014-07-02 | 2018-06-05 | SekureTrak, Inc. | System and method for monitoring and tracking items |
US10028084B2 (en) | 2015-02-10 | 2018-07-17 | Qualcomm Incorporated | Adaptive position indicator |
US12114283B2 (en) | 2016-08-21 | 2024-10-08 | Qualcomm Incorporated | Methods and systems for support of location for the internet of things |
US11405863B2 (en) | 2016-10-05 | 2022-08-02 | Qualcomm Incorporated | Systems and methods to enable combined periodic and triggered location of a mobile device |
WO2018085017A1 (en) * | 2016-11-07 | 2018-05-11 | Qualcomm Incorporated | Systems and methods to enable combined periodic and triggered location of a mobile device |
US20190317223A1 (en) | 2018-04-16 | 2019-10-17 | Pinpoint Ideas, LLC | GPS Tracking Device with Extended Battery Life |
US12105206B2 (en) | 2018-04-16 | 2024-10-01 | Pinpoint Ideas, LLC | GPS tracking device with extended battery life |
US10957204B1 (en) | 2018-05-17 | 2021-03-23 | Fleetilla, LLC | Systems and methods for tracking cargo assets |
US12108305B2 (en) | 2020-09-29 | 2024-10-01 | Qualcomm Incorporated | System and methods for power efficient positioning of a mobile device |
US20240107268A1 (en) * | 2022-09-23 | 2024-03-28 | Insight Direct Usa, Inc. | Dynamic asset tracking |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6801129B2 (en) * | 2001-10-01 | 2004-10-05 | Uscpc, Llc | Tracking system for locating stolen currency |
US20050068169A1 (en) * | 2002-05-14 | 2005-03-31 | Copley Shuan Michael | Personal tracking device |
US8154401B1 (en) * | 2008-02-08 | 2012-04-10 | Global Trek Xploration Corp. | System and method for communication with a tracking device |
Family Cites Families (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6919803B2 (en) * | 2002-06-11 | 2005-07-19 | Intelligent Technologies International Inc. | Low power remote asset monitoring |
US5982281A (en) * | 1998-05-02 | 1999-11-09 | Pro Tech Monitoring, Inc. | Offender and victim collision avoidance and advanced warning system |
US6043748A (en) * | 1997-12-19 | 2000-03-28 | Invisible Fence Company, Inc. | Satellite relay collar and programmable electronic boundary system for the containment of animals |
US6054928A (en) * | 1998-06-04 | 2000-04-25 | Lemelson Jerome H. | Prisoner tracking and warning system and corresponding methods |
US6774797B2 (en) | 2002-05-10 | 2004-08-10 | On Guard Plus Limited | Wireless tag and monitoring center system for tracking the activities of individuals |
US6774799B2 (en) | 2002-06-03 | 2004-08-10 | Pro Tech Monitoring, Inc. | House arrest tracker system |
US7123141B2 (en) | 2003-08-20 | 2006-10-17 | Contestabile Robert A | Electronic monitoring systems and methods |
WO2005062066A2 (en) | 2003-10-22 | 2005-07-07 | Awarepoint Corporation | Wireless position location and tracking system |
US20070229350A1 (en) * | 2005-02-01 | 2007-10-04 | Scalisi Joseph F | Apparatus and Method for Providing Location Information on Individuals and Objects using Tracking Devices |
US7321305B2 (en) | 2005-07-05 | 2008-01-22 | Pinc Solutions | Systems and methods for determining a location of an object |
US7245215B2 (en) | 2005-02-10 | 2007-07-17 | Pinc Solutions | Position-tracking device for position-tracking system |
US7330122B2 (en) | 2005-08-10 | 2008-02-12 | Remotemdx, Inc. | Remote tracking and communication device |
US7545318B2 (en) | 2006-07-14 | 2009-06-09 | Remotemdx | Remote tracking system and device with variable sampling and sending capabilities based on environmental factors |
US7936262B2 (en) | 2006-07-14 | 2011-05-03 | Securealert, Inc. | Remote tracking system with a dedicated monitoring center |
US7737841B2 (en) | 2006-07-14 | 2010-06-15 | Remotemdx | Alarm and alarm management system for remote tracking devices |
US8797210B2 (en) | 2006-07-14 | 2014-08-05 | Securealert, Inc. | Remote tracking device and a system and method for two-way voice communication between the device and a monitoring center |
US7996887B2 (en) * | 2006-08-15 | 2011-08-09 | International Business Machines Corporation | Security of a network system |
WO2008027985A2 (en) | 2006-08-29 | 2008-03-06 | Satellite Tracking Of People Llc | Wireless tag and auxiliary device for use with home monitoring unit for tracking individuals or objects |
US7847727B2 (en) * | 2006-08-29 | 2010-12-07 | Pinpoint Productions LLC | Object identity and location tracking system |
US7696887B1 (en) * | 2006-10-25 | 2010-04-13 | Arturo Echavarria | Person tracking and communication system |
US7639131B2 (en) | 2006-12-18 | 2009-12-29 | Motorola, Inc. | Tracking device that conserves power using a sleep mode when proximate to an anchor beacon |
-
2009
- 2009-02-09 US US12/322,941 patent/US8154401B1/en not_active Expired - Fee Related
-
2012
- 2012-04-10 US US13/443,180 patent/US8760286B2/en active Active
-
2014
- 2014-06-24 US US14/313,339 patent/US9219978B2/en active Active
-
2015
- 2015-12-07 US US14/961,556 patent/US9781558B2/en active Active
-
2017
- 2017-08-23 US US15/684,156 patent/US10129695B2/en active Active
-
2018
- 2018-10-02 US US16/149,990 patent/US11272313B2/en active Active
-
2022
- 2022-03-01 US US17/684,089 patent/US20220295218A1/en not_active Abandoned
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6801129B2 (en) * | 2001-10-01 | 2004-10-05 | Uscpc, Llc | Tracking system for locating stolen currency |
US20050068169A1 (en) * | 2002-05-14 | 2005-03-31 | Copley Shuan Michael | Personal tracking device |
US8154401B1 (en) * | 2008-02-08 | 2012-04-10 | Global Trek Xploration Corp. | System and method for communication with a tracking device |
US8760286B2 (en) * | 2008-02-08 | 2014-06-24 | Global Trek Xploration Corp. | System and method for communication with a tracking device |
US9219978B2 (en) * | 2008-02-08 | 2015-12-22 | Global Trek Xploration Corp. | System and method for communication with a tracking device |
US9781558B2 (en) * | 2008-02-08 | 2017-10-03 | Inventergy Lbs, Llc | System and method for communication with a tracking device |
US10129695B2 (en) * | 2008-02-08 | 2018-11-13 | Inventergy Lbs, Llc | System and method for communication with a tracking device |
US11272313B2 (en) * | 2008-02-08 | 2022-03-08 | Inventergy Lbs, Llc | System and method for communication with a tracking device |
Also Published As
Publication number | Publication date |
---|---|
US9781558B2 (en) | 2017-10-03 |
US20150057015A1 (en) | 2015-02-26 |
US9219978B2 (en) | 2015-12-22 |
US8760286B2 (en) | 2014-06-24 |
US20160198294A1 (en) | 2016-07-07 |
US20120202519A1 (en) | 2012-08-09 |
US10129695B2 (en) | 2018-11-13 |
US8154401B1 (en) | 2012-04-10 |
US20190174256A1 (en) | 2019-06-06 |
US20180048995A1 (en) | 2018-02-15 |
US11272313B2 (en) | 2022-03-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20220295218A1 (en) | System And Method For Communication With A Tracking Device | |
US11249196B2 (en) | Method and apparatus for intelligent acquisition of position information | |
JP6599321B2 (en) | Mobile network-based geofencing | |
US10609516B2 (en) | Authorized location monitoring and notifications therefor | |
US20110054776A1 (en) | Location-based weather update system, method, and device | |
US8121619B1 (en) | Geographic location information updates | |
US10634759B2 (en) | Method for estimating location, and electronic device and server thereof | |
US8457612B1 (en) | Providing location-based multimedia messages to a mobile device | |
US20020042266A1 (en) | System and methods for conserving wireless resources | |
US20100289659A1 (en) | Dynamic reporting scheme for location based services | |
BRPI0722228A2 (en) | GNSS OR GPS METHODS DISTRIBUTED ORBIT PROPAGATION AND PROGRAMMING | |
CN102215562B (en) | The transmission method of location data and transmission system | |
KR20170098101A (en) | Electronic device and location estimation method thererof | |
KR20130002240A (en) | Location base system using signal intensity of wireless lan | |
CN103329001A (en) | Populating non-positional transmitter location databases using information about recognized positional transmitters | |
Wei et al. | The research and implementation of GPS intelligent transmission strategy based on on-board Android smartphones | |
CN105092781A (en) | Method and device for generating air data | |
CN116915877B (en) | Data processing method and system | |
Aguilar et al. | Quantifying Position Accuracy of Multimodal Data from Global Positioning System–Enabled Cell Phones | |
MXPA05012256A (en) | Two-way sms/xml position location api. |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |