The present disclosure is generally related to a system and method for integrating with the vehicle engine bus so as to enable an intelligent system to automate controls and operation of a vehicle based on contextual information and data.
Vehicles when they are produced today include computing devices that collect data regarding the performance of various systems within a vehicle. Modern vehicles also include an on board diagnostic computer bus (OBD) that service technicians may couple devices to such that fault codes and certain operational characteristics of a vehicle may be monitored. Today vehicles are manufactured that include an ODB version 2 bus (OBD-II), these ODB buses include connection ports to which diagnostic or monitoring equipment may be connected when a technician evaluates performance characteristics or fault codes of a vehicle.
While diagnostic busses included in vehicles today are made according to a standard, only diagnostic devices owned by service technicians have been manufactured to collect and evaluate data communicated over a diagnostic bus. What are needed are new types of equipment that provide new functions to vehicle owners as their vehicles are used.
The presently claimed invention relates to a method, a non-transitory computer-readable storage medium, and an apparatus that evaluates data. A first embodiment of the presently claimed invention is a method that receives image data from an optical sensor, identifies that the image data includes facial data of a person, identifies that the facial data does not belong to a primary driver, sends a message to an electronic device of a user, and receives a response from the user electronic device, wherein the person is allowed to access the vehicle according to the response.
A second embodiment of the presently claimed invention is a non-transitory computer-readable storage medium where a processor executes instructions to perform the presently claimed method. Here again the method may include receiving image data from an optical sensor, identifying that the image data includes facial data of a person identifying that the facial data does not belong to a primary driver sending a message to an electronic device of a user, and receiving a response from the user electronic device, wherein the person is allowed to access the vehicle according to the response.
A third embodiment of the presently claimed invention is an apparatus that includes an optical sensor that receives image data. The Apparatus may also include a memory and a processor that executes instructions out of the memory to identify that the image data includes facial data of a person, identify that the facial data does not belong to a primary driver, send a message to an electronic device of a user, and receive a response from the user electronic device, wherein the person is allowed to access the vehicle according to the response
The present disclosure is directed to methods and apparatus that may collect data from at a vehicle. Data may be collected by connecting to a port of an on board diagnostic bus at the vehicle or this data may be received via a wireless communication interface. Collected data may be stored at a database and this data may be analyzed to identify whether a person at a vehicle is authorized to access or drive the vehicle. This collected data may also be analyzed to identify faults that may occur at a vehicle and recommendations to responding those faults may be provided to a driver of the vehicle via a user interface such as a speaker or display at the vehicle.
Engine bus 120 may be a specialized internal communications network that interconnects components inside a vehicle 105 to other computing devices. Special requirements for vehicle control administrated by a computer may include assured message delivery, non-conflicting message delivery, minimum time message delivery, low cost message delivery, and of electromagnetic frequency (EMF) noise resilience. Such requirements may also include redundant routing or other characteristics that may have been mandated or include the use of common or uncommon networking protocols. Such exemplary network protocols may include, yet are not limited to a controller area network (CAN), local interconnect network (LIN). All cars sold in the United States since 1996 have required an on-board diagnostic (OBD) port that complies with the OBD-II standard, OBD-II is an improvement over OBD-I in both capability and standardization. The OBD-II standard specifies the type of diagnostic connector and its pinout, the electrical signaling protocols available, and the messaging format. It also provides a candidate list of vehicle parameters to monitor along with how to encode the data for each. These diagnostic computer connectors include a pin in the connector that provides power for the scan tool from the vehicle battery. This eliminates the need to connect a scan tool to a power source separately. However, some technicians might still connect a scan tool to an auxiliary power source to protect data collected by the scan tool in the unusual event that a vehicle experiences a loss of electrical power due to a malfunction. Finally, the OBD-II standard provides a list of standardized diagnostic trouble codes (DTCs). As a result of this standardization, a single device can query the on-board computer(s) for parameters in any vehicle and the DTC codes may be used to identify components within a vehicle that are failing or these codes may indicate that the vehicle components are operating within normal operating parameters. The OBD-II standard was prompted to simplify diagnosis of increasingly complicated emissions equipment, and though only emission-related codes and data are required to be transmitted through it according to U.S. legislation, most manufacturers have made the OBD-II data link connector the main connector in the vehicle through which all systems are diagnosed and reprogrammed. Cloud or Internet 135 may be the on-demand availability of computer system resources, especially data storage and computing power, without direct active management by the user. The term is generally used to describe data centers available to many users over the Internet. Large clouds, predominant today, often have functions distributed over multiple locations from central servers. If the connection to the user is relatively close, it may be designated an edge server.
The vehicle application network (VAN) 160 connects and communicates to at least one vehicle 105 through the communication interface 110 via the Internet or cloud 135. The vehicle application network 160 also includes a memory that may store various software modules, such as a base module, a location module, and a telematics module of the vehicle application network (VAN). Vehicle 160 may also include processor 165 that executes instructions out of a memory and a database 175 that may be accessed by processor 165. While not illustrated, processor 165 may be coupled to a communication network that allows the vehicle application network 160 computer to communication with vehicle computer 105. The processor 165 of vehicle application network 160 may collects data from the vehicle computer 125.
A communication interface coupled to processor 165 may allow the vehicle application network (VAN) continuously communicate with vehicle computer 105. The vehicle application network (VAN) base module stored in memory 170 at vehicle application network 160 may initiate operation instructions of the VAN location module and the VAN telematics module stored in the memory 170 of the vehicle application network 160. Instructions of the VAN location module and the VAN telematics module stored in the memory 170 may be initiated or executed in sequenced fashion or in parallel fashion. Operation of the VAN location module may be initiated by the VAN base module. This process may start by continuously polling at least one vehicle computer 125 for a current location of the vehicle 105. This location information may be stored in database 175 that may be referred to as the VAN database 175.
The VAN telematics module may be initiated by instructions of the VAN base module. This process may result in telematics data being collected from vehicle computer 110 by communications sent via communication interface 110 and the cloud or Internet. Functions associated with the use of telematics may include but not limited to, sending, receiving and storing information using telecommunication devices to control remote objects, the integrated use of telecommunications and informatics for application in vehicles, the control vehicles on the move. These functions may rely on or use a form of and global navigation satellite system technology, such as the global positioning system (GPS). Such functionality may be integrated with computers and mobile communications technology in automotive navigation systems.
The VAN database 175 may store data collected by vehicle computer 105 based on communications received via communication interface 110. The data stored in the VAN database 175 can be used for a number of applications, such as, but not limited to, fleet management, improved navigation, vehicle maintenance, vehicle and user safety, and insurance.
The VLA device may store and perform functions of the VLA base module, VLA telematics module, VLA location module, image module, VLA acoustics module, VLA context module in memory 150. The various databases 155 accessible to VLA device 140 include (VLA) telematics database, context database, advice database, and image database. VLA device 140 may communicatively connect to the vehicle computer 110 via a communications port such as an OBD compatible port to collect data and to control operations the vehicle 105. Alternatively VLA device 140 may connect and communicate with the vehicle computer 125 via Bluetooth, Wi-Fi, or cellular wireless communication medium. This may allow VLA device 140 to process vehicle and contextual data of vehicle 105.
The VLA base module stored in memory 150 may be initiated when the vehicle computer 125 is accessed or when vehicle 105 is turned on. VLA device 140 may continuously poll the vehicle computer 125 to see if the vehicle 105 is running. Instructions of the VLA base module when executed by processor 145 may be initiate operation of the VLA telematics module, VLA location module, image module, VLA acoustics module, and VLA context module stored in memory 150. The modules can be initiated in sequence or in a parallel fashion. For example, in one embodiment operation of the image module may be initiated when vehicle computer 110 is accessed for the purpose of identifying a person entering vehicle 105 for security purposes. Once all the modules have been initiated by the VLA base module, operation of the VLA base module may end until vehicle 105 is turned off and then turned back on again.
The VLA telematics module may be initiated by the VLA base module. This may result in telematics data being collected from vehicle computer 110 through a communications port such as but not limited to, an OBD port, a Bluetooth connection, or other wired or r communication connection. Telematics data may include but not limited to, sending, receiving and storing information using telecommunication devices to control remote objects, the integrated use of telecommunications and informatics for application in vehicles and to control vehicles on the move, and global navigation satellite system technology integrated with computers and mobile communications technology in automotive navigation systems, (most narrowly) the use of such systems within road vehicles, also called vehicle telematics.
Operation of the VLA location module may be is initiated by the VLA base module. This may cause processor 145 to continuously poll vehicle's GPS system or other location sensors when a current position of the vehicle is identified. The location of the vehicle 105 may be continuously polled until the vehicle 105 is turned off. The location data acquired from the VLA location module at Memory 150 may be stored in stored in the VLA Telematics database of databases 155. A vehicle tracking system may combine the use of automatic vehicle location of individual vehicles with software that collects fleet data for a comprehensive picture of vehicle locations. Modern vehicle tracking systems commonly use GPS or GLONASS technology for locating the vehicle, but other types of automatic vehicle location technology can also be used. Vehicle information can be viewed on electronic maps via the Internet or specialized software. Urban public transit authorities are an increasingly common user of vehicle tracking systems, particularly in large cities.
Furthermore, the VLA location module at Memory 150 may initiate an augmented reality module (AR/Image) (even through an AR module is not included in the figures) which may use the location data for overlaying augmented reality (AR/Image) data. Such an AR/Image module may be initiated by the VLA location module. The AR/Image module may continuously poll the VLA location module for location of the vehicle 105. Once a location and direction of the vehicle 105 are received by the AR/Image module, the AR/Image module may overlay relevant point of interest (POI) information over image data that may then be displayed on a display at vehicle 105. Augmented reality overlay is expected to include registration and tracking between the superimposed perceptions, sensations, information, data, and images and some portion of the real world. Some example may include, but not limited to, points of interest, navigation, vehicle information, etc. The display may include a screen, a hand help displays or mobile device screen, or a heads-up display (HUD).
The VLA AR/Image module may be initiated by the base module when the vehicle is accessed or when the vehicle 105 is powered on. The VLA AR/Image module may continuously poll optical sensors at vehicle 105 or on a standalone device that stores and runs the applications of the VLA device 140. Images from all-optical sensors may be stored in the image database of databases 155 as long as the vehicle 105 is running or while there is activity in vehicle 105.
Furthermore, the VLA AR/Image module may also initiate the operation of a face module, a gesture module, and/or a driver stress module. These modules may be initiated sequentially or maybe initiated in parallel even though they are not included in the figures as discrete software modules. Operation of the VLA AR/Image module may then end once the vehicle 105 is turned off or after there are no more persons within vehicle 105.
This face module may uses facial recognition to identify persons that are in the vehicle 105. This may allow VLA device 140 to identify if a driver is authorized to be operating vehicle 105. User facial recognition data is stored in the VLA user database of databases 155. This may allow the processor 140 facial recognition technologies to authorize the use of a vehicle 105. There may be multiple levels of users or drivers, for example, a temporary user could be a friend or a teenage son or daughter who needs the approval of a primary user to use the vehicle 105. Instructions of such a face module would prevent the theft of vehicle 105 as the vehicle 105 may not be allowed to operate if a person's face is not recognized.
Operation of a gesture module may be initiated by the AR/Image module. Processor 145 may execute instructions of the gesture module continuously while vehicle 105 is running. This may allow processor 145 to monitors acquired AR/Image data stored in the image database of databases 155 when user movements are analyzed for gestures from a user.
Gestures by a user can be recognized within AR/Image data and specific gestures can be used to control computing devices associated with the vehicle. Gesture recognition is a type of perceptual computing user interface that allows computers to capture and interpret human gestures as commands. The general definition of gesture recognition is the ability of a computer to understand gestures and execute commands based on those gestures.
Operation of a driver stress module may be initiated by the VLA AR/Image module when image data is continuously monitored and stored in the image database. A person's stress or emotional state can be determined by analyzing facial features, posture, and movements of a person in vehicle 105.
Operation of the VLA acoustic module may be initiated by the VLA base module at Memory 150 once the vehicle 105 is turned. The VLA acoustic monitor may continuously monitor the acoustics of vehicle 105 until the vehicle 105 is turned off. Instructions of the VLA acoustic module may allow processor 145 to monitor the acoustics of vehicle 105 in real-time. Processor 145 may then compares the real-time acoustics to data stored at an acoustic database. Such an acoustic database may store a baseline of what the vehicle 105 should sound like when running optimally as well as sounds that would relate to potential vehicle problems. For example, a knocking sound could be an engine problem, a clicking noise may be related to low oil, or a squeaking noise could be a brake or bearings issue. Since computers can analyze acoustic signatures outside the human hearing range, operation of the VLA acoustics module may allow processor 145 to identify potential issues and problems before they are audible to a human. Furthermore, using acoustic triangulation, even if a specific problem can't be identified, the general location of the acoustic signature can be identified to help guide maintenance workers to the possible problem. Specific sounds coming from vehicle 105 can be associated with specific problems. Acoustic signatures can be matched to a library of signatures.
Operation of the VLA context module at Memory 150 may be initiated by the VLA base module. This may allow processor 145 to continuously monitor VLA databases 155 new data that has been stored in the databases 155. Instructions of the VLA context module may allow processor 145 to compares new data found in the databases to data stored in a context database 148 to determine if there is a contextual event that requires a response. For example, weather data, historical query data, navigation data, vehicle diagnostics data, user calendar information, traffic information, etc. Methods consistent with the present disclosure may use contextual stimuli to provide a more custom response to the user rather than just a programmed response to a query. For example, a user may request directions to a specific location, processor 145 may identify based on contextual data, that the user should be asked or suggested to take an alternative route because of a potential safety or contextual issue identified by processor 145. In an instance when the vehicle has low tire pressure, contextual data associated with the low tire pressure may result in changing a route of the vehicle to include a stop at a service station to add air. Contextual data associated with an engine noise may result in a recommendation that the drive not drive on a highway or at speeds that exceed a speed (e.g. 35 miles per hour).
The VLA telematics database of databases 155 may store sets of telematics data collected by operation of instructions of the VLA telematics module. This telematics data may data include, but is not limited to, vehicle sensor data, driving habits data (such as acceleration and de-acceleration rates), vehicle maintenance records, and warranty information. The context database may store potential responses to user queries and additional contextual data required to generate such queries. For example, if a user asks for directions to a location, instead of just looking up a shortest route the, contextual data could be accessed when additional questions are generated such that a driver could be provided a best route considering contextual data that the driver is concerned with. The advice database of databases 155 may store advice that may be provided to a user for a specific situation. Specifically, the advice database of 155 may be used to provide suggested actions for a user based on their emotional state.
The VLA user database may store user information, including facial recognition data, an indication that identifies the face of a primary user or a secondary user. The VLA user database may also store information that identifies a temporary user. The VLA acoustic database may stores a variety of sounds related to the optimal operation of a vehicle as a baseline for comparison as well as acoustic signatures for known problems for identifying issues with a vehicle. The AR/Image database may stores all image data that the received based on operation of the instructions of the AR/Image module. As such all data sensed by an optical sensor or a camera may be stored.
If the no communication can be established between the VAN device 160 and vehicle computer 125, the VAN device 160 may continue to poll for a connection or signal which would indicate the vehicle is on.
The VAN base module may also continue to monitor the vehicle to ensure that the vehicle is still running. Operation of the VAN location module 200B may begin with polling a vehicle computer for location data. This location data can come from any location sensor associated with the vehicle. Location data may include, but not limited, GPS location data, cellular triangulation, or by interpolating the position of the vehicle from available data. Vehicle location may be interpolated by identifying a direction of travel, a speed, an acceleration, and a time. As mentioned above, the vehicle location may be stored in the VAN database in step 240 of
Next in step 250 of
Once the data has been stored in the VAN database the vehicle computer may be polled in step 210 of
Table 1 illustrates data that may be stored in a VAN database after location and telematics data has been received from a vehicle computer. The VAN database stored data of table 1 includes times, locations, directions, tire pressure, engine temperature, fuel levels, an amount of instantaneous acceleration or deceleration, fuel consumption, and a vehicle speed. The location data may identify a latitude and a longitude. Note that table 1 identifies different sets of data that were collected at 1:00 PM, 1:05 PM, and 1:10 PM. Data stored in the VAN database may be collected at discrete time intervals, may be collected when certain types of events occur (e.g. moments of high acceleration or deceleration), or both. Note that at 1:00 PM the vehicle was located at a location of 44.04/−72.71, when the vehicle was traveling in a South East (SE) direction. At this time the tire pressure was 35 pounds per square inch (PSI), the fuel level was 10 gallons, the vehicle was accelerating at a measure of 1, the fuel consumption was 0.01, and the vehicle speed was 35 miles per hour (MPH). Once stored at the VAN database this data may be provided to other applications use. For example, a third party may use the data to analyze user driving behavior. While not illustrated in table 1, collected data may be overlaid with road information when behavior of a driver is analyzed. By overlaying such information, a third party may be able to identify that the driver was driving at an excessive speed on local streets and such a finding could result in a warning being sent to the driver or to a supervisor of the driver.
The various modules illustrated in
This diagnosis data may be stored in a different table within a local telematics database. When a diagnosis is located within the local telematics database an alert may be sent to a display either within the vehicle or to a standalone display on a device in step 325 of
After operation of the local (or VLA) location module is initiated a location of the vehicle may be identified in step 330 and that location may be stored in the telematics database in step 335 of
Once the most recent location data has been stored, the VLA location module may identify whether the vehicle is still running or in use. Once the vehicle is no longer on or running there may be no further purpose to collect location data as the vehicle is not moving.
While not illustrated in
Functions of the AR module may include polling the local telematics database for most recent location data of the vehicle. This data may include a location and a direction the vehicle. The location and direction may be used to orient data that may be overlaid a display of the vehicle or of an associated device. This process may include accessing image data for the most recent image that may be included in the display of overlaid information. The telematics database may then be polled again for recent information about the vehicle including, but not limited vehicle speed, directional information, sensor data, diagnostic information or identified issues. The context database of the databases 155 of
Once image data and the location/directional data are aligned, other polled data can be overlaid. The processing of overlaying data on to an image or display is well known in the art and can be done as long as the overlaid data has geospatial information associated with it. For example, a point of interest such as a restaurant has a known location and that location can be overlaid on to and image on a display based the location and direction of the image versus the location and direction of the point of interest from the display. The vehicle may then be polled to see if it is still on or running.
After step 335 of
After step 345, program flow may move to steps of the image module 300E of
After step 365 of
The image data received in
When determination step 420 identifies that the image data does not include a face of a known or registered user, program flow may move from step 420 to step 440. Program flow may also move to step 440 when determination step 430 identifies that an identified user is not the primary user. An alert may then be sent to a computing device of the primary user in step 440 to inform the primary user that individuals other than the primary user are attempting to access or use the vehicle.
After the primary user has been sent the alert, a response may be received from the computing device of the primary user. This response may include an indication to allow these other individuals to access or use the vehicle or may identify that the vehicle should be disabled. For example, if an unauthorized person attempts to enter the vehicle to steal it, the owner of the vehicle would be notified and the owner could disable the vehicle. Additionally, access to a vehicle could be controlled for “temporary users” or other known users such as teenagers or friends borrowing your vehicle. When determination step 460 identifies that the response from the primary user indicates that the vehicle should be disabled, program flow may move to step 470 where the vehicle is disabled. The disabling of the vehicle may be performed by sending a special code to a computer at the vehicle that does not allow the vehicle to be accessed. Such an action may also result in the police being called. After step 470 or when determination step 460 identifies that the vehicle can be accessed or used by the other individuals, the flow chart of
An analyzed face or faces from the image data may then be identified by comparing acquired facial data with data stored in a user database. Since each person has unique facial features, facial recognition functions performed in
In another embodiment, a temporary user may be assigned designated times and dates preprogrammed into their profile stored on the user database. These designated times and dates may identify when the temporary user could use the vehicle without sending a message to the primary.
When determination step 520 identifies that the image data include a gesture program flow may move to step 540 where an action associated with the gesture may be performed. After step 540 program flow may move to either step 550 or step 510. Program flow may move to step 550 in an instance when the action corresponds to disabling the vehicle after which the vehicle will be disabled in step 550. This may help driver whose vehicle has been carjacked by a perpetrator. In such an instance, the perpetrator would not be aware of the fact that the driver commanded to vehicle to be disabled and this may lead to perpetrator leaving the vehicle. When program flow moves to step 510 after step 540, additional image data may be retrieved for gesture analysis after the action is performed.
When step 530 identifies that additional image data should be reviewed for gestures, program flow may move to step 510 where additional image data may be retrieved for gesture analysis. When step 530 identifies that additional data should not be retrieved or after step 550, operations of the flow chart of
Other exemplary gestures may include a user moving their open hand from a distance closer to optical sensor to a distance farther away or moving their figures from being close together to farther away, such gestures may represent zooming in on content displayed on a display. As such various gestures may be associated different commends or actions and once a gesture is identified a corresponding action may be performed.
When the driver is present, the image data is then analyzed to determine the user's emotional state in step 610 of
Once the driver's emotional state or stress level is determined, determination step 620 may access an advice database to identify an action that can be taken to help a driver reduce stress in step 620. For example, a moderate stress level may prompt the user to take a few deep breaths or calming music may be played automatically. Whereas a more extreme level of stress may prompt a complete change in the navigation to a less congested traffic area, other suggestions may be provided to the driver. Such a recommendation may include recommending that the driver stop somewhere and rest for a few minutes. In other instances, certain actions the driver can take in the vehicle may be limited.
When the user's emotional state doesn't require any action program flow may move to step 650 where the flow chart of
When the acoustic data is outside a normal acoustic level, then an abnormal acoustic signature or the acoustic data itself may be analyzed in step 730 of
Determination step 830 may identify whether the new data match other data stored at the contextual database. When determination step 830 identifies that there is a match, program flow may move to step 840 of
Either after step 850 or when determination step 830 identifies that the new data did not match other contextual data, program flow may move to step 860, where the flow chart of
Functioning of the “Local Telematics Database” will now be explained with reference to
Table 2 illustrates data that may be stored in a telematics database consistent with the present disclosure. This data may have been collected by the operation of instructions of the VLA telematics module previously discussed. The data stored may include, yet is not limited tool vehicle sensor data such as time, pressure and temperatures, location data, direction, speed, acceleration or de-acceleration rates, fuel levels, fuel consumption rate, and vehicle diagnostic information. Furthermore, VLA Local Telematics Database stores the entire baseline or normal ranges for a vehicle operating at normally. The baseline or normal ranges are used to determine if data from the vehicle is outside normal ranges.
Table 3 illustrates data that may be stored in a contextual database. Table 3 may store information relating to any number of possible contextual events that could occur and associated with the events are a plurality of data points and a suggested action. The contextual event may include but not limited to, any type of vehicle issue, need for maintenance, fuel, or the state of the driver, for example, as the driver been driving too long without a break, etc. A possible data point may include but not limited to any telematics data, location data, image data, driver emotional state data, etc. Furthermore, the action in many cases may be a suggestion to the driver regarding what they should do but, in some embodiments, an automated action could be executed without user interaction. The data in table 2 identifies that certain sets of contextual information, e.g. a high engine temperature may correspond to an identified noise and a high driver stress level. Note also that other a driver experiencing moderate stress in high traffic conditions should be provided with calming music and that a driver experiencing high stress in high traffic conditions should be provided with an alternate route.
A user database consistent with the present disclosure may be stored in a table that cross-reference a user name with a type of user and with a file that includes facial recognition data or with a file that include voice recognition data. This data may identify that John and Jane Smith are both primary drivers and that Sara Smith and Marko Evans are temporary drivers. This data may be used to identify the user by using facial or voice recognition. This data may also be accessed when a person enters a vehicle and it may be used to identify whether an alert should be sent to a computing device when identifying whether the person entering the vehicle should be allowed to access or use the vehicle.
Table 4 illustrates exemplary data that may be stored in an acoustic database. The acoustic database may store different types of data, a first type of data associated with the current acoustic data collected from a vehicle. Some of this collected data may be associated with normal vehicle noises for which no action is required. Other data stored in the acoustic database may be associated with a detected vehicle issue that should result in a recommendation that the driver drive to a service station. A second type of data that maybe stored in the database may be associated with noises of known problems that a vehicle may experience. Each of the items in table 4 are also associated with a recording of acoustic data (acoustic1.dat through acoustic 7.dat). Acoustic data of these known problems may be stored in the acoustic database such that a VLA device may identify a braking or other issue based on a noise that someday may recorded at the vehicle. A noise of a vehicle that sufficiently matches library problem acoustic data may be used to identify a particular problem that subsequently develops at the vehicle.
An image database of the present disclosure may store image data collected from a sensor or database. The data is used for any number of purposes including facial recognition, driver stress levels, etc. This image may also be used for insurance or accident fault identification.
The components shown in
Mass storage device 930, which may be implemented with a magnetic disk drive or an optical disk drive, is a non-volatile storage device for storing data and instructions for use by processor unit 910. Mass storage device 930 can store the system software for implementing embodiments of the present invention for purposes of loading that software into main memory 920.
Portable storage device 940 operates in conjunction with a portable non-volatile storage medium, such as a FLASH memory, compact disk or Digital video disc, to input and output data and code to and from the computer system 900 of
Input devices 960 provide a portion of a user interface. Input devices 960 may include an alpha-numeric keypad, such as a keyboard, for inputting alpha-numeric and other information, or a pointing device, such as a mouse, a trackball, stylus, or cursor direction keys. Additionally, the system 900 as shown in
Display system 970 may include a liquid crystal display (LCD), a plasma display, an organic light-emitting diode (OLED) display, an electronic ink display, a projector-based display, a holographic display, or another suitable display device. Display system 970 receives textual and graphical information, and processes the information for output to the display device. The display system 970 may include multiple-touch touchscreen input capabilities, such as capacitive touch detection, resistive touch detection, surface acoustic wave touch detection, or infrared touch detection. Such touchscreen input capabilities may or may not allow for variable pressure or force detection.
Peripherals 980 may include any type of computer support device to add additional functionality to the computer system. For example, peripheral device(s) 980 may include a modem or a router.
Network interface 995 may include any form of computer interface of a computer, whether that be a wired network or a wireless interface. As such, network interface 995 may be an Ethernet network interface, a BlueTooth™ wireless interface, an 802.11 interface, or a cellular phone interface.
The components contained in the computer system 900 of
The present invention may be implemented in an application that may be operable using a variety of devices. Non-transitory computer-readable storage media refer to any medium or media that participate in providing instructions to a central processing unit (CPU) for execution. Such media can take many forms, including, but not limited to, non-volatile and volatile media such as optical or magnetic disks and dynamic memory, respectively. Common forms of non-transitory computer-readable media include, for example, a floppy disk, a flexible disk, a hard disk, magnetic tape, any other magnetic medium, a CD-ROM disk, digital video disk (DVD), any other optical medium, RAM, PROM, EPROM, a FLASH EPROM, and any other memory chip or cartridge.
While various flow diagrams provided and described above may show a particular order of operations performed by certain embodiments of the invention, it should be understood that such order is exemplary (e.g., alternative embodiments can perform the operations in a different order, combine certain operations, overlap certain operations, etc.).
The foregoing detailed description of the technology herein has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the technology to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. The described embodiments were chosen in order to best explain the principles of the technology and its practical application to thereby enable others skilled in the art to best utilize the technology in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the technology be defined by the claim.
The present application claims the priority benefit of U.S. provisional patent application 62/879,955, filed Jul. 29, 2019, the disclosure of which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5289369 | Hirshberg | Feb 1994 | A |
5893893 | Holt et al. | Apr 1999 | A |
6339745 | Novik | Jan 2002 | B1 |
6963899 | Fernandez et al. | Nov 2005 | B1 |
8234173 | Kumar | Jul 2012 | B1 |
8234216 | Reese et al. | Jul 2012 | B1 |
8468214 | Bourlas et al. | Jun 2013 | B1 |
8694328 | Gormley | Apr 2014 | B1 |
9230379 | Ricci | Jan 2016 | B2 |
9536197 | Penilla et al. | Jan 2017 | B1 |
9996878 | Fox et al. | Jun 2018 | B1 |
10124682 | Tsuchiya | Nov 2018 | B2 |
10134042 | Prasad et al. | Nov 2018 | B1 |
10198877 | Maltsev et al. | Feb 2019 | B1 |
10470025 | Hunt et al. | Nov 2019 | B1 |
10629191 | Cheng et al. | Apr 2020 | B1 |
10791417 | Nicholson et al. | Sep 2020 | B1 |
10940790 | Mazuir | Mar 2021 | B1 |
20010039509 | Dar et al. | Nov 2001 | A1 |
20020111822 | Shimizu et al. | Aug 2002 | A1 |
20030028451 | Ananian | Feb 2003 | A1 |
20030065427 | Funk et al. | Apr 2003 | A1 |
20030088348 | Gustavsson et al. | May 2003 | A1 |
20040139034 | Farmer | Jul 2004 | A1 |
20050075829 | Polimadei | Apr 2005 | A1 |
20070005233 | Pinkus et al. | Jan 2007 | A1 |
20070061057 | Huang et al. | Mar 2007 | A1 |
20070136088 | Farrel | Jun 2007 | A1 |
20070233363 | Rosario et al. | Oct 2007 | A1 |
20080052180 | Lawhorn | Feb 2008 | A1 |
20080119965 | McCrary | May 2008 | A1 |
20090006194 | Sridharan et al. | Jan 2009 | A1 |
20090018770 | Burgess et al. | Jan 2009 | A1 |
20090076949 | Olliphant et al. | Mar 2009 | A1 |
20090222338 | Hamilton et al. | Sep 2009 | A1 |
20100042340 | Piszko | Feb 2010 | A1 |
20100063717 | Proefke et al. | Mar 2010 | A1 |
20100082246 | Crane | Apr 2010 | A1 |
20100106401 | Naito et al. | Apr 2010 | A1 |
20100127847 | Evans et al. | May 2010 | A1 |
20100138146 | Vogt et al. | Jun 2010 | A1 |
20100145609 | Boss et al. | Jun 2010 | A1 |
20100198508 | Tang | Aug 2010 | A1 |
20100217482 | Vogel et al. | Aug 2010 | A1 |
20100228639 | Gindele | Sep 2010 | A1 |
20110112870 | Berg et al. | May 2011 | A1 |
20110191220 | Kidston et al. | Aug 2011 | A1 |
20110224900 | Hiruta et al. | Sep 2011 | A1 |
20110246330 | Tikku et al. | Oct 2011 | A1 |
20120136865 | Blom et al. | May 2012 | A1 |
20120179347 | Aldighieri et al. | Jul 2012 | A1 |
20120271725 | Cheng | Oct 2012 | A1 |
20120323664 | Klems | Dec 2012 | A1 |
20130144471 | Min et al. | Jun 2013 | A1 |
20130179057 | Fischer et al. | Jul 2013 | A1 |
20130261953 | Kiyama et al. | Oct 2013 | A1 |
20130274972 | Kusumi et al. | Oct 2013 | A1 |
20130289837 | Beams et al. | Oct 2013 | A1 |
20130308470 | Bevan et al. | Nov 2013 | A1 |
20140032101 | Pandya et al. | Jan 2014 | A1 |
20140136187 | Wolverton et al. | May 2014 | A1 |
20140188388 | Malahy et al. | Jul 2014 | A1 |
20140199980 | Rao et al. | Jul 2014 | A1 |
20140200038 | Rao et al. | Jul 2014 | A1 |
20140207959 | Kamali et al. | Jul 2014 | A1 |
20140210604 | Kawashima et al. | Jul 2014 | A1 |
20140278056 | Williams et al. | Sep 2014 | A1 |
20140309868 | Ricci | Oct 2014 | A1 |
20140359499 | Cho et al. | Dec 2014 | A1 |
20140372221 | Momin et al. | Dec 2014 | A1 |
20150112730 | Binion et al. | Apr 2015 | A1 |
20150112731 | Binion et al. | Apr 2015 | A1 |
20150112800 | Binion et al. | Apr 2015 | A1 |
20150158393 | Kawano et al. | Jun 2015 | A1 |
20150195678 | Fay et al. | Jul 2015 | A1 |
20150210292 | George-Svahn et al. | Jul 2015 | A1 |
20150213420 | Krishnamurthy et al. | Jul 2015 | A1 |
20150213518 | Krishnamurthy et al. | Jul 2015 | A1 |
20150213519 | Krishnamurthy et al. | Jul 2015 | A1 |
20150278933 | Barfield | Oct 2015 | A1 |
20150310451 | Plagens et al. | Oct 2015 | A1 |
20150363986 | Hoyos | Dec 2015 | A1 |
20160311410 | Donzis et al. | Oct 2016 | A1 |
20160349075 | Son | Dec 2016 | A1 |
20170067747 | Ricci | Mar 2017 | A1 |
20170103327 | Penilla et al. | Apr 2017 | A1 |
20170256106 | Hino | Sep 2017 | A1 |
20180031381 | Delaruelle | Feb 2018 | A1 |
20180143029 | Nikulin et al. | May 2018 | A1 |
20180286245 | Obaidi | Oct 2018 | A1 |
20180300337 | Thomas et al. | Oct 2018 | A1 |
20180350167 | Ekkizogloy et al. | Dec 2018 | A1 |
20190084420 | Kim et al. | Mar 2019 | A1 |
20190178661 | Sakaida et al. | Jun 2019 | A1 |
20190184774 | Okada | Jun 2019 | A1 |
20190189132 | Viswanathan | Jun 2019 | A1 |
20190193681 | Ito | Jun 2019 | A1 |
20190316922 | Petersen | Oct 2019 | A1 |
20190318035 | Blanco et al. | Oct 2019 | A1 |
20200027283 | Nishikawa | Jan 2020 | A1 |
20200055518 | Johnson | Feb 2020 | A1 |
20200092689 | Zhang et al. | Mar 2020 | A1 |
20200193549 | Pedersen et al. | Jun 2020 | A1 |
20200211553 | Bohl et al. | Jul 2020 | A1 |
20200238952 | Lindsay | Jul 2020 | A1 |
20200247195 | Kona et al. | Aug 2020 | A1 |
20200250696 | Cordell | Aug 2020 | A1 |
20200250898 | Rafferty et al. | Aug 2020 | A1 |
20210081863 | Gonzalez | Mar 2021 | A1 |
20210082207 | Gonzalez | Mar 2021 | A1 |
20210173377 | Laftchiev et al. | Jun 2021 | A1 |
20210217409 | Choi et al. | Jul 2021 | A1 |
20210404833 | Padeimaite et al. | Dec 2021 | A1 |
Number | Date | Country |
---|---|---|
2680523 | Feb 2005 | CN |
107590763 | Jan 2018 | CN |
WO 2020091806 | May 2020 | WO |
Entry |
---|
U.S. Appl. No. 16/940,173 Final Office Action dated Nov. 9, 2021. |
AirWire Connected CAR IoT Device, AirWire Technologies, Sep. 2016. |
AirWire Technologies and Reliance Jio Partner to Bring Connected Car Apps and Services to India, Business Wire, Feb. 26, 2017. https://www.businesswire.com/news/home/20170226005089/en/AirWire-Technologies-and-Reliance-Jio-Partner-to-Bring-Connected-Car-Apps-and-Services-to-India (Year: 2017). |
U.S. Appl. No. 16/940,173 Office Action dated Jun. 28, 2021. |
U.S. Appl. No. 16/940,173 Final Office Action mailed Jul. 6, 2023. |
U.S. Appl. No. 16/940,173 Office Action mailed Aug. 11, 2022. |
U.S. Appl. No. 16/942,679 Final Office Action mailed Jun. 20, 2023. |
U.S. Appl. No. 16/942,679 Office Action mailed Aug. 11, 2022. |
Macro, computer science, wikipedia, archives org Feb. 11, 2020 http://web.archive.org/web/20200211082902/https://en.wikipedia.org/wiki/Macro_(computer_science) (Year: 2020). |
U.S. Appl. No. 16/940,173 Office Action mailed Apr. 16, 2024. |
Number | Date | Country | |
---|---|---|---|
20210078539 A1 | Mar 2021 | US |
Number | Date | Country | |
---|---|---|---|
62879955 | Jul 2019 | US |