The following relates to the parking occupancy forecasting and guidance arts, and more generally to system state forecasting over short time horizons e.g. on the order of 1-20 minutes in some tasks, and to related arts.
In a common task, parking occupancy forecasting is desirably performed on a short time horizon of, for example, 2-10 minutes. As other illustrative tasks, it may be desired to forecast the number of jobs at a particular stage of a process in a print shop, or the number of people waiting in an emergency medical facility on a time scale over which it is possible to redeploy resources. Frequently, continuous time (semi-)Markov models are applied for such purposes. In these approaches, predictions are given by computing matrix exponentials. However, real-world systems are often more variable than such models predict. For instance, in parking occupancy forecasting, there may be variation in parking demand from day-to-day, and/or parking sensor observations may be subject to variable delays.
In some embodiments disclosed herein, a parking guidance device comprises an electronic processor and a non-transitory storage medium operatively connected with the electronic processor and storing instructions readable and executable by the electronic processor to perform a parking guidance method. The parking guidance method suitably includes: receiving, at the electronic processor, parking event data acquired by parking sensors of a parking facility; constructing a current occupancy state i for the parking facility at a time t from the received parking event data wherein the current occupancy state estimates a fraction of parking spaces of the parking facility occupied at the time t; computing occupancy state probabilities for the parking facility at a future time t+s using the matrix quantity (ξ)·expm(Qξs) where expm( . . . ) denotes the matrix exponential, Q is a generator matrix, and ξ is a random variable; generating parking guidance information based at least on the computed occupancy state probabilities; and transmitting the parking guidance information to an electronic device other than the electronic processor.
In some embodiments disclosed herein, a non-transitory storage medium stores instructions readable and executable by an electronic processor to perform a forecasting method comprising: receiving, at the electronic processor, data characterizing a system; constructing a current state i of the system at a time t from the received data; constructing a current state i of the system at a time t from the received data; computing probabilities pij of the state of the system at a future time t+s where pij is the probability that the system is in state j at the future time t+s and pij is computed to have a value given by pij=(ξ) [expm(Qξs)]ij where expm( . . . ) denotes the matrix exponential, Q is a generator matrix, ξ is a random variable having a non-negative probability density function, and [expm(Qξs)]ij denotes element (i,j) of the matrix quantity (ξ)·expm(Qξs); and generating a forecast state of the system at the future time t+s based on the computed probabilities pi.
In some embodiments disclosed herein, a parking guidance method is disclosed. Parking event data acquired by parking sensors of a parking facility is received at an electronic processor. The electronic processor reads and executes instructions stored on a non-transitory storage medium to perform operations including: constructing a current occupancy state i for the parking facility at a time t from the received parking event data wherein the current occupancy state estimates the fraction of occupied parking spaces of the parking facility at the time t; computing occupancy state probabilities for the parking facility at a future time t+s using a continuous-time Markov chain model modified by multiplying the time s input to the model by a random variable ξ and scaling the occupancy state probabilities by an expectation of the random variable ξ; and generating parking guidance information based at least on the computed occupancy state probabilities. The parking guidance information is transmitted to an electronic device other than the electronic processor.
In some embodiments disclosed herein, forecasting is performed using a likelihood function based on matrix powers to forecast a process that is more variable than suggested by a Markov model. This provides a simple and natural formula which captures extra variability.
Illustrative embodiments described herein are directed to parking occupancy forecasting for a parking facility, such as an open parking lot, an enclosed parking garage, a streetside parking block, or so forth, and to higher level tasks leveraging such occupancy forecasting such as providing parking facility recommendations to a vehicle navigator device, operating a “Lot full” sign of a parking facility, or so forth. These are merely illustrative tasks, and it will be appreciated that the system state forecasting techniques disclosed herein may be applied to diverse applications, e.g. other tasks benefiting from accurate parking occupancy forecasts, or tasks employing forecasting of the future state of some other type of system, such as the number of queued print jobs at a print shop, or forecasting the waiting list for an Emergency Medical Department, or so forth.
With reference to
To provide parking event data for use in parking occupancy forecasting, at least a portion of the parking spaces are monitored by parking sensors S. In the illustrative example, only even-spaced parking spaces are monitored by respective parking sensors S—this approach reduces the cost of installing and maintaining the parking sensors S. In the illustrative example with even-numbered parking spaces monitored by the parking sensors S it follows that one-half of the parking spaces are monitored; in other embodiments, a greater or lesser fraction of parking spaces may be monitored. In general, monitoring one-half or fewer fo the parking spaces is likely to provide substantial sensor cost savings. The parking sensors S may monitor actual occupancy of a parking space, e.g. outputting “1” if the space is occupied or “0” if unoccupied. An example of such a parking sensor is a weight-based parking sensor that is activated by the weight of a vehicle occupying the parking space. Alternatively, the parking sensors S may monitor parking arrival and departure events, for example using motion detection sensors. It will be appreciated that in considering these two examples, the weight-based occupancy sensors are likely to be more accurate but much costly to install and difficult to retrofit to an existing parking facility (since doing so entails installing the weight sensors underneath the concrete or other lot surface). By contrast, motion detection sensors are likely to be less expensive to install and are amenable to retrofit installation; however, they are more likely to produce erroneous sensor data, e.g. due to detection of spurious motion due to passing vehicles or persons.
In a typical setup, a sensors reader 78 is operatively connected to receive parking event data (e.g. occupancy data from weight-based occupancy sensors, or arrival or departure events from motion detection sensors) from the parking sensors. The sensors reader 78 may be wired to the sensors S, or may be in wireless communication via a local WiFi or other wireless data communication network. In the interest of data collection efficiency, the sensors reader 78 is typically disposed on the premises of, or closely proximate to, the parking facility 60. Nonetheless, depending upon the communication pathway and the processing capacity of the sensors reader 78, there may be time delays and potentially errors introduced by this data gathering process.
The parking event data acquired by the parking sensors S and the sensors reader 78 are communicated to a parking guidance forecasting server 80. Depending upon the task to be performed, this server 80 may be located locally at the parking facility 60, or may be remotely located. For example, if the only task to be performed by the parking guidance forecasting server 80 is to operate the “Lot full” sign 76, then local placement may be appropriate (indeed, in such an embodiment it may be practical to integrate the sensors reader with the forecasting server as a single component). On the other hand, if the parking guidance forecasting server 80 has a wider scope of application, such as generating parking occupancy data for analysis at a city parking department, providing parking recommendations for motorists, or so forth, then a remote placement may be more appropriate, as the parking guidance forecasting server 80 in such embodiments is likely to provide forecasting for a number of different parking facilities. For example, to provide parking recommendations the parking guidance forecasting server 80 beneficially forecasts parking occupancies for a number of different parking facilities (including the illustrative parking facility 60) in order to recommend the parking facility with lowest forecast occupancy.
The parking guidance forecasting server 80 is configured to provide a forecast of the parking occupancy of the parking facility 60 at some time in the future, typically on the order of one to twenty minutes inclusive in the future, and in some embodiments 2-10 minutes into the future. Such a time frame is useful, for example, in operating the “Lot full” sign 76, since it is desirable to predict when the lot will be full a few minutes into the future so as to turn the “Lot full” 76 on a few minutes before the parking facility 60 is actually full in order to provide the last vehicles entering the facility time to park. Likewise, such a time frame is useful in the case of providing a parking recommendation to a vehicle navigation device since the request for a parking recommendation is preferably made a few minutes before the vehicle is actually at the parking facility (e.g. perhaps issued as the vehicle is approaching the freeway exit ramp into downtown). Put more precisely, in some illustrative embodiments it is desired that at a time t the parking guidance forecasting server 80 determines a parking occupancy forecast for a time t+s where s denotes a time horizon 82. In some embodiments, s is in the range [1 min, 20 min] inclusive, though a larger or smaller value of s is also contemplated depending upon the application.
The parking guidance forecasting server 80 is suitably implemented as a computer (e.g. a server computer) or other electronic processing device including a microprocessor or other electronic processor, and a non-transitory storage medium which stores instructions readable and executable by the computer or other electronic processor to perform an embodiment of the disclosed parking guidance forecasting method. The non-transitory storage medium may, for example, comprise one or more of: an internal hard disk drive of a computer, an external hard drive or a network-accessible hard drive or RAID or other magnetic storage medium; or may be a solid state drive (SSD) of a computer or some other electronic storage medium; or may be an optical disk or other optical storage medium; or may be some combination of the foregoing; or so forth. The parking guidance forecasting server 80 is in communication with the sensors reader 78 to receive parking event data acquired by the parking sensors S of the parking facility 60. For example, the communication pathway from the sensors reader 78 to the parking guidance forecasting server 80 may include one or more of a wired and/or wireless local area network (LAN), the Internet, various combinations thereof, or so forth.
The parking guidance forecasting server 80 is also in operative communication with an electronic device (other than the parking guidance forecasting server 80 itself) that receives parking guidance information from the parking guidance forecasting server 80. By way of illustration, the parking guidance forecasting server 80 may be in wired or wireless communication with the “Lot full” sign 76 to turn that sign on or off based on whether the forecast parking occupancy indicates the parking facility 60 is likely to be full at the future time t+s. In another example, the parking guidance forecasting server 80 may be in wireless communication with a vehicle navigation device 84 of a vehicle 86 in order to provide a parking recommendation to the navigation device 84. The navigation device 84 may, for example, be a cellular telephone (“cellphone”), tablet computer, dashboard-mounted navigation unit of the vehicle 86, or so forth. The navigation device 84 is in wireless communication with the parking guidance forecasting server 80 via a suitable communication link such as a cellular telephone (e.g. 4G) link. The navigation device 84 includes locating hardware for locating the navigation device 84 (and, by extension, the vehicle 86) in the city or other locale. In the illustrative embodiment, the locating hardware comprises a Global Positioning System (GPS) receiver 88; additionally or alternatively, the locating hardware may comprise a WiFi radio accessing a WiFi location service, a 4G or other cellular radio leveraging a cellular location service based on cell tower signal strengths, and/or so forth. The navigation device 84 includes an electronic processor (e.g. microprocessor or microcontroller) that runs a navigation program (“app”) 90 that reads the GPS receiver 88 or other locating hardware to determine a current location of the navigation device 84 (and hence of the vehicle 86). Typically, the navigator app 90 accesses a regional map of the city or other locale either stored in flash memory, a solid state drive (SSD), or other local storage of the navigation device 84 or downloaded via the cellular connection, and displays the relevant portion of the map with the current GPS location indicated, possibly also along with a recommended route or other relevant navigation information.
The navigator app 90 also performs a parking recommendation query process 92 that queries the parking guidance forecasting server 80 to obtain a parking recommendation. This query may be variously triggered, e.g. by a verbal command picked up by a microphone of the navigation device 84, or automatically triggered when the GPS location comes within a threshold distance to (or estimated time of arrival at) a destination. The query may be transmitted by 4G or other cellular link, and preferably includes transmission of the current GPS location so that the server 80 can determine one or more nearby parking facilities (which may or may not include or consist of the illustrative parking facility 60) with a forecast parking occupancy at the future time t+s that is low enough that the vehicle is deemed likely to find an open (i.e. available) parking space. The server 80 then transmits parking guidance suitably comprising an identification of the one or more recommended parking facilities back to the navigation device 84, again suitably via the 4G or other cellular connection, and the navigation app 90 provides these recommendations to the driver (e.g. by plotting them on the displayed map, and/or adjusting the navigation route to terminate at a selected one of the recommended parking facilities, and/or so forth).
In general, the parking guidance forecasting server 80 forecasts the parking occupancy of the parking facility 80 at the future time t+s as follows. Based on the current parking event data received from the sensors S and sensors reader 78, a current occupancy state (denoted herein without loss of generality as current state i) is constructed for the parking facility at the time t. The current occupancy state i estimates the fraction of occupied parking spaces of the parking facility 60 at time t. Occupancy state probabilities are computed for the parking facility 60 at future time t+s using a continuous-time Markov chain model with a generator matrix Q(θ) 96 (where θ is a parameter vector learned on training data) modified by multiplying the time s input to the model by a random variable ξ 98 and scaling the occupancy state probabilities by an expectation of the random variable ξ 98. Parking guidance information is then generated based at least on the computed occupancy state probabilities, e.g. if the parking states run from 0-n where n is the number of parking spaces (so the state n means the lot is completely full while the state 0 means the lot is completely empty) then the parking guidance may be computed as the most probable state and, if this most probable state is within some threshold of n then the parking facility 60 is deemed to be likely to be full at time t+s.
In the following, embodiments of the disclosed forecasting approach are described, both generally and with specific application to the illustrative parking occupancy forecasting task.
The general forecasting task can be formulated as follows. We suppose a system which has state X(t) at time t where X(t) is drawn from a state space of size n. If the state at time t is X(t)=i then the state at time t+s is X(t+s)=j with probability pij(s). In the classic continuous-time Markov chain model for such a system, one can write pij(s)=expm(Qs) for some matrix Q∈n×n called the generator matrix, where expm(·) denotes the matrix exponential. One problem with such a model is that the number of transitions of real-world systems over a time interval [t, t+s) is usually more variable than such a continuous-time Markov model would predict. If this problem is not addressed, forecasts will be more precise than is justifiable and as a consequence, resource allocation and guidance will be suboptimal as the uncertainty involved will be underestimated.
A simple formulation of the forecasting task applied to parking occupancy forecasting is as follows. One has n sensors S in n parking spaces (where as a non-limiting example, n=52 for the parking facility 60 shown in illustrative
In a more realistic parking guidance setting, one has m<n sensors S in n parking spaces which sense parking events consisting of arrivals and departures. For instance, in illustrative
Additionally, the sensors S do not always identify arrivals or departures, but rather sometimes send signals corresponding to “unknown” events as the signals were too ambiguous to classify as arrivals, departures or background noise. Furthermore, sensors sometimes stop working and fail to send any signals for a long period. For instance if there are usually 4 events per day at a sensor and we have waited over a day since the last event, then we may make an inference that the sensor has stopped working. Finally, sensors may sometimes detect that a parking space is vacant when it is in fact occupied and vice versa. In analyses of some existing parking sensor systems, the false-positive rate was around 5% and the false-negative rate was around 10%. This can make it hard to tell if a block face (or other parking facility) is full. For instance, a full block face with n=7 stalls would only be detected as full with probability 0.97≈0.478.
Some illustrative examples of disclosed forecasting approaches employing a continuous-time Markov chain model with generator matrix Q(θ) 96 (where θ is a parameter vector learned on training data) modified by multiplying the time s input to the model by random variable ξ 98 and scaling the occupancy state probabilities by the expectation of the random variable ξ 98 are next described. Suppose X(t)∈[n] is a continuous-time Markov chain with generator Q∈n×n. Then (X(t+s)=j|X(t)=i)=[expm(Qs)]ij where for A ∈n×n the matrix exponential is
This Markov chain model is modified as disclosed herein by modeling a variable delay, an uncertain horizon or a variable number of events over the horizon. This is done by replacing time s by a random variable ξs and setting:
X(t+s)=j|X(t)=i)=(ξ)·expm(Qξs) (1)
where (ξ) denotes the expectation of the random variable ξ. This term mainly contributes to the variance, and adds an additional degree of freedom to decouple variance and average.
In one illustrative embodiment, the random variable ξ 98 is a unit-mean gamma-distributed random variable with variance v, that is to say:
ξ:gamma(mean=1,variance=v) (2)
Said another way, the probability density function of the random variable ξ is the aforementioned unit-mean gamma-distribution. For this formulation of the random variable ξ, Equation (1) has the following closed form in terms of the matrix power function:
(ξ)·expm(Qξs)=(I−vsQ)−1/v (3)
This can be derived by considering the moment-generating function of gamma-distributed random variables.
In another illustrative embodiment, rather than assuming a single gamma random variable, a more general model is a mixture of nm gamma random variables with unit mean so that:
ξ|k:gamma(mean=μk,variance=vk) (4)
where:
k: multinomial(w1,w2. . . ,wn
under the constraint that:
For this formulation of the random variable ξ, Equation (1) has the following closed form in terms of the matrix power function:
This representation adds substantial flexibility to the model. For instance, in parking data we see a heavy-tailed delay (recall that in the mentioned parking sensors system analysis roughly 80% of delays were between 40 seconds and 120 seconds, but the top 10% of delays had a heavy-tailed distribution frequently involving delays of over 1 hour). This heavy-tailed distribution can be captured as a mixture of a low variance and a high variance gamma random variables.
In the following illustrative examples, the random variable ξ 98 is assumed to have a probability distribution function which is a single gamma distribution, that is, the example of Equations (2) and (3) above.
With reference to
Given observations of ((X(tk)=ik,X(tk+S)=jk): k=1,2, . . . , no) and a parameterized model Q(θ) for the generator matrix 96 for parameter vector θ∈n
In order to estimate parameters θ, v as per Equation (6), the efficient and stable computation of the derivatives of the matrix power function is suitably done as follows. In general the derivative of a matrix functions ƒ: n×n→n×n at A∈n×n in direction E∈n×n is known as the Fréchet derivative Lƒ(A,E). This is a function such that:
ƒ(A+E)−ƒ(A)−Lƒ(A,E)=o(∥E∥) (7)
for all A,E∈n×n and if Lƒ(A,E) exists then it is unique. Thus we may write:
For the subject model, it may be noted that:
(I−vQ)−1/v=expm(−(1/v)log m(I−vQ)) (9)
Thus a stable and efficient computation of the derivatives proceeds by applying two functions expm_frechet_pade and log m_frechet_pade. See Al-Mohy et al., “Computing the Frechet derivative of the matrix exponential, with an application to condition number estimation”, SIAM Journal on Matrix Analysis and Applications, 30 (4): 1639-1657 (2009); Al-Mohy et al., “Computing the Fréchet derivative of the matrix logarithm and estimating the condition number”, SIAM Journal on Scientific Computing 35 (4): C394-C410 (2013).
Having discussed the general formulation, application to the task of parking occupancy forecasting is next described. Again, the single gamma probability density function formulation of the random variable ξ as per Equations (2) and (3) is again used. Let Z(t)∈n+1 be the occupancy of a set of n stalls at time t. We wish to predict Z(tb)|Z(ta) for current time ta and prediction time tb>ta. Let the midpoint of this interval be tm: =(ta+tb)/2.
In a simple model of parking, over interval [ta, tb] vehicles attempt arrive at rate λ(tm)∈+ and each vehicle departs at rate μ(tm) ∈+. A more general model might allow for time-varying rates over [ta, tb], but then we would not typically have a matrix-exponential solution to the basic continuous-time Markov chain and as we are aiming at short-term prediction, it seems reasonble to assume that the rates are constant over a short time interval. Let us fix a particular tm and write λ=λ(tm) and μ=μ(tm).
The generator matrix Q∈(n+1)×(n+1) (where element Qij corresponds to i=Z(t+)+1 and j=Z(t)+1 and t+ is the time just after t) for this continuous-time Markov chain is given by Q:=ΔA+μB. In terms of the Kronecker delta we have [A]ij:=δi−1,j−δi,j and [B]ij:=i(δi,j−1−δi,j). For instance, for n=4 we have:
and
Thus applying Equation (3) yields:
(Z(tb)=i|Z(ta)=j)=[(I−v(tb−ta)(λA+μB))−1/v]ij (11)
With reference to
With reference to
The illustrative embodiments are directed to forecasting parking occupancy of a parking facility. More generally, the disclosed forecasting entails computing probabilities pij of the state of a system at a future time t+s, where pij is the probability that the system is in state j at the future time t+s and pij is computed to have a value given by pij=(ξ)·[expm(Qξs)]ij where expm( . . . ) denotes the matrix exponential, Q is a generator matrix, is a random variable having a non-negative probability density function, and [expm(Qξs)]ij denotes element (i,j) of the matrix quantity (ξ)·expm(Qξs). Such forecasting can be usefully employed in diverse applications in which it may be anticipated that the transitions over the time interval [t, t+s) may exhibit greater variability than that predicted by a conventional continuous-time Markov model. For example, the disclosed forecasting approaches may find application in other forecasting tasks such as forecasting the number of queued print jobs at a print shop, or forecasting the waiting list for an Emergency Medical Department, or so forth.
It will be appreciated that various of the above-disclosed and other features and functions, or alternatives thereof, may be desirably combined into many other different systems or applications. Also that various presently unforeseen or unanticipated alternatives, modifications, variations or improvements therein may be subsequently made by those skilled in the art which are also intended to be encompassed by the following claims.
Number | Name | Date | Kind |
---|---|---|---|
10032368 | Thompson | Jul 2018 | B1 |
20120161984 | Amir | Jun 2012 | A1 |
20140340242 | Belzner | Nov 2014 | A1 |
20150161891 | Dance | Jun 2015 | A1 |
20170191849 | Agam | Jul 2017 | A1 |
Entry |
---|
Neuts, “A versatile Markovian point process,” Journal of Applied Probability, vol. 16 (4), pp. 764-779 (1979). |
Al-Mohy, et al., “Computing the Freéchet derivative of the matrix exponential, with an application to condition number estimation,” SIAM Journal on Matrix Analysis and Applications, vol. 30 (4), pp. 1639-1657 (2009). |
Al-Mohy, et al.,“Computing the Fréchet derivative of the matrix logarithm and estimating the condition number,” SIAM Journal on Scientific Computing, vol. 35 (4), pp. C394-C410 (2013). |
Al-Mohy, Awad H. et al., “Computing the Fréchet Derivative of the Matrix Exponential, with an Application to Condition Number Estimation”, SIAM Journal on Matrix Analysis and Applications, vol. 30. No. 4, pp. 1639-1657, 2009. |
Al-Mony, Awad H. et al., “Computing the Fréchet Derivative of the Matrix Logarithm and Estimating the Condition Number”, SIAM Journal on Scientific Computing, vol. 35, No. 4, pp. C394-C410, 2013. |
Neuts, Marcel, “A Versatile Markovian Point Process”, Journal of Applied Probability, vol. 16, No. 4, pp. 764-779, Dec. 1979. |