This application claims priority to and the benefit of Korean Patent Application Nos. 10-2013-0009944 and 10-2013-0064793 filed in the Korean Intellectual Property Office on Jan. 29, 2013 and Jun. 5, 2013, the entire contents of which are incorporated herein by reference.
(a) Field of the Invention
The present invention relates to a communication device, a multicast control method, and a scheduling control method.
(b) Description of the Related Art
Network coding is a technique which allows a relay node to code multiple packets by linear coupling or an exclusive OR operation (XOR) and forward them, and a receiving node to decode a coded signal and receive the packets during a packet transfer process.
One of the simplest examples is DAF (decode-and-forward) two-way relaying. DAF is applicable when two nodes exchange data.
According to DAF, two nodes, i.e., node A and node B, in a network send data. Relay node R relays between node A and node B.
First, node A sends packet X to relay node R. Then, node B sends packet Y to relay node R. Node A and node B store the packet X and packet Y they have sent in local buffers.
Hereupon, relay node R linearly couples the received packet X and packet Y and at the same time forwards them to node A and node B. Node A and node B decode and receive packet X and packet Y, respectively, using the packet X and the packet Y which have been stored in their local buffers.
However, there is a limitation that the conventional DAF can be applied only when two nodes in a multi-hop network send and receive data in a linear phase.
When using multicasting without network coding in a multi-hop network in the conventional art, packet transmission occurs as follows.
1) node 1 transmits packet (a) to node 2 and node 3, respectively, which are connected to it.
2) node 4 transmits packet (b) to node 3 which is connected to it.
3) node 3 transmits packet (a) to node 4.
4) node 3 transmits packet (b) to node 1 and node 2.
In this way, packet transmission is carried out in four stages in the conventional art.
The above information disclosed in this Background section is only for enhancement of understanding of the background of the invention and therefore it may contain information that does not form the prior art that is already known in this country to a person of ordinary skill in the art.
The present invention has been made in an effort to provide a communication device, a multicast control method, and a scheduling control method which allow for multicast transmission using network coding.
An exemplary embodiment of the present invention provides a communication device. The communication device includes: a decoding buffer that stores a first multicast packet received from a first node and a second multicast packet received from a second node; an encoder that performs network coding of the first and second multicast packets; and a transmitter that transmits the network-coded packets output from the encoder to the first node and the second node.
The communication device may further include a queue that is separate from the decoding buffer and is matched to buffer nodes having multicast packets and a destination node to store the multicast packets.
The communication device may further include a scheduler that schedules the transmission priority of each of the first and second multicast packets by using the number of packets stored in the queue and the set of all cases where the destination node is divided into a plurality of subsets, and combines the scheduling results of the first and second multicast packets together to schedule the transmission priority of the network-coded packets.
The scheduler may calculate a scheduling weighted value of the network-coded packets by calculating a scheduling weighted value of the first multicast packet and a scheduling weighted value of the second multicast packet and adding the calculated weighted values together.
The scheduler may compare the scheduling weighted value of the first multicast packet, the scheduling weighted value of the second multicast packet, and the scheduling weighted value of the network-coded packets, choose the largest scheduling weighted value, and determine transmission of the packet corresponding to the chosen scheduling weighted value.
Another embodiment of the present invention provides a multicast control method. The multicast control method includes: transmitting a first multicast packet to at least one neighboring node and a relay node from one of a plurality of nodes constituting a network; performing network coding of the first multicast packet and a second multicast packet received from a destination node and transmitting the first and second multicast packets to the node and the at least one neighboring node from the relay node; and decoding the network-coded packets by using the first multicast packet to enable the node and the at least one neighboring node to acquire the second multicast packet.
The multicast control method further includes, after transmitting the first multicast packet, storing the first multicast packet in a decoding buffer of the node, and storing the first multicast packet in a decoding buffer of the at least one neighboring node.
In the acquiring of the second multicast packet, the first multicast packet stored in decoding buffers may be used.
The multicast control method may further include, after transmitting to the node, and the at least one neighboring node: receiving the network-coded packets from the relay node by the destination node; and acquiring the first multicast packet by decoding the network-coded packets by using the second multicast packet.
The multicast control method further includes, before receiving the network-coded packets, storing the second multicast packet in the decoding buffer of the destination node.
In the acquiring of the first multicast packet, the second multicast packet stored in the decoding buffer may be used.
The multicast control method further includes storing multicast packets in queues of the node, the at least one neighboring node, the relay node, and the destination node, which are separate from the decoding buffers.
Each queue may match a multicast packet to the destination node and the buffer node storing the multicast packet in the decoding buffer.
Yet another embodiment of the present invention provides a scheduling control method. The scheduling control method includes: scheduling a transmission priority of a first multicast packet by one of a plurality of nodes constituting a network; scheduling a transmission priority of a second multicast packet; and scheduling a transmission priority of the first and second multicast packets, which are network-coded, according to the scheduling of the first multicast packet and the scheduling of the second multicast packet.
In the scheduling of the transmission priority of the network-coded packets, a scheduling weighted value of the network-coded packets may be calculated by a sum of a scheduling weighted value of the first multicast packet and a scheduling weighted value of the second multicast packet.
The scheduling control method may further include, after scheduling the transmission priority of the network-coded packets: comparing the scheduling weighted value of the first multicast packet, the scheduling weighted value of the second multicast packet, and the scheduling weighted value of the network-coded packets to choose the largest scheduling weighted value; and transmitting the packet corresponding to the chosen scheduling weighted value.
The transmission priority of the first multicast packet and the second multicast packet is calculated by the following equation:
where QkD,C(t) denotes the number of packets at a given time t whose destination node set is D and which are stored in the packet queue QkD,C of buffer node C,(D,n) denotes a destination node assigned to the jth receiving node, and ij is the jth receiving node, and as a consequence,
denotes the queue length of the receiving node versus B, and
denotes the sum of queue lengths of B by which the sum of queue lengths of receiving nodes is minimal.
According to an embodiment of the present invention, multicast performance, i.e., an amount of data transmitted per unit time, can be increased. Furthermore, the present invention can achieve maximum effect in a multi-hop network having a shared medium, and is applicable to a general wireless network.
In the following detailed description, only certain exemplary embodiments of the present invention have been shown and described, simply by way of illustration. As those skilled in the art would realize, the described embodiments may be modified in various different ways, all without departing from the spirit or scope of the present invention. Accordingly, the drawings and description are to be regarded as illustrative in nature and not restrictive. Like reference numerals designate like elements throughout the specification.
In the specification, when a certain part “includes” a certain component, this indicates that the part may further include another component instead of excluding another component unless there is a different disclosure.
In addition, terms, such as “ . . . unit,” “ . . . er/or,” “module,” or “block,” disclosed in the specification indicates a unit for processing at least one function or operation, and this may be implemented by hardware, software, or a combination of both.
Hereinafter, a communication device, a multicast control method, and a scheduling control method according to an exemplary embodiment of the present invention will be described in detail with reference to the drawings.
First of all, referring to
The nodes 100, 200, 300, and 400 cannot simultaneously send and receive packets because they have a single wireless interface.
There are two multicast flows generated by node 1 (100) and node 4 (400), and these flows transmit (a) and (b) to {node2, node4} and {node1, node2}, respectively.
That is, the first multicast flow goes from node 1 (100) to node 2 (200) and from node 1 (100) to node 4 (400), and the second multicast flow goes from node 4 (400) to node 1 (100) and from node 4 (400) to node 2 (200).
Each node 100, 200, 300, and 400 stores, in a decoding buffer, packets that they have generated and received from neighboring nodes to achieve efficient multicasting, which will be described in further detail with reference to
The solid line box next to each node denotes a decoding buffer. That is, each node 100, 200, 300, and 400 has their own decoding buffer 101, 201, 301, and 401.
Referring to
Referring to
Referring to
Then, node 1 (200) acquires packet (b) by performing an (a+b)−a operation using packet (a) stored in the decoding buffer 101.
Also, node 2 (200) acquires packet (b) by performing an (a+b)−a operation using packet (a) stored in the decoding buffer 201.
Also, node 4 (400) acquires packet (a) by performing an (a+b)−b operation using packet (b) stored in the decoding buffer 401.
In this way, multicast transmission to nodes 1, 2, and 4 is completed through a total of three multicast transmissions. This multicast transmission improves performance by 33%.
As used herein, buffer nodes C refer to nodes which have particular packets stored in their decoding buffers. Destination nodes D refer to nodes to which particular packets should be forwarded. The destination node D of each packet is different for each relay node due to the nature of multicasting.
Referring to
The destination nodes D of node 1 include node 4, node 5, and node 6. After node 1 is branched into node 2 and node 3, the destination nodes of node 2 are node 4 and node 5 and the destination node D of node 3 is node 6.
If a multicast packet is generated by node 1 and transmitted to node 2, node 3, and node 4, the destination nodes D of node 1 are {4, 5, 6}. Because the packet is stored in buffers upon transmission/reception, the buffer node C is Ø when the packet is firstly generated.
If the packet generated by node 1 is transmitted to node 2 and node 3, the destination nodes of node 2 are {4, 5} and the buffer nodes C of node 2 are {1, 2, 3}. The destination node D of node 3 is {6}, and the buffer nodes C of node 3 are {1, 2, 3}.
The packet transmitted or received by each node is stored in a packet queue (QkD,C) by using “destination node-buffer node” pair information.
Here, if node k receives a packet whose destination node set is D and whose buffer node is C, the packet queue of node k is QkD,C. That is, node k stores the received packet in QkD,C. Such a packet queue can be subdivided by flow when necessary.
Also, the number of packets in the packet queue QkD,C at a given time t is equal to QkD,C(t).
Each node copies the packets transmitted by them and the packets received from neighboring nodes and manages these packets in the decoding buffers 101, 201, 301, and 401, which are memory spaces separated from the packet queue.
The decoding buffers 101, 201, 301, and 401 have limited space. If the decoding buffers 101, 201, 301, and 401 are full, they are managed by using various queue management techniques, for example, FIFO.
(k, {i1, . . . , in}) is a multicast link from node k to k's neighboring nodes i1, . . . , in, which is represented by (k, I). A unicast link from k to i1 is represented by (k, {i1}).
(D, n) refers to the set of all cases where the destination node set D is divided into n subsets n. If D={1, 2, 3}, n=2, (D, n) is represented by the following Equation 1.
(D,n)={[{1},{2,3}],[{2},{1,3}],[{3},{1,2}],[{2,3},{1}],[{1,3},{2}],[{1,2},{3}]} (Equation 1)
The communication device may operate as node 1 (100), node 2 (200), node 3 (300), or node 4 (400) in
Referring to
The receiver 501 receives multicast packets from at least one neighboring node. If the communication device 500 operates as the first node 100 of
If the communication device 500 operates as the second node 200 of
If the communication device 500 operates as the third node 300 of
If the communication device 500 operates as the fourth node 400 of
The decoding buffer 503 stores multicast packets received by the receiver or multicast packets generated and transmitted by it.
If the decoding buffer 503 is the decoding buffer 101 of the first node 100 of
If the decoding buffer 503 is the decoding buffer 101 of the third node 300 of
If the decoding buffer 503 is the decoding buffer 101 of the fourth node 400 of
If the decoder 505 operates as the first node 100, second node 200, or fourth node 400 of
If the decoder 505 operates as the first node 100 or second node 200 of
If the decoder 505 operates as the fourth node 400 of
The queue 507 is configured in the same manner as the above-described packet queue, and is embodied as a packet queue QkD,C based on “destination node-buffer node” pair information. That is, the queue 507 matches each multicast packet to a destination node and a buffer node and stores it.
The scheduler 509 schedules the sequence of transmission of multicast packets stored in the decoding buffer 503 to at least one neighboring node.
If the encoder 511 operates as the third node 300 of
For example, the encoder 511 performs network coding of the received first multicast packet (a) and second multicast packet (b) and outputs packets (a+b).
The transmitter 513 transmits multicast packets to neighboring nodes.
If the transmitter 513 operates as the first node 100 of
If the transmitter 513 operates as the fourth node 400 of
If the transmitter 513 operates as the third node 300 of
Referring to
Also, the destination node 400 transmits a second multicast packet (b) to a neighboring node, i.e., node 3 (300) (S105).
Then, the relay node 300 performs network coding of the first and second multicast packets (a) and (b) (S107) and transmits the network-coded packets to at least one neighboring node, i.e., node 1 (100), node 2 (200), and node 4 (400) (S109, S111, and S113).
As used herein, scheduling control is classified into a “scheduling/routing” algorithm for individual multicast packets (a) and (b) and a “scheduling/routing/coding” algorithm for network-coded packets (a+b).
The “scheduling/routing/coding” algorithm determines the priority and direction of transmission of multicast packets/multicast links (k, {i1, . . . , in}) and whether to apply network coding or not, and is implemented using packet queue length information between neighboring nodes.
Referring to
The priority w(k,{i
where Bj is a destination node assigned to the jth receiving node, and ij is the jth receiving node. As a consequence,
denotes the queue length of the receiving node versus B, and
denotes the sum of queue lengths of B by which the sum of queue lengths of receiving nodes is minimal.
For example, when node 1 divides multicast packets to be transmitted to destination nodes, i.e., node 4, node 5, and node 6 of
w
(1,{2,3})
{4,5,6},Ø(t)=Q1{4,5,6},Ø(t)−(Q2{4,5},{1,2,3}(t)+Q3{6},{1,2,3}(t)) Equation 3:
There are various ways of dividing the destination node D into N. Thus, the optimal priority is calculated according to the following Equation 4:
Equation 4 is turned into the above-described Equation 2 by generalization.
Next, the scheduler 509 schedules the priority of transmission of network-coded packets (a+b) (S205).
The packets (a) and (b) to be individually scheduled and routed for transmission can be network-coded and transmitted at one time, as shown in
In this way, the scheduler 509 calculates the scheduling/routing/coding weighted value for coding and transmitting the packets at one time by calculating the scheduling/routing priority weighted values and then adding them together to satisfy a particular condition.
Afterwards, the scheduler 509 compares the scheduling weighted values of the multicast packets (a) and (b), which are calculated by Equation 2, and the scheduling weighted value of the network-coded packets (a+b), which is calculated in S205 (S207), and determines transmission using the largest scheduling weighted value (S209). That is, the scheduling/routing weighted values and the scheduling/routing/coding weighted value are compared to choose the largest weighted value and transmit the packets.
In this case, in order for the receiving node to perform decoding, all information except information it has to receive should be kept in the decoding buffer 503, and therefore I1⊂C2 and I2⊂C1 must be satisfied.
When applying this condition to the coding and transmission of n packets to be scheduled and routed, Ii⊂Cj for all j≦n and j=i must be satisfied to enable coding. The scheduling/routing/coding weighted value is calculated by Σi=1nw(k,I
An exemplary embodiment of the present invention may not only be embodied through the above-described apparatus and method, but may also be embodied through a program that executes a function corresponding to a configuration of the exemplary embodiment of the present invention or through a recording medium on which the program is recorded.
While this invention has been described in connection with what is presently considered to be practical exemplary embodiments, it is to be understood that the invention is not limited to the disclosed embodiments, but, on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2013-0009944 | Jan 2013 | KR | national |
10-2013-0064793 | Jun 2013 | KR | national |