The present disclosure generally relates to management of spatial big data, and more specifically, relates to systems and methods for joining data sets.
In the Internet era, an online on-demand service platform may receive, from its users or other entities, a spatial big data set including real time or historical locations of the users. A joining operation may be performed to combine the spatial big data set with another dada set. For example, a joining operation may be performed to compare a spatial big data set with a data set including a road network map to determine a new road not included in the road network map. However, because the amount of data in a spatial big data set is extremely large, it is difficult to process the spatial big data set efficiently. Therefore, it is desirable to provide systems and methods for joining data sets to process a spatial big data set efficiently.
According to a first aspect of the present disclosure, a data processing electronic system to optimize Spatial Big Data partitions may include at least one storage device and at least one processor configured to communicate with the at least one storage device. The at least one storage device may include a set of instructions. When executing 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 a first data set. The first data set may be a Spatial Big Data set associated with spatial information within a target region. The at least one processor may divide the first data set into a plurality of first preliminary partitions based on the spatial information. The at least one processor may determine a first spatial index for the first data set based on the plurality of first preliminary partitions. The at least one processor may generate a plurality of first modified partitions by obtaining a plurality of first boundary data sets associated with the plurality of first preliminary partitions based on the first spatial index and conducting a first shuffling operation to the plurality of first boundary data sets. The plurality of first boundary data sets may include data associated with one or more first regions surrounding the plurality of first preliminary partitions.
In some embodiments, the at least one processor may determine a spatial index range for each of the plurality of first preliminary partitions based on the first spatial index. The at least one processor may determine the plurality of first boundary data sets associated with the plurality of first preliminary partitions based on the spatial index ranges of the plurality of first preliminary partitions.
In some embodiments, the at least one processor may conduct distribute computation to the plurality of first preliminary partitions to generate the plurality of first modified partitions according to a distributed computing method.
In some embodiments, the at least one processor may obtain a second data set within the target region. The at least one processor may divide the second data set into a plurality of second preliminary partitions. The at least one processor may determine a second spatial index for the second data set based on the plurality of second preliminary partitions. The at least one processor may conduct distributed computation to the plurality of second preliminary partitions to generate a plurality of second modified partitions according to the distributed computing method and the second spatial index.
In some embodiments, to generate the plurality of second modified partitions, the at least one processor may obtain a plurality of second boundary data sets associated with the plurality of second preliminary partitions based on the second spatial index. The plurality of second boundary data sets may include data associated with one or more second regions surrounding the plurality of second preliminary partitions. The at least one processor may conduct a second shuffling operation to the plurality of second boundary data sets to generate the plurality of second modified partitions.
In some embodiments, the at least one processor may join at least one of the plurality of first modified partitions in the first data set and at least one of the plurality of second modified partitions in the second data set.
In some embodiments, the first data set may include tracing points of a plurality of user terminals communicated with the electronic system, and the second data set includes road network information of the target region.
In some embodiments, for each of the plurality of second modified partitions, a location of the second modified partition, an area of the second modified partition, and a shape of the second modified partition may be same as one of the plurality of first modified partitions.
In some embodiments, the first spatial index or the second spatial index may be associated with at least one of a Hilbert curve or a Z-curve.
In some embodiments, the distributed computing method may include at least one of Spark framework, Hadoop, Phoenix, Disco, or Mars.
According to another aspect of the present disclosure, a method to optimize Spatial Big Data partitions may include one or more of the following operations. At least one processor may obtain a first data set. The first data set may be a Spatial Big Data set associated with spatial information within a target region. The at least one processor may divide the first data set into a plurality of first preliminary partitions based on the spatial information. The at least one processor may determine a first spatial index for the first data set based on the plurality of first preliminary partitions. The at least one processor may generate a plurality of first modified partitions by obtaining a plurality of first boundary data sets associated with the plurality of first preliminary partitions based on the first spatial index and conducting a first shuffling operation to the plurality of first boundary data sets. The plurality of first boundary data sets may include data associated with one or more first regions surrounding the plurality of first preliminary partitions.
According to yet another aspect of the present disclosure, a non-transitory computer readable medium may comprise at least one set of instructions. The at least one set of instructions may be executed by at least one processor of a computer server. The at least one processor may obtain a first data set. The first data set may be a Spatial Big Data set associated with spatial information within a target region. The at least one processor may divide the first data set into a plurality of first preliminary partitions based on the spatial information. The at least one processor may determine a first spatial index for the first data set based on the plurality of first preliminary partitions. The at least one processor may generate a plurality of first modified partitions by obtaining a plurality of first boundary data sets associated with the plurality of first preliminary partitions based on the first spatial index and conducting a first shuffling operation to the plurality of first boundary data sets. The plurality of first boundary data sets may include data associated with one or more first regions surrounding the plurality of first preliminary partitions.
According to yet another aspect of the present disclosure, a system to optimize Spatial Big Data partitions may include an obtaining module configured to obtain a first data set. The first data set may be a Spatial Big Data set associated with spatial information within a target region. The system may also include a data set processing module configured to divide the first data set into a plurality of first preliminary partitions based on the spatial information and determine a first spatial index for the first data set based on the plurality of first preliminary partitions. The system may also include an extension module configured to generate a plurality of first modified partitions by obtaining a plurality of first boundary data sets associated with the plurality of first preliminary partitions based on the first spatial index and conducting a first shuffling operation to the plurality of first boundary data sets. The plurality of first boundary data sets may include data associated with one or more first regions surrounding the plurality of first preliminary partitions.
Additional features will be set forth in part in the description which follows, and in part will become apparent to those skilled in the art upon examination of the following and the accompanying drawings or may be learned by production or operation of the examples. The features of the present disclosure may be realized and attained by practice or use of various aspects of the methodologies, instrumentalities, and combinations set forth in the detailed examples discussed below.
The present disclosure is further described in terms of exemplary embodiments. These exemplary embodiments are described in detail with reference to the drawings. These embodiments are non-limiting exemplary embodiments, in which like reference numerals represent similar structures throughout the several views of the drawings, and wherein:
The following description is presented to enable any person skilled in the art to make and use the present disclosure, and is provided in the context of a particular application and its requirements. Various modifications to the disclosed embodiments will be readily apparent to those skilled in the art, and the general principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the present disclosure. Thus, the present disclosure is not limited to the embodiments shown, but is to be accorded the widest scope consistent with the claims.
The terminology used herein is for the purpose of describing particular example embodiments only and is not intended to be limiting. As used herein, the singular forms “a,” “an,” and “the” may be intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprise,” “comprises,” and/or “comprising,” “include,” “includes,” and/or “including,” when used in this disclosure, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
These and other features, and characteristics of the present disclosure, as well as the methods of operations and functions of the related elements of structure, and the combination of parts and economies of manufacture, may become more apparent upon consideration of the following description with reference to the accompanying drawings, all of which form part of this disclosure. It is to be expressly understood, however, that the drawings are for the purpose of illustration and description only and are not intended to limit the scope of the present disclosure. It is understood that the drawings are not to scale.
The flowcharts used in the present disclosure illustrate operations that systems implement according to some embodiments of the present disclosure. It is to be expressly understood, the operations of the flowchart may be implemented not in order. Conversely, the operations may be implemented in inverted order, or simultaneously. Moreover, one or more other operations may be added to the flowcharts. One or more operations may be removed from the flowcharts.
Moreover, while the systems and methods disclosed in the present disclosure are described primarily regarding joining data sets, it should also be understood that this is only one exemplary embodiment. The system or method of the present disclosure may be applied to any application scenario which may produce spatial big data. For example, the system and method of the present disclosure may be applied to different transportation systems including land, ocean, aerospace, or the like, or any combination thereof. The vehicle of the transportation systems may include a taxi, a private car, a hitch, a bus, a train, a bullet train, a high speed rail, a subway, a vessel, an aircraft, a spaceship, a hot-air balloon, a driverless vehicle, a bicycle, a tricycle, a motorcycle, or the like, or any combination thereof. The system and method of the present disclosure may be applied to taxi hailing, chauffeur services, delivery service, carpool, bus service, take-out service, driver hiring, vehicle hiring, bicycle sharing service, train service, subway service, shuttle services, location service, or the like, among others. As used here, big data refers to data of which the amount is large to the extent that requires indexing for efficient processing.
The positioning technology used in the present disclosure may include a global positioning system (GPS), a global navigation satellite system (GLONASS), a compass navigation system (COMPASS), a Galileo positioning system, a quasi-zenith satellite system (QZSS), a wireless fidelity (WiFi) positioning technology, or the like, or any combination thereof. One or more of the above positioning technologies may be used interchangeably in the present disclosure.
An aspect of the present disclosure relates to systems and methods for joining data sets. Systems and methods in the present disclosure may be configured to join road network data sets with spatial big data sets including enormous (from a few billions to thousands of billion-scale) tracing points of user terminals communicated with an online on-demand service platform. To this end, the systems and methods provide an indexing system to support effectively management and processing of the data sets. According to embodiments of the present disclosure, the systems and methods may divide the special big data set into partitions and individually index each of the partitions. The systems and methods then may modify each of the partitions by adding thereto boundary data sets of regions surrounding the partitions and shuffle the boundary data sets. The systems and methods may do the same to the road network data set. When the online on-demand service platform needs to join a few partitions of the two data sets, such as when a user of the platform wants to know whether there is new road not included in an existing road network map, the above indexing systems of the two data sets may facilitate searching and joining of data from the two data sets in the corresponding partitions, especially when the data scale of the two data sets are of billion-scale and larger and the searching and joining operation is required to be completed in microseconds or nanoseconds.
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., 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 user terminal 140, and/or the storage device 150 via the network 120. As another example, the server 110 may be directly connected to the user terminal 140, and/or the storage device 150 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 200 having one or more components illustrated in
In some embodiments, the server 110 may include a processing engine 112. The processing engine 112 may process information and/or data to perform one or more functions described in the present disclosure. For example, the processing engine 112 may perform a shuffling operation on a partition in a spatial big data set. 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 one or more hardware processors, such as 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.
The network 120 may facilitate the exchange of information and/or data. In some embodiments, one or more components in the on-demand service system 100 (e.g., the server 110, the user terminal 140, the storage device 150, and the positioning system 160) may send information and/or data to other component(s) in the on-demand service system 100 via the network 120. For example, the processing engine 112 may obtain a plurality of data points from the storage device 150 and/or the user terminal 140 via the network 120. In some embodiments, the network 120 may be any type of wired or wireless network, or a combination thereof. Merely by way of example, the network 120 may include a cable network, a wireline network, an optical fiber network, a telecommunications network, an intranet, the 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, or the like, or any combination thereof. In some embodiments, the network 120 may include one or more network access points. For example, the network 120 may include wired or wireless network access points such as base stations and/or internet exchange points 120-1, 120-2, . . . , through which one or more components of the on-demand service system 100 may be connected to the network 120 to exchange data and/or information.
In some embodiments, the user terminal 140 may include a mobile device 140-1, a tablet computer 140-2, a laptop computer 140-3, or the like, or any combination thereof. In some embodiments, the mobile device 140-1 may include a smart home device, a wearable device, a mobile equipment, 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 bracelet, footgear, glasses, a helmet, a watch, clothing, a backpack, a smart accessory, or the like, or any combination thereof. In some embodiments, the mobile equipment may include a mobile phone, a personal digital assistance (PDA), a gaming device, a navigation device, a point of sale (POS) device, a laptop, a desktop, or the like, or any combination thereof. In some embodiments, the virtual reality device and/or the augmented reality device may include a virtual reality helmet, a virtual reality glass, a virtual reality patch, an augmented reality helmet, augmented reality glasses, an augmented reality patch, or the like, or any combination thereof. For example, the virtual reality device and/or the augmented reality device may include a Google Glass™, a RiftCon™, a Fragments™, a Gear VR™, etc. In some embodiments, the user terminal 140 may be a device with positioning technology for locating the position of the user terminal 140. In some embodiments, the user terminal 140 may send positioning information to the server 110.
The storage device 150 may store data and/or instructions. In some embodiments, the storage device 150 may store data obtained from the user terminal 140 and/or the processing engine 112. For example, the storage device 150 may store a plurality of data points obtained from the user terminal 140. As another example, the storage device 150 may store a shuffled partition in a spatial big data set determined by the processing engine 112. In some embodiments, the storage device 150 may store data and/or instructions that the server 110 may execute or use to perform exemplary methods described in the present disclosure. For example, the storage device 150 may store instructions that the processing engine 112 may execute or user to perform a shuffling operation on a partition in a spatial big data set. In some embodiments, the storage device 150 may include a mass storage, a 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 a 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 thyrisor 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 (EPROM), 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 150 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 150 may be connected to the network 120 to communicate with one or more components in the on-demand service system 100 (e.g., the server 110, the user terminal 140, etc.). One or more components in the on-demand service system 100 may access the data or instructions stored in the storage device 150 via the network 120. In some embodiments, the storage device 150 may be directly connected to or communicate with one or more components in the on-demand service system 100 (e.g., the server 110, the user terminal 140, etc.). In some embodiments, the storage device 150 may be part of the server 110.
The positioning system 160 may determine information associated with an object, for example, the user terminal 140. For example, the positioning system 160 may determine a location of the user terminal 140 in real time. In some embodiments, the positioning system 160 may be a global positioning system (GPS), a global navigation satellite system (GLONASS), a compass navigation system (COMPASS), a BeiDou navigation satellite system, a Galileo positioning system, a quasi-zenith satellite system (QZSS), etc. The information may include a location, an elevation, a velocity, or an acceleration of the object, an accumulative mileage number, or a current time. The location may be in the form of coordinates, such as, latitude coordinate and longitude coordinate, etc. The positioning system 160 may include one or more satellites, for example, a satellite 160-1, a satellite 160-2, and a satellite 160-3. The satellites 160-1 through 160-3 may determine the information mentioned above independently or jointly. The satellite positioning system 160 may send the information mentioned above to the network 120, or the user terminal 140 via wireless connections.
The processor 210 (e.g., logic circuits) may execute computer instructions (e.g., program code) and perform functions of the processing engine 112 in accordance with techniques described herein. For example, the processor 210 may include interface circuits 210-a and processing circuits 210-b therein. The interface circuits may be configured to receive electronic signals from a bus (not shown in
The computer instructions may include, for example, routines, programs, objects, components, data structures, procedures, modules, and functions, which perform particular functions described herein. For example, the processor 210 may process a plurality of data points obtained from the user terminal 140, the storage device 150, and/or any other component of the on-demand service system 100. In some embodiments, the processor 210 may include one or more hardware processors, such as a microcontroller, a microprocessor, a reduced instruction set computer (RISC), an application specific integrated circuits (ASICs), an application-specific instruction-set processor (ASIP), a central processing unit (CPU), a graphics processing unit (GPU), a physics processing unit (PPU), a microcontroller unit, a digital signal processor (DSP), a field programmable gate array (FPGA), an advanced RISC machine (ARM), a programmable logic device (PLD), any circuit or processor capable of executing one or more functions, or the like, or any combinations thereof.
Merely for illustration, only one processor is described in the computing device 200. However, it should be noted that the computing device 200 in the present disclosure may also include multiple processors, thus operations and/or method steps that are performed by one processor as described in the present disclosure may also be jointly or separately performed by the multiple processors. For example, if in the present disclosure the processor of the computing device 200 executes both step A and step B, it should be understood that step A and step B may also be performed by two or more different processors jointly or separately in the computing device 200 (e.g., a first processor executes step A and a second processor executes step B, or the first and second processors jointly execute steps A and B).
The storage 220 may store data/information obtained from the user terminal 140, the storage device 150, and/or any other component of the on-demand service system 100. In some embodiments, the storage 220 may include a mass storage, a removable storage, a volatile read-and-write memory, a read-only memory (ROM), or the like, or any combination thereof. For example, the mass storage may include a magnetic disk, an optical disk, a solid-state drives, etc. The removable storage may include a flash drive, a floppy disk, an optical disk, a memory card, a zip disk, a magnetic tape, etc. The volatile read-and-write memory may include a random access memory (RAM). The 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. The ROM may include a mask ROM (MROM), a programmable ROM (PROM), an erasable programmable ROM (EPROM), an electrically erasable programmable ROM (EEPROM), a compact disk ROM (CD-ROM), and a digital versatile disk ROM, etc. In some embodiments, the storage 220 may store one or more programs and/or instructions to perform exemplary methods described in the present disclosure. For example, the storage 220 may store a program for the processing engine 112 for performing a shuffling operation on a partition in a spatial big data set.
The I/O 230 may input and/or output signals, data, information, etc. In some embodiments, the I/O 230 may enable a user interaction with the processing engine 112. In some embodiments, the I/O 230 may include an input device and an output device. Examples of the input device may include a keyboard, a mouse, a touch screen, a microphone, or the like, or a combination thereof. Examples of the output device may include a display device, a loudspeaker, a printer, a projector, or the like, or a combination thereof. Examples of the display device may include a liquid crystal display (LCD), a light-emitting diode (LED)-based display, a flat panel display, a curved screen, a television device, a cathode ray tube (CRT), a touch screen, or the like, or a combination thereof.
The communication port 240 may be connected to a network (e.g., the network 120) to facilitate data communications. The communication port 240 may establish connections between the processing engine 112 and the user terminal 140, the positioning system 160, or the storage device 150. The connection may be a wired connection, a wireless connection, any other communication connection that can enable data transmission and/or reception, and/or any combination of these connections. The wired connection may include, for example, an electrical cable, an optical cable, a telephone wire, or the like, or any combination thereof. The wireless connection may include, for example, a Bluetooth™ link, a Wi-Fi™ link, a WiMax™ link, a WLAN link, a ZigBee link, a mobile network link (e.g., 3G, 4G, 5G, etc.), or the like, or a combination thereof. In some embodiments, the communication port 240 may be and/or include a standardized communication port, such as RS232, RS485, etc.
To implement various modules, units, and their functionalities described in the present disclosure, computer hardware platforms may be used as the hardware platform(s) for one or more of the elements described herein. A computer with user interface elements may be used to implement a personal computer (PC) or any other type of work station or terminal device. A computer may also act as a server if appropriately programmed.
One of ordinary skill in the art would understand that when an element of the on-demand service system 100 performs, the element may perform through electrical signals and/or electromagnetic signals. For example, when the processing engine 112 processes a task, such as making a determination, or identifying information, the processing engine 112 may operate logic circuits in its processor to process such task. When the processing engine 112 receives data (e.g., a plurality of data points) from the user terminal 140, a processor of the processing engine 112 may receive electrical signals including the data. The processor of the processing engine 112 may receive the electrical signals through an input port. If the user terminal 140 communicates with the processing engine 112 via a wired network, the input port may be physically connected to a cable. If the user terminal 140 communicates with the processing engine 112 via a wireless network, the input port of the processing engine 112 may be one or more antennas, which may convert the electrical signals to electromagnetic signals. Within an electronic device, such as the user terminal 140, and/or the server 110, when a processor thereof processes an instruction, sends out an instruction, and/or performs an action, the instruction and/or action is conducted via electrical signals. For example, when the processor retrieves or saves data from a storage medium (e.g., the storage device 150), it may send out electrical signals to a read/write device of the storage medium, which may read or write structured data in the storage medium. The structured data may be transmitted to the processor in the form of electrical signals via a bus of the electronic device. Here, an electrical signal may refer to one electrical signal, a series of electrical signals, and/or a plurality of discrete electrical signals.
The obtaining module 401 may be configured to obtain a data set, such as a first data set including a plurality of data points associated with spatial information within a target region, and/or a second data set including road network information within a target region. In some embodiments, the obtaining module 401 may obtain the data set from the storage medium (e.g., the storage device 150, or the storage 220 in the computing device 200).
The data set processing module 403 may be configured to divide the data set into a plurality of preliminary partitions and determine a spatial index for the data set based on the plurality of preliminary partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
The extension module 405 may be configured to generate a plurality of modified partitions based on the plurality of preliminary partitions. In some embodiments, the extension module 405 may determine a boundary data set for each of the plurality of preliminary partitions and perform a shuffling operation on the boundary data set for each of the plurality of first preliminary partitions to determine the plurality of modified partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
The joining module 407 may be configured to join two data sets. In some embodiments, the joining module 407 may join at least one of a plurality of first modified partitions in a first data set and at least one of a plurality of second modified partitions in a second data set.
The modules in the processing engine 112 may be connected to or communicate with each other via a wired connection or a wireless connection. The wired connection may include a metal cable, an optical cable, a hybrid cable, or the like, or any combination thereof. The wireless connection may include a Local Area Network (LAN), a Wide Area Network (WAN), a Bluetooth, a ZigBee, a Near Field Communication (NFC), or the like, or any combination thereof. Two or more of the modules may be combined as a single module, and any one of the modules may be divided into two or more units. For example, the data set processing module 403 may be integrated in the extension module 405 as a single module which may both determine a plurality of preliminary partitions and a plurality of modified partitions. As another example, the data set processing module 403 may be divided into two units. The first unit may be configured to determine a plurality of preliminary partitions. The second unit may be configured to determine a spatial index based on the plurality of preliminary partitions.
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. However, those variations and modifications do not depart from the scope of the present disclosure. For example, the processing engine 112 may further include a storage module (not shown in
Systems and methods in the present disclosure may be configured to join road network data sets with spatial big data sets including enormous (from a few billions to thousands of billion-scale) tracing points of user terminals communicated with an online on-demand service platform. To this end, the systems and methods provide an indexing system to support effectively management and processing of the data sets. According to embodiments of the present disclosure, the systems and methods may divide the special big data set into partitions and individually index each of the partitions. The systems and methods then may modify each of the partitions by adding thereto boundary data sets of regions surrounding the partitions and shuffle the boundary data sets. The systems and methods may do the same to the road network data set. When the online on-demand service platform needs to join a few partitions of the two data sets, such as when a user of the platform wants to know whether there is new road not included in an existing road network map, the above indexing systems of the two data sets may facilitate searching and joining of data from the two data sets in the corresponding partitions, especially when the data scale of the two data sets are of billion-scale and larger and the searching and joining operation is required to be completed in microseconds or nanoseconds.
In 501, the obtaining module 401 (and/or the processing engine 112, and/or the interface circuits 210-a) may obtain a first data set associated with spatial information within a target region. In some embodiments, the processing engine 112 may obtain the first data set from the storage medium (e.g., the storage device 150, or the storage 220 in the computing device 200).
As used herein, the first data set may be a spatial big data set including a plurality of data points. Each data point may be a spatial coordinate or a representation of the location of a user terminal (e.g., a mobile device such as a smart phone) that is in communication with the online on-demand transportation platform 100. When a passenger or a driver holding the user terminal moves in a region, the platform 100 (or the server 110, the processor 220 etc.) may collect the location of the user terminal at certain frequency and record the location in the spatial big data set. Over time, the location of the user terminal may form a series of tracing points in the spatial big data set. Since there are millions of mobile devices in communication with the platform 100 every seconds, the number of the plurality of data points may be numerous. For example, the number of the plurality of data points may be in billion-scale (e.g., hundreds of billions). Commercially, when the platform 100 receives a request to search and/or process the spatial big data set, platform must return a result to the request in microseconds or nanoseconds. Therefore, the spatial big data set must be properly indexed to support the above processing requirement. The term “user” in the present disclosure may refer to an individual, an entity, or a tool that may request a service, order a service, provide a service, or facilitate the providing of the service. In the present disclosure, the terms “user” and “user terminal” may be used interchangeably.
Each of the plurality of data points may include spatial information. The spatial information of a data point included in the first data set may include a time point and a geographic location of a user corresponding to the data point at the time point. In some embodiments, the geographic location may be represented by coordinates of latitude and longitude, an address, or a point of interest (POI) name, or a combination thereof. In some embodiments, the plurality of data points may correspond to a certain time period and/or a target region. For example, the obtaining module 410 may obtain a plurality of data points corresponding to one day in Beijing.
In some embodiments, the user terminal 140 may establish a communication (e.g., a wireless communication) with the processing engine 112 and/or the storage device 150, via an application installed in the user terminal 140. The application may be associated with the on-demand service system 100. For example, the application may be a taxi-hailing application or a navigation application. The provider terminal 140 may obtain a location of a user through a positioning technology in the user terminal 140, for example, a GPS, a GLONASS, a COMPASS, a QZSS, a WiFi positioning technology, or the like, or any combination thereof. The application may direct the user terminal 140 to constantly or periodically send the real time or historical location of the user to the processing engine 112 and/or the storage device 150. Consequently, the processing engine 112 and/or the storage device 150 may receive the location of the user in real time or substantially real time. In addition, the processing engine 112 and/or the storage device 150 may also receive a historical location of the user corresponding to a specific time point or time period.
In some embodiments, each of the plurality of data points may further include a user identification (ID) of a user corresponding to the data point. The user may register an account of the application when the user first uses the application. The processing engine 112 may generate a user ID for the user after the user registration. The application may direct the user terminal 140 to send the user ID to the processing engine 112 and/or the storage device 150 along with the real time or historical location of the user.
In some embodiments, at least one of the plurality of data points may include information associated with a user corresponding to the at least one of the plurality of data points. The information associated with the user may include the name of the user, the age of the user, the phone number of the user, the gender of the user, the occupation of the user, a vehicle relating to the user, the plate number of the vehicle, the brand of the vehicle, the color of the vehicle, or the like, or any combination thereof. In some embodiments, such user information is included in all the data points or a portion of the data points. The user may input the information associated with the user through an interface of the application. The application may direct the user terminal 140 to send the information associated with the user to the processing engine 112 and/or the storage device 150 along with the real time or historical location of the user.
In some embodiments, when a user is in a process of requesting, using, or providing an on-demand service (e.g., a driver is providing a taxi-hailing service to a passenger), the application may direct the user terminal 140 associated with the user to send information associated with the on-demand service to the processing engine 112 and/or the storage device 150 along with the real time or historical location of the user. For example, when a user (e.g., a driver) is providing a taxi-hailing service to a passenger, the information associated with the taxi-hailing service being provided may include an origin of the trip, a destination of the trip, or the like, or any combination thereof.
In 503, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may divide the first data set into a plurality of first preliminary partitions based on the spatial information (e.g., as descried elsewhere in this disclosure in detail in connection with
In 505, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may determine a first spatial index for the first data set based on the plurality of first preliminary partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
In 507, the extension module 405 (and/or the processing engine 112, and/or the processing circuits 210-b) may generate a plurality of first modified partitions based on the plurality of first preliminary partitions. In some embodiments, the extension module 405 may determine a boundary data set for each of the plurality of first preliminary partitions and perform a shuffling operation on the boundary data set for each of the plurality of first preliminary partitions to determine the plurality of first modified partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
In some embodiments, the extension module 405 may determine the plurality of first modified partitions based on the plurality of first preliminary partitions according to a distributed computing method. The distributed computing method may include Storm framework, Spark framework, Hadoop, Phoenix, Disco, Mars, or the like, or any combination thereof. In some embodiments, the distributed computing method may be performed by a plurality of worker nodes and a manager that distributes tasks to the plurality of worker nodes. In some embodiments, the plurality of first preliminary partitions may be transmitted to the manager. The manager may distribute the plurality of first preliminary partitions to the plurality of worker nodes. For example, each of the plurality of first preliminary partitions may be transmitted to different worker nodes. As another example, one of the plurality of first preliminary partitions may be transmitted to a first worker node and another two of the plurality of first preliminary partitions may be transmitted to a second worker node. In some embodiments, the manager and/or the plurality of worker nodes may be a part of the processing engine 112 or communicate with the processing engine 112 via a network (e.g., the network 120).
Merely by way of example, as shown in
In 509, the obtaining module 401 (and/or the processing engine 112, and/or the interface circuits 210-a) may obtain a second data set within the target region. In some embodiments, the obtaining module 401 may obtain the second data set from the storage medium (e.g., the storage device 150, or the storage 220 in the computing device 200).
In some embodiments, the second data set may be a road network map including road network information within the target region. In some embodiments, the road network information may include a plurality of transportation routes such as roads, streets, expressways, overpasses, rivers, subway routes, underpasses, or the like, or any combination thereof.
In some embodiments, the obtaining module 401 may obtain a second data set including a plurality of second modified partitions to join at least one of the plurality of first modified partitions in the first data set and at least one of the plurality of second modified partitions in the second data set. In some embodiments, for the plurality of second modified partitions, the location of the second modified partition, the area of the second modified partition, and the shape of the second modified partition may be different from the plurality of first modified partitions. Alternatively, for some or each of the plurality of second modified partitions, the location of the second modified partition, the area of the second modified partition, and the shape of the second modified partition may be the same as corresponding partitions of the plurality of first modified partitions, which indicates that the second modified partition corresponds to the first modified partition. For example, as shown in
In some embodiments, the process for generating the plurality of second modified partitions may be the same as the process for generating the plurality of first modified partitions illustrated in 503-507 of the process 500-1. Merely by way of example, the process for generating the plurality of second modified partitions may include 511-515.
In 511, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may divide the second data set into a plurality of second preliminary partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
In 513, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may determine a second spatial index for the second data set based on the plurality of second preliminary partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
In 515, the extension module 405 (and/or the processing engine 112, and/or the processing circuits 210-b) may generate a plurality of second modified partitions based on the plurality of second preliminary partitions. In some embodiments, the extension module 405 may determine a boundary data set for each of the plurality of second preliminary partitions and perform a shuffling operation on the boundary data set for each of the plurality of second preliminary partitions to determine the plurality of second modified partitions (e.g., as descried elsewhere in this disclosure in detail in connection with
In 517, the joining module 307 (and/or the processing engine 112, and/or the processing circuits 210-b) may join at least one of the plurality of first modified partitions and at least one of the plurality of second modified partitions. In some embodiments, a first modified partition may be joined with a second modified partitions that corresponds to the first modified partitions. For example, as shown in
In some embodiments, for a first modified partition (or second modified partition), the joining module 407 may search the second data set (or first data set) to determine a second modified partition (or first modified partition) corresponding to the first modified partition (or second modified partition) to perform a joining operation. In some embodiments, a partition serial number of the first modified partition in the first spatial index may relate to a partition serial number, in the second spatial index, of the second modified partition corresponding to the first modified partition. For example, the partition serial numbers of the first modified partition and the second modified partition may be MP1, or the partition serial number of the first modified partition may be MP1-A and the partition serial number of the second modified partition may be MP1-B. The joining module 407 may search the second data set to determine the second modified partition corresponding to the first modified partition based on “MP1”. In some embodiments, the joining module 407 may search the second data set to determine the second modified partition corresponding to the first modified partition based on the location, the area, and the shape of the first modified partition.
In an application scenario of finding one or more new transportation routes not included in a road network map, the joining module 407 may join the first data set (e.g., a plurality of data point) and the second data set (e.g., a road network map) to compare the first data set with the second data set to find one or more new transportation routes not included in the second data set (e.g., a road network map). For example, the joining of the first data set and the second data set may be just like covering a road network map with a transparent mask including a plurality of points (e.g., data points in the first data set). If a certain number of points (e.g., more than 1000 points) correspond to a region including no transportation route in the road network map, there may be one or more new transportation routes not included in the road network map.
In some embodiments, the joining module 407 may join at least one of the plurality of first modified partitions and at least one of the plurality of second modified partitions according to a distributed computing method. Merely by way of example, as shown in
In 601, the obtaining module 401 (and/or the processing engine 112, and/or the interface circuits 210-a) may obtain a data set (e.g., the first data set, the second data set) within a target region. In some embodiments, the obtaining module 401 may obtain the data set from the storage medium (e.g., the storage device 150, or the storage 220 in the computing device 200).
In 603, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may divide the data set into a plurality of data blocks. In some embodiments, a data block may represent a geographic region. In some embodiments, each of the geographic regions may have a regular (e.g. triangle, rectangle, square, circle, pentagon, hexagon, etc.) or irregular shape. In some embodiments, the sizes of geographic regions may be same. For example, each of the geographic region may be a square of which the side length is 500 meters. In some embodiments, the sizes of geographic regions may be different. For example, the geographic region A may be a square of which the side length is 200 meters, and the geographic region B is a square of which the side length is 300 meters.
In some embodiments, for the first data set including a plurality of data points with spatial information, the data set processing module 403 may first divide the target region that the first data set corresponds to into the plurality of first data blocks, and then determine how many data points and/or which data points are in each first data block based on the spatial information of the plurality of data points. In some embodiments, for the second data set including road network information, the data set processing module 403 may divide the target region that the road network information corresponds to into the plurality of second data blocks. For each of the plurality of second data blocks, the location, the area, and the shape of the second data block may be the same as one of the plurality of first data blocks, which indicates that the second data block corresponds to the first data block. In some embodiments, data included in two corresponding data blocks and/or the amounts of data of the two corresponding data blocks may be different. For example, a first data block may include data points indicating locations of users, and a second data block corresponding to the first data block may include road network information.
In 605, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may determine a block serial number for each of the plurality of data blocks. In some embodiments, the data set processing module 403 may determine the block serial numbers based on a space-filling curve, for example, a Hilbert curve, a Z-order curve, a Quad tree, R-trees, a Hilbert R-tree, a Binary Space Partitioning (BSP) tree, a Gray curve, a Dragon curve, a Gosper curve, a Peano curve, or the like, or any combination thereof. In some embodiments, the space-filling curve is a Hilbert curve that, when used a map, passes through the geographic regions corresponding to the data blocks, leaving no empty space and no overlap. The data set processing module 403 may number the plurality of data blocks according to the order that the space-filling curve passes through geographic regions corresponding to the plurality of data blocks.
In some embodiments, the block serial numbers of two corresponding data blocks may relate to each other. For example, the block serial numbers of two corresponding data blocks may be same. As another example, a part of the block serial numbers of two corresponding data blocks may be same, such as B1-A and B1-B.
In 607, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may divide the plurality of data blocks into a plurality of preliminary partitions.
In some embodiments, for the first data set including a plurality of data points with the spatial information, the data set processing module 403 may divide the plurality of data blocks into the plurality of preliminary partitions based on an estimated distribution of data points of the plurality of data blocks and the block serial numbers of the plurality of data blocks.
As used herein, the estimated distribution of data points of the plurality of data blocks may indicate which data blocks include relatively more data points and which data blocks include relatively fewer data points. The estimated distribution may include an estimated density distribution of the plurality of data points, an estimated number distribution of the plurality of data points, or the like, or any combination thereof.
For example, for the estimated density distribution, the data set processing module 403 may determine, for each data block, a density of data points based on the number of data points in the data block and the size of the geographic region corresponding to the data block, and determine the estimated density distribution based on the density of data points in each data block. As another example, for the estimated number distribution, the data set processing module 403 may determine the number of data points in each data block, and determine the estimated number distribution based on the number of data points in each data block. Alternatively, the data set processing module 403 may select one or more data blocks from the plurality of data blocks as a sample, and determine the estimated distribution based on the density of data points and/or the number of data points in each of the selected one or more data blocks.
In order to improve the efficiency of data point processing, the number of data points in each preliminary partition may be substantially similar (e.g., differences between the numbers of data points in any two partitions are less than a threshold such as 100, 500, 1000, 5000, or 10000 data points). In some embodiments, the data set processing module 403 may divide the plurality of data blocks into the plurality of preliminary partitions based on the estimated distribution of the plurality of data points to make the number of data points in each preliminary partition substantially similar. In some embodiments, the block serial numbers of data blocks in a preliminary partition may be continuous. For example, the block serial numbers of data blocks in a preliminary partition may be 1-10000.
In some embodiments, the numbers of data blocks of two corresponding preliminary partitions may be equal. The data blocks in the two corresponding preliminary partitions may have a one-to-one correspondence relationship.
In 609, for each of the plurality of preliminary partitions, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may rank the data blocks based on the block serial numbers of the data blocks included in each of the preliminary partitions.
For example, a preliminary partition may include 1000 data blocks of which the block serial numbers are 10001-11000. In some embodiments, the data set processing module 403 may rank the 1000 data blocks in the ascending order and determine the data block with the block serial number of 10001 as the first data block in the preliminary partition. Alternatively, in some embodiments, the data set processing module 403 may rank the 1000 data blocks in the descending order and determine the data block with the block serial number of 11000 as the first data block in the preliminary partition.
In 611, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may determine a partition serial number for each of preliminary partitions by ranking the plurality of preliminary partitions based on the block serial numbers of the plurality of data blocks. For example, the data set processing module 403 may determine a partition serial number of PP1 for a preliminary partition that includes data blocks of which the block serial numbers are 1-10000, and determine a partition serial number of PP2 for a preliminary partition includes data blocks of which the block serial numbers are 10001-11000.
In some embodiments, the partition serial numbers of two corresponding partitions may relate to each other. For example, the partition serial numbers of two corresponding partitions may be same. As another example, a part of the partition serial numbers of two corresponding partitions may be same, such as PP1-A and PP1-B.
In 613, the data set processing module 403 (and/or the processing engine 112, and/or the processing circuits 210-b) may determine a spatial index for the data set based on the block serial numbers of the plurality of data blocks and the partition serial numbers of the plurality of preliminary partitions. The spatial index may indicate a relationship of the plurality of data blocks and the plurality of preliminary partitions. For example, for a data block, the spatial index may indicate which preliminary partition includes the data block and which data block is adjacent to the data block. As another example, for a preliminary partition, the spatial index may indicate which data blocks are included in the preliminary partition and which preliminary partition is adjacent to the preliminary partition.
It should be noted that the above description for distributing the plurality of service requests is merely provided for the purpose of illustration, and not intend 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. However, those variations and modifications do not depart from the present disclosure. For example, step 609 may be omitted in some embodiments.
In 701, the obtaining module 401 (and/or the processing engine 112, and/or the interface circuits 210-a) may obtain a data set (e.g., the first data set or the second data set) including a plurality of preliminary partitions (e.g., first preliminary partitions, second preliminary partitions). In some embodiments, the data set may be divided into the preliminary partitions based on the process 600 illustrated in
In 703, the extension module 405 (and/or the processing engine 112, and/or the processing circuits 210-b) may determine a boundary data set for each of the plurality of preliminary partitions. In some embodiments, the boundary data set for a preliminary partition may be adjacent to and surround the preliminary partition. In some embodiments, a boundary data set for a preliminary partition may include a plurality of data blocks determined in 603 of the process 600 illustrated in
In some embodiments, the data set processing module 403 may determine the boundary data set for a preliminary partition based on a spatial index of the data set. In some embodiments, the data set processing module 403 may determine which data blocks are included in the preliminary partition based on the spatial index. The block serial numbers of the data blocks included in the preliminary partition may be referred to as a spatial index range of the preliminary partition. For example, a preliminary partition may be represented as PP1[1-10000], which indicates that the partition serial number of the preliminary partition is PP1, and data blocks of which the block serial numbers are 1-10000 are included in the preliminary partition. The range of 1-10000 may be the spatial index range of the preliminary partition. In some embodiments, the extension module 405 may determine the boundary data set of the preliminary partition by determining the block serial numbers of data blocks that are adjacent to and surround the preliminary partition, and which preliminary partitions include the data blocks that are adjacent to and surround the preliminary partition based on the spatial index range of the preliminary partition and the spatial index of the data set.
In 705, the extension module 405 (and/or the processing engine 112, and/or the processing circuits 210-b) may perform a shuffling operation on the boundary data set for each of the plurality of preliminary partitions. In some embodiments, the shuffling operation may refer to data exchange among two or more preliminary partitions. In some embodiments, the shuffling operation on a boundary data set of a preliminary partition may include ranking the data blocks included in the boundary data set based on the block serial numbers of the data blocks and adding the boundary data set including the ranked data blocks to the preliminary partition. The combination of the preliminary partition and the boundary data set may be referred to as a modified partition. For example, the extension module 405 may determine a boundary data set of [10001-10400] for a preliminary partition of [1-10000]. A set of [1-10400] may be a modified partition.
In some embodiments, because a modified partition corresponding to a preliminary partition may be generate by shuffling a boundary data set of the preliminary partition instead of the preliminary partition or the whole data set, the order of magnitude of the calculated amount of generating the modified partition may be the square root of the order of magnitude of the amount of data in the preliminary partition, which improves the efficiency of generating a modified partition compared to generating a modified partition by processing all data in the data set in existing technology.
Merely by way of example, as shown 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/or “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/CN2017/119894, filed on Dec. 29, 2017, which claims priority to International Application No. PCT/CN2017/119699 filed on Dec. 29, 2017, the contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2017/119894 | Dec 2017 | US |
Child | 16743654 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2017/119699 | Dec 2017 | US |
Child | PCT/CN2017/119894 | US |