Peer-to-peer networking has proven to be a promising method for delivering live video streams and other content to a large number of clients over the Internet. Much effort has been devoted to the research and development of these live peer-to-peer streaming systems. Some deployed systems have shown that the peer-to-peer systems can scale to millions of online users in a single session.
In the design of the peer-to-peer streaming systems, one of the most important problems to address is how to organize the dynamic and heterogeneous peers into an efficient overlay. The structure and behavior of the overlay greatly affects the efficiency of many modules such as peer discovery, data transmission, and the final streaming performance perceived by end users.
Mesh-based and tree-based approaches are the two common methods for overlay construction in peer-to-peer streaming systems.
In the tree-based approach, peers or nodes (peers and nodes are used interchangeably throughout this document) form one or multiple trees to disseminate the streaming packets. Within each tree, the node receives packets from its parent nodes and delivers their copies to its child nodes. Multiple trees are usually disjointed, i.e., each node is an interior node of one tree and the leaf node of all the other trees. However, the tree is not robust to peer churn, since it requires high cost in repairing the tree structure when peers are joining and leaving the session frequently.
In the mesh-based approach, peers are organized in a more unstructured way. There is no explicit tree structure over the peers. Instead, peers simply find a number of other nodes as their partners and exchange data with them according to their available packets. Some research work has shown that the mesh-based approach is more robust and efficient than the tree-based one when delivering live video. Consequently, most deployed peer-to-peer streaming systems use mesh-based approaches.
However, current mesh-based approaches use a randomly constructed overlay to organize the peers for transmitting video, otherwise known as an undirected graph approach. Due to this undirected graph approach, it is difficult to describe the relationship between peers, the heterogeneity in the capability of the peers and the ability to optimize the overlay. As such, previous mesh-based and tree-based approaches are either not flexible or not robust enough for providing satisfactory performance.
A novel approach for constructing a P2P streaming overlay is described herein using a directed graph model to describe and organize the heterogeneous peers into a dynamic overlay. Based on this model, a set of efficient protocols and algorithms is developed for overlay construction and optimization. The protocols and algorithms in the directed graph model primarily comprise a membership protocol for providing a peer with a mechanism to join a session and an overlay construction and optimization module which provides algorithms to enhance data flow among the peers. This is accomplished using a parent-child protocol where two peers can both be parents of each other. In fact, peer can be any combination of parent and child in this model, thus aiding significantly the ability to exchange and pass information among the peers.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
The detailed description is described with reference to accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items.
Overview
This document describes a directed graph P2P streaming model. In this model, a source video server continuously generates streaming packets and delivers those packets to its children peers. All the other peers cooperate and exchange the video packets among one another. A bootstrap server is also deployed to help a new peer join the streaming session. A membership protocol is used when a peer first joins a session and an overlay construction and optimization module is used to enhance data flow among the peers.
This directed graph model has several advantages. First, the model is general enough to describe the overlay topology. In this model, two peers can be the parent nodes of each other, thus they can bilaterally exchange streaming data packets whenever possible.
Under the directed graph model, it is also more convenient to capture the heterogeneity in peer capabilities. End hosts on the Internet often have heterogeneous access bandwidths, processing power and the like. Furthermore, in many applications, such as asymmetric digital subscriber line (ADSL), users are connecting to the Internet via an asymmetric ADSL for uploading and downloading bandwidths. The incoming and outgoing degree of the directed graph can describe such heterogeneity very well.
Finally, the explicit parent-child relationship utilized in the directed graph model can precisely describe the data flow in the streaming overlay. Therefore, the directed P2P graph can be optimized to achieve the desired performance more easily. For example, a contribution-aware mechanism can be used to ensure that peers with higher bandwidths will get better streaming quality. As a result, the quality of service (QoS) of the P2P streaming system is much improved.
The graph in the directed graph P2P streaming model consists of the streaming source node or content server and a number of other nodes representing the peers that participate in the same streaming session.
Illustrative Architecture
As illustrated architecture 100 also includes a content server 106 that contains content 114 and is also referred to as the source node in the session. Nodes or peers 116 also participate in the session. Each node 116, such as node 116(1), contains one or more processors 118, memory 120, a membership module 122 and an overlay construction and optimization module 124.
The membership module 122 resides on each of the peers 116 and describes the process in which the various peers 116 can join a session and the information that is recorded by each of the peers 116 and the bootstrap server 102.
The overlay construction and optimization module 124 also resides on each of the peers 116 and defines the process for data exchange between the peers and also for replacing and discarding peers 116.
The server 112 and nodes 116 participate in the streaming overlay. However, the bootstrap server 102 typically does not participate in the streaming overlay. The streaming overlay is comprised of various levels and each level in the session is assigned a hop count 126. The hop count 126 represents the directed distance from the source node 112 to the peer 116, i.e. the length of the shortest path which consists of a number of consecutive directed arcs from the source to the peer.
In other words, the hop count of the source node r is always 0, and the hop count of the peer p is the length of the shortest path from r to p on the directed graph. Since the bootstrap server 102 does not participate in the streaming overlay, its hop count is set to H∞.
For a particular peer 116(1), a membership module 222 is described and provides a mechanism for a peer 116(1) to join a session. If a peer 116(1) is new to the session, the membership module 222 begins by contacting the bootstrap node or server 102. As such, the bootstrap server 102 is the entry point of the P2P streaming session. However, if the peer 116(1) is already a member of the session, then peer 116 can initiate the membership module 222 without going through the bootstrap server 102 and can contact another peer directly. Each peer 116(1), including the bootstrap server 102, maintains a partial view of the overlay. The partial view of the overlay contains peer record information and is more fully described later in this document.
The membership module 222 contains a peer record engine 224 for generating a peer record 226. The partial view of the overlay consists of a number of peer records 226. The maximum size of the partial view of a peer 116(1) is set to be a predefined value. The maximum size of the partial view of the bootstrap server 102 can be larger than the peers 116. In an illustrative embodiment, the maximum size of the partial view of a peer 116(1) is set to twenty and the maximum size of the partial view of the bootstrap server 102 is set to 100. Peers 116 periodically exchange their partial view information to update their membership information, both with the peers 116 and the bootstrap server 102.
The peer record engine 224 periodically generates a peer record 226 for each peer 116(1) to describe its current status. The peer record 226 contains a number of pieces of information. For instance, the peer record 226 may include a record number 228, a peer ID 230, a network address 232, one or more gossip times 234 and an overlay status 236. The first piece is the record number 228. The record number 228 uniquely identifies a particular record originated from the same source peer. In this arrangement, the newer record has a larger record number. The second piece of information in the peer record 226 is the peer ID 230. Each peer has a unique ID. The peer ID 230 can be a 128-bit UUID generated by the OS or an ID generated by any other method that provides a robust ID. The peer record 226 also includes a network address 232. The network address 232 of a peer 116(1) may be its internet protocol (IP) address, port or other address information that provides other peers with the ability to contact this peer through. The peer record 226 also includes the gossip times 234. Gossip times 234 are the number of times that this peer record 226 been relayed through the gossip message (described in detail below). Finally, the peer record 226 includes the overlay status 236. The overlay status is the status of the peer 116(1) in the streaming overlay, including current hop count of the peer, the current in degree and out degree of the peer, the max in and max out degree of the peer, and any other similar information.
To join the session, a new peer 116 first contacts the bootstrap server 102 and the bootstrap server 102 selects a number of nodes 116 randomly from its own partial view and sends them to the new peer 116. The peer 116 then adds the received peer records 226 to its own partial view and starts the gossip process engine 238. The bootstrap server 102 will add the new peer 116 into the partial view. If the addition of the new peer 116 causes the bootstrap server 102 to exceed the maximum size of the partial view, the bootstrap server 102 will randomly remove one node 116 from the partial view of the bootstrap server 102.
The gossip process engine 238 is an epidemic style gossip process to help peers 116 join the session and disseminate the membership information. The process is very efficient and robust to peer failure. Each peer 116(1), including the bootstrap server 102, runs a gossip process engine such as the gossip process engine 238. The gossip process engine 238 begins with a gossip message engine 240, which generates a gossip message. For each time period τ, each peer 116(1) randomly chooses one target peer from the partial view and tries to contact the target peer. If the peer successfully connects with the target peer, these two peers will send a gossip message from the gossip message engine 234 to each other. The gossip message 238 includes the partial views of the respective peers. In one implementation, the time period τ is set to τ=2 s. To prevent the peer overlay from separation, each peer is allowed to gossip with the bootstrap node 102 with a small probability Pbs where Pbs=0.01 in one implementation.
The partial view engine 242 executes when one peer receives the gossip message 238 from another peer. In this instance, the peer will merge the remote partial view with its local partial view according to a set of rules. For each record in the remote partial view, the record is added if the corresponding peer is not present in the local partial view. If a record exists which originated from the same peer in the local view but its sequence number is smaller, then the local record is replaced with the remote record. If the remote peer record is marked as a “dead node,” the local peer record will be marked as dead and the overlay module will be notified. In the event the merged cache resulting from the record additions exceed the pre-defined threshold, the records are sorted in the partial view by their gossip times in an ascending order and the view is truncated to the desired size by removing the records at the bottom of the sorted list.
A dead node removal engine 244 completes the gossip process engine 244. The resulting partial views are stored in a bootstrap cache 108 in the bootstrap server 102 and a local cache 246 on each peer.
A more detailed description of the dead node removal engine 244 is described below. Because the peers are frequently joining and leaving the overlay, some records in the cache will become “dead records” when the corresponding peers have quit the session. These “dead records” will affect the performance of the streaming overlay. Therefore, the dead nodes should be removed as quickly as possible. The dead node removal engine 244 is accomplished by setting a time-to-live (TTL) value for each record in the partial view. If the record is not updated for a longer time than the TTL, the node will be removed from the local cache 246. A MAX_GOSSIP_TIMES threshold is also set. When the gossip times of a record exceed the MAX_GOSSIP_TIMES threshold, that record will also be removed from the cache.
Each peer may also send a PEER_QUIT message to all the other peers in its own partial view when the peer quits the overlay elegantly. And when a peer receives a PEER_QUIT message from another peer, it will mark the quitted peer as dead. The dead peer record will be kept in the local cache 246 for some time until the TTL for that record has expired. And when exchanging gossip messages, the dead peer record will also be disseminated to other peers, so that the other peer will also know that the peer is dead. The dead peers are assigned extremely large gossip times (larger than MAX_GOSSIP_TIMES). Therefore, when merging the partial view, the dead peers will become the last peers listed in the partial view and may be truncated out if the merged partial view has exceeded the maximum size threshold.
When a peer selects another target peer from the local partial view and initiates a gossip process 238 with the target peer, the peer may sometimes fail to connect with the target peer. In this case, the target peer record will not be marked as dead in the local cache 246 and disseminated to others, because the failed connection may be caused by some connectivity issue such as a firewall, etc (i.e., for reasons other than the target peer being “dead”). Instead, the peer may simply remove the target peer from the local partial view.
Returning now to the bootstrap cache 108 and the local cache 246, because the membership module 222 maintains a number of peer records 226 and periodically updates them, the membership module 222 enables the upper overlay module to discover other peers and get the updated peer information in the current session.
The bootstrap server 102 will try to cache a number of underloaded nodes as the potential parent candidates for new peers. To do that, the bootstrap server maintains a cache in its memory named a bootstrap cache 108. During the gossip process 238 when the bootstrap server 102 finds a new peer which is underloaded (i.e. the peer has some free outgoing links), the bootstrap server 102 will put that peer record 226 into the bootstrap cache 108. The peer record 226 in the bootstrap cache 108 will be removed either when the bootstrap server 102 finds that the peer is no longer underloaded, or the record's TTL has expired (i.e. that record has not been updated for a long time).
After joining the session, each peer also needs to cache a number of underloaded nodes as its parent candidates. Therefore, each peer maintains a local cache 246 in its memory 120. During the gossip process 238, when a peer finds another peer which is underloaded, it will put that peer record into the local cache 246. The peer record 226 in the local cache 246 will be removed either when the peer finds that the cached peer is no longer underloaded, or the record's TTL has expired (i.e. that record has not been updated for a long time).
The overlay construction and optimization module 324 is one example of a overlay construction and optimization module 124 for an individual peer 116. The overlay construction and optimization module 324 begins with initialization engine 324 of a peer 116. The initialization engine 324 sets various in-degree and out-degree settings. Initially, both the peer's in-degree and out-degree are set to zero. The number of a peer's parents is defined as its in-degree, and the number of a peer's children is defined as its out-degree. The initial max in-degree is set to be a constant Kin. The initial max out-degree is equal to the max in-degree. The peer's initial overlay hop count is set to H∞.
To describe the different capability of the peers, some constraints on each node's incoming and outgoing degrees are set. Each peer has a maximum out-degree Kout(p), which stands for the maximal number of child nodes that it can support. Meanwhile, each node has a max in-degree Kin(p), which stands for the maximal number of parents it will try to find.
In the P2P streaming overlay, since each peer 116(1) will receive a video stream with constant bit-rate, the max in-degree of non-root peers is set to a constant value Kin. However, the max out-degree Kout(p) of each peer p needs to be determined by its own capability, particularly its uploading bandwidth. An adaptive method, described in more detail below, is used to adjust the peer's max out-degree in this P2P system. The video source node is the root of the whole directed graph, which has only outgoing links. Therefore, its max in-degree is always zero and its max out-degree is set to be a predefined constant value, which is decided by its outgoing bandwidth.
The overlay construction and optimization module 324 depends on a parent-child protocol 328. The parent-child relationship is defined as a directed arc from peer p to peer q to represent that the peer p is the “parent” of the peer q and the peer q is the child of the peer p. This is denoted by the expression p→q. There should be no duplicate arc with the same direction between two nodes. However, there may be two opposite directed arcs between two nodes. That is, two nodes can both be the parents of each other. In the P2P streaming session, each peer 116 will try to find several other peers as its parents and request streaming data from them. Meanwhile, a peer can also be the parent node of other peers and deliver video data to them.
In the parent-child engine 328, when a peer (subscribing peer) wants to add another or later peer (requested peer) as its parent, the peer will first send a SUBSCRIBE message to the requested peer. The requested peer checks its own status and decides whether to accept or decline this subscribe request. If the subscribe request is accepted, the requested peer will send back a SUBSCRIBE_ACCEPT message, add the subscribing peer as its child peer, and increase its out-degree by one. After receiving the SUBSCRIBE_ACCEPT message, the subscribing peer will add the requested node as a parent peer and increase its out-degree by one.
When a peer 116 wants to replace one of its parent nodes with some other better parent candidate, it may send an UNSUBSRIBE message to the parent node and decrease its in-degree by one. After receiving the unsubscribe message, the parent peer will remove the child node and decrease its out degree by one. When necessary, a parent node can also one remove one of its child nodes by sending a DISCARD message to it and decrease its out degree. After receiving the discard message, the child peer will remove the parent peer and decrease its in-degree.
Each peer 116 keeps alive all its parent nodes and child nodes by sending HEARTBEAT messages to them every few seconds. If the heartbeat message of some parent/child node is timed out, the peer 116 will think the node has left the overlay. The peer 116 will then remove the parent/child node and decrease its in-degree and out-degree respectively.
The overlay construction and optimization protocol 324 next employs a parent node engine 330 for finding parent nodes. After joining the overlay, the new peer 116 will send a query message to the bootstrap node 102. The bootstrap node 102 selects a number of underloaded nodes randomly from the bootstrap cache 108 and sends them back to the new peer 116. The new peer 116 will fill its own local cache with these nodes. Later, the new peer 116 will get the underloaded nodes from its own local cache. Underloaded is defined as a peer having an out-degree that is smaller than its max out-degree. Similarly, overloaded is defined as a peer having a max out-degree that is larger than its out-degree.
Periodically, each peer 116 will check the number of its parents and calculate the current required parent number as follows
dr(p)=Kin−d(p)+dp(p)
Where Kin is the max in degree, d(p) is the peer's current in degree, and dp(p) is the current number of p's poor parents. A poor parent node is defined as a parent node having a throughput less than a threshold. The peer will then select dr(p) parent candidates from its local cache and try to add them as parents. The peer records in the local cache are sorted by their overlap hop count in ascending order. The first dr(p) peers will be selected as the parent candidates. With a small probability, the peer will also select a random node from the local cache as the parent candidate. If the peer cannot get enough parent candidates from the local cache over a predetermined period of time, it will contact the bootstrap node 102 again to query for some parent candidates. After the selection procedure has been completed, the peer 116 will send SUBSCRIBE messages to the parent candidates to request they become its parent nodes.
A children node engine 332 is provided for accepting children nodes and occurs when a peer q receives the subscribe request from peer p. In the event this occurs, it will use the algorithm described herein to decide whether to accept or decline this subscribe request. In this procedure, the peer q first checks whether it has any parent (H(q)=H∞?). If peer q has no parent yet, it will simply decline peer p's request. Otherwise, it will continue to check its children's status.
If peer q is currently underloaded, it will accept the peer p as a child node immediately. Otherwise, it will adopt a contribution-aware strategy to handle peer p's request.
Each peer also has a contribution rate. The contribution rate used to describe how many packets the peer has delivered to other peers during the recent transmission process. For each peer p, the initial contribution rate is set to be zero. At the end of each scheduling round, the contribution rate C(p) is updated as follows:
where T(p,q) is the number of packets sent by p to its child peer q during last round, and α is a smoothing constant ranging in (0,1). The peer q first checks the contribution rates of its children and selects the child u which has the least contribution rate during the last Tc scheduling rounds. If u's contribution is less than a threshold Cmin, q will discard the child u and replace it with p, otherwise, q will decline p's request. The threshold for the minimum contribution rate Cmin is decided by the source video packet rate R and maximum in-degree Kin. We use the following equation to calculate Cmin.
Where, b is a small constant. We take b=1 in our implementation.
Packets scheduling engine 334 uses a pull-based method to exchange video packets among peers. The transmission procedure is arranged in scheduling rounds. Each scheduling round lasts Ts seconds. The live video is composed of a sequence of data packets. Every video packet has a sequence number to represent its location in the video stream. Each peer buffers a short period of video packets in a first-in, first-out (FIFO) queue with a fixed length. A bit vector, named buffer map, is used to describe the buffer status. The length of the bit vector is fixed and each bit in the vector represents the availability of the corresponding packet in the buffer. The maximum sequence number of the buffer is also recorded and transmitted with the buffer map.
Each peer periodically broadcasts its buffer map to all of its children to notify its current buffer status. According to the received buffer maps and its own buffer status, the child node schedules the missing packets to be pulled from its parents through some packet scheduling strategy. If two nodes are both the parent and child of each other, they will exchange their buffer maps as well as video packets.
The parent peer publishes its buffer map to its children for every Ts/2 seconds so that the children will get the update of their parents' buffer status for at least once within each scheduling round.
For every Ts second, each peer will schedule the packets which are missing in its cache according to the parents' buffer status and current available bandwidth using an intelligent packet scheduling algorithm. After scheduling, it will send a PULL message to its parent, which consists of a bit vector indicating the required packets. After receiving the pull message, the parent starts sending the required packets to the child immediately.
The contribution rate engine 336 generates a contribution rate as described briefly above. The contribution rate is used to describe how many packets the peer has delivered to other peers during the recent transmission process. For each peer p, the initial contribution rate is set to zero. At the end of each scheduling round, the contribution rate C(p) is updated as follows:
where T(p,q) is the number of packets sent by p to its child peer q during last round, and α is a smoothing constant ranging in (0,1).
Each peer will calculate its own contribution rate in each scheduling round and send it to its parent. The contribution rate information can be piggybacked on the parent along with the pull message. The parents will then adopt the contribution-aware strategy to adjust its children peers according to their contribution rates.
The poor parent engine 338 identifies those poor parents that need to be replaced. During the packets scheduling engine 334 operation, the peer measures the incoming data throughput from each parent node. If the peer finds one of its parents has a throughput less than a threshold, it will mark that parent as a “poor” parent. It will also send a POOR message to indicate that parent node and try to find another peer to replace the poor parent through the parent node engine 330 process. Once another parent node has been found, the poor parent will be removed from the partial view information on the peer's local cache.
To fully utilize the peer's out-going bandwidth on each outgoing link, each peer will also monitor the outgoing data throughput to each child in the inefficient children engine 340. The inefficient children engine 340 identifies those children that need to be replaced. If a child has not pulled any data from the link for more than a predetermined number of rounds, it will send a DISCARD message to that child and remove the discarded child peer.
In order to increase efficiency and performance, an adaptive max-out degree engine 342 is used. The initial max out-degree Kout(p) is set as the same value as the max in-degree Kin. After joining the overlay, the peer p will adjust Kout(p) adapting to p's outgoing bandwidth.
A peer p will decrease or increase its max out-degree Kout(p) when either of the following criteria is satisfied. First, consider a degree increase. Suppose a peer has served Kout(p) children for a time period Td. During this period, if it has not received any unsubscribe or poor throughput indication message from its children, and it has received a sufficient number of video packets, the peer will increase its max out-degree as follows:
Kout(p)=min(Kout(p)+1,Koutmax)
where Koutmax is a pre-defined constant value to prevent the exhaustive use of the peer's resources. In an exemplary implementation, Koutmax=20.
On the other hand, anytime a peer receives an unsubscribe message from a child due to poor throughput, it will decrease its max out-degree as follows
Kout(p)=max(Kout(p)−1,0).
Illustrative Processes
In operation 402, a peer, which may also include the bootstrap server, randomly chooses a target peer from its partial view and attempts to contact the target peer. As described earlier, the partial view includes peer record information for other peers in the session. If the peer and the target peer connect successfully, the two peers send a gossip message to each other in operation 404. The gossip message includes the respective partial views of each peer. In operation 406, the peer merges the remote partial view with its own partial view according to a set of rules. The rules provide that the target peer record will be added if it was not present in the originating peer's partial view. If the target peer record does exist, its sequence number will be checked to determine whether it is smaller than the existing record. If so, the existing record will be replaced with the new target peer record. Finally, if the target peer record is marked as a dead peer, the record in the originating peer will be marked as dead and the overlay will be notified.
All of the records are sorted in the partial view by their gossip times in ascending order in operation 408. If the number of records exceeds a predetermined or desired size, the partial view will be truncated and records removed to reduce the partial view to the desired size. In operation 410, the dead peers are identified and removed from the truncated partial view. Since these dead peers would have been at the end of the sort list in operation 408, they will be the first to be truncated in the event the partial view exceeds its threshold size.
In operation 502, a peer is initialized. The initialization sets the in-degree, the out-degree, the initial max in-degree, the initial max out-degree and the initial hop count as described in more detail above. Operation 504 provides for the utilization of a parent-child protocol. This is an important element in the overlay construction and optimization model and provides for two peers to be parents of each other, thus greatly enhancing data flow between peers. Operation 506 schedules a packet for exchange using a pull-based method. In operation 508, a contribution rate is calculated for each peer. The contribution rate is communicated along with the packet scheduling information to the requesting peers in operation 510. The hierarchy of all of the children peers is adjusted according to the contribution rate of each of the children peers in operation 512. Operation 514 replaces the parent peers that have an incoming throughput less than a predetermined threshold. Operation 516 discards the children peers that have an outgoing throughput less than a predetermined threshold.
The description herein describes a directed graph model using a peer-to-peer (P2P) overlay structure and a gossip-based protocol to maintain the distributed membership. A protocol suite for peers to join the live streaming session, form the P2P streaming overlay, and exchange video packets with others has also been presented. The different capabilities of the heterogeneous peers are well depicted using an adaptive out-degree mechanism. The performance of the whole system is maintained by a contribution-aware mechanism which ensures that the peers with large contribution will get more chance to be served than those with small or no contribution.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
Number | Name | Date | Kind |
---|---|---|---|
6205140 | Putzolu et al. | Mar 2001 | B1 |
7065579 | Traversat et al. | Jun 2006 | B2 |
7143139 | Burbeck et al. | Nov 2006 | B2 |
20060126527 | Cheung et al. | Jun 2006 | A1 |
20060200251 | Gu et al. | Sep 2006 | A1 |
20060224668 | Ginis | Oct 2006 | A1 |
20070086366 | Luo et al. | Apr 2007 | A1 |
20070280255 | Tsang et al. | Dec 2007 | A1 |
20080112315 | Hu et al. | May 2008 | A1 |
20100030909 | Magharei et al. | Feb 2010 | A1 |
Number | Date | Country |
---|---|---|
WO2008066560 | Jun 2008 | WO |
Number | Date | Country | |
---|---|---|---|
20100146092 A1 | Jun 2010 | US |