Systems and methods for dynamic device programming

Information

  • Patent Grant
  • 11206171
  • Patent Number
    11,206,171
  • Date Filed
    Thursday, November 30, 2017
    7 years ago
  • Date Issued
    Tuesday, December 21, 2021
    3 years ago
  • Inventors
    • Zywicki; Dean (Irvine, CA, US)
    • Shields; Robert (Irvine, CA, US)
  • Original Assignees
  • Examiners
    • Malkowski; Kenneth J
    Agents
    • Barnes & Thornburg LLP
Abstract
Systems and methods for dynamic device programming in accordance with embodiments of the invention are disclosed. One embodiment includes a vehicle telematics device including a processor, a memory containing a dynamic telematics messaging application, a plurality of accumulators, and a communications interface, wherein the dynamic telematics messaging application directs the processor to obtain a first message data describing a requested set of sensor data using the communications interface, dynamically reconfigure the plurality of accumulators to measure the requested set of sensor data, and transmit a second message data describing the measured set of sensor data.
Description
FIELD OF THE INVENTION

The present invention relates to system communication processing and more specifically to dynamically processing disparate messages.


BACKGROUND

Telematics is the integrated use of telecommunications and informatics. Telematics units are installed in vehicles to provide a variety of telematics functionality in the vehicle. This functionality includes, but is not limited to, emergency warning systems, navigation functionality, safety warnings, vehicle location determination, and automated driving assistance. Telematics units are also capable of recording data related to the operation of the vehicle and providing that information for analysis, whether in real-time or during a time when the vehicle is being serviced. This information can be used in a variety of applications, such as fleet tracking, shipment tracking, insurance calculations, and in vehicle management and service.


SUMMARY OF THE INVENTION

Systems and methods for dynamic device programming in accordance with embodiments of the invention are disclosed. One embodiment includes a vehicle telematics device including a processor, a memory containing a dynamic telematics messaging application, a plurality of accumulators, and a communications interface, wherein the dynamic telematics messaging application directs the processor to obtain a first message data describing a requested set of sensor data using the communications interface, dynamically reconfigure the plurality of accumulators to measure the requested set of sensor data, and transmit a second message data describing the measured set of sensor data.


In another embodiment, the processor includes a plurality of processing engines.


In a further embodiment, at least one of the plurality of processing engines is a virtual processing engine.


In still another embodiment, a first processing engine in the plurality of processing engines is directed to transcode the first message data into a format usable by a second processing engine in the plurality of processing engines.


In a still further embodiment, the first message data is encoded in a standardized message format.


In yet another embodiment, the vehicle telematics device is connected to a vehicle using the communications interface.


In a yet further embodiment, the communications interface includes a diagnostic port connector.


In another additional embodiment, the dynamic telematics messaging application further directs the processor to determine what sensor devices are available from the vehicle, generate configuration data based on the available sensor devices, and dynamically reconfigure the plurality of accumulators based on the configuration data.


In a further additional embodiment, dynamically reconfiguring the plurality of accumulators includes assigning at least one accumulator in the plurality of accumulators to a sensor device.


In another embodiment again, the configuration data describes what sensor devices are available and which sensor data are to be stored.


In a further embodiment again, a method for dynamically configuring a vehicle telematics device includes obtaining a first message data from a vehicle telematics server system using a communications interface, reconfiguring at least one accumulator in a plurality of accumulators to store sensor data based on the first message data, and transmitting a second message data describing the sensor data using the communications interface.


In still yet another embodiment, the method further includes transcoding the first message data from a first format to a second format, where the first format is not usable by at least one processing engine.


In a still yet further embodiment, the at least one processing engine is a virtual processing engine.


In still another additional embodiment, the method further includes connecting to a vehicle via a communications interface, determining a plurality of sensor devices from the vehicle, generating a configuration data based on the plurality of sensor devices, and reconfiguring the at least one accumulator in the plurality of accumulators to store a set of sensor data from the plurality of sensor devices.


In a still further additional embodiment, the configuration data includes priority data describing which sensor data should be measured.


In still another embodiment again, reconfiguring at least one accumulator in a plurality of accumulators to store sensor data further includes updating a configuration data describing which sensor devices are available, wherein the configuration data includes a priority data describing which sensor data should be measured.


In a still further embodiment again, the priority data includes a behavior profile.


In yet another additional embodiment, the first message data is obtained from a dynamic telematics server system.


In a yet further additional embodiment, a vehicle telematics device includes a first processing engine for directed to generate status reports, a second processing engine directed to process sensor data, a third processing engine directed to transcode message data for the first and second processing engines, a plurality of accumulators configured to store sensor data, and a memory comprising a dynamic telematics messaging application, wherein the dynamic telematics messaging application directs the processor to obtain a first message data in a first message format from a dynamic telematics server system, classify the transcoded message data, transcode the first message data to a second format using the third processing engine, process the transcoded message data using the appropriate processing engine, reconfigure the plurality of accumulators based on the transcoded message data, generate a second message data based on the sensor data stored by the plurality of accumulators, and provide the second message data.


In yet another embodiment again, the first, second, and third processing engines are virtual processing engines.


In a yet further embodiment again, the vehicle telematics device further includes a communications interface connected to the diagnostic port of a vehicle.


In another additional embodiment again, the dynamic telematics messaging application further directs the processor to obtain sensor data from the vehicle.


Other objects, advantages and novel features, and further scope of applicability of the present invention will be set forth in part in the detailed description to follow, and in part will become apparent to those skilled in the art upon examination of the following, or may be learned by practice of the invention. The objects and advantages of the invention may be realized and attained by means of the instrumentalities and combinations particularly pointed out in the prepended claims.





BRIEF DESCRIPTION OF THE DRAWINGS

The description will be more fully understood with reference to the following figures, which are presented as exemplary embodiments of the invention and should not be construed as a complete recitation of the scope of the invention, wherein:



FIG. 1 is a conceptual illustration of a vehicle telematics system in accordance with an embodiment of the invention;



FIG. 2A is a conceptual illustration of a vehicle telematics device in accordance with an embodiment of the invention;



FIG. 2B is a conceptual illustration of a telematics server system in accordance with an embodiment of the invention;



FIG. 3 is a flow chart illustrating a process for automatically configuring a vehicle telematics device in accordance with an embodiment of the invention;



FIG. 4 is a flow chart illustrating a process for reconfiguring vehicle telematics devices in accordance with an embodiment of the invention; and



FIG. 5 is a flow chart illustrating a process for transcoding message data in accordance with an embodiment of the invention.





DETAILED DESCRIPTION

Turning now to the drawings, systems and methods for dynamic device programming in accordance with embodiments of the invention are disclosed. Fleets of vehicles are a core component of many industries such as logistics and personal transportation. In many cases, it can be beneficial to be able to monitor and track the status of vehicles within the fleet. As such, many vehicles are equipped with vehicle telematics devices. These vehicle telematics devices can obtain and/or measure a variety of data regarding the conditions and/or location of the vehicle along with receiving and transmitting data to telematics server systems. Vehicle telematics devices can have a set of accumulators configured to store measured data. However, there are often not enough accumulators to store all measurable data. Furthermore, vehicle telematics devices may be preprogrammed to measure a certain set of data, but without knowing what type of vehicle it is going to be connected to, there is a chance that accumulator space may be unused and/or the device itself may need to be reprogrammed post-installation. Vehicle telematics devices can include one or more processing engines. In a variety of embodiments, processing engines can include engines for processing and generating status reports and processing and generating sensor data messages, although any processing engines can be utilized as appropriate to the requirements of specific applications of embodiments of the invention.


In many embodiments, vehicle telematics devices can automatically detect the type of available data after connecting to a vehicle. In numerous embodiments, vehicle telematics devices can dynamically assign accumulators to change what data is measured and/or reported back to a telematics server system. Vehicle telematics devices can change their behavior in response to messages from telematics server systems including, but not limited to, what data is being stored, what data is being transmitted, the format of transmitted messages, and/or any other behavioral change as appropriate to the requirements of a given application. In numerous embodiments, vehicle telematics devices include a processing engine for transcoding messages into formats usable by other processing engines. In this way, vehicle telematics devices can automatically maintain compatibility with a variety of telematics server systems and/or messaging formats while maintaining functionality and/or compatibility with legacy on-board processing engines. Systems and methods for dynamic telematics messaging, including a variety of formats for transmitting messages within a vehicle telematics system, that can be utilized in accordance with embodiments of the invention are described in U.S. patent application Ser. No. 15/818,260 entitled “Systems and Methods for Dynamic Telematics Messaging”, filed Nov. 20, 2017, the disclosure of which is hereby incorporated by reference in its entirety.


Vehicle Telematics Systems


Vehicle telematics systems in accordance with embodiments of the invention can transmit a variety of data between a telematics server system and a vehicle telematics device. A conceptual diagram of a vehicle telematics system in accordance with an embodiment of the invention is shown in FIG. 1. The vehicle telematics system 10 includes a vehicle telematics device 20 that can communicate with a vehicle data bus 22, an input/output (I/O) interface 24, and/or a network 30 as appropriate to the requirements of specific applications of embodiments of the invention. In a variety of embodiments, vehicle telematics device 20 communicates with a telematics server system 40 via the network 30. In a variety of embodiments, the network 30 is the Internet. In many embodiments, the network 30 is any wired or wireless network, such as a cellular network, between the vehicle telematics device 20 and the telematics server system 40. In a number of embodiments, the telematics server system 40 implemented using a single server system. In several embodiments, the telematics server system 40 is implemented using multiple server systems.


In a variety of embodiments, the vehicle telematics device 20 is installed in a vehicle having a vehicle data bus 22. In several embodiments, the vehicle telematics device 20 is connected to a vehicle diagnostic connector that provides access to the vehicle data bus 22. The vehicle telematics device 20 can obtain data from any of a variety of vehicle devices connected to the vehicle data bus 22 utilizing any of a variety of techniques as appropriate to the requirements of specific applications of embodiments of the invention. Vehicle devices can include, but are not limited to, engine sensors, electronic control unit (ECU) devices, alternator sensors, vibration sensors, voltage sensors, oxygen sensors, Global Positioning System (GPS) receivers, ignition devices, weight sensors, wireless network devices, and/or acceleration determination devices. Systems and methods for connecting to a vehicle data bus that can be utilized in accordance with embodiments of the invention are described in SAE J1978, titled “OBD II Scan Tool,” first published by SAE International of Troy, Mich. on Mar. 1, 1992 and last updated Apr. 30, 2002. Systems and methods for obtaining data from devices connected to a vehicle data bus are described in SAE J1979, titled “E/E Diagnostic Test Modes,” first published by SAE International on Dec. 1, 1991 and last updated Aug. 11, 2014. The disclosures of SAE J1978 and SAE J1979 are hereby incorporated by reference in their entirety.


The vehicle telematics device 20 can include any of a variety of sensors and/or devices, including those described above with respect to the vehicle data bus and any described in more detail below, to obtain data regarding the status of the vehicle. The vehicle telematics device 20 can also communicate with any of a variety of sensors and/or devices using the I/O interface 24. The I/O interface 24 can be any connection, including wired and wireless connections, as appropriate to the requirements of specific applications of embodiments of the invention. In several embodiments, the vehicle telematics device 20 is capable of executing scripts to read data and/or perform particular processes. These scripts can be pre-loaded on the device and/or obtained from the telematics server system 40, vehicle data bus 22, and/or the I/O interface 24 as appropriate to the requirements of specific applications of embodiments of the invention. The vehicle telematics device 20 can be self-powered and/or connected into the electrical system of the vehicle in which the vehicle telematics device 20 is installed. In a variety of embodiments, the vehicle telematics device is powered via the vehicle data bus 22 and/or the I/O interface 24. In many embodiments, the vehicle telematics device 20 utilizes a Global Positioning System (GPS) receiver in order to determine the location, speed, and/or acceleration of the vehicle. However, it should be noted that any location-determining techniques, such as cellular tower triangulation, wireless network geolocation techniques, and dead reckoning techniques, could be utilized as appropriate to the requirements of specific applications of embodiments of the invention.


In a variety of embodiments, the vehicle telematics device 20 and/or telematics server system 40 provides a user interface allowing for visualizing and interacting with the data transmitted and/or received between the systems. In several embodiments, the vehicle telematics device 20 and/or telematics server system 40 provide an interface, such as an application programming interface (API) or web service that provides some or all of the data to third-party systems for further processing. Access to the interface can be open and/or secured using any of a variety of techniques, such as by using client authorization keys, as appropriate to the requirements of specific applications of the invention.


Although a specific architecture of a vehicle telematics system in accordance with embodiments of the invention are discussed above and illustrated in FIG. 1, a variety of architectures, including sensors and other devices and techniques not specifically described above, can be utilized in accordance with embodiments of the invention. Furthermore, the processes described herein can be performed using any combination the vehicle telematics device and/or the telematics server system as appropriate to the requirements of specific applications of embodiments of the invention.


Vehicle Telematics Devices


Vehicle telematics devices in accordance with many embodiments of the invention can transmit and receive data. A conceptual illustration of a vehicle telematics device in accordance with an embodiment of the invention is shown in FIG. 2A. The vehicle telematics device 200 includes a processor 210 in communication with a memory 240. Processor 210 can include any number of processing engines. In many embodiments, three processing engines are used. Processing engines can have specialized purposes including, but not limited to, processing sensor data, generating reports, transcoding messages, and/or any other purpose as appropriate to the requirements of a given application. Processing engines can be implemented in hardware and/or as virtual processing engines. In many embodiments, memory includes a series of accumulators configured to store bit strings. Accumulators can be assigned static identifiers, e.g. 0, 1, 2 . . . etc. The vehicle telematics device 200 includes a communications interface 220 capable of sending and receiving data. Although the processor 210 and communications interface 220 are illustrated as separate components, some or all of these devices can be implemented using a single-chip solution as appropriate to the requirements of specific applications of embodiments of the invention.


Sensor devices 230 can include, but are not limited to, RPM sensors, voltage sensors, GPS receivers, noise sensors, vibration sensors, acceleration sensors, weight sensors, and any other device capable of measuring data regarding a vehicle as appropriate to the requirements of specific applications of embodiments of the invention. In certain embodiments, sensor devices 230 are included within the vehicle telematics device 200. However, vehicle telematics devices can also acquire sensor data from sensor devices located externally to the vehicle telematics device 200. In a variety of embodiments, sensor devices 230 include any sensors integrated into the vehicle and transmitted to the vehicle telematics device 200. In many embodiments, sensors are integrated into the vehicle and transmitted over a vehicle data bus. In numerous embodiments, sensor readings are stored as bit strings in the series of accumulators.


In several embodiments, the memory 240 is any form of storage storing a variety of data, including, but not limited to, a messaging application 242, device configuration data 244, and/or sensor data 246. In many embodiments, the messaging application 242, device configuration data 244, and/or sensor data 246 are stored using an external server system and received by the vehicle telematics device 200 using the communications interface 220. Device configuration data can be used to direct the processor to generate messages in a chosen static message profile. In a variety of embodiments, dynamic messaging applications can generate dynamic messages that require minimal processing by dynamic telematics messaging systems. In numerous embodiments, device configuration data 244 describes what sensor data is available and/or which types of sensor data are currently being collected.


Turning now to FIG. 2B, a conceptual illustration of a telematics server system is shown. The telematics server system 260 contains a processor 270 in communication with a memory 290 and a communications interface 280. Processor 270 can be any type of computational processing unit, including, but not limited to, microprocessors, central processing units, graphical processing units, parallel processing engines, or any other type of processor as appropriate to the requirements of a given application. The communications interface 280 can be utilized to transmit and receive messages from and to vehicle telematics devices, as well as to transmit data between server systems and interface devices. Communications interface 280 can include multiple ports and/or technologies in order to communicate with various devices as appropriate to the requirements of specific applications of embodiments of the invention.


Memory 290 can be implemented using any combination of volatile and/or non-volatile memory, including, but not limited to, random access memory, read-only memory, hard disk drives, solid-state drives, flash memory, or any other memory format as appropriate to the requirements of a given application. In several embodiments, the memory 290 stores a variety of data, including, but not limited to, a dynamic messaging application 292 and/or received report data 293. In many embodiments, the dynamic messaging application 292 and/or received report data 293 are stored using an external server system and received by the telematics server system 200 using the communications interface 280.


Processor 210 and processor 270 can be directed, by messaging application 242 and dynamic messaging application 292, to perform a variety of dynamic telematics messaging processes. As described in more detail below dynamic messaging processes can include, but are not limited to, dynamically configuring a vehicle telematics device and generating message data including data read using one or more sensor devices.


Although specific architectures for vehicle telematics devices and telematics server systems in accordance with embodiments of the invention are conceptually illustrated in FIGS. 2A and 2B, any of a variety of architectures, including those that store data or applications on disk or some other form of storage and are loaded into memory at runtime, can also be utilized. In a variety of embodiments, a memory includes circuitry such as, but not limited to, memory cells constructed using transistors, that are configured to store instructions. Similarly, a processor can include logic gates formed from transistors (or any other device) that dynamically perform actions based on the instructions stored in the memory. In several embodiments, the instructions are embodied in a configuration of logic gates within the processor to implement and/or perform actions described by the instructions. In this way, the systems and methods described herein can be performed utilizing both general-purpose computing hardware and by single-purpose devices such as, but not limited to, systems-on-a-chip (SoC). Furthermore, telematics server systems can be implemented on multiple servers within at least one server system. For example, telematics server system systems can be implemented on various remote “cloud” server systems as appropriate to the requirements of a given application.


Configuring Vehicle Telematics Devices


When vehicle telematics devices are connected to vehicles, they can determined what data and/or is available, and accumulators can be assigned to different data types. Dynamic telematics messaging processes in accordance with embodiments of the invention can include querying the vehicle to generate initialization data and automatically configure the vehicle telematics device. Turning now to FIG. 3, a process for dynamically configuring a vehicle telematics device in accordance with an embodiment of the invention is illustrated. Process 300 includes connecting (310) to a vehicle. In many embodiments, the connection is made to the vehicle data bus. In numerous embodiments, the connection to the vehicle data bus is made via a diagnostic port located within the vehicle. However, any number of connection methods, including direct wiring into particular devices and/or sensors located within the vehicle, can be used as appropriate to the requirements of a given application.


Process 300 further includes determining (320) available sensor devices. In numerous embodiments, the determination of available sensor devices includes detecting what sensor devices are available via the vehicle data bus. In many embodiments, the available sensors devices is determined using a bus discovery process, such as those described in SAE J1978 and J1979 incorporated by reference above. The bus discovery process can provide a list of sensor devices in a variety of formats, including a bit string matching a standardized format, as appropriate to the requirements of specific applications of embodiments of the invention. In a variety of embodiments, vehicle identification information such as, but not limited to, a vehicle identification number (VIN), are used to determine what sensor devices are available. In numerous embodiments, vehicle identification information can be used to query a database to determine an appropriate initial device configuration data.


The vehicle telematics device can be dynamically configured (330). In many embodiments, device configuration data generated based on the available sensor devices is used to configure the vehicle telematics device. In numerous embodiments, sensor data are dynamically assigned to accumulators. If there are more sensor devices and/or collectable types of data available than there are accumulators, a record can be kept of available sensor devices. In many embodiments, which sensors are assigned to accumulators is determined based on a predetermined priority data describing which data is of highest value. In a number of embodiments, the assignment of sensor devices to accumulators can be automatically updated based on requests for data from particular sensor devices.


In a number of embodiments, process 300 also includes initializing (340) data collection and/or providing (350) a vehicle report. In many embodiments, initializing data collection includes storing sensor data in accumulators. Vehicle reports can include information about available sensor data, the type of vehicle, the time of install, and/or any other initialization information as appropriate to the requirements of a given application. In several embodiments, the vehicle report is generated by a script that automatically compiles the current value of one or more accumulators.


Specific processes for configuring vehicle telematics devices in accordance with embodiments of the invention are described above and shown with respect to FIG. 3; however, any number of processes, including those that use alternative techniques for determining available sensor devices and/or storing sensor data, can be utilized as appropriate to the requirements of a specific application in accordance with embodiments of the invention.


Dynamically Reconfiguring Vehicle Telematics Devices


There are situations where data that is accessible by a vehicle telematics device is not being recorded and/or there is a request for particular data to be measured by a vehicle telematics device. In several embodiments, messages can be provided to vehicle telematics devices to dynamically reconfigure its behavior. Dynamic telematics messaging processes in accordance with embodiments of the invention can include dynamically reconfiguring vehicle telematics devices in response to a message. Turning now to FIG. 4, a method for dynamically reconfiguring a vehicle telematics device in accordance with an embodiment of the invention is illustrated. Process 400 includes obtaining (410) message data. The message type can be determined (420). Message types can be, but are not limited to, messages that request changes in sensor data, message format, communications protocol, firmware updates, and/or any other reconfigurable behavior in accordance with an embodiment of the invention.


The vehicle telematics device can be dynamically reconfigured (430) based on the message data. In many embodiments, when the message data includes a request for a change in sensor data, the requested sensor data is assigned to an accumulator. The particular accumulator utilized can be determined automatically and/or defined in the message data as appropriate to the requirements of specific applications of embodiments of the invention. If there are no available accumulators, an accumulator currently in use can be reassigned to store the requested sensor data. In numerous embodiments, the message indicates which sensor data is no longer required so that the accumulator previously used to store the data is reassigned. In a variety of embodiments, the accumulator to be reassigned is based on predetermined priority data. However, which accumulator is reassigned can be determined in any number of ways, including, but not limited to number of times an accumulator has been reassigned, and/or any other metric as appropriate to the requirements of a given application of the invention. In a variety of embodiments, device configuration data can describe a number of behavior profiles indicating accumulator assignments. In many embodiments, the message data can include a request for a new behavior profile from stored behavior profiles and/or transmit a new behavior profile. When the message requests a change in reporting data format(s), the vehicle telematics device can dynamically reconfigure the message structure used to generate vehicle reports. In numerous embodiments, when the message requests a change in transmission protocol, the vehicle telematics device can be dynamically reconfigured to communicate via the updated transmission protocol.


Process 400 can further include providing (440) requested data. In numerous embodiments, the requested data contains the newly requested sensor data. In many embodiments, the requested data is in a message format includes containers for a large number of different types of data, but only the types of data stored accumulators are stored in the message. In numerous embodiments, identifying data about the vehicle and/or vehicle telematics device are stored in the message. Identifying data can be stored as metadata in message format. In a variety of embodiments, the requested data includes one or more vehicle reports as described in more detail above.


Specific processes for dynamically reconfiguring vehicle telematics devices in accordance with embodiments of the invention are described above and shown with respect to FIG. 4; however, any number of processes, including those that use alternative techniques for allocating memory, can be utilized as appropriate to the requirements of a specific application in accordance with embodiments of the invention.


Transcoding Message Data


Vehicle telematics devices can perform a variety of processes to transcode message data in a first format into a second format usable by specific processing engines. Dynamic telematics messaging processes in accordance with embodiments of the invention can include transcoding received messages into specific formats. For example, the first message format can utilize the extensible markup language (XML) standard, while the second format includes a hex-encoded bit string. However, it should be noted that any data formats can be utilized and/or transcoded as appropriate to the requirements of specific applications of embodiments of the invention.


Turning now to FIG. 5, a process for providing transcoded message data in accordance with an embodiment of the invention is illustrated. Process 500 includes obtaining (510) message data. In numerous embodiments, obtained message data is in a format that is typically not readable by vehicle telematics devices. Message data can be transcoded (520) into a usable format. In many embodiments, message data is encoded in a standardized format that is not readable by vehicle telematics devices. Standardized message data can be converted into a device specific format. In numerous embodiments, message data is transcoded by applying a set of rules describing transformations of instruction data stored within message data. In many embodiments, the instruction data provides requests for data such as, but not limited to, sensor data. In a variety of embodiments, instruction data describes changes to communications protocols. The instruction data can be stored as transcoded message data. The transcoded message data can be provided (530). In numerous embodiments, the transcoded message data is provided to hardware within a vehicle telematics device. In a variety of embodiments, the transcoded message data is provided to a processing engine executing within the vehicle telematics device. However, any transcoded message data can be provided to any number of devices such as, but not limited to, relays, modems, user interfaces, and/or any other device as appropriate to the requirements of a given application.


In many embodiments, transcoded message data can trigger processes for dynamically reconfiguring vehicle telematics devices. In numerous embodiments, data requested by transcoded message data can be provided (540). In numerous embodiments, the provided data includes one or more vehicle reports as described in more detail above.


Specific processes for providing transcoded message data in accordance with embodiments of the invention are described above and shown with respect to FIG. 5; however, any number of processes, including those that use alternative transcoding techniques, can be utilized as appropriate to the requirements of a specific application in accordance with embodiments of the invention.


Although the present invention has been described in certain specific aspects, many additional modifications and variations would be apparent to those skilled in the art. In particular, any of the various processes described above can be performed in alternative sequences and/or in parallel in order to achieve similar results in a manner that is more appropriate to the requirements of a specific application. It is therefore to be understood that the present invention can be practiced otherwise than specifically described without departing from the scope and spirit of the present invention. Thus, embodiments of the present invention should be considered in all respects as illustrative and not restrictive. It will be evident to the person skilled in the art to freely combine several or all of the embodiments discussed here as deemed suitable for a specific application of the invention. Throughout this disclosure, terms like “advantageous”, “exemplary” or “preferred” indicate elements or dimensions which are particularly suitable (but not essential) to the invention or an embodiment thereof, and may be modified wherever deemed suitable by the skilled person, except where expressly required. Accordingly, the scope of the invention should be determined not by the embodiments illustrated, but by the appended claims and their equivalents.

Claims
  • 1. A vehicle telematics device comprising: a processor;a memory storing a dynamic telematics messaging application;a plurality of accumulators; anda communications interface;wherein the dynamic telematics messaging application directs the processor to: obtain a first message data describing a requested sensor data from a corresponding sensor device using the communications interface;determine whether each accumulator of the plurality of accumulators has been previously assigned to store a corresponding sensor data different from the requested sensor data;select, in response to a determination that each accumulator of the plurality of accumulators has been previously assigned to store a corresponding sensor data, a first accumulator of the plurality of accumulators to be dynamically reconfigured to store the requested sensor data, wherein the first accumulator is selected based on the first message data and the sensor data previously assigned to the first accumulator;dynamically reconfigure the first accumulator to measure the requested sensor data by reassigning the first accumulator from the sensor data previously assigned to the first accumulator to the requested sensor data to store the requested sensor data received from the corresponding sensor device; andtransmit a second message data describing the measured set of sensor data.
  • 2. The vehicle telematics device of claim 1, wherein the processor comprises a plurality of processing engines.
  • 3. The vehicle telematics device of claim 2, wherein at least one of the plurality of processing engines is a virtual processing engine.
  • 4. The vehicle telematics device of claim 2, wherein a first processing engine in the plurality of processing engines is directed to transcode the first message data into a format usable by a second processing engine in the plurality of processing engines.
  • 5. The vehicle telematics device of claim 1, wherein the first message data is encoded in a standardized message format.
  • 6. The vehicle telematics device of claim 1, wherein the vehicle telematics device is connected to a vehicle using the communications interface.
  • 7. The vehicle telematics device of claim 6, wherein the communications interface comprises a diagnostic port connector.
  • 8. The vehicle telematics device of claim 6, wherein the dynamic telematics messaging application further directs the processor to: determine what sensor devices are available from the vehicle; generate configuration data based on the available sensor devices; and dynamically reconfigure the plurality of accumulators based on the configuration.
  • 9. The vehicle telematics device of claim 8, wherein dynamically reconfiguring the plurality of accumulators comprises assigning at least one accumulator in the plurality of accumulators to an available sensor device.
  • 10. The vehicle telematics device of claim 8, wherein the configuration data describes what sensor devices are available and which sensor data are to be stored.
  • 11. A method for dynamically configuring a vehicle telematics device, the method comprising: obtaining a first message data describing a requested sensor data from a corresponding sensor device from a vehicle telematics server system using a communications interface;determining whether each accumulator of a plurality of accumulators has been previously assigned to store a corresponding sensor data different from the requested sensor data;selecting, in response to a determination that each accumulator of the plurality of accumulators has been previously assigned to store a corresponding sensor data, a first accumulator of the plurality of accumulators to be dynamically reconfigured to store the requested sensor data, wherein the first accumulator is selected based on the first message data and the sensor data previously assigned to the first accumulator;dynamically reconfiguring the first accumulator to measure the requested sensor data by reassigning the first accumulator from the sensor data previously assigned to the first accumulator to the requested sensor data to store the requested sensor data received from the corresponding sensor device; andtransmitting a second message data describing the measured sensor data using the communications interface.
  • 12. The method of claim 11 further comprising transcoding the first message data from a first format to a second format, where the first format is not usable by at least one processing engine.
  • 13. The method of claim 12, wherein the at least one processing engine is a virtual processing engine.
  • 14. The method of claim 11 further comprising: connecting to a vehicle via a communications interface;determining a plurality of available sensor devices from the vehicle;generating a configuration data based on the plurality of available sensor devices; andreconfiguring the plurality of accumulators to store a set of sensor data from the plurality of available sensor devices.
  • 15. The method of claim 14, wherein the configuration data comprises priority data describing which sensor data should be measured.
  • 16. The method of claim 11, wherein dynamically reconfiguring the plurality of accumulators further comprises updating a configuration data describing which sensor devices are available, wherein the configuration data comprises a priority data describing which sensor data should be measured.
  • 17. The method of claim 16, wherein the priority data comprises a behavior profile.
  • 18. The method of claim 11, wherein the first message data is obtained from a dynamic telematics server system.
  • 19. A vehicle telematics device comprising: a first processing engine directed to generate status reports;a second processing engine directed to process sensor data;a third processing engine directed to transcode message data for the first and second processing engines;a communications interface connected to the diagnostic port of a vehicle;a plurality of accumulators configured to store sensor data from a plurality of different sensor devices of the vehicle via the communications interface; anda memory comprising a dynamic telematics messaging application, wherein the dynamic telematics messaging application directs the processor to: obtain a first message data in a first message format from a dynamic telematics server system;transcode the first message data to a second format using the third processing engine;process the transcoded message data using the appropriate processing engine, wherein the transcoded message data describes a requested sensor data from a corresponding sensor device;determine whether each accumulator of the plurality of accumulators has been previously assigned to store a corresponding sensor data different from the requested sensor data;select, in response to a determination that each accumulator of the plurality of accumulators has been previously assigned to store a corresponding sensor data, a first accumulator of the plurality of accumulators to be dynamically reconfigured to store the requested sensor data, wherein the first accumulator is selected based on the transcoded message data and the sensor data previously assigned to the first accumulator;dynamically reconfigure the first accumulator to measure the requested sensor data by reassigning the first accumulator from the sensor data previously assigned to the first accumulator to the requested sensor data to store the requested sensor data received from the corresponding sensor device;generate a second message data based on the sensor data stored by the plurality of accumulators; andprovide the second message data.
  • 20. The vehicle telematics device of claim 19, wherein the first, second, and third processing engines are virtual processing engines.
CROSS REFERENCE TO RELATED APPLICATIONS

The instant application claims priority to U.S. Provisional Patent Application No. 62/582,818, filed Nov. 7, 2017, the disclosure of which is hereby incorporated by reference in its entirety.

US Referenced Citations (212)
Number Name Date Kind
4549277 Brunson et al. Oct 1985 A
5117375 Worcester et al. May 1992 A
5251161 Gioutsos et al. Oct 1993 A
5339242 Jensen et al. Aug 1994 A
5559699 Gioutsos et al. Sep 1996 A
5563791 Gioutsos et al. Oct 1996 A
5587906 Muckley et al. Dec 1996 A
5684701 Breed et al. Nov 1997 A
5754849 Dyer et al. May 1998 A
5758301 Saito et al. May 1998 A
5780782 O'Dea et al. Jul 1998 A
5825283 Camhi Oct 1998 A
5841201 Ibaraki et al. Nov 1998 A
5862511 Croyle et al. Jan 1999 A
6029111 Croyle Feb 2000 A
6076028 Donnelly et al. Jun 2000 A
6085151 Farmer et al. Jul 2000 A
6163690 Lilja Dec 2000 A
6269290 Tsuji et al. Jul 2001 B1
6308134 Croyle et al. Oct 2001 B1
6346876 Flick Feb 2002 B1
6356841 Hamrick et al. Mar 2002 B1
6363308 Potti et al. Mar 2002 B1
6401027 Xu et al. Jun 2002 B1
6417802 Diesel Jul 2002 B1
6431593 Cooper et al. Aug 2002 B1
6438475 Gioutsos et al. Aug 2002 B1
6532419 Begin Mar 2003 B1
6540255 Garcia et al. Apr 2003 B1
6611755 Coffee et al. Aug 2003 B1
6737989 Flick May 2004 B2
6756885 Flick Jun 2004 B1
6812888 Drury et al. Nov 2004 B2
6832140 Fan et al. Dec 2004 B2
6850839 Mcgibney Feb 2005 B1
7015830 Flick Mar 2006 B2
7020501 Elliott et al. Mar 2006 B1
7085637 Breed et al. Aug 2006 B2
7110880 Breed et al. Sep 2006 B2
7250850 Mizutani Jul 2007 B2
7272493 Hamrick et al. Sep 2007 B1
7286929 Staton et al. Oct 2007 B2
7348895 Lagassey et al. Mar 2008 B2
7366608 Hamrick et al. Apr 2008 B2
7391299 Bender Jun 2008 B2
7460954 Hamrick et al. Dec 2008 B2
7484756 Chou et al. Feb 2009 B2
7527288 Breed et al. May 2009 B2
7577525 Hamrick et al. Aug 2009 B2
7643919 Nicaise Jan 2010 B2
7660652 Smith et al. Feb 2010 B2
7671727 Flick Mar 2010 B2
7725218 Hamrick et al. May 2010 B2
7765039 Hagenbuch Jul 2010 B1
7805231 Cluff et al. Sep 2010 B2
8004397 Forrest et al. Aug 2011 B2
8010251 Hamrick et al. Aug 2011 B2
8032278 Flick Oct 2011 B2
8065342 Borg Nov 2011 B1
8330626 Adelson Dec 2012 B1
8489271 Hergesheimer et al. Jul 2013 B2
8635091 Amigo et al. Jan 2014 B2
8688380 Cawse et al. Apr 2014 B2
8712633 Sul Apr 2014 B2
8762009 Ehrman et al. Jun 2014 B2
8812173 Chen et al. Aug 2014 B2
8855143 Acampora Oct 2014 B1
9002538 Hergesheimer et al. Apr 2015 B2
9171460 Chen Oct 2015 B2
9179497 Teixeira et al. Nov 2015 B1
9217757 Hergesheimer et al. Dec 2015 B2
9406222 Hergesheimer et al. Aug 2016 B2
9459277 Hergesheimer et al. Oct 2016 B2
9607449 Chen Mar 2017 B1
9644977 Camisa May 2017 B2
9648579 Abhishek May 2017 B2
20020065045 Kim et al. May 2002 A1
20020100310 Begin Aug 2002 A1
20030001368 Breed et al. Jan 2003 A1
20030005117 Kang et al. Jan 2003 A1
20030121027 Hines Jun 2003 A1
20030151507 Andre et al. Aug 2003 A1
20030176959 Breed et al. Sep 2003 A1
20030216889 Marko Nov 2003 A1
20040036261 Breed et al. Feb 2004 A1
20040075539 Savoie et al. Apr 2004 A1
20040132500 Rogalski et al. Jul 2004 A1
20040142659 Oesterling Jul 2004 A1
20040155790 Tsuji et al. Aug 2004 A1
20040171378 Rautila et al. Sep 2004 A1
20040257208 Huang et al. Dec 2004 A1
20050065711 Dahlgren et al. Mar 2005 A1
20050071314 Caron Mar 2005 A1
20050099289 Arita et al. May 2005 A1
20050240343 Schmidt et al. Oct 2005 A1
20050267947 Patrick et al. Dec 2005 A1
20050273516 Patrick et al. Dec 2005 A1
20050283286 Kanda et al. Dec 2005 A1
20060022469 Syed et al. Feb 2006 A1
20060031432 Patrick et al. Feb 2006 A1
20060034237 Patrick et al. Feb 2006 A1
20060041336 Schubert et al. Feb 2006 A1
20060050953 Farmer et al. Mar 2006 A1
20060074621 Rachman Apr 2006 A1
20060199537 Eisenbach et al. Sep 2006 A1
20070027612 Barfoot et al. Feb 2007 A1
20070038653 Li et al. Feb 2007 A1
20070109117 Heitzmann et al. May 2007 A1
20070185646 Juergen Aug 2007 A1
20070186546 Midgley Aug 2007 A1
20070257791 Arita et al. Nov 2007 A1
20070266078 Rittle et al. Nov 2007 A1
20070271014 Breed Nov 2007 A1
20070299587 Breed et al. Dec 2007 A1
20080043821 Brockhage et al. Feb 2008 A1
20080111666 Plante et al. May 2008 A1
20080114545 Takaoka et al. May 2008 A1
20080150707 Shamoto Jun 2008 A1
20080195261 Breed Aug 2008 A1
20080202199 Finley et al. Aug 2008 A1
20080211666 Saidi et al. Sep 2008 A1
20080211914 Herrera et al. Sep 2008 A1
20080275601 Saito et al. Nov 2008 A1
20090077229 Ebbs Mar 2009 A1
20090177350 Williams et al. Jul 2009 A1
20090217163 Jaroker Aug 2009 A1
20090217733 Stachow Sep 2009 A1
20090221320 Walley et al. Sep 2009 A1
20100039216 Knight et al. Feb 2010 A1
20100039247 Ziegler et al. Feb 2010 A1
20100039318 Kmiecik et al. Feb 2010 A1
20100097316 Shaw et al. Apr 2010 A1
20100185524 Watkins Jul 2010 A1
20100205427 Bauer et al. Aug 2010 A1
20100235433 Ansari et al. Sep 2010 A1
20100273422 Garrett et al. Oct 2010 A1
20100279647 Jacobs et al. Nov 2010 A1
20100312473 Hoshizaki Dec 2010 A1
20100318257 Kalinadhabhotla Dec 2010 A1
20110053575 Veliu et al. Mar 2011 A1
20110060496 Nielsen et al. Mar 2011 A1
20110071971 Parks et al. Mar 2011 A1
20110106373 Hergesheimer et al. May 2011 A1
20110109438 Dijkstra et al. May 2011 A1
20110130906 Mayer Jun 2011 A1
20110153367 Amigo Jun 2011 A1
20110202225 Willis et al. Aug 2011 A1
20110238289 Lehmann et al. Sep 2011 A1
20110264393 An Oct 2011 A1
20110320088 Eom et al. Dec 2011 A1
20120022780 Kulik et al. Jan 2012 A1
20120041618 Sun et al. Feb 2012 A1
20120050095 Scherzinger Mar 2012 A1
20120116669 Lee May 2012 A1
20120155389 Mcnamee et al. Jun 2012 A1
20120158211 Chen Jun 2012 A1
20120159142 Jibbe et al. Jun 2012 A1
20120231821 Swanson Sep 2012 A1
20120233237 Roa et al. Sep 2012 A1
20120233668 Leafe et al. Sep 2012 A1
20120253551 Halimi et al. Oct 2012 A1
20120253585 Harvie Oct 2012 A1
20120259526 Inoue Oct 2012 A1
20120303203 Olsen et al. Nov 2012 A1
20130002415 Walli Jan 2013 A1
20130024202 Harris Jan 2013 A1
20130030811 Olleon et al. Jan 2013 A1
20130038439 Saito et al. Feb 2013 A1
20130073142 Hergesheimer et al. Mar 2013 A1
20130095841 Quimby et al. Apr 2013 A1
20130148554 Chen et al. Jun 2013 A1
20130182693 Sperling et al. Jul 2013 A1
20130244210 Nath et al. Sep 2013 A1
20130249713 Adelson Sep 2013 A1
20130275001 Hergesheimer et al. Oct 2013 A1
20130288659 Hrabak et al. Oct 2013 A1
20130297137 Fushiki et al. Nov 2013 A1
20130302756 Takeuchi Nov 2013 A1
20130338855 Mason Dec 2013 A1
20140074315 Frye et al. Mar 2014 A1
20140074353 Lee et al. Mar 2014 A1
20140094210 Gellens et al. Apr 2014 A1
20140095211 Gloerstad et al. Apr 2014 A1
20140111354 Hergesheimer et al. Apr 2014 A1
20140142886 Hergesheimer et al. May 2014 A1
20140149145 Peng May 2014 A1
20140180529 Simon et al. Jun 2014 A1
20140236518 Hergesheimer et al. Aug 2014 A1
20140236519 Hergesheimer et al. Aug 2014 A1
20140237463 Sriram et al. Aug 2014 A1
20140303836 Phelan et al. Oct 2014 A1
20140309843 Chen et al. Oct 2014 A1
20140358394 Picciotti Dec 2014 A1
20140379208 McQuade et al. Dec 2014 A1
20150015385 Tomita et al. Jan 2015 A1
20150051796 Levy Feb 2015 A1
20150178997 Ohsaki Jun 2015 A1
20150268059 Borghesani Sep 2015 A1
20150271271 Bullotta et al. Sep 2015 A1
20150271299 Bullotta et al. Sep 2015 A1
20150339241 Warner et al. Nov 2015 A1
20160104123 Viswanath et al. Apr 2016 A1
20160146615 Abhishek May 2016 A1
20160173281 White et al. Jun 2016 A1
20160335813 Hergesheimer et al. Nov 2016 A1
20160341559 Camisa Nov 2016 A1
20170023610 Hergesheimer et al. Jan 2017 A1
20170075835 Langer Mar 2017 A1
20170147331 Liem et al. May 2017 A1
20170318117 Stenneth Nov 2017 A1
20180261020 Petousis Sep 2018 A1
20190141156 Srinivasulu May 2019 A1
Foreign Referenced Citations (10)
Number Date Country
2000017607 Mar 2000 WO
2002018873 Mar 2002 WO
2014130077 Aug 2014 WO
2014130078 Aug 2014 WO
2014202110 Dec 2014 WO
2015183677 Dec 2015 WO
2016081901 May 2016 WO
2016191306 Dec 2016 WO
2019090366 May 2019 WO
2019094988 May 2019 WO
Non-Patent Literature Citations (19)
Entry
Extended European Search Report for European Application No. 13875407.2, Search completed Nov. 22, 2016, dated Nov. 30, 2016, 7 Pgs.
Extended European Search Report for European Application No. 13875911.3, Search completed Nov. 22, 2016, dated Dec. 9, 2016, 6 Pgs.
International Preliminary Report on Patentability for International Application PCT/US2013/054939, dated Aug. 25, 2015, dated Sep. 3, 2015, 4 Pgs.
International Preliminary Report on Patentability for International Application PCT/US2013/054943, dated Aug. 25, 2015, dated Sep. 3, 2015, 6 Pgs.
International Search Report and Written Opinion for International Application No. PCT/US13/54939, Completed Feb. 5, 2014, dated Feb. 24, 2014, 5 pgs.
International Search Report and Written Opinion for International Application No. PCT/US13/54943, Completed Feb. 13, 2014, dated Feb. 27, 2014, 6 pgs.
International Search Report and Written Opinion for International Application PCT/US2015/061990, completed Jan. 12, 2016, dated Feb. 4, 2016, 6 Pgs.
International Search Report and Written Opinion for International Application PCT/US2016/033621, completed Jul. 28, 2016, dated Aug. 5, 2016, 11 Pgs.
SAE International Surface Vehicle Recommended Practice, “E/E Diagnostic Test Modes”, SAE Standard J1979, Issued Dec. 1991, 19 pgs.
SAE International Surface Vehicle Recommended Practice, “OBD II Scan Tool”, SAE Standard J1978, Issued Mar. 1992, 13 pgs.
“Road vehicles—Diagnostic Systems—Part 2: CARB requirements for interchange of digital information”, ISO 9141-2, Feb. 1, 1994, 18 pgs.
“Surface Vehicle Recommended Practice, E/E Diagnostic Test Modes, Dec. 1991, 32 pgs.”.
“Surface Vehicle Recommended Practice, Universal Interface for OBD II Scan”, SAE Standard J2201, Issued Jun. 30, 1993, 45 pgs.
“Surface Vehicle Recommended Practice; OBD II Scan Tool, Mar. 1992, 14 pgs.”.
ETSI, “GSM Technical Specification”, GSM 07.07, Version 5.0.0, Jul. 1, 1996, 77 pgs.
International Search Report and Written Opinion for International Application No. PCT/US2018/061648, Search completed Feb. 12, 2019, dated Apr. 15, 2019, 14 Pg.
International Search Report and Written Opinion for International Application No. PCT/US2018/061650, Search completed Feb. 17, 2019, dated Mar. 25, 2019, 17 Pgs.
International Preliminary Report on Patentability for International Application PCT/US2018/061650 Report dated May 12, 2020, dated May 22, 2020, 11 Pgs.
International Preliminary Report on Patentability for International Application PCT/US2018/061648 Report dated May 12, 2020, dated May 22, 2020, 9 Pgs.
Related Publications (1)
Number Date Country
20190140886 A1 May 2019 US
Provisional Applications (1)
Number Date Country
62582818 Nov 2017 US