The present disclosure relates to road network congestion, and more particularly to a system and a process using real-time High Speed Vehicle Telemetry data (HSVT data) collected from a city-scale of motor vehicles to identify root causes of road congestion for mitigating the same.
Transportation agencies often lack comprehensive knowledge of root causes of road congestion and an associated effect on a transportation system. Moreover, transportation agencies can lack knowledge to classify the types of road congestion active in different locations, such as recurring congestion and non-recurring congestion. Municipalities currently typically retain civil engineering consultants to conduct annual reviews and analyses to evaluate and determine fundamental roadway infrastructure faults and capacity limitations. These consultants can use partially deployed static sensors placed along roadways to conduct the annual reviews. However, a drawback of these static sensors is that the collection of data is limited in coverage (both spatially and temporally), can be time consuming and/or expensive to deploy, and often lead to mistaken recommendations due to a lack of up-to-date data.
Thus, while existing systems for mitigating road congestion achieve their intended purpose, there is a need for a new and improved system that addresses these issues.
According to several aspects of the present disclosure, a system is provided for identifying, classifying, mitigating, and root-causing a road network congestion. The system includes a plurality of motor vehicles positioned in a plurality of associated locations in a road network. Each motor vehicle has one or more sensors for generating an input. Each motor vehicle further has a Telematics Control Unit (TCU) for generating at least one location signal for a location of the associated motor vehicle and at least one event signal for an event related to the associated motor vehicle, with the at least one location signal and the at least one event signal being corresponding to a High Speed Vehicle Telemetry Data (HSVT data) based on the input from the at least one sensor. The system further includes a display device and a computer, which communicates with the display device and the TCU of the associated motor vehicles. The computer includes one or more processors coupled to the TCU of the associated motor vehicles and receives the HSVT data from the TCU of the associated motor vehicles. The computer further includes a non-transitory computer readable storage medium (CRM) including instructions, such that the processor is programmed to identify the road network congestion at a current time slot based on the HSVT data. The processor is further programmed to determine that the road network congestion is a recurring congestion or a non-recurring congestion based on the HSVT data over a period of time. The processor is further programmed to determine a source of the recurring congestion and a cause of the non-recurring congestion. The processor is further programmed to generate a notification signal associated with the recurring congestion, the source and the location of the recurring congestion, the non-recurring congestion, and/or the cause and the location of the non-recurring congestion, such that the display device displays an associated one of the recurring congestion, the source and the location of the recurring congestion, the non-recurring congestion, and the cause and the location of the non-recurring congestion, in response to the display device receiving the notification signal from the processor.
In one aspect, the sensor is at least one of a GPS unit, a thermocouple, a humidity sensor, a brake sensor, an airbag sensor, an ADAS module, a perception sensor suite, and a motion sensor communicating with the TCU.
In another aspect, the processor is programmed to use a causal inference model to determine a causal relationship between a causal factor in a first location at a first time slot and the non-recurring congestion in a second location at a second time slot.
In another aspect, the processor is further programmed to use the causal inference model according to:
Y(pi,t)=Σk=1PmkY(pi,t−k)+Σk=0PnkX(pj,t−k)+Σk=0POkε(pi,t−k)+φ
where Y(pi, t) represents the non-recurring congestion in the location pi at the time slot t; where Σk=1PmkY(pi, t−k) represents an historical congestion in location pi at [t−K, t−1]; where mk represents a weighted vector function for element Y(pi, t−k) at time slot t−k; where Y represents a non-recurring congestion vector in an historical data; where k represents a kth historical time slot before a current time slot t; where Σk=0PnkX(pj, t−k) represents an historical non-recurring congestion in location pj at [t−K, t]; where nk is associated with at least one causal factor; where X represents the causal factor that contributes to a formation of a non-recurring congestion event Y; where Σk=0POkε(pi, t−k) represents an autocorrelation function between a non-recurring congestion event vector Y and a causing factor vector X, which is normally to be assumed as a normal (Gaussian) distribution N(O, σ2); where Ok represents a weighted function for an autocorrelation function element ε(pi, t−k); where k represents the kth historical time slot before the current time slot t; and where φ represents a random Gaussian noise.
In another aspect, the processor is further programmed to determine that the causal factor in the first location at the first time slot causes the non-recurring congestion in the second location at the second time slot according to a statistical equation:
where δ(X→Y) represents a causality determination function to determine that the non-recurring congestion event Y is caused by a contributing event X; where ƒ(|n|, |o|) represents a function operation between a weighted vector n and a weighted vector o; where n represents a weighted vector of the contributing event vector; where o represents a weighted vector of the autocorrelation function between the contributing event vector and the non-recurring congestion event; where g(|m|) represents a function operation of the weighted vector m; and where m represents a weighted vector of the non-recurring congestion event.
In another aspect, the processor is further programmed to determine the source of the recurring congestion by: using an Origin-Destination Matrix (OD Matrix) derived from an historical HSVT data to determine a first route capacity estimation for a road link; using a Direct Measurement from a collection of HSVT data, e.g., collected in real-time or over a predetermined amount of time such as a full day, to determine a second route capacity estimation for the road link; comparing the first and second route capacity estimations; and calibrating the processor based on a comparison between the first and second route capacity estimations.
In another aspect, the processor is programmed to create and use the OD Matrix by: determining a Spectral Temporal-Spatio Data Extrapolation (Spectral T-S Data Extrapolation) of the historical HSVT data; determining the OD Matrix based on the Spectral T-S Data Extrapolation; determining a Route Assignment based on the OD Matrix; and determining the first route capacity estimation based on the Route Assignment and the OD Matrix.
In another aspect, the processor is further programmed to generate a Partial Origin Destination Matrix (Partial OD Matrix) and a Partial Trajectory Data based on the HSVT data. The processor is further programmed to determine the OD matrix by: determining an Origin Destination Matrix Estimation (OD Matrix Estimation) based on the Partial Trajectory Data and the HSVT data; determining a Dynamic Route Assignment and Road Capacity Estimation based on the OD Matrix Estimation; and determining a Static Route Assignment and Road Capacity Estimation based on the Partial Trajectory Data and the HSVT data.
In another aspect, the processor is further programmed to determine the Spectral T-S Data Extrapolation according to a Spectral Decomposition:
In another aspect, the processor is further programmed to determine the Spectral T-S Data Extrapolation according to an Object Function Formulation:
In another aspect, the processor is further programmed to use an iterative approach to decrease a Mean Square Error (MSE) between the Spectral T-S Data Extrapolation and a ground truth.
According to several aspects of the present disclosure, a computer of a system is provided for identifying, classifying, mitigating, and root-causing a road network congestion. The system includes a plurality of motor vehicles positioned in a plurality of locations in a road network. Each motor vehicle includes one or more sensors for generating an input. Each motor vehicle further includes a Telematics Control Unit (TCU), which generates one or more location signals for a location of the associated motor vehicle and one or more event signals for an event related to the associated motor vehicle, with the location signal and the event signal being corresponding to a High Speed Vehicle Telemetry Data (HSVT data) based on the input from the sensor. The computer includes one or more processors coupled to the TCU of the associated motor vehicles, and the processor receives the HSVT data from the TCUs. The computer further includes a non-transitory computer readable storage medium (CRM) including instructions, such that the processor is programmed to identify the road network congestion at a current time slot based on the HSVT data. The processor is further programmed to determine that the road network congestion is a recurring congestion or a non-recurring congestion based on the HSVT data over a period of time. The processor is further programmed to determine a source of the recurring congestion and a cause of the non-recurring congestion. The processor is further programmed to generate a notification signal associated with the recurring congestion, the source of the recurring congestion, the non-recurring congestion, and/or the cause of the non-recurring congestion, such that the display device displays an associated one of the recurring congestion, the source of the recurring congestion, the non-recurring congestion, and the cause of the non-recurring congestion, in response to the display device receiving the notification signal from the processor.
In one aspect, the processor is further programmed to use a causal inference model to determine a causal relationship between the causal factor in the first location at the first time slot and the non-recurring congestion in the second location at the second time slot.
In another aspect, the processor is further programmed to use the causal inference model according to:
Y(pi,t)=Σk=1PmkY(pi,t−k)+Σk=0PnkX(pj,t−k)+Σk=0POkε(pi,t−k)+φ
where Y(pi, t) represents the non-recurring congestion in the location pi at the time slot t; where Σk=1PmkY(pi, t−k) represents an historical congestion in location pi at [t−K, t−1]; where mk represents a weighted vector function for element Y(pi, t−k) at time slot t−k; where Y represents a non-recurring congestion vector in an historical data; where k represents a kth historical time slot before a current time slot t; where Σk=0PnkX(pj, t−k) represents an historical non-recurring congestion in location pj at [t−K, t]; where nk is associated with at least one causal factor; where X represents the causal factor that contributes to a formation of a non-recurring congestion event Y; where Σk=0POkε(pi, t−k) represents an autocorrelation function between a non-recurring congestion event vector Y and a causing factor vector X, which is normally to be assumed as a normal (Gaussian) distribution N(O, σ2); where Ok represents a weighted function for an autocorrelation function element ε(pi, t−k); where k represents the kth historical time slot before the current time slot t; and where φ represents a random Gaussian noise.
In another aspect, the processor is further programmed to determine that the causal factor in the first location at the first time slot causes the non-recurring congestion in the second location at the second time slot according to a statistical equation:
where δ(X→Y) represents a causality determination function to determine that the non-recurring congestion event Y is caused by a contributing event X; where ƒ(|n|, |o|) represents a function operation between a weighted vector n and a weighted vector o; where n represents a weighted vector of the contributing event vector; where o represents a weighted vector of the autocorrelation function between the contributing event vector and the non-recurring congestion event; where g(|m|) represents a function operation of the weighted vector m; and where m represents a weighted vector of the non-recurring congestion event.
In another aspect, the processor is further programmed to determine the source of the recurring congestion by: using an Origin-Destination Matrix (OD Matrix) derived from an historical HSVT data to determine a first route capacity estimation for a road link; using a Direct Measurement from a collection of HSVT data to determine a second route capacity estimation for the road link; comparing the first and second route capacity estimations; and calibrating the processor based on a comparison between the first and second route capacity estimations.
According to several aspects of the present disclosure, a process of operating a system for identifying, classifying, mitigating, and root-causing a road network congestion. The system includes a plurality of motor vehicles positioned in a plurality of locations in a road network. Each motor vehicle has one or more sensors for generating an input. Each motor vehicle further includes a Telematics Control Unit (TCU), which generates one or more location signals for a location of the associated motor vehicle and one or more event signals for an event related to the associated motor vehicle, with the location signal and the event signal being corresponding to a High Speed Vehicle Telemetry Data (HSVT data) based on the input from the sensor. The system further includes a computer having one or more processors coupled to the TCU of the associated motor vehicles. The computer further has a non-transitory computer readable storage medium (CRM) including instructions. The process includes identifying, using the processor, the road network congestion at a current time slot based on the HSVT data. The process further includes determining, using the processor, that the road network congestion is a recurring congestion and/or a non-recurring congestion based on the HSVT data over a period of time. The process further includes determining, using the processor, a source of the recurring congestion or a cause of the non-recurring congestion. The process further includes generating, using the processor, a notification signal associated with the recurring congestion, the source of the recurring congestion, the non-recurring congestion, or the cause of the non-recurring congestion, such that the display device displays an associated one of the recurring congestion, the source of the recurring congestion, the non-recurring congestion, and the cause of the non-recurring congestion, in response to the display device receiving the notification signal from the processor.
In one aspect, the process further includes using, with the processor, a causal inference model to determine a causal relationship between a causal factor in a first location at the first time slot and the non-recurring congestion in a second location at a second time slot.
In another aspect, the process further includes using, with the processor, the causal inference model according to:
Y(pi,t)=Σk=1PmkY(pi,t−k)+Σk=0PnkX(pj,t−k)+Σk=0POkε(pi,t−k)+φ
where Y(pi, t) represents the non-recurring congestion in the location pi at the time slot t; where Σk=1PmkY(pi, t−k) represents an historical congestion in location pi at [t−K, t−1]; where mk represents a weighted vector function for element Y(pi, t−k) at time slot t−k; where Y represents a non-recurring congestion vector in an historical data; where k represents a kth historical time slot before a current time slot t; where Σk=0PnkX(pj, t−k) represents an historical non-recurring congestion in location pj at [t−K, t]; where nk is associated with at least one causal factor; where X represents the causal factor that contributes to a formation of a non-recurring congestion event Y; where Σk=0POkε(pi, t−k) represents an autocorrelation function between a non-recurring congestion event vector Y and a causing factor vector X, which is normally to be assumed as a normal (Gaussian) distribution N(O, σ2); where Ok represents a weighted function for an autocorrelation function element ε(pi, t−k); where k represents the kth historical time slot before the current time slot t; and where φ represents a random Gaussian noise.
where δ(X→Y) represents a causality determination function to determine that the non-recurring congestion event Y is caused by a contributing event X; where ƒ(|n|, |o|) represents a function operation between a weighted vector n and a weighted vector o; where n represents a weighted vector of the contributing event vector; where o represents a weighted vector of the autocorrelation function between the contributing event vector and the non-recurring congestion event; where φ|m| represents a function operation of the weighted vector m; and where m represents a weighted vector of the non-recurring congestion event.
In another aspect, the process further includes the processor determining the source of the recurring congestion. The process further includes the processor using an Origin-Destination Matrix (OD Matrix) derived from an historical HSVT data to determine a first route capacity estimation for a road link. The process further includes the processor using a Direct Measurement from a collection of HSVT data to determine a second route capacity estimation for the road link. The process further includes the processor comparing the first and second route capacity estimations. The process further includes the processor being calibrated based on a comparison between the first and second route capacity estimations.
Further areas of applicability will become apparent from the description provided herein. It should be understood that the description and specific examples are intended for purposes of illustration only and are not intended to limit the scope of the present disclosure.
The drawings described herein are for illustration purposes only and are not intended to limit the scope of the present disclosure in any way.
The following description is merely exemplary in nature and is not intended to limit the present disclosure, application, or uses. Although the drawings represent examples, the drawings are not necessarily to scale and certain features may be exaggerated to better illustrate and explain a particular aspect of an illustrative example. Any one or more of these aspects can be used alone or in combination within one another. Further, the exemplary illustrations described herein are not intended to be exhaustive or otherwise limiting or restricting to the precise form and configuration shown in the drawings and disclosed in the following detailed description. Exemplary illustrations are described in detail by referring to the drawings as follows:
Referring to
In this non-limiting example, the system 100 includes the motor vehicles 102 positioned in a plurality of locations in a road network 103 for travelling along associated road edges 104 and travelling through associated road intersections 106. As described in detail below, the system 100 can determine a congested intersection and a congested edge connected to one another form a first subgraph 108 with road congestion, and the system 100 can further determine two congested edges connected to one another form a second subgraph 110 with road congestion.
Referring to
As described in detail below, the system 100 can include a local road model with Peer-to-Peer (P2P) or edge computing that utilizes the TCU 112 of motor vehicles communicating with the TCU 112 of other motor vehicles 102. Edge computing is a distributed computing paradigm that brings computation and data storage closer to the sources of data to improve response times and save bandwidth. The system 100 can further include cloud computing with a global road model that utilizes a remote computer 128 or server. The computer 128 includes one or more processors 134 and a non-transitory computer readable storage medium 132 (“CRM”) including instructions, such that the processor 134 is programmed to receive the HSVT data from the sensors 113 of the associated motor vehicles 102.
The processor 134 is further programmed to identify the road network congestion at a current time slot based on the HSVT data. More specifically, the processor 134 is further programmed to determine that the road network congestion is at least one of a recurring congestion and a non-recurring congestion based on an analysis of the HSVT data over time (e.g., days, weeks, months, etc.) to distinguish if observed congestion is part of a repeated or recurring pattern (by location, time of day, day of week, etc.). The processor 134 is programmed to use the causal inference model to determine a causal relationship between a causal factor in a first location at a first time slot and the non-recurring congestion in a second location at a second time slot according to:
Y(pi,t)=Σk=1PmkY(pi,t−k)+Σk=0PnkX(pj,t−k)+Σk=0POkε(pi,t−k)+φ Eqn. 1
where non-limiting examples of the casual factors can include, but are not limited to, weather and related road surface conditions, traffic accidents, construction zones, shock waves, police events, special sport/public/concert events, or other temporary road/lane closures; where Y(pi, t) represents the non-recurring congestion in the location pi at the time slot t; where k=1 mkY(pi, t−k) represents an historical congestion in location pi at [t−K, t−1]; where mk represents a weighted vector function for element Y(pi, t−k) at time slot t−k; where Y represents a non-recurring congestion vector in an historical data; where k represents a kth historical time slot before a current time slot t; where Σk=0PnkX(pj, t−k) represents an historical non-recurring congestion in location pj at [t−K, t]; where nk is associated with at least one causal factor; where X represents the causal factor that contributes to a formation of a non-recurring congestion event Y; where Σk=0POkε(pi, t−k) represents an autocorrelation function between a non-recurring congestion event vector Y and a causing factor vector X, which is normally to be assumed as a normal (Gaussian) distribution N(O, σ2); where Ok represents a weighted function for an autocorrelation function element ε(pi, t−k); where k represents the kth historical time slot before the current time slot t; and where φ represents a random Gaussian noise. A person of ordinary skill in the art will understand that Eqn. 1 is one non-limiting example to show how the non-recurring congestion event could be modeled as a weighted summation of several impacting factors including: the historical non-recurring congestion event, the contributing factor event which might cause the non-recurring congestion event, the autocorrelation between non-recurring congestion event and the contributing factor event which might cause the non-recurring congestion event, as well as the random Gaussian noise. It is contemplated that other non-limiting examples or equivalents of Eqn. 1 or other modeling approaches could be used to model the non-recurring congestion event.
The processor 134 is further programmed to determine a source and a location of the recurring congestion and a cause and a location of the non-recurring congestion. The processor 134 is further programmed to determine that the causal factor in the first location at the first time slot causes the non-recurring congestion in the second location at the second time slot according to a statistical equation:
where δ(X→Y) represents a causality determination function to determine that the non-recurring congestion event Y is caused by a contributing event X (such as weather condition, construction zone, police event etc.); where ƒ(|n|, |o|) represents a function operation between a weighted vector n and a weighted vector o; where n represents a weighted vector of the contributing event vector (as described in Eqn. 1); where o represents a weighted vector of the autocorrelation function between the contributing event vector and the non-recurring congestion event (as described in Eqn. 1); where g(|m|) represents a function operation of the weighted vector m; and where m represents a weighted vector of the non-recurring congestion event.
A person of ordinary skill in the art will appreciate that Eqn. 2 is one non-limiting example to show whether the non-recurring congestion event is caused by a given contributing factor event that could be determined by the operations of weighted factors associated with several impacting factors, including: an historical non-recurring congestion event, a contributing factor event which might cause the non-recurring congestion event, an autocorrelation between non-recurring congestion event and the contributing factor event which can cause the non-recurring congestion event, as well as the random Gaussian noise. It is contemplated that other equivalents or variants of Eqn. 2 or other modeling approaches could be used to determine that the non-recurring congestion event Y is caused by the contributing event X.
The processor 134 is further programmed to determine the source of the recurring congestion by: using an Origin-Destination Matrix (OD Matrix) derived from an historical HSVT data to determine a first route capacity estimation for a road link; using a Direct Measurement from a collection of HSVT data (e.g., historical traffic volumes and speeds) to determine a second route capacity estimation for the road link; comparing the first and second route capacity estimations; and calibrating the processor based on a comparison between the first and second route capacity estimations.
The processor 134 is further programmed to create and use the OD Matrix by: determining a Spectral Temporal-Spatio Data Extrapolation (Spectral T-S Data Extrapolation) of the historical HSVT data; determining the OD Matrix, e.g., a city-wide OD Matrix or a region-wide OD Matrix, based on the Spectral T-S Data Extrapolation; determining a Route Assignment based on the OD Matrix; and determining the first route capacity estimation based on the Route Assignment and the OD Matrix.
The processor 134 is further programmed to generate a Partial Origin Destination Matrix (Partial OD Matrix) and a Partial Trajectory Data based on the HSVT data, and the processor is further programmed to determine the OD matrix by: determining an Origin Destination Matrix Estimation (OD Matrix Estimation) based on the Partial Trajectory Data and the HSVT data; determining a Dynamic Route Assignment and Road Capacity Estimation based on the OD Matrix Estimation; and determining a Static Route Assignment and Road Capacity Estimation based on the Partial Trajectory Data and the HSVT data. The processor 134 is further programmed to determine the Spectral T-S Data Extrapolation according to a Spectral Decomposition, such as principle component analysis (PCA) or singular vector decomposition (SVD):
The processor 134 is further programmed to determine the Spectral T-S Data Extrapolation according to an Object Function Formulation:
A person of ordinary skill in the art will appreciate that the above equations are a non-limiting examples to show spectral decomposition method that can assist with conducting the data extrapolation using partial OD matrix data. However, it is contemplated that equivalents or variants of these equations or other modeling approaches using spectral decomposition and reconstruction could be used.
The processor 134 is further programmed to use an iterative approach to decrease a Mean Square Error (MSE) between the Spectral T-S Data Extrapolation and a ground truth.
The processor 134 is further programmed to generate a notification signal associated with at least one location of recurring congestion, the source of the recurring congestion, the location of non-recurring congestion, and the cause of the non-recurring congestion, such that the display device displays the location of recurring congestion, the source of the recurring congestion, the location of non-recurring congestion, and the cause of the non-recurring congestion based on the HSVT data in response to the display device receiving the notification signal from the processor. As disclosed in U.S. patent application Ser. No. 17/575,017, (the entire contents of which are incorporated by reference), congestion is a system state identified through comparison of observed speeds and travel times on a road link versus a referenced non-congestion state derived using historical HSVT data and formally occurring when the observed traffic volume or derived flow rate reaches the road link capacity.
In one non-limiting example, the display device can be a display screen in the motor vehicle for informing the vehicle occupant of the road congestion, such that the occupant can drive the motor vehicle along an alternate route that does not have road congestion. In another non-limiting example, the display device can be a display screen in an autonomous vehicle for informing the vehicle occupant of the road congestion and indicating that the autonomous vehicle will be driven along the alternate route without the road congestion. In still another non-limiting example, the display device can be a monitor of a desktop computer utilized by a municipality for analyzing road congestion and modifying traffic control infrastructure to better manage city traffic, sending first responders to an accident event, sending snow plow trucks to clear locations of road network covered with snow, or taking any other suitable action.
Referring now to
At block 204, the process 200 further includes determining, using the processor 134, that the road network congestion is at least one of a recurring congestion and a non-recurring congestion condition based on the HSVT data.
At block 206, the process 200 further includes determining, using the processor 134, at least one of a source of the recurring congestion and a cause of the non-recurring congestion. More specifically, the process 200 can include using, with the processor 134, a causal inference model to determine a causal relationship between a causal factor in a first location at the first time slot and the non-recurring congestion in a second location at a second time slot. The process 200 can include using, with the processor 134, the causal inference model according to Equation 1 above:
The process 200 further includes determining, with the processor 134, that the causal factor in the first location at the first time slot causes the non-recurring congestion in the second location at the second time slot according to Equation 2 above.
The process 200 further includes determining, with the processor 134, the source of the recurring congestion by using, with the processor, an Origin-Destination Matrix (OD Matrix) to determine a first route capacity estimation for a road link; using, with the processor, a Direct Measurement to determine a second route capacity estimation for the road link; comparing, with the processor, the first and second route capacity estimations; and calibrating, with the processor, the processor based on a comparison between the first and second route capacity estimations.
At block 208, the process 200 further includes generating, using the processor 134, a notification signal associated with the recurring congestion, the source of the recurring congestion, the non-recurring congestion, and/or the cause of the non-recurring congestion. The display device 136 displays an associated one of the recurring congestion, the source of the recurring congestion, the non-recurring congestion, and the cause of the non-recurring congestion based on the HSVT data, in response to the display device receiving the notification signal from the processor.
Computers and computing devices generally include computer executable instructions, where the instructions may be executable by one or more computing devices such as those listed above. Computer executable instructions may be compiled or interpreted from computer programs created using a variety of programming languages and/or technologies, including, without limitation, and either alone or in combination, JAVA, C, C++, MATLAB, SIMUEDGE, STATEFLOW, VISUAL BASIC, JAVA SCRIPT, PERL, HTML, TENSORFLOW, PYTHON, PYTORCH, KERAS, etc. Some of these applications may be compiled and executed on a virtual machine, such as the JAVA virtual machine, the DALVIK virtual machine, or the like. In general, a processor (e.g., a microprocessor) receives instructions, e.g., from a memory, a computer readable medium, etc., and executes these instructions, thereby performing one or more processes, including one or more of the processes described herein. Such instructions and other data may be stored and transmitted using a variety of computer readable media. A file in a computing device is generally a collection of data stored on a computer readable medium, such as a storage medium, a random-access memory, etc.
The CRM (also referred to as a processor readable medium) participates in providing data (e.g., instructions) that may be read by a computer (e.g., by a processor of a computer). Such a medium may take many forms, including, but not limited to, non-volatile media and volatile media. Non-volatile media may include, for example, optical or magnetic disks and other persistent memory. Volatile media may include, for example, dynamic random-access memory (DRAM), which typically constitutes a main memory. Such instructions may be transmitted by one or more transmission media, including coaxial cables, copper wire and fiber optics, including the wires that comprise a system bus coupled to a processor of an ECU. Common forms of computer readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD ROM, DVD, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH EEPROM, any other memory chip or cartridge, or any other medium from which a computer can read.
In some examples, system elements may be implemented as computer readable instructions (e.g., software) on one or more computing devices, stored on computer readable media associated therewith (e.g., disks, memories, etc.). A computer program product may comprise such instructions stored on computer readable media for carrying out the functions described herein.
With regard to the media, processes, systems, methods, heuristics, etc. described herein, it should be understood that, although the steps of such processes, etc. have been described as occurring according to a certain ordered sequence, such processes may be practiced with the described steps performed in an order other than the order described herein. It further should be understood that certain steps may be performed simultaneously, that other steps may be added, or that certain steps described herein may be omitted. In other words, the descriptions of processes herein are provided for the purpose of illustrating certain embodiments and should in no way be construed so as to limit the claims.
Accordingly, it is to be understood that the above description is intended to be illustrative and not restrictive. Many embodiments and applications other than the examples provided would be apparent to those of skill in the art upon reading the above description. The scope of the invention should be determined, not with reference to the above description, but should instead be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled. It is anticipated and intended that future developments will occur in the arts discussed herein, and that the disclosed systems and methods will be incorporated into such future embodiments. In sum, it should be understood that the invention is capable of modification and variation and is limited only by the following claims.
All terms used in the claims are intended to be given their plain and ordinary meanings as understood by those skilled in the art unless an explicit indication to the contrary in made herein. In particular, use of the singular articles such as “a,” “the,” “said,” etc. should be read to recite one or more of the indicated elements unless a claim recites an explicit limitation to the contrary.
This application is a continuation-in-part of prior U.S. patent application Ser. No. 17/575,017, filed on Jan. 13, 2022, the entire contents of which are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 17575017 | Jan 2022 | US |
Child | 17581528 | US |