The present disclosure is generally related to traffic control systems, and more particularly related to controlling traffic using traffic rules generated based on types of objects present in a traffic stream and associated traffic flow rates.
The subject matter discussed in the background section should not be assumed to be prior art merely as a result of its mention in the background section. Similarly, a problem mentioned in the background section or associated with the subject matter of the background section should not be assumed to have been previously recognized in the prior art. The subject matter in the background section merely represents different approaches, which in and of themselves may also correspond to implementations of the claimed technology.
Controlling vehicular traffic on roads is essential for transportation of persons and goods. Further, vehicular traffic may include various types of vehicles such as trucks, buses, cars, bikes, etc. in a traffic stream. Typically, vehicular traffic is controlled using traffic light switching systems. For example, a traffic light switching system is used to detect vehicles approaching or waiting at a road intersection and change the status of the traffic lights accordingly (i.e. from the red light being illuminated indicating stop to the green light being illuminated indicating go).
Generally, traffic light systems have pre-programmed timing which is updated every year or few years, based on traffic conditions and available resources. However, frequent changes in traffic patterns result in the outdating of traffic light switching systems and cause traffic inefficiencies. Such inefficiencies result in environmental pollution that can create or exacerbate health problems. Therefore, there is a need for updating the pre-programmed timing of traffic systems in real-time as traffic patterns change.
Thus, the current state of art does not provide real-time traffic optimization. Therefore, there is a need to improve traffic signaling for different types of vehicles, in real-time, for controlling vehicular traffic.
One or more example embodiments of inventive concepts are directed to providing adaptive traffic control at an intersection (or a group of intersections in vicinity of each other) based on analysis of types of objects detected at the intersection and a correlation thereof to traffic flow rates.
One aspect of the present disclosure includes a device with memory having computer-readable instructions stored therein and one or more processors. The one or more processors are configured to execute the computer-readable instructions to receive video data of traffic flowing through an intersection; based on the video data, determine if a rate of flow of the traffic is greater than a predetermined threshold; determine a correlation between the rate of flow and one of a plurality of object types if the rate of flow is not greater than the predetermined threshold; determine a rule for controlling the traffic flow through the intersection based on the correlation; and cause adjustments to traffic control settings of a traffic light at the intersection based on the rule.
One aspect of the present disclosure includes one or more non-transitory computer-readable medium having computer-readable instructions stored therein, which when executed by one or more processors, cause the one or more processors to receive video data of traffic flowing through an intersection; based on the video data, determine if a rate of flow of the traffic is greater than a predetermined threshold; determine a correlation between the rate of flow and one of a plurality of object types if the rate of flow is not greater than the predetermined threshold; determine a rule for controlling the traffic flow through the intersection based on the correlation; cause adjustments to traffic control settings of a traffic light at the intersection based on the rule.
One aspect of the present disclosure includes a method of object-type based traffic control. The method includes receiving video data of traffic flowing through an intersection; based on the video data, determining if a rate of flow of the traffic is greater than a predetermined threshold; determining a correlation between the rate of flow and one of a plurality of object types if the rate of flow is not greater than the predetermined threshold; determining a rule for controlling the traffic flow through the intersection based on the correlation; causing adjustments to traffic control settings of a traffic light at the intersection based on the rule.
The accompanying drawings illustrate various embodiments of systems, methods, and embodiments of various other aspects of the disclosure. Any person with ordinary skills in the art will appreciate that the illustrated element boundaries (e.g. boxes, groups of boxes, or other shapes) in the figures represent one example of the boundaries. It may be that in some examples one element may be designed as multiple elements or that multiple elements may be designed as one element. In some examples, an element shown as an internal component of one element may be implemented as an external component in another, and vice versa. Furthermore, elements may not be drawn to scale. Non-limiting and non-exhaustive descriptions are described with reference to the following drawings. The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating principles.
Some embodiments of this disclosure, illustrating all its features, will now be discussed in detail. The words “comprising,” “having,” “containing,” and “including,” and other forms thereof, are intended to be equivalent in meaning and be open ended in that an item or items following any one of these words is not meant to be an exhaustive listing of such item or items, or meant to be limited to only the listed item or items.
It must also be noted that as used herein and in the appended claims, the singular forms “a,” “an,” and “the” include plural references unless the context dearly dictates otherwise. Although any systems and methods similar or equivalent to those described herein can be used in the practice or testing of embodiments of the present disclosure, the preferred, systems and methods are now described.
Although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first element could be termed a second element, and similarly, a second element could be termed a first element, without departing from the scope of this disclosure. As used herein, the term “and/or,” includes any and all combinations of one or more of the associated listed items.
When an element is referred to as being “connected,” or “coupled,” to another element, it can be directly connected or coupled to the other element or intervening elements may be present. By contrast, when an element is referred to as being “directly connected,” or “directly coupled,” to another element, there are no intervening elements present. Other words used to describe the relationship between elements should be interpreted in a like fashion (e.g., “between,” versus “directly between,” “adjacent,” versus “directly adjacent,” etc.).
It should also be noted that in some alternative implementations, the functions/acts noted may occur out of the order noted in the figures. For example, two figures shown in succession may in fact be executed substantially concurrently or may sometimes be executed in the reverse order, depending upon the functionality/acts involved.
Specific details are given in the following description to provide a thorough understanding of embodiments. However, it will be understood by one of ordinary skill in the art that embodiments may be practiced without these specific details. For example, systems may be shown in block diagrams so as not to obscure the embodiments in unnecessary detail. In other instances, well-known processes, structures and techniques may be shown without unnecessary detail in order to avoid obscuring embodiments.
Although a flow chart may describe the operations as a sequential process, many of the operations may be performed in parallel, concurrently or simultaneously. In addition, the order of the operations may be re-arranged. A process may be terminated when its operations are completed, but may also have additional steps not included in the figure. A process may correspond to a method, function, procedure, subroutine, subprogram, etc. When a process corresponds to a function, its termination may correspond to a return of the function to the calling function or the main function.
Example embodiments of the present disclosure will be described more fully hereinafter with reference to the accompanying drawings in which like numerals represent like elements throughout the several figures, and in which example embodiments are shown. Example embodiments of the claims may, however, be embodied in many different forms and should not be construed as limited to the example embodiments set forth herein. The examples set forth herein are non-limiting examples and are merely examples among other possible examples.
In one example embodiment, the traffic light 117 can have different traffic signals directed towards all the roads leading to the intersection 101. The different signals may comprise a Red light, Yellow light, and a Green light.
While
The light controller 102 can include one or more processors and one or more memories. The light controller 102, by implementing computer-readable instructions stored on the one or more memories, can implement traffic control rules and adjust timing and phase of the traffic light 117 according to a give traffic control rule. This will be further described below.
The light controller 102 can be communicatively coupled to the traffic controller 104. The traffic controller 104 can be accessible via a cloud 110 using various known or to be developed wired and/or wireless schemes. The cloud 110 may be a public, private or a hybrid of public and private cloud platforms provided by a cloud service provider. The traffic controller 104 can access one or more databases via the cloud 110 such as video database 105, tracking and ID database 106 and rules database 107, all of which will be further described below. Furthermore, traffic controller 104 can have one or more processors such as processor 108 and one or more memories such as memory 109 having computer-readable instructions stored therein, which when executed by the one or more processors enable the traffic controller 104 to carry out traffic controlling functionalities, as will be further described below.
In one example, the traffic controller 104 can be co-located (physically) with the light controller 102, which together can be co-located in a geographical proximity of smart traffic camera 103. In another example, the light controller 102 and the traffic controller 104 can be the same computing unit implementing functionalities of both, as will be described below. In yet another example embodiment, the traffic controller 104 and the light controller 102 can be part of a centralized traffic control system.
The traffic controller 104 can be accessible by respective/authorized operators. A graphical user interface (GUI) 112 can be associated with the traffic controller 104, which authorized users and operators can log into to gain access to a particular intersection or intersections such as the intersection 101 to provide further input and data, which can be used by the traffic controller 104 to create traffic rules, view various data and information about intersection(s), and designate various zones therein for identifying traffic patterns and applying adaptive traffic control, etc.
In one or more example embodiments, traffic controller 104 can receive traffic patterns, rules, and other information pertaining to nearby intersection(s) such as intersections/corridors 116 from their respective traffic control systems 114. In another example, such additional traffic information pertaining to other intersection(s) need not be limited to nearby intersections but may be of other intersections, in other cities, countries, etc., having similar traffic patterns, which may be used by the traffic controller 104 for adaptive and smart controlling of traffic at the intersection 101 and/or nearby intersections.
While certain components of the system 100 are illustrated in
As mentioned above, the components of the system 100 can communicate with one another using any known or to be developed wired and/or wireless network. For example, for wireless communication, techniques such as Visible Light Communication (VLC), Worldwide Interoperability for Microwave Access (WiMAX), Long Term Evolution (LTE), Fifth Generation (5G) cellular, Wireless Local Area Network (WLAN), Infrared (IR) communication, Public Switched Telephone Network (PSTN), Radio waves, and other communication techniques known in the art may be utilized.
The light controller 102 can comprise a processor 202, interface(s) 204, sensor(s) 206, and memory 208. The processor 202 may execute an algorithm stored in the memory 208 for maintaining control of traffic. The processor 202 may also be configured to decode and execute any instructions received from one or more other electronic devices or server(s). The processor 202 may include one or more general purpose processors (e.g., INTEL® or Advanced Micro Devices® (AMD) microprocessors, ARM) and/or one or more special purpose processors (e.g., digital signal processors or Xilinx® System On Chip (SOC) Field Programmable Gate Array (FPGA) processor). The processor 202 may be configured to execute one or more computer-readable program instructions, such as program instructions to carry out any of the functions described in this description.
The interface(s) 204 may assist an operator in interacting with the light controller 102. The interface(s) 204 of the light controller 102 may be used instead of or in addition to the graphical user interface 112 that is centrally accessible by operators or may be the same as the graphical user interface 112. The interface(s) 204 either accept an input from the operator or provide an output to the operator, or may perform both the actions. The interface(s) 204 may either be a Command Line Interface (CLI), Graphical User Interface (GUI), voice interface, and/or any other user interface known in the art or to be developed.
The sensor(s) 206 can be one or more smart cameras such as fish-eye cameras mentioned above or any other type of sensor/capturing device that can capture various types of data regarding activities at the intersection 101. Any one such sensor 206 can be located at/attached to the light controller 102, located at/attached to the smart traffic camera 103, or remotely installed from the light controller 102 and the smart traffic camera 103 and communicatively coupled to one or both.
As mentioned, the sensor(s) 206 may be installed to capture objects moving across the roads. The sensor(s) 206 used may include, but are not limited to, optical sensors such as fish-eye cameras mentioned above, Closed Circuit Television (CCTV) cameras, and Infrared cameras. Further, sensor(s) 206 can include, but not limited to induction loops, Light Detection and Ranging (LIDAR), weather sensors, motion sensors, audio sensors, pneumatic road tubes, magnetic sensors, piezoelectric cable, and weigh-in motion sensor, which may also be used alone or in combination with the optical sensor(s).
The memory 208 may include, but is not limited to, fixed (hard) drives, magnetic tape, floppy diskettes, optical disks, Compact Disc Read-Only Memories (CD-ROMs), and magneto-optical disks, semiconductor memories, such as ROMs, Random Access Memories (RAMs), Programmable Read-Only Memories (PROMs), Erasable PROMs (EPROMs), Electrically Erasable PROMs (EEPROMs), flash memory, magnetic or optical cards, or other type of media/machine-readable medium suitable for storing electronic instructions.
The memory 208 may comprise modules implemented as a program and executed by the processor 202. In one case, the memory 208 may comprise a base module (service) 210 and a rules implementation module 212. These modules (services) are computer-readable instructions stored on the memory 208 for execution by the processor 202. Functionalities implemented by executing based module 210 and/or the rules implementation module 212 will be further described below with reference to
The traffic controller 104 can comprise a processor 302 (which may be the same as the processor 108 described with reference to
The interface(s) 304 may assist an operator in interacting with the traffic controller 104. The interface(s) 304 of the traffic controller 104 may be used instead of or in addition to the graphical user interface 112 that is centrally accessible by operators or may be the same as the graphical user interface 112. The interface(s) 304 either accept an input from the operator or provide an output to the operator, or may perform both the actions. The interface(s) 304 may either be a Command Line Interface (CLI), Graphical User Interface (GUI), voice interface, and/or any other user interface known in the art or to be developed.
The memory 306 may include, but is not limited to, fixed (hard) drives, magnetic tape, floppy diskettes, optical disks, Compact Disc Read-Only Memories (CD-ROMs), and magneto-optical disks, semiconductor memories, such as ROMs, Random Access Memories (RAMs), Programmable Read-Only Memories (PROMs), Erasable PROMs (EPROMs), Electrically Erasable PROMs (EEPROMs), flash memory, magnetic or optical cards, or other type of media/machine-readable medium suitable for storing electronic instructions.
The memory 306 may comprise modules implemented as a program and executed by the processor 302. In one case, the memory 306 may comprise a tracking and ID module 308, a learning module 310, and/or a rules creation module 312. These modules (services) are computer-readable instructions stored on the memory 306 for execution by the processor 302. Functionalities implemented by executing the tracking and ID module 308, the learning module 310 and/or the rules creation module 312 will be further described below with reference to
As mentioned above, light controller 102 and traffic controller 104 may form a single physical unit, in which case system components of each, as described with reference to
Having described examples of system components, the disclosure now turns to example embodiments that enable generation and application of traffic rules (traffic control rules) based on the type of objects (e.g., vehicles) detected at an intersection at any given point in time.
At step 400, the traffic controller 104 may receive video data from the smart traffic camera 103 and/or sensors 206 (directly) or alternatively receive the video data of traffic captured by the smart traffic camera 103 via the light controller 102.
At step 402, the traffic controller 104 may store the received video data in the video database 105.
The video data may also be referred to as sensor data captured by the sensors 206 of light controller 102 and may be received and stored in real-time. The sensor data may include sensor data of the objects moving across the intersection 101.
At step 404, the traffic controller 104 may implement computer-readable instructions corresponding to the tracking and ID module 308, to analyze the stored video data in order to identify and track the types of objects (e.g., type of vehicles) detected in the video data at the intersection 101. The detection of the types of vehicles can be based on template matching or any other known or to be developed method of image/video processing for detecting object types in captured video/image data. As mentioned above, the types of vehicles may include, but are not limited to, cars, trucks, buses, bikes, etc. Furthermore, cars, trucks, buses and bikes can further be broken down into sub-categories. For example, cars can be categorized into sedans, vans, SUVs, etc. Trucks can be categorized into light trucks such as pickup trucks, medium trucks such as box trucks or fire trucks, heavy duty trucks such as garbage trucks, crane movers, 18-wheelers, etc.
In one example, the traffic controller assigns a type to each identified object (car) (associates each identified object with one of a plurality of object types) and may then determine a number of the detected objects having the same object type (e.g., the number of cars, the number of trucks, etc.).
At step 406, the traffic controller 104 stores the results of the analysis and identification of object types in the tracking and ID database 106.
In one example embodiment, the steps 400-406 may be continuously performed by the traffic controller 104 as traffic flows through the intersection 101 continuously.
At step 408, the traffic controller 104 determines a rate of traffic flow at the intersection 101 and whether the determined rate is less than or equal to some predetermined threshold. The threshold can be a configurable parameter set by an operator of traffic controller 104 (e.g., through the interface 304 or the graphical user interface 112) and may be determined based on experiments and/or empirical studies. For example, the threshold may be set to 10 vehicles per minute.
In one example, the traffic controller 104 can receive instructions via the graphical user interface 112 to designate entrance, monitoring and exit zones at the intersection 101 and then apply analytics to the video of vehicles moving through the intersection 101 to determine the number of vehicles entering and exiting the intersection 101 at any given point in time. Based on this determination, the traffic controller 104 can determine the rate of traffic flow at the intersection 101. The traffic flow rate may be directional specific, meaning that it may be specified for traffic associated with any one or more of north-south, north-east, north-west, east-north, east-south, east-west, west-east, west-north, west-south, south-north, south-east and south-west bound directions at the intersection 101.
In another example, the traffic controller 104 may determine traffic flow rates using various techniques which are well known in the art. In one example, a traffic flow rate may be determined by multiplying a predicted space mean speed (Vse) with a traffic density (k). For example, Vse of 60 miles/hour with k=20 vehicles/mile yields a traffic flow rate of 1200 vehicles/hour.
In one example, the tracking and ID database 106 may have stored therein, the rates of traffic flows in addition to identified object (number of objects) associated with each type of object, as reflected in Table 1 below.
If at step 408, the traffic controller 104 determines that the traffic flow rate is not less than or equal to the threshold (is greater than the threshold), the process reverts back to step 400 and the traffic controller 104 may repeat steps 400-408.
However, if at step 408, the traffic controller 104 determines that the traffic flow rate is less than or equal to the threshold, then at step 410, the traffic controller 104 determines a correlation between each of the identified object types (a plurality of object types) stored in the tracking and ID database 106 and the traffic flow rate determined at step 408. More specifically, at step 408, the traffic controller 104 determines a correlation between the number of objects (cars) associated with each object type (as determined per step 404) and the rate of traffic flow. This may be referred to as an object type-traffic flow rate correlation. This step can be implemented when the processor 302 implements the computer-readable instructions corresponding to the learning module 310. This step will be further described with reference to
For example, graph 500 of
Similarly, graph 504 shows a correlation between the number of cars at the intersection 101 and the traffic flow rate over the given period of time, with a corresponding coefficient of determination (correlation coefficient) shown by line 506 (e.g., R2=−0.5).
While
Returning back to
If at Step 412, the correlation is determined not be less than or greater than the correlation threshold (is greater than the correlation threshold), then the process reverts back to step 400 and the controller 104 repeats steps 400-412.
However, if at step 412, the traffic controller 104 determines that then correlation is less than or equal to the correlation threshold, then at step 414, the traffic controller 104 creates a traffic rule. The term traffic rule(s) can be used interchangeably with the term traffic control rule(s).
In one example, such traffic rule(s) are created based on known or to be developed optimization rules, or various input criteria such as normal traffic flow rate (received from external sources). This can be, for example, based on data received from other traffic systems (e.g., traffic systems 114) having similar rules established for similar correlations. In another example, the traffic controller 104 can determine a proportion between a normal (average) traffic rate and the current identified traffic flow rate and based on such proportion adjust current or average traffic control signals and durations thereof. For example, if the traffic flow rate has decreased by 50% due to presence of 5 trucks at the intersection 101 and assuming that the average duration of a green light is set to 30 seconds, the traffic controller 104 can create a rule, whereby, upon detection of 4-6 trucks (or exactly 5 trucks), the duration of green light is increased by 50% (e.g., to 45 seconds instead of 30 seconds).
Thereafter, at step 416, the traffic controller 104 stores the created traffic rule in the rules database 107. In one example, the traffic controller 104 stores the created traffic rule in association with the correlation determined at step 410, for future reference as will be described below.
For example, the rules database 107 can have stored therein the created rules per Table 2 shown below.
Several steps of
At step 600, the traffic controller 104 performs steps 400-412 of
At step 602 and after determining that the correlation is less than or equal to the correlation threshold as per step 412, the traffic controller 104 may determine if a matching rule exists in the rules database 107 for the correlation identified per step 410. For example, assume that currently, the traffic controller 104 has detected 5 trucks at the intersection 101. Furthermore, assume that the traffic controller 104 has previously performed the process of
Therefore, at step 602, the traffic controller 104 may search the rules database 107 to see if a matching rule exists for when 5 trucks are detected at the intersection 101. If the matching rule exists, which in this example it does, then at step 604, the traffic controller 104 retrieves the rule from the rules database 107 and then at step 606 transmits the rule to the light controller 102 for implementation at the traffic light 117.
However, if at step 602, the traffic controller 104 determines that no match for the identified correlation exists in the rules database 107, then at step 608, the traffic controller 104 performs steps 414 and 416 of
Having describes the rules creation and providing of the same by the traffic controller 104 to light controller 102, the disclosure now turns to describing functionalities of the light controller 102 for retrieving and implementing traffic rules created by traffic controller 104.
At step 700, the light controller 102 monitors the rules database 107 for new rules created and stored thereon by the traffic controller 104. Alternatively, and as described above, the light controller 102 may receive the new rules upon creation thereof, from the traffic controller 104. These new traffic rules may be referred to as a newly discovered traffic rules by the light controller 102. Step 700 may be performed by the processor 202 implementing computer-readable instructions corresponding to the rules implementation module 212.
At step 702, the light controller 102 retrieves, from the rules database 107, the traffic light settings for one or more of the newly discovered traffic rules and can optionally store them on the memory 206.
At step 704, the light controller 102 may retrieve a default traffic light setting. An example default traffic light setting for the intersection 101 is shown in
As shown in
Furthermore,
Referring back to
Upon detecting the triggering condition at step 706, then at step 708, the light controller applies the light settings of a corresponding one of newly discovered rules to the default traffic light settings at the traffic light 117 (adjust the default traffic light settings). The step 708 may be implemented by the processor 202 implementing computer-readable instructions corresponding to the base module 310. In this example, given that the 5 trucks are detected at the phase C and that the newly discovered rule is that the green light is to be increased by 50% when 5 trucks are detected (per the example described above with reference to
At step 710, the light controller 102 determines if the triggering condition is still valid. If it is, the light controller 102 continues to perform step 708. Once the triggering condition is no longer valid, then at step 712, the light controller 102 changes the traffic light setting on the traffic light 117 to the default traffic light settings of step 704. Thereafter, the process reverts back to step 700.
In one example and regardless of whether the light controller 102 is implementing the default traffic light setting or an adjusted version thereof based on the newly discovered rule(s), the light controller 102 can be configured to receive an emergency situation indication. This may be made possible for example, receiving audio signals via an audio sensor at the smart traffic camera 103 indicating the audio sounds emitted by a siren of an approaching fire truck or ambulance. Accordingly, the light controller 102 can override the currently implemented traffic light setting by applying an emergency traffic light setting according to which, for example, the light corresponding to the direction from which the ambulance or the fire truck is approaching the intersection 101, is immediately switch to green and remains green for a period of 30 seconds.
Another example of an emergency situation is one provided by a traffic control operator (e.g., via the graphical user interface 112) indicating a security situation or a police pursuit situation, which results in an immediate override of currently implemented traffic light settings at one or more intersections on the corresponding route so that emergency vehicles or law enforcement vehicles can pass through.
In another example, the light controller 102 may detect an abnormality in the traffic pattern or the rate of traffic flow for which no rule exists. For example, there may be a situation in which the rate of traffic flow falls below the threshold (e.g., below 10 vehicles per minute in phase C). However, the light controller 102 is unable to identify 5 trucks at phase C of the intersection 101. Therefore, the light controller 102 is unable to find a matching newly discovered traffic rule, in order to use the traffic light settings thereof to adjust the timing of lights at the traffic light 117. In such case, the light controller 102 may send a signal to the traffic controller 104 requesting an operator's feedback or instructions on changes to be made to the traffic light settings at the intersection 101 in order to alleviate the abnormally low rate of traffic flow.
Example embodiments of the present disclosure may be provided as a computer program product, which may include a computer-readable medium tangibly embodying thereon instructions, which may be used to program a computer (or other electronic devices) to perform a process. The computer-readable medium may include, but is not limited to, fixed (hard) drives, optical disks, compact disc read-only memories (CD-ROMs), and magneto-optical disks, semiconductor memories, such as ROMs, random access memories (RAMs), programmable read-only memories (PROMs), erasable PROMs (EPROMs), electrically erasable PROMs (EEPROMs), flash memory, magnetic or optical cards, or other type of media/machine-readable medium suitable for storing electronic instructions (e. g., computer programming code, such as software or firmware).
Moreover, example embodiments of the present disclosure may also be downloaded as one or more computer program products, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
This application claims priority to U.S. Provisional Patent Application No. 62/544,504 filed on Aug. 11, 2017, the entire content of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62544504 | Aug 2017 | US |