This application claims the benefit of Korean Patent Application No. 10-2009-0128412 filed on Dec. 21, 2009, which is hereby incorporated by reference in its entirety into this application.
1. Field of the Invention
The present invention relates generally to a server-sensor network cooperative spatial query processing method and a server using the method, which are capable of extending the life span of sensor nodes, and, more particularly, to a server-sensor network cooperative spatial query processing method which, when a spatial query is given in a sensor network environment, searches for sensor nodes satisfying a spatial query condition while minimizing the energy consumption of sensor nodes, and enables a server to acquire the sensed information of the found sensor nodes, and a server using the method.
2. Description of the Related Art
In general, the simplest method of performing sensor network-based spatial query processing is the centralized method. In the centralized method, a server acquires pieces of sensed/position information from all sensor nodes and then performs a spatial query. In the centralized method, however, the server accesses all the sensor nodes in order to acquire all the pieces of sensed/position information. That is, the centralized method is disadvantageous because the number of times that wireless communication is performed is greatly increased by the process of accessing all the sensor nodes.
In order to overcome the disadvantage of the conventional centralized method, an in-network spatial query processing method was proposed. The in-network spatial query processing method employs a method in which a spatial query is not performed by a server, but is distributed across a sensor network and then processed. In such in-network spatial query processing methods, in order to increase efficiency when the spatial query is distributed across and performed by sensor nodes, a distributed spatial index method is chiefly used. More particularly, in the in-network spatial query processing method, a spatial search for the sensor nodes is performed using a distributed spatial index. Furthermore, based on the spatial search results, access to sensor nodes not satisfying a spatial query condition is not performed. As described above, the in-network spatial query processing method reduces the total number of times that wireless communication required to perform the spatial query is performed, as compared to the former conventional technology.
Even in the in-network spatial query processing method, however, dead space inevitably is formed within the distributed spatial index constructed in the sensor network environment. This dead space is unfortunately problematic in that it causes unnecessary wireless communication when the distributed spatial query is performed. Furthermore, the dead space tends to further increase in the distributed spatial index of the sensor network environment.
Referring to
Unlike in the conventional centralized method in which the server performs the entire spatial query, in the conventional in-network spatial query processing method, the spatial query processing is not performed by the server, but is distributed into the sensor network and then performed. Accordingly, the number of times that wireless communication required for processing the spatial query is performed between the sensor nodes may be reduced. The conventional in-network spatial query processing method has the advantage of reducing the number of times that wireless communication is performed as described above, but still has a problem in that unnecessary wireless communication with the sensor nodes Nos. 5, 7, and 8 of
In other words, the conventional in-network spatial query processing method has the problem of performing unnecessary wireless communication with sensor nodes having no actual spatial search results. Such unnecessary wireless communication may be more frequently performed in a sensor network environment with lots of dead spaces. Here, the term “dead space” refers to an area which is included in a distributed spatial index structure, but does not actually have information. The number of dead spaces may be greatly increased in the sensor network environment. This is because wireless communication between the sensor nodes included in the distributed spatial index structure does not actually include information, unlike the sensor nodes.
Accordingly, the present invention has been made keeping in mind the above problems occurring in the prior art, and an object of the present invention is to provide a server-sensor network cooperative spatial query processing method which, when a spatial query is given in a sensor network environment, searches for sensor nodes satisfying a spatial query condition while minimizing the energy consumption of sensor nodes and enables a server to acquire the sensed information of the found sensor nodes, and a server using the method.
In order to accomplish the above object, the present invention provides a server-sensor network cooperative spatial query processing method, including the server detecting supplementary information for selecting sensor nodes to be excluded from among a plurality of sensor nodes by performing a preliminary spatial query, before starting a spatial query with the plurality of sensor nodes; and the server requesting the spatial query to the sensor nodes, selected based on the supplementary information, when starting the spatial query with the plurality of sensor nodes.
The supplementary information may include information about the positions of sensor nodes detected as results of the preliminary spatial query, information about spatial search objects having no results of the preliminary spatial query, and/or information about sensor nodes having no results of the preliminary spatial query.
The server detecting the supplementary information may include the server sending the preliminary spatial query before starting the spatial query with the plurality of sensor nodes; and detecting the supplementary information for selecting sensor nodes to be excluded from among the plurality of sensor nodes based on results of the preliminary spatial query.
The preliminary spatial query may search for sensor nodes satisfying the preliminary spatial query based on spatial index information including information about positions of the plurality of sensor nodes.
The providing query/filtering information may include providing the supplementary information to the plurality of sensor nodes; and requesting the spatial query to the selected sensor nodes based on the supplementary information.
The providing the supplementary information may include the server providing information about the positions of the sensor nodes to the sensor nodes when the information about the positions of the sensor nodes which is results of the preliminary spatial query is used as the supplementary information.
The providing the supplementary information may include the server providing information about spatial search objects, other than information about spatial search objects having no results of the preliminary spatial query, to the sensor nodes when the information about the spatial search objects having no results of the preliminary spatial query is used as the supplementary information.
The providing the supplementary information may include the server providing information about sensor nodes having no results of the preliminary spatial query, together with information about spatial search objects having no results of the preliminary spatial query, to the sensor nodes when the information about the spatial search objects and the information about the sensor nodes having no results of the preliminary spatial query are simultaneously used as the supplementary information.
The requesting the spatial query to the selected sensor nodes may include the server excluding the sensor nodes having no results of the preliminary spatial query when performing the spatial query using the spatial search objects.
Additionally, in order to accomplish the above object, the present invention provides a server for performing server-sensor network cooperative spatial query processing, including a preliminary query execution unit for detecting supplementary information for selecting sensor nodes to be excluded from among a plurality of sensor nodes by performing a preliminary spatial query, before starting a spatial query with the plurality of sensor nodes; and a query/filtering information provision unit for requesting the spatial query to the sensor nodes, selected based on the supplementary information, when starting the spatial query with the plurality of sensor nodes.
The above and other objects, features and advantages of the present invention will be more clearly understood from the following detailed description taken in conjunction with the accompanying drawings, in which:
Reference now should be made to the drawings, in which the same reference numerals are used throughout the different drawings to designate the same or similar components.
Embodiments of the present invention will be described in detail with reference to the accompanying drawings.
Referring to
The system includes a construction for supporting the above-described in-network-based spatial query processing process together, and a description of the construction is omitted here.
Furthermore, it is assumed that the same index information as is stored in the sensor nodes, such as distributed spatial index information, is stored in the server and operations are performed in a system in which the locations of the sensor nodes have been fixed. However, the construction of the system is only illustrative for the sake of description, and the present invention is not limited thereto.
It is also assumed that spatial query indexing between the server and the sensor network is performed on the basis of the structure of the server 100-the base station 110-the sensor nodes 120. However, the structure is only illustrative for convenience of description, but the present invention is not limited thereto.
Referring to
Referring to
An example of the unnecessary spatial search objects may be the spatial search object β shown in
Furthermore, an example of a sensor node that should not be visited may be the spatial search object α shown in
For the above reasons, in the present invention, the server sends the pieces of supplementary information to the sensor nodes. In a distributed spatial index process between the server and the sensor network, the number of sensor nodes that should be actually visited is reduced on the basis of the pieces of supplementary information. As described above, the present invention operates in such a way as to reduce the total number of times that wireless communication is performed.
Referring to
The server processing unit 340 generates a spatial query in the sensor network, receives query results in response to the spatial query, and provides the query results to a user. The spatial query may be input by a user or automatically generated by software set aside for this purpose. Furthermore, any construction may be used as the server processing unit 340 as long as it can generate a spatial query and receive and process a query result.
The preliminary query execution unit 300 performs a preliminary spatial query before performing distributed spatial indexing in response to the input spatial query. The execution of the preliminary spatial query is a process of searching for sensor nodes satisfying a spatial query condition. The process is performed on the basis of spatial index information of the spatial index unit 310. The present invention is applied to fixed sensor nodes. Here, the server can store spatial index information (e.g., a sensor node ID and information about the position of a sensor node) about sensor nodes, and a preliminary spatial query may be easily processed.
Furthermore, in the process of performing the preliminary spatial query, the preliminary query execution unit 300 extracts pieces of supplementary information which may be efficiently used when a distributed spatial query is performed in the sensor network in the future. The pieces of supplementary information include pieces of information about the positions of sensor nodes (i.e., results of a preliminary spatial query), information about spatial search objects having no results of a preliminary spatial query, and information about sensor nodes including no actual results of the preliminary spatial query even though the sensor nodes are visited. The pieces of supplementary information are used to reduce unnecessary access to sensor nodes when the distributed spatial query is performed between the server and the sensor network.
The server query/filtering information provision unit 320 functions to analyze and convert the generated spatial query and to send the converted spatial query to the sensor network. The server query result collection unit 330 functions to collect query results collected from the sensor network and to transfer them.
Furthermore, the server query/filtering information provision unit 320 changes a spatial query method on the basis of the supplementary information extracted by the preliminary query execution unit 300 when processing the generated spatial query, and then performs the changed spatial query method. That is, when information about spatial search objects having no results of a preliminary spatial query is used as the supplementary information, the server query/filtering information provision unit 320 sends information about the remaining spatial search objects other than the information about the spatial search objects having no results of the preliminary spatial query, when sending the converted spatial query to the sensor network. For example, as shown in
Furthermore, when information about spatial search objects having no results of a preliminary spatial query, and information about sensor nodes actually having no results of the preliminary spatial query even though the sensor nodes are visited are used as the supplementary information at the same time, the server query/filtering information provision unit 320 sends spatial query information, including the information about the sensor nodes actually having no results of the preliminary spatial query even though the sensor nodes are visited, together with information about the spatial search objects α, γ, and δ, to the sensor network. Accordingly, when performing a predetermined spatial query using the spatial search objects α, γ, and δ, the distributed query execution unit 400 of the sensor node 120 no longer propagates the execution of the spatial query to the child sensor node if the child sensor node is included in the sensor nodes having no results of the preliminary spatial query even though they are visited, even though the spatial query has to be propagated to a child sensor node because of a spatial overlap between the spatial search objects α, γ, and δ and spatial index information about the child sensor node. That is, information about sensor nodes which seem to include results of the preliminary spatial query in a spatial search process using a spatial index when a preliminary spatial query is performed but do not actually include the results of the preliminary spatial query is used. In this case, neither spatial search for the sensor nodes Nos. 7 and 8 nor spatial search for the sensor node No. 5 is performed.
As described above, in the present invention, the server searches for unnecessary spatial search objects and supplementary information about sensor nodes that should not be actually visited, by performing a preliminary spatial query before performing distributed spatial search. The server 100 reduces the number of times that wireless communication is performed between sensor nodes in the process of processing the spatial query on the basis of the supplementary information.
Referring to
The distributed query execution unit 400 functions to determine whether a current sensor node satisfies a predetermined spatial query condition. If it is determined that the sensor node satisfies the spatial query condition, the distributed query execution unit 400 stores the sensed/position information of the sensor node in the server query result collection unit 430. Furthermore, the distributed query execution unit 400 functions to determine whether the child sensor nodes of the sensor node satisfy the spatial query condition in advance. If it is determined that the child sensor nodes satisfy the spatial query condition, the distributed query execution unit 400 stores the spatial query, currently being performed, in the query/filtering information provision unit 420 in order to propagate the spatial query to the child sensor nodes. Here, the spatial index information of the distributed spatial index unit 410 is used to determine whether the child sensor nodes satisfy the spatial query condition.
The query/filtering information provision unit 420 functions to propagate the stored spatial query to the child sensor nodes. The query result collection unit 430 functions to send information about the results of the spatial query, collected by himself and information about results of the spatial query, collected from the child sensor nodes, to a higher-ranking parent sensor node. If a specific sensor node does not satisfy a preliminary spatial query condition and its child sensor nodes do not satisfy the preliminary spatial query condition, the specific sensor node does not propagate a spatial query to the child sensor nodes and does not send the results of the preliminary spatial query condition to its parent sensor node. Accordingly, the total number of times wireless communication is performed can be reduced.
Meanwhile, when performing a spatial query, the distributed query execution unit 400 changes the above spatial query method on the basis of the supplementary information received from the server. That is, when position information about the corresponding sensor node (i.e., the results of the preliminary spatial query) is used as the supplementary information, the distributed to query execution unit 400 performs the spatial query on the basis of the information about the position of the sensor node (i.e., the actual results of the preliminary spatial query) other than a spatial search object given in the spatial query. When the spatial search is performed on the basis of the accurate information about the position of the sensor node (i.e., the results of the preliminary spatial query) as described above, there is an advantage in that a spatial search for dead space, such as a search based on a spatial search object, is not performed. For example, in
Furthermore, when information about a spatial search object having no results of the preliminary spatial query and information about a sensor node having no results of the preliminary spatial query even though the sensor node is visited are simultaneously used as the supplementary information, the distributed query execution unit 400 receives spatial query information, including the information about the sensor node having no results of the preliminary spatial query even though the sensor node is visited, together with the information about the spatial search objects α, γ, and δ from the server query/filtering information provision unit 320. Accordingly, when performing a predetermined spatial query using the spatial search objects α, γ, and δ, the distributed query execution unit 400 of the sensor node 120 no longer propagates the execution of the spatial query to the child sensor node if the child sensor node is included in the sensor node having no results of the preliminary spatial query even though the child sensor is visited, even though the spatial query has to be propagated to a child sensor node because of a spatial overlap between the spatial search objects α, γ, and δ and spatial index information about the child sensor node. In this case, neither spatial search for the sensor nodes Nos. 7 and 8 nor spatial search for the sensor node No. 5 is performed.
Hereinafter, a server-sensor network cooperative spatial query processing method according to the present invention is described in detail with reference to the accompanying drawings.
Referring to
After the preliminary spatial query has been generated, the server query result collection unit 330 of the server collects query results from sensor nodes at step S20. Furthermore, in the process of performing the preliminary spatial query, the preliminary query execution unit 300 extracts pieces of supplementary information which may be efficiently used when a distributed spatial query is performed in the sensor network in the future at step S30.
The server query/filtering information provision unit 320 performs a spatial query using the pieces of supplementary information at step S40. That is, the server query/filtering information provision unit 320 performs a distributed spatial index on the basis of the pieces of supplementary information extracted between the server and the sensor network.
As described above, the pieces of supplementary information include pieces of information about the positions of sensor nodes (i.e., the results of a preliminary spatial query), information about spatial search objects having no results of the preliminary spatial query, and information about sensor nodes including no actual results of the preliminary spatial query even though the sensor nodes are visited. The pieces of supplementary information may be used to reduce unnecessary access to sensor nodes when the distributed spatial query is performed in the sensor network.
When the pieces of information about the positions of sensor nodes (i.e., the results of the preliminary spatial query) are used as the supplementary information at step S40 will now be described.
When performing a spatial query, the distributed query execution unit 400 performs the spatial query on the basis of not the spatial search object given in the spatial query but information about the position of a sensor node (i.e., the actual result of the preliminary spatial query), at step S50. If the spatial search is performed on the basis of accurate information about the position of the sensor node (i.e., the result of the preliminary spatial query) as described above, there is an advantage in that spatial search for dead space, such as search based on spatial search objects, is not performed. For example, in
Meanwhile, the case where the information about spatial search objects having no results of the preliminary spatial query is used as the supplementary information at step S40 will now be described. The query/filtering information provision unit 320 of the server 100 sends information about the remaining spatial search objects, other than the information about the spatial search objects having no results of the preliminary spatial query, to the sensor network when sending the converted spatial query to the sensor network at step S60. For example, as shown in
Meanwhile, the case where the information about spatial search objects having no results of the preliminary spatial query and the information about the sensor nodes having no results of the preliminary spatial query even though the sensor nodes are visited are used as the supplementary information at the same time (i.e., when information included in the results of the preliminary spatial query, but included in the information about the sensor nodes actually having no results of the preliminary spatial query is used) at step S40 will now be described. The server query/filtering information provision unit 320 of the server 100 sends spatial query information, including the information about the sensor nodes having no results of the preliminary spatial query even though the sensor nodes are visited, together with the information about the spatial search objects α, γ, and δ, to the sensor network at step S60. When performing a predetermined spatial query using the spatial search objects α, γ, and δ, the distributed query execution unit 400 of the sensor node 120 no longer propagates the execution of the spatial query to the child sensor node at step S72 if the child sensor node is included in the sensor nodes having no results of the preliminary spatial query even though they are visited, even though the spatial query has to be propagated to a child sensor node because of a spatial overlap between the spatial search objects α, β, and δ and spatial index information about the child sensor node. In this case, neither spatial search for the sensor nodes Nos. 7 and 8 nor spatial search for the sensor node No. 5 is performed.
After finishing distributed query execution, query results are collected at step S80.
As described above, in the server-sensor network cooperative spatial query processing method according to the present invention, the server performs a spatial query in advance and extracts various pieces of supplementary information as described above, and a distributed spatial query is performed in the sensor network on the basis of the pieces of supplementary information. Accordingly, unnecessary access to sensor nodes can be prevented, and therefore the total number of times wireless communication is performed between the sensor nodes can be reduced.
In accordance with the present invention, in an in-network-based spatial query processing process, a predetermined spatial query is cooperatively processed between the server and the sensor nodes of a sensor network. Accordingly, there is an advantage in that unnecessary wireless communication is not performed.
Furthermore, there are advantages in that the energy consumption of sensor nodes is reduced and the lifespan thereof is increased because of a reduction in the number of times that wireless communication is performed.
Although the preferred embodiments of the present invention have been disclosed for illustrative purposes, those skilled in the art will appreciate that various modifications, additions and substitutions are possible, without departing from the scope and spirit of the invention as disclosed in the accompanying claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2009-0128412 | Dec 2009 | KR | national |