The present disclosure generally relates to systems and methods for traffic control, and more particularly, relates to systems and methods for controlling traffic lights.
With more and more vehicles on the street in urban areas, traffic congestion becomes part of people's daily lives. In many forms of traffic congestion, traffic overflow is undoubtedly a more serious one. Traffic overflow is defined in a certain flow direction of a certain section, caused by the influence of the factors such as road planning or traffic signal timing. In a traffic overflow, a queue of vehicles accumulates waiting for traffic within a certain period is greater than the length of the road section, and the queue extends to the upstream intersection. The spillover of the queue may lead to the gridlock at the intersection. Therefore, it is desirable to develop systems or methods for avoiding or reducing the queue spillover in order to alleviate traffic congestion.
According to an aspect of the present disclosure, a method for controlling traffic lights of an upstream intersection and a downstream intersection linked by a road is provided. The method may include one or more of the following operations. A processor may obtain historical track data of a plurality of vehicles that passed the road, the upstream intersection, and the downstream intersection over a historical period. The processor may obtain a congestion period. The processor may determine a discharge speed during the congestion period based on a portion of the historical track data corresponding to the congestion period. The processor may further determine an offset value based on a length of the road, the discharge speed, a cycle length of a first traffic light, a cycle length of a second traffic light, and a time length of a green light of the second traffic light being lit, wherein the first traffic light being at the downstream intersection, the second traffic light being at the upstream intersection, the cycle length of the first traffic light being equal to the cycle length of the second traffic light. The processor may determine a signal timing of the second traffic light based on the offset value.
In some embodiments, the historical period may include a plurality of workdays.
In some embodiments, the historical track data of the plurality of vehicles may include data of positions of the plurality of vehicles on the road and corresponding time points at which the plurality of vehicles at the positions.
In some embodiments, the processor may determine, for each of a plurality of first vehicles that pass through a boundary between the road and the downstream intersection during the congestion period, a relative start time point based on historical track data corresponding to the each of the plurality of first vehicles. The processor may further determine the discharge speed based on the relative start time points of the plurality of first vehicles.
In some embodiments, the processor may obtain an actual start time point of the each of the plurality of first vehicles that the each of the plurality of first vehicles started to move from a stop condition and across the boundary between the road and the downstream intersection during a period of the green light of the first traffic light being lit. The processor may obtain a start time point of the period of the green light of the first traffic light being lit, and further determine the relative start time point based on the actual start time point of the each of the plurality of first vehicles and the start time point of the period of the green light of the first traffic light being lit.
In some embodiments, the processor may determine the discharge speed based on the relative start time points of the plurality of first vehicles and corresponding positions of the plurality of first vehicles at the relative time points.
In some embodiments, the processor may determine an offset value range based on the length of the road, the discharge speed, the cycle length of the first traffic light, the cycle length of the second traffic light, and the time length of the green light of the second traffic light being lit, and determine the offset value based on the offset value range.
In some embodiments, the length of the road may include a length of the upstream intersection.
In some embodiments, the processor may control the second traffic light to delay for the offset value relative to the first traffic light corresponding to the congestion period.
In some embodiments, the processor may determine a first time point that the green light of the first traffic light starts to be on for a first time. The processor may determine a second time point based on the first time point and the offset value. The processor may extend a period of a red light of the second traffic light to the second time point. The processor may light the green light of the second traffic light at the second time point.
According to another aspect of the present disclosure, a system is provided. The system may include at least one storage medium and at least one processor configured to communicate with the at least one storage medium. The at least one storage medium may include a set of instructions. When the at least one storage medium executes the set of instructions, the at least one processor may be directed to perform one or more of the following operations. The at least one processor may obtain historical track data of a plurality of vehicles that passed the road, the upstream intersection, and the downstream intersection over a historical period. The at least one processor may obtain a congestion period. The at least one processor may determine a discharge speed during the congestion period based on a portion of the historical track data corresponding to the congestion period. The at least one processor may further determine an offset value based on a length of the road, the discharge speed, a cycle length of a first traffic light, a cycle length of a second traffic light, and a time length of a green light of the second traffic light being lit, wherein the first traffic light being at the downstream intersection, the second traffic light being at the upstream intersection, the cycle length of the first traffic light being equal to the cycle length of the second traffic light. The at least one processor may determine a signal timing of the second traffic light based on the offset value.
According to another aspect of the present disclosure, a non-transitory computer readable medium is provided. The non-transitory computer readable medium may comprise executable instructions that cause at least one processor to effectuate a method. The method may include one or more of the following operations. The at least one processor may obtain historical track data of a plurality of vehicles that passed the road, the upstream intersection, and the downstream intersection over a historical period. The at least one processor may obtain a congestion period. The at least one processor may determine a discharge speed during the congestion period based on a portion of the historical track data corresponding to the congestion period. The at least one processor may further determine an offset value based on a length of the road, the discharge speed, a cycle length of a first traffic light, a cycle length of a second traffic light, and a time length of a green light of the second traffic light being lit, wherein the first traffic light being at the downstream intersection, the second traffic light being at the upstream intersection, the cycle length of the first traffic light being equal to the cycle length of the second traffic light. The at least one processor may determine a signal timing of the second traffic light based on the offset value.
The present disclosure is further described in terms of exemplary embodiments. These exemplary embodiments are described in detail with reference to the drawings. The drawings are not to scale. These embodiments are non-limiting exemplary embodiments, in which like reference numerals represent similar structures throughout the several views of the drawings, and wherein:
In order to illustrate the technical solutions related to the embodiments of the present disclosure, brief introduction of the drawings referred to in the description of the embodiments is provided below. Obviously, drawings described below are only some examples or embodiments of the present disclosure. Those having ordinary skills in the art, without further creative efforts, may apply the present disclosure to other similar scenarios according to these drawings. Unless stated otherwise or obvious from the context, the same reference numeral in the drawings refers to the same structure and operation.
As used in the disclosure and the appended claims, the singular forms “a,” “an,” and “the” include plural referents unless the content clearly dictates otherwise. It will be further understood that the terms “comprises,” “comprising,” “includes,” and/or “including” when used in the disclosure, specify the presence of stated steps and elements, but do not preclude the presence or addition of one or more other steps and elements.
Some modules of the system may be referred to in various ways according to some embodiments of the present disclosure. However, any number of different modules may be used and operated in a client terminal and/or a server. These modules are intended to be illustrative, not intended to limit the scope of the present disclosure. Different modules may be used in different aspects of the system and method.
According to some embodiments of the present disclosure, flowcharts are used to illustrate the operations performed by the system. It is to be expressly understood, the operations above or below may or may not be implemented in order. Conversely, the operations may be performed in inverted order, or simultaneously. Besides, one or more other operations may be added to the flowcharts, or one or more operations may be omitted from the flowchart.
Technical solutions of the embodiments of the present disclosure are described with reference to the drawings as described below. It is obvious that the described embodiments are not exhaustive and are not limiting. Other embodiments obtained, based on the embodiments set forth in the present disclosure, by those with ordinary skill in the art without any creative works are within the scope of the present disclosure.
In an aspect, the present disclosure is directed to systems and methods for controlling traffic lights. The system may determine a discharge speed of a vehicle queue from the downstream intersection reaching the upstream stop line during a congestion period based on historical vehicle track data of a plurality of vehicles. The system may determine the light-cycle of a traffic light at the upstream intersection based on the discharge speed. The system may further control the traffic light based on the light-cycle.
In some embodiments, the server 110 may perform a plurality of operations to determine the signal timing of the traffic lights 160. The server 110 may control the traffic lights 160 according to the determined signal timing. In some embodiments, the server 110 may obtain the track data of a plurality of vehicles. The server 110 may determine the signal timing of the traffic lights 160 based on the collected track data. In some embodiments, the server 110 may be a single server or a server group. The server group may be centralized, or distributed (e.g., the server 110 may be a distributed system). In some embodiments, the server 110 may be local or remote. For example, the server 110 may access information and/or data stored in the driver terminal 120, the information source 150, and/or the storage device 130 via the network 140. As another example, the server 110 may be directly connected to the driver terminal 120 and/or the storage device 130 to access stored information and/or data. In some embodiments, the server 110 may be implemented on a cloud platform. Merely by way of example, the cloud platform may include a private cloud, a public cloud, a hybrid cloud, a community cloud, a distributed cloud, an inter-cloud, a multi-cloud, or the like, or any combination thereof. In some embodiments, the server 110 may be implemented on a computing device having one or more components illustrated in
In some embodiments, the server 110 may include a processing engine 112. The processing engine 112 may determine a signal timing for controlling the traffic lights 160 to avoid or reduce the spillover. In some embodiments, the processing engine 112 may include one or more processing engines (e.g., single-core processing engine(s) or multi-core processor(s)). Merely by way of example, the processing engine 112 may include a central processing unit (CPU), an application-specific integrated circuit (ASIC), an application-specific instruction-set processor (ASIP), a graphics processing unit (GPU), a physics processing unit (PPU), a digital signal processor (DSP), a field programmable gate array (FPGA), a programmable logic device (PLD), a controller, a microcontroller unit, a reduced instruction-set computer (RISC), a microprocessor, or the like, or any combination thereof.
In some embodiments, the driver terminal 120 may transmit positioning information associated with a vehicle to the server 110. For example, the driver terminal 120 may be a smartphone equipped with a global positioning system (GPS) chipset capable of determining the position of the smartphone. The driver terminal 120 may determine its positions over time and transmit the position data (also referred as the track data) to the server 110. The server 110 may treat the position data as the track data of a vehicle associated with the user of the driver terminal 120 since the positions of the driver terminal 120 may be the same (or almost the same) as the positions of the vehicle. As another example, the driver terminal 120 may be a computing device installed in a vehicle and equipped with a GPS chipset. The driver terminal 120 may determine its positions over time and transmit the position data to the server 120. The server 110 may further obtain track data corresponding to the positioning information. For example, the track data may include a plurality of positions of the driver terminal 120 and/or the vehicles.
In some embodiments, the driver terminal 120 may include a mobile device, a tablet computer, a laptop computer, and a built-in device in a motor vehicle, or the like, or any combination thereof. In some embodiments, the mobile device may include a smart home device, a wearable device, a smart mobile device, a virtual reality device, an augmented reality device, or the like, or any combination thereof. In some embodiments, the smart home device may include a smart lighting device, a control device of an intelligent electrical apparatus, a smart monitoring device, a smart television, a smart video camera, an interphone, or the like, or any combination thereof. In some embodiments, the wearable device may include a smart bracelet, a smart footgear, a smart glass, a smart helmet, a smartwatch, a smart clothing, a smart backpack, a smart accessory, or the like, or any combination thereof. In some embodiments, the smart mobile device may include a smartphone, a personal digital assistant (PDA), a gaming device, a navigation device, or the like, or any combination thereof. In some embodiments, the built-in device in the motor vehicle may include an onboard computer, an onboard television, etc. In some embodiments, the driver terminal 120 may include a device with positioning technology for locating the position of the vehicle (e.g., a device equipped with a GPS chipset).
The storage device 130 may store data and/or instructions. In some embodiments, the storage device 130 may store data obtained/acquired from the driver terminal 120. In some embodiments, the storage device 130 may store data and/or instructions that the server 110 may execute or use to perform exemplary methods described in the present disclosure. In some embodiments, the storage device 130 may include a mass storage, removable storage, a volatile read-and-write memory, a read-only memory (ROM), or the like, or any combination thereof. Exemplary mass storage may include a magnetic disk, an optical disk, a solid-state drive, etc. Exemplary removable storage may include a flash drive, a floppy disk, an optical disk, a memory card, a zip disk, a magnetic tape, etc. Exemplary volatile read-and-write memory may include random-access memory (RAM). Exemplary RAM may include a dynamic RAM (DRAM), a double date rate synchronous dynamic RAM (DDR SDRAM), a static RAM (SRAM), a thyristor RAM (T-RAM), and a zero-capacitor RAM (Z-RAM), etc. Exemplary ROM may include a mask ROM (MROM), a programmable ROM (PROM), an erasable programmable ROM (PEROM), an electrically erasable programmable ROM (EEPROM), a compact disk ROM (CD-ROM), and a digital versatile disk ROM, etc. In some embodiments, the storage device 130 may be implemented on a cloud platform. Merely by way of example, the cloud platform may include a private cloud, a public cloud, a hybrid cloud, a community cloud, a distributed cloud, an inter-cloud, a multi-cloud, or the like, or any combination thereof.
In some embodiments, the storage device 130 may be connected to the network 140 to communicate with one or more components in the system 100 (e.g., the server 110, the driver terminal 120). One or more components in the system 100 may access the data or instructions stored in the storage device 130 via the network 140. In some embodiments, the storage device 130 may be directly connected to or communicate with one or more components in the system 100 (e.g., the server 110, the driver terminal 120). In some embodiments, the storage device 130 may be part of the server 110.
The network 140 may facilitate exchange of information and/or data. In some embodiments, one or more components in the system 100 (e.g., the server 110, the driver terminal 120, the storage device 130) may send and/or receive information and/or data to/from another component (s) in the system 100 via the network 140. For example, the server 110 may obtain/acquire the trajectory data of the vehicles from a terminal via the network 140. In some embodiments, the network 140 may be any type of wired or wireless network, or combination thereof. Merely by way of example, the network 140 may include a cable network, a wireline network, an optical fiber network, a tele communications network, an intranet, an Internet, a local area network (LAN), a wide area network (WAN), a wireless local area network (WLAN), a metropolitan area network (MAN), a wide area network (WAN), a public telephone switched network (PSTN), a Bluetooth™ network, a ZigBee™ network, a near field communication (NFC) network, a global system for mobile communications (GSM) network, a code-division multiple access (CDMA) network, a time-division multiple access (TDMA) network, a general packet radio service (GPRS) network, an enhanced data rate for GSM evolution (EDGE) network, a wideband code division multiple access (WCDMA) network, a high speed downlink packet access (HSDPA) network, a long term evolution (LTE) network, a user datagram protocol (UDP) network, a transmission control protocol/Internet protocol (TCP/IP) network, a short message service (SMS) network, a wireless application protocol (WAP) network, a ultra wide band (UWB) network, an infrared ray, or the like, or any combination thereof. In some embodiments, the system 100 may include one or more network access points. For example, the system 100 may include wired or wireless network access points such as base stations and/or wireless access points 140-1, 140-2, . . . , through which one or more components of the system 100 may be connected to the network 140 to exchange data and/or information.
The information source 150 may be a source configured to provide other information for the system 100. The information source 150 may provide the system 100 with service information, such as weather conditions, traffic information, information of laws and regulations, news events, or the like. In some embodiments, the information source 150 may include an official traffic database, which provides historical and/or current traffic data (e.g., a congestion period, traffic light pattern). The server 110 may obtain the cycle length of a traffic light from the information source 150. The cycle length of a traffic light refers to a periodical duration of the traffic light including a green light duration, a red light duration, and a yellow light duration (if necessary). In the present disclosure, the red-light duration and the green-light duration are discussed while the yellow-light duration is not discussed, but a person having ordinary skill in the art would understand how to include the yellow-light duration in view of the present disclosure without undue experimentation. In some embodiments, the yellow-light duration may be considered to be included in the green-light duration or the red light duration. The information source 150 may be implemented in a single central server, multiple servers connected via a communication link, or multiple personal devices. When the information source 150 is implemented in multiple personal devices, the personal devices can generate content (e.g., as referred to as the “user-generated content”), for example, by uploading text, voice, image, and video to a cloud server. An information source may be generated by the multiple personal devices and the cloud server.
The computing device 200, for example, may include COM ports 250 connected to and from a network connected thereto to facilitate data communications. The computing device 200 may also include a processor (e.g., the processor 220), in the form of one or more processors (e.g., logic circuits), for executing program instructions. For example, the processor 220 may include interface circuits and processing circuits therein. The interface circuits may be configured to receive electronic signals from a bus 210, wherein the electronic signals encode structured data and/or instructions for the processing circuits to process. The processing circuits may conduct logic calculations, and then determine a conclusion, a result, and/or an instruction encoded as electronic signals. Then the interface circuits may send out the electronic signals from the processing circuits via the bus 210.
The exemplary computing device may include the internal communication bus 210, program storage and data storage of different forms including, for example, a disk 270, and a read-only memory (ROM) 230, or a random access memory (RAM) 240, for various data files to be processed and/or transmitted by the computing device. The exemplary computing device may also include program instructions stored in the ROM 230, RAM 240, and/or another type of non-transitory storage medium to be executed by the processor 220. The methods and/or processes of the present disclosure may be implemented as the program instructions. The computing device 200 also includes an I/O component 260, supporting input/output between the computer and other components. The computing device 200 may also receive programming and data via network communications.
Merely for illustration, only one CPU and/or processor is illustrated in
In order to implement various modules, units and their functions described above, a computer hardware platform may be used as hardware platforms of one or more elements (e.g., a component of the server 110 described in
The acquisition module 410 may obtain data from one or more components in the system 100 (e.g., the driver terminal 120 or the storage device 130). In some embodiments, the obtained data may include historical track data relating to a plurality of vehicles. In some embodiments, the obtained data may include a congestion period (e.g., rush hours in workdays). The acquisition module 410 may transmit the obtained data to storage (e.g., the storage device 130) for storing. The acquisition module 410 may transmit the obtained data to other modules of the processing engine 112 for further processing.
The discharge speed determination module 420 may determine a discharge speed based on the obtained historical track data. For example, the discharge speed determination module 420 may determine the discharge speed during the congestion period based on a portion of the historical track data. In some embodiments, the discharge speed determination module 420 may map the portion of historical track data to a cycle duration on a time-space diagram. In some embodiments, the discharge speed determination module 420 may determine a plurality of relative start time points of the plurality of vehicles. The discharge speed determination module 420 may determine the discharge speed based on the plurality of relative start time points of the plurality of vehicles.
The offset value determination module 430 may determine an offset value of a second traffic light relative to a first traffic light based on a length of the road, the discharge speed, a cycle length of the first traffic light, a cycle length of the second traffic light, and a time length of a green light of the second traffic light being lit. The cycle length of a traffic light refers to a periodical duration of the traffic light including a green light duration, a red light duration, and/or a yellow light duration. In some embodiments, the yellow-light duration may be considered to be included in the green-light duration or the red light duration. The first traffic light may be a traffic light at the downstream intersection. The second traffic light may be a traffic light at the upstream intersection. In some embodiments, the offset value determination module 430 may determine a relative time within a cycle at which the discharge wave from downstream intersection reaches upstream stop line of the upstream intersection. The offset value determination module 430 may further determine the offset value of the second traffic light relative to the first traffic light based on the relative time and the time length of a green light of the second traffic light. For example, the offset value determination module 430 may determine the offset value of the second traffic light relative to the first traffic light according to inequality (19).
The adjustment module 440 may determine a signal timing of the second traffic light based on the offset value. In some embodiments, the adjustment module 440 may delay the second traffic light for a time duration that is the offset value during the congestion period. For example, the adjustment module 440 may determine the signal timing of the second traffic light as illustrated in
It should be noted that the above description of the processing engine 112 is merely provided for the purposes of illustration, and not intended to limit the scope of the present disclosure. For persons having ordinary skills in the art, multiple variations and modifications may be made under the teachings of the present disclosure. For example, the processing engine 112 may further include a storage module facilitating data storage. However, those variations and modifications do not depart from the scope of the present disclosure.
It should be noted that the above description is merely provided for the purposes of illustration, and not intended to limit the scope of the present disclosure. For persons having ordinary skills in the art, multiple variations and modifications may be made under the teachings of the present disclosure. For example, the one-way road network 500 may include but not limited that two intersections, such as three intersections.
The time-space diagram in
where qc and ρc represent a flow rate and a density for a discharging traffic state, respectively, and qj and ρj represent the flow rate and the density for a jam traffic state, respectively. For those skilled in the art, the triangle fundamental model may be an essential model for researching a traffic problem and not described in detail in the present disclosure.
The queue length trajectory will increase if vehicles from the upstream join the queue (e.g., Stage (4)), and the queue length trajectory remain unchanged if no vehicle comes (e.g., Stage (5)). The decreasing lines (e.g., the bold dashed lines shown in Stage (6) in
l
r
+l
g
<l
0
+l
g≤2(lr+lg) (2),
where lg and lr denote the growth of the queue length in one green light period and one red light period, respectively. lg may be given by Equation (3) as follows:
lr may be given by Equation (4) as follows:
The queue length trajectory finally converges to a cyclic recurrent pattern shown by a combination of stages (7) to (10) in
l
max
=l
0+2lg (5).
In this case, Tmax denotes the duration that the maximum queue length lmax lasts. Equation (6) may be determined based on the similarity of triangles, as follows:
Then the value of Tmax may be determined by the Equation (7) as follows:
In some embodiments, given different initial values of l0, the processor may determine a general expression of lmax and Tmax as follows:
where function ceil(x) rounds x to the nearest integer towards infinity, function floor(x) rounds x to the nearest integer towards minus infinity, and function mod(x, y) refers to a reminder after dividing x by y.
As shown in
In some embodiments, a whole intersection spillover time (IST) may be divided into two distinct parts, a backward intersection spillover time (BIST) and a perpendicular intersection spillover time (PIST). The whole intersection spillover time may be described as follows:
IST=BIST+PIST (10).
In this case, the length of AB indicates BIST, and the length of BC indicates PIST. According to the similarity of triangles EAB, XCB and XDE, BIST and PIST may be determined according to Equation (12) and Equation (13), respectively, as follows:
where X is the nearest crossover point to the upstream intersection that is on both the upstream red wave and downstream green wave simultaneously. A value of lmax and a value of Tmax are given in Equations (8) and (9) above, and the position of X may be given by Equation (14) as follows:
In some embodiments, the BIST may be equal to zero; i,e., the IST is equal to the PIST, for example, the dashed circle 703 as shown in
Nevertheless, the case as illustrated in
BIST=Tmax (15),
PIST=0 (16).
It should be noted that Equations (10) and (11) still hold for the case illustrated in
Afterward, the queue may be discharged and re-formed cyclically similar to that in
For
In 902, the processor (e.g., the acquisition module 410 of the processing engine 112) may obtain historical track data of a plurality of vehicles that passed a road, an upstream intersection, and a downstream intersection over a historical period. The road may connect the upstream intersection and the downstream intersection. For example, as shown in
In 904, the processor (e.g., the acquisition module 410) may obtain a congestion period. In some embodiments, the congestion period is a predetermined period according to experience (e.g., rush hours of workdays), for example, 7:00 a.m. to 9:00 a.m. In some embodiments, the processor may obtain the predetermined congestion period from storage (e.g., the storage device 130). For example, the user may predetermine a congestion period via a terminal (e.g., a mobile phone). Then the predetermined congestion period may be stored in the storage device 130. The acquisition module 410 may obtain the predetermined congestion period from the storage device 130.
In some embodiments, the processor (e.g., the acquisition module 410) may obtain the congestion period based on the historical track data of a plurality of vehicles. For example, the processing engine 112 may determine a queue length of the vehicles between two adjacent intersections, i.e., the upstream intersection and the downstream intersection, based on the historical track data of the plurality of vehicles. The processing engine 112 may determine the congestion period based on the queue length. The acquisition module 410 may obtain the determined congestion period. Assuming that, during a time period (t1˜t2), if the queue length of the vehicles is greater than a threshold (e.g., the road length between the upstream intersection and the downstream intersection), or the queue spill to an adjacent road, the processing engine 112 may determine that the period (t1˜t2) is the congestion period. For another example, the processing engine 112 may determine the congestion period based on the average passing speed of a plurality of vehicles that passed the road. The acquisition module 410 may obtain a passing time of the vehicle when it passes through the road based on the historical track data. The processing engine 112 may further determine the passing speed of each of the plurality of vehicles that passed the road based on the road length and corresponding passing time of the each of the plurality of vehicles. The processing engine 112 may determine the average passing speed by dividing a sum of the corresponding passing speed of each vehicle by the number of the plurality of the vehicles. If the average passing speed of the plurality of vehicles during a period (t3˜t4) is slow, for example, the average passing speed is less than a value (e.g., 5 km/h, 10 km/h), the processing engine 112 may determine that the period (t3˜t4) is the congestion period.
In some embodiments, the processor (e.g., the acquisition module 410) may obtain the congestion period from a third party database (e.g., a map service provider, an official transport database), for example, rush hours in the morning or afternoon.
Merely for illustration, the processor may process the historical track data of the plurality of vehicles to generate a time-space diagram as illustrated in
In some embodiments, the processor may determine whether a period is a congestion period. For example, as shown in
In some embodiments, the processor may determine a passing time period of each of a plurality of vehicles that passes a road according to the time-space diagram. For example, the processor may obtain a start time point when the vehicle passes the upstream intersection, and/or a finishing time point when the vehicle passes the downstream intersection. The start time point refers to the time point corresponding to the start point of the trajectory of a vehicle. The finishing time point refers to the time point corresponding to the finishing point of the trajectory of the vehicle. The processor may determine the time duration between the start time point and the finishing time point as the passing time period of the vehicle. The processor may also determine the passing speed of each of the plurality of vehicles that passes the road based on the road length and corresponding passing time period of the each of the plurality of vehicles. The processor may further determine the average passing speed based on the determined passing speeds of the vehicles. If the average passing speed of the plurality of vehicles during a period is slow, for example, the average passing speed is less than a value (e.g., 5 km/h, 10 km/h), the processor may determine that the period is the congestion period.
In 906, the processor (e.g., the discharge speed determination module 420) may determine a discharge speed during the congestion period based on a portion of the historical track data. The portion of the historical track data refers to historical track data of the plurality of vehicles during the congestion period (e.g., 7:00 a.m. to 9:00 a.m. on a workday). For example, the acquisition module 410 may obtain historical track data of a plurality of vehicles that passed through an intersection (e.g., the downstream intersection B shown in
In some embodiments, the processor may determine a relative start time point of each of a plurality of first vehicles based on the historical track data. The first vehicles may include the vehicles that started to move from a stop condition and crossed the boundary between the road and the downstream intersection during one period of the green light of the first traffic light being lit. For example, the processor may obtain an actual start time point of each of the plurality of first vehicles, and a start time point of the period of the green light of the first traffic light being lit. The processor may further determine the relative start time point based on the actual start time point of the first vehicle and the start time point of the period of the green light of the first traffic light being lit. For example, the actual start time point of the first vehicle is at a time point A. The start time point of the period of the green light of the first traffic light is at a time point B. Given that the discharge wave may start to propagate backward to the upstream with a discharge speed at the start time point of the period of the green light of the first traffic light, the time point A is later than the time point B. The processor may determine a relative time length of the first vehicle based on the difference between the time point A and the time point B (i.e., A−B). In a cycle duration, the start time point of the green light may be designated as a reference time point (e.g., r1 as shown in
The processor may determine the discharge speed based on the relative time points of the plurality of first vehicles. For example, the processor may determine the corresponding positions of the plurality of first vehicles at the relative time points. The processor may further determine the discharge speed based on the relative time points of the plurality of first vehicles and the corresponding positions of the plurality of first vehicles at the relative time points. For example, the processor may fit track points corresponding to the relative start time points and the corresponding positions to a straight line based on a linear fitting method (e.g., the fitted straight line 1322 shown in
In 908, the processor (e.g., the offset value determination module 430) may determine an offset value of the second traffic light relative to the first traffic light based on the length of the road, the discharge speed, the cycle length of the first traffic light, the cycle length of a second traffic light, and the time length of the green light of the second traffic light being lit. The second traffic light refers to a traffic light at the upstream intersection, and the first traffic light refers to a traffic light at the downstream intersection. As used herein, the offset value of the second traffic light relative to the first traffic light refers to a difference value between a start time point of light-cycle of the first traffic light, and a corresponding start time point of light-cycle of the second traffic light (considering that the cycle lengths of the first traffic light and the second traffic light are same). For example, at about 9:00 in the morning, the green light of the first traffic light may start to being lit at 9:01, while the green light of the second traffic light may start to being lit at 9:02. The offset value of the second traffic light relative to the first traffic light is the difference between the two time points; that is, 1 minute. For controlling the queue spillover, it is desired to let the discharge wave from the downstream intersection reaches a stop line of the upstream intersection during the time duration of the green light of the second traffic light being lit. The processor may determine the offset value of the second traffic light relative to the first traffic light, such that the discharge wave from the downstream intersection reaches a stop line of the upstream intersection during the time duration of the green light of the second traffic light. In some embodiments, the processor may further determine the offset value of the second traffic light relative to the first traffic light based on a relative time within a cycle at which the discharge wave from downstream intersection reaches upstream stop line. In some embodiments, the relative time may be determined based on Equation (18) as follows:
where ti denotes the relative time within a cycle at which the discharge wave from downstream intersection reaches upstream stop line for a road i, δi denotes the offset value, Li denotes the length of the road i, ωi denotes the discharge speed, c denotes a cycle length of a traffic light, and function mod (x,y) is the reminding after dividing x by y. The length of the road Li may include the length of the upstream intersection. For example, as shown in
where gi denotes the time length of green light of the second traffic light being lit. There may be an offset value range that all offset values included in the offset value range may satisfy the inequality (19). For example, the solution of the offset value range, and δi∈[0, c). In some embodiments, the offset value determination module 430 may obtain the length of the road Li, the discharge speed ωi, the cycle length of the traffic light c, and gi from a storage device (e.g., the storage device 130). The processor may further determine the offset value based on the determined offset value range. For example, the offset value may be a value within the determine offset value range.
In 910, the processor (e.g., the adjustment module 440) may determine a signal timing of the second traffic light based on the offset value. The signal timing of a traffic light refers to a periodical rule of a plurality of repeated cycles of a traffic light being lit. A cycle of a traffic light may include a green-light duration and a red-light duration. The green-light duration may be a constant value (e.g., g0), and the red-light duration may be a constant value (e.g., r0).
In some embodiments, at a start time point of the congestion period, the processor may determine the signal timing of the second traffic light by control the second traffic light to delay for the offset value relative to the first traffic light. For example, as illustrated in
In some embodiments, the processor may determine the signal timing of the second traffic light based on a first time point that the green light of the first traffic light starts to be on for a first time and the offset value. More specifically, the processor may determine a first time point that the green light of first traffic light starts to be lit for a first time. The processor may determine a second time point that the green light of the second traffic light starts to be lit, based on the first time point and the offset value. For example, the second time point may be equal to a sum of the first time point and the offset value. The processor may extend a period of red light of the second traffic light to the second time point. Then processor may cause the green light of the second traffic light to be lit at the second point.
In 1102, the processor (e.g., the discharge speed determination module 420) may determine a relative start time point based on historical data corresponding to each of a plurality of first vehicles. The first vehicles may include the vehicles that started to move from a stop condition and crossed the downstream stop line of the road during one period of the green light of the first traffic light being lit. The first traffic light may be the traffic light being at the downstream intersection. The historical track data may include positions of the plurality of first vehicles on the road and corresponding time points at which the plurality of first vehicles at the positions. In some embodiments, the processor may obtain the actual start time of the first vehicle based on historical track data of the first vehicle. The process may obtain a start time point of the period of the green light of the first traffic light being lit. The processor may further determine the relative start time point based on the actual start time point of the each of the plurality of first vehicles and the start time point of the period of the green light of the first traffic light being lit. For example, the discharge speed determination module 420 may designate the start time point of the green light being lit as a reference time point. The discharge speed determination module 420 may also designate the difference between the actual start time point of the first vehicle and the start time point of the green light as a relative time length. The discharge speed determination module 420 may further determine the relative start time point based on the reference time point and the relative time length. For example, the actual start time point of the first vehicle is at a time point A. The start time point of the period of the green light of the first traffic light is at a time point B. Given that the discharge wave may start to propagate back to the upstream with a discharge speed at the start time point of the period of the green light of the first traffic light, the time point A is later than the time point B. The processor may determine a relative time length of the first vehicle based on the difference between the time point A and the time point B (i.e., A−B). In a cycle duration, the start time point of the green light may be designated as a reference time point (e.g., r1 as shown in
In 1104, the processor (e.g., the discharge speed determination module 420) may determine a discharge speed based on the relative start time points of the plurality of first vehicles. More specifically, the processor may determine the discharge speed based on the relative start time points of the plurality of first vehicles and the corresponding positions of the vehicles at the relative start time points.
The time points when the plurality of first vehicles passed the road may not be in the same cycle. For example, as shown in
Merely for illustration, as illustrated in
In 1202, the processor may obtain an actual start time point of each of a plurality of first vehicles when each of the plurality of first vehicles started to move from a stop condition and crossed the boundary between the road and the downstream intersection during a period of the green light of first traffic light being lit. The first traffic light may be a traffic light at the downstream intersection. The boundary between the road and the downstream intersection may be a stop line of the downstream intersection (herein also referred to as the downstream intersection). The processor may obtain the actual start time of a first vehicle from historical track data of that first vehicle. The historical track data of a first vehicle may include the positions of the first vehicle at various time points. For example, the processor may obtain a historical track point where the first vehicle started to move from a stop condition. The processor may obtain the actual start time of the first vehicle based on the historical track point.
In 1204, the processor may obtain a start time point of the period of the green light of the first traffic light being lit. In some embodiments, the acquisition module 410 may obtain the start time point of the green light of the first traffic light using a loop detector on the road. The loop detector may detect the time information of the first traffic light, for example, the start time point of the green light or the red light and the time duration of the green light or red light being lit. In some embodiments, the processor may obtain the start time point of the green light of the first traffic light from a database (e.g., an official transport database).
In 1206, the processor may determine the relative start time point based on the actual start time point of the each of the plurality of first vehicles and the start time point of the period of the green light of the first traffic light being lit. For example, the discharge speed determination module 420 may designate the start time point of the green light being lit as a reference time point. The discharge speed determination module 420 may also designate the difference between the actual start time point of the first vehicle and the start time point of the green light as a relative time length. The discharge speed determination module 420 may determine the relative start time point based on the reference time point and the relative time length (e.g., based on the descriptions in 906).
The process 900 as illustrated in
Having thus described the basic concepts, it may be rather apparent to those skilled in the art after reading this detailed disclosure that the foregoing detailed disclosure is intended to be presented by way of example only and is not limiting. Various alterations, improvements, and modifications may occur and are intended to those skilled in the art, though not expressly stated herein. These alterations, improvements, and modifications are intended to be suggested by this disclosure, and are within the spirit and scope of the exemplary embodiments of this disclosure.
Moreover, certain terminology has been used to describe embodiments of the present disclosure. For example, the terms “one embodiment,” “an embodiment,” and “some embodiments” mean that a particular feature, structure or characteristic described in connection with the embodiment is included in at least one embodiment of the present disclosure. Therefore, it is emphasized and should be appreciated that two or more references to “an embodiment” or “one embodiment” or “an alternative embodiment” in various portions of this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures or characteristics may be combined as suitable in one or more embodiments of the present disclosure.
Further, it will be appreciated by one skilled in the art, aspects of the present disclosure may be illustrated and described herein in any of a number of patentable classes or context including any new and useful process, machine, manufacture, or composition of matter, or any new and useful improvement thereof. Accordingly, aspects of the present disclosure may be implemented entirely hardware, entirely software (including firmware, resident software, micro-code, etc.) or combining software and hardware implementation that may all generally be referred to herein as a “module,” “unit,” “component,” “device,” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer-readable media having computer readable program code embodied thereon.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including electro-magnetic, optical, or the like, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that may communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device. Program code embodied on a computer readable signal medium may be transmitted using any appropriate medium, including wireless, wireline, optical fiber cable, RF, or the like, or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object-oriented programming language such as Java, Scala, Smalltalk, Eiffel, JADE, Emerald, C++, C#, VB. NET, Python or the like, conventional procedural programming languages, such as the “C” programming language, Visual Basic, Fortran 2003, Perl, COBOL 2002, PHP, ABAP, dynamic programming languages such as Python, Ruby, and Groovy, or other programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider) or in a cloud computing environment or offered as a service such as a Software as a Service (SaaS).
Furthermore, the recited order of processing elements or sequences, or the use of numbers, letters, or other designations, therefore, is not intended to limit the claimed processes and methods to any order except as may be specified in the claims. Although the above disclosure discusses through various examples what is currently considered to be a variety of useful embodiments of the disclosure, it is to be understood that such detail is solely for that purpose and that the appended claims are not limited to the disclosed embodiments, but, on the contrary, are intended to cover modifications and equivalent arrangements that are within the spirit and scope of the disclosed embodiments. For example, although the implementation of various components described above may be embodied in a hardware device, it may also be implemented as a software-only solution, e.g., an installation on an existing server or mobile device.
Similarly, it should be appreciated that in the foregoing description of embodiments of the present disclosure, various features are sometimes grouped together in a single embodiment, figure, or description thereof for the purpose of streamlining the disclosure aiding in the understanding of one or more of the various embodiments. This method of disclosure, however, is not to be interpreted as reflecting an intention that the claimed subject matter requires more features than are expressly recited in each claim. Rather, claim subject matter lie in less than all features of a single foregoing disclosed embodiment.
This application is a Continuation of International Application No. PCT/CN2018/096931, filed on Jul. 25, 2018, the contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2018/096931 | Jul 2018 | US |
Child | 16220250 | US |