Language selection

Search

Patent 2791231 Summary

Third-party information liability

Some of the information on this Web page has been provided by external sources. The Government of Canada is not responsible for the accuracy, reliability or currency of the information supplied by external sources. Users wishing to rely upon this information should consult directly with the source of the information. Content provided by external sources is not subject to official languages, privacy and accessibility requirements.

Claims and Abstract availability

Any discrepancies in the text and image of the Claims and Abstract are due to differing posting times. Text of the Claims and Abstract are posted:

  • At the time the application is open to public inspection;
  • At the time of issue of the patent (grant).
(12) Patent: (11) CA 2791231
(54) English Title: SEAMLESS HANDOVER OF MULTICAST SESSIONS IN INTERNET PROTOCOL BASED WIRELESS NETWORKS USING STAGGERCASTING
(54) French Title: TRANSFERT TRANSPARENT DE SESSIONS MULTI-DIFFUSIONS DANS DES RESEAUX IP SANS FIL PAR DIFFUSION ECHELONNEE
Status: Granted and Issued
Bibliographic Data
(51) International Patent Classification (IPC):
  • H4L 12/18 (2006.01)
  • H4W 4/06 (2009.01)
(72) Inventors :
  • LIU, HANG (United States of America)
  • RAMASWAMY, KUMAR (United States of America)
(73) Owners :
  • INTERDIGITAL CE PATENT HOLDINGS, SAS
(71) Applicants :
  • INTERDIGITAL CE PATENT HOLDINGS, SAS (France)
(74) Agent: CRAIG WILSON AND COMPANY
(74) Associate agent:
(45) Issued: 2015-09-01
(22) Filed Date: 2006-04-29
(41) Open to Public Inspection: 2007-11-15
Examination requested: 2012-09-27
Availability of licence: N/A
Dedicated to the Public: N/A
(25) Language of filing: English

Patent Cooperation Treaty (PCT): No

(30) Application Priority Data: None

Abstracts

English Abstract

A method and apparatus are described for recovering from loss of an original data packet, including detecting data packet loss, joining a delayed multicast group, receiving a delayed data packet and using the delayed data packet to recover the original data packet that was lost. The delayed data packet is one of a copy of the original data packet, a copy of the original data packet encoded at a lower bit rate or a parity packet. Also described are a method and apparatus for staggercasting including encoding and compressing a first data sequence, packetizing the compressed encoded data sequence to form a data packet, multicasting the data packet to a first multicast group, encoding and compressing a second data sequence, packetizing the compressed encoded second data sequence to form a packet and multicasting the packet delayed by an offset time to a second multicast group.


French Abstract

Un procédé et un appareil sont décrits pour la récupération de la perte dun paquet de données original, y compris la détection dune perte dun paquet de données, ladhésion à un groupe multidiffusion, la réception dun paquet de données retardé et lutilisation du paquet de données retardé pour récupérer le paquet de données original qui a été perdu. Le paquet de données retardé est une dune copie du paquet de données original, dune copie du paquet de données original codé à un taux de bits inférieur ou un dun paquet de parité. Sont également décrits un procédé et un appareil de diffusion échelonnée comprenant le codage et la compression dune première séquence de données, la mise en paquet de la séquence de données codée comprimée pour former un paquet de données, la multidiffusion du paquet de données à un premier groupe de multidiffusion, le codage et la compression dune deuxième séquence de données, la mise en paquet de la deuxième séquence de données comprimée codée pour former un paquet et la multidiffusion du paquet retardé par un délai temporel à un deuxième groupe de multidiffusion.

Claims

Note: Claims are shown in the official language in which they were submitted.


CLAIMS
1. A method for staggercasting, said method comprising:
encoding and compressing a first data sequence;
packetizing said compressed encoded first data sequence to form a first data
packet;
multicasting said first data packet to a first multicast group;
generating a second data sequence related to said first data sequence;
packetizing said second data sequence to form a packet; and
multicasting said packet by an offset time to a second multicast group.
2. The method according to claim 1, further comprising adding a
packet header to said first data packet.
3. The method according to claim 1, wherein said offset time is pre-
determined.
4. The method according to claim 3, wherein said pre-determined
offset time is greater than one of an expected handoff duration and a maximum
handoff duration.
5. The method according to claim 1, wherein said packet is one of a
copy of said first data packet and a copy of said first data packet encoded at
a lower
bit rate.
6. The method according to claim 1, wherein said packet is a parity
packet.
7. An apparatus for staggercasting, comprising:
means for encoding and compressing a first data sequence;
means for packetizing said compressed encoded first data sequence to form
a first data packet;
means for multicasting said first data packet to a first multicast group;
means for generating a second data sequence related to said first data
sequence;
17

means for packetizing said second data sequence to form a packet; and
means for multicasting said packet by an offset time to a second multicast
group.
8. The apparatus according to claim 7, further comprising means for
adding a packet header to said first data packet.
9. The apparatus according to claim 7, wherein said offset time is pre-
determined.
10. The apparatus according to claim 9, wherein said pre-determined
offset time is greater than one of an expected handoff duration and a maximum
handoff duration.
11. The apparatus according to claim 7, wherein said packet is one of a
copy of said first data packet and a copy of said first data packet encoded at
a lower
bit rate.
12. The apparatus according to claim 7, wherein said packet is a parity
packet.
18

Description

Note: Descriptions are shown in the official language in which they were submitted.


CA 02791231 2012-09-27
PU060061'A
SEAMLESS HANDOVER OF MULTICAST SESSIONS IN INTERNET PROTOCOL
BASED WIRELESS NETWORKS USING STAGGERCASTING
This application is a division of Canadian Serial No. 2,649,667 filed April
29, 2006.
FIELD OF THE INVENTION
The present invention relates to wireless networking and in particular, to
seamless
handovers/handoffs using staggercasting.
BACKGROUND OF THE INVENTION
In video multicast/broadcast over IP-based wireless networks, video data is
encapsulated in UDP/IP packets and multicast/broadcast to the mobile devices
over wireless
networks. The IP-based wireless networks can be wireless local area networks
(WLANs),
cellular networks, wireless metropolitan area networks (WMANs) and wireless
regional area
networks (WRANs). When a mobile device moves from one cell to another, it is
handed-
over/handed-off from the base station (BS)/access point (AP) with which it is
currently
associated to another BS/AP. The two BSs/APs generally operate at different
frequencies/channels. A number of packets are lost when the mobile device
changes operating
frequency to associate with the new BS/AP.
Typically, a broadcast signal is transmitted to all possible receivers
simultaneously. A
multicast signal is transmitted to a selected subset (one or more) of all
possible receivers in a
group simultaneously. As used herein multicast also includes broadcast. That
is, a multicast
signal may be transmitted to a selected subset of all possible receivers in a
group where the
selected subset may include the entire set of all possible receivers, i.e. the
multicast group is
all receivers.
In wireless systems, channel coding is used at the physical layer to protect
packets
against multipath fading and interference. However, channel coding cannot
recover burst
packet loss during handovers/handoffs.
One prior art method provides for transmission of duplicate data time-
delayed/time-
shifted from the original data (staggercasting) in an ATSC system to improve
broadcast
system robustness. When duplicate, time-staggered streams are sent, the system
can tolerate
signal loss up to the duration of the time shift between the two streams.
Another prior art
method provides a lower bit rate version of the original data (instead of the
exact original
data) is repetitively transmitted with a time delay. This approach reduces the
bandwidth used
by the redundant data. However, both of these prior art schemes send a
composite signal and
always send the signals whether or not there are any clients/receivers that
want/need the data.
1

CA 02791231 2012-09-27
PU060061 A
Yet another prior art method provided for the use of cross-packet forward
error
correction (FEC) codes to protect against synchronization loss in an ATSC
system. FEC codes
have also been used to recover lost packets in IP-based wireless networks. In
general, an
erroneous packet is discarded by the link layer. The FEC codes are applied
across data packets
at the transport and application layers and erasure decoding is used to
recover the lost packets.
However, the FEC parity packets are generally sent together with the data
packet. During
handoffs/handovers, long error bursts may occur. These long error bursts lead
to the loss of
data packets and parity packets exceeding the FEC capability, so that the lost
data packets
cannot be recovered.
The problem addressed and solved by the present invention is how to protect
against
packet loss during handoff/handover for high-quality video multicast/broadcast
over IP-based
wireless networks.
SUMMARY OF THE INVENTION
In wireless networks, a mobile device may be handed-over/handed-off from one
base
station/access point to another base station/access point. The data
transmitted during these
handover/handoff periods are lost to the receiver/mobile device. The present
invention
provides a method and apparatus to recover from data packet loss for seamless
handoff/handover by repeatedly transmitting data packets with a time shift
(staggercasting).
Alternative embodiments are also provided, including staggercasting a lower
bit rate version
of the original data or staggercasting parity data generated by a cross-packet
forward error
correction code.
The system described herein includes one or more
server(s)/sender(s)/transmitter(s),
wireless base stations or access points, Ethernet switches, and receivers. A
receiver as used
herein is typically a mobile device. Mobile devices include, but are not
limited to, mobile
telephones, cellular telephones, mobile terminals, personal digital assistants
(PDAs) and
laptops.
The normal/original data and the time-shifted data are transmitted in a
backwards
compatible manner using different IP multicast groups. That is, if a mobile
device does not
have the capability provided in the present invention, it can still receive
the normal data
packets alone with low system resilience to packet loss. The delayed recovery
packets are
discarded by the mobile device. This achieves backward compatibility with
legacy devices.
A method and apparatus are described for recovering from loss of an original
data
packet, including detecting data packet loss, joining a delayed multicast
group, receiving a
2

CA 02791231 2012-09-27
PU060061 A
delayed data packet and using the delayed data packet to recover the original
data packet that
was lost. The delayed data packet is one of a copy of the original data
packet, a copy of the
original data packet encoded at a lower bit rate or a parity packet. Also
described are a method
and apparatus for staggercasting including encoding and compressing a first
data sequence,
packetizing the compressed encoded data sequence to form a data packet,
multicasting the data
packet to a first multicast group, encoding and compressing a second data
sequence,
packetizing the compressed encoded second data sequence to form a packet and
multicasting
the packet delayed by an offset time to a second multicast group. The packet
is one of a copy
of the original data packet, a copy of the original data packet encoded at a
lower bit rate or a
parity packet.
BRIEF DESCRIPTION OF THE DRAWINGS
The present invention is best understood from the following detailed
description when
read in conjunction with the accompanying drawings. The drawings include the
following
figures briefly described below where like-numbers on the figures represent
similar elements:
Fig. 1 is a schematic diagram of a multicast system in an internet protocol
based
wireless network using staggercasting.
Fig. 2a is a flowchart of an exemplary staggercasting video server/sender
implementation in accordance with the principles of the present invention.
Fig. 2b is a schematic diagram of an exemplary staggercasting video
server/sender
implementation in accordance with the principles of the present invention.
Fig. 3a is a flowchart of an exemplary staggercasting mobile receiver
implementation
in accordance with the principles of the present invention.
Fig. 3b is a schematic diagram of an exemplary staggercasting mobile receiver
implementation in accordance with the principles of the present invention.
Fig. 4 is an example of packet loss recovery using staggercasting in
accordance with
the principles of the present invention.
Fig. 5a is a flowchart of an exemplary video server/encoder implementation
with lower
quality video in the delayed recovery multicast group in accordance with the
principles of the
present invention.
Fig. 5b is a schematic diagram of an exemplary video server/encoder
implementation
with lower quality video in the delayed recovery multicast group in accordance
with the
principles of the present invention.
3

CA 02791231 2012-09-27
PU060061A
Fig. 6a is a flowchart of an exemplary mobile receiver implementation with
lower
quality video in the delayed recovery multicast group in accordance with the
principles of the
present invention.
Fig. 6b is a schematic diagram of an exemplary mobile receiver implementation
with
lower quality video in the delayed recovery multicast group in accordance with
the principles
of the* present invention.
Fig. 7 is an example of packet loss recovery with lower quality video in the
delayed
recovery multicast group in accordance with the principles of the present
invention.
Fig. 8a is a flowchart of an exemplary video server/encoder implementation
with
parity packets generated by a cross-packet forward error correction (FEC) code
in the delayed
recovery multicast group in accordance with the principles of the present
invention.
Fig. 8b is a schematic diagram of an exemplary video server/encoder
implementation
with parity packets generated by a cross-packet forward error correction (FEC)
code in the
delayed recovery multicast group in accordance with the principles of the
present invention.
Fig. 9 is an example of cross-packet encoding in accordance with the
principles of the
present invention.
Fig. 10a is a flowchart of an exemplary mobile receiver implementation with
parity
packets generated by a cross-packet FEC code in the delayed recovery multicast
group in
accordance with the principles of the present invention.
Fig. 10b is a schematic diagram of an exemplary mobile receiver implementation
with
parity packets generated by a cross-packet FEC code in the delayed recovery
multicast group
in accordance with the principles of the present invention.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
The present invention is directed to staggercasting in wireless networks to
recover
from the data packet loss during handoff/handover. This is accomplished by
repeatedly
transmitting data packets with a time shift/time delay. The data packets may
be copies of the
original/normal data packets or alternatively a lower bit rate version of the
original data
packets. Furthermore, the present invention provides another alternative
embodiment for
staggercasting the parity data generated by a cross-packet FEC code. The
present invention is
independent of video coding schemes. The present invention can also be used to
transmit
audio streams although video multicast over wireless networks is used as an
example to
explain the invention.
4

CA 02791231 2012-09-27
PU060061 A
Referring to Fig. 1, a typical network system in accordance with the present
invention
is shown. Multiple base stations/access points API, AP2 form a cellular
network to increase
the coverage. To reduce the interference, the adjacent wireless base
stations/access points
AP1/AP2 are operated in different frequency carriers/wireless channels. At
least one video
server 105 is connected to multiple wireless base stations (BSs) or access
points (APs)
through high-speed Ethernet LANs or other wired high-speed networks. The video
server 105
includes among other components a video encoder/transcoder and a packetizer.
For live video
multicast/broadcast, the video contents are encoded/transcoded, packetized and
then multicast
to a number of mobile clients (110, 11 5a, 115b, 120a, 120b, 125) through
wireless base
stations/access points API, AP2. Pre-coded video contents can also be
packetized and then
multicast to a number of mobile clients through wireless base stations/access
points.
When a mobile device (e.g., 115a, 120b) moves from one cell to another, the
mobile
device is handed-over/handed-off from the base station (BS)/access point (AP)
with which it
is currently associated to another BS/AP. A number of packets may be lost when
the mobile
device (115a, 120b) changes its operating frequency to associate with the new
BS/AP. To
recover from packet loss and achieve seamless handover, the present invention
provides for
simulcasting the same video content (data packets) with a time shift. The
normal video packet
stream is sent to all the base stations/access points in an IP multicast group
(normal video
multicast group). In addition, a duplicate, time-staggered/shifted/delayed
version of the
normal video packet stream is sent to all the mobile devices in another IP
multicast group
(delayed recovery multicast group). This technique is called staggercasting
herein. The normal
video stream and the time-shifted video stream provide time-diversity to
improve system
robustness in the handover/handoff situation. The system can transparently
tolerate the packet
loss up to the duration of time shift.
When a mobile device is handed-off from a BS/AP to an adjacent BS/AP, the
mobile
device sends a request to the new BS/AP to join/subscribe to both the normal
video multicast
group and the delayed video multicast group either when an error is detected
or as soon as a
handoff/handover situation occurs. The new BS/AP transmits/multicasts both the
normal video
packet stream and the delayed video packet stream in multicast over the
wireless link. The
mobile device receives both of the streams. If the mobile device detects that
some packets or a
video segment (a few video frames or Group of Frames (GOF)) are lost in the
normal video
packet stream, then the mobile device switches to the time-delayed video
packet stream to
recover the lost packets or video segment of the original video packet stream.
If the time

CA 02791231 2012-09-27
PU060061 A
shift duration/period between the normal video packet stream and the delayed
video packet
stream is greater than the handoff time, the lost video data can be recovered.
After the lost
data in the normal video packet stream are recovered, the mobile device can
send a request to
the BS/AP to leave/unsubscribe/exit the delayed video multicast group. If no
mobile device
associated with a BS/AP wants the data for a multicast group (normal video
data or delayed
video data), i.e. there are no members of a multicast group, the BS/AP will
not transmit data
for this multicast group in wireless networks, but discards the data. This
saves wireless
bandwidth. The Internet Multicast Management Protocol (GIMP) or other
protocols can be
used for the mobile device to request the BS/AP to join or leave a multicast
group. In an
alternative embodiment, the mobile device sends the request to the Ethernet
switch to join or
leave a multicast group. If no mobile device associated with a BS/AP wants the
data for a
multicast group, the Ethernet switch will not transmit the data for that
multicast group to the
BS/AP.
In particular, still referring to Fig. 1, mobile device 115b moves from a cell
serviced/supported by AP2 to a cell serviced/supported by API. In so doing,
mobile device
(now 115a - supported by API) requests API to join/subscribe to the normal and
delayed
video multicast groups, and receives both the normal video packet stream
(stream 1) and the
delayed/time-shifted version of the video packet stream (stream 2). If errors
are detected
(some packets or a video segment are/is lost) in the normal video packet
stream, then the
mobile device switches to the time-delayed video packet stream to recover the
lost packets or
video segment of the original video packet stream. If the time shift duration
between the
normal video packet stream and the delayed video packet stream is greater than
the handoff
time, the lost video data can be recovered. After the lost data in the normal
video packet
stream are recovered, the mobile device 115a can send a request to the BS/AP
to
leave/unsubscribe/exit the delayed video multicast group.
Similarly, mobile device 120a moves from a cell serviced/supported by API to a
cell
serviced/supported by AP2. In so doing, mobile device (now 120b - supported by
AP2)
requests AP2 to join/subscribe to the normal and delayed video multicast
groups, and receives
both the normal video packet stream (stream 1) and the delayed/time-shifted
version of the
video packet stream (stream 2). If errors are detected (some packets or a
video segment are/is
lost) in the normal video packet stream, then the mobile device switches to
the time-delayed
video packet stream to recover the lost packets or video segment of the
original video packet
stream. If the time shift duration between the normal video packet stream and
the delayed
6

CA 02791231 2012-09-27
PU060061 A
video packet stream is greater than the handoff time, the lost video data can
be recovered.
After the lost data in the normal video packet stream are recovered, the
mobile device 120b
can send a request to the BS/ AP to leave/unsubscribe/exit the delayed video
multicast group.
Fig. 2a is a flowchart of an exemplary video server/sender staggercasting
implementation for video multicast over IP-based wireless networks in
accordance with the
present invention. The source encoder/transcoder encodes/compresses the
uncompressed
video data sequence at 205. The possible video coding formats include H.264,
MPEG-2, etc.
The compressed video is packetized by the packetizer and the packet header is
added at 210.
If the real-time transport protocol (RTP) is used for video multicast, the
packet header is RTP
header. The RTP data packets are encapsulated in UDP and multicast in an IP
multicast group
(normal video multicast group) at step 215. A copy of these packetized
compressed video
data packets is also stored for an offset time Td at 220. The video data
(normal and delayed)
are transmitted/multicast at 215. The delayed version of the video packets are
transmitted/multicast to another IP multicast group (delayed recovery
multicast group).
Fig. 2b is a schematic diagram of an exemplary video server/sender
staggercasting
implementation for video multicast over IP-based wireless networks in
accordance with the
present invention. Uncompressed video sequence data is received by a video
server/sender
225. The video server/sender includes at least a video transcoder/encoder 225a
and a video
packetizer 225b. The video transcoder/encoder compresses the video sequence
data. The
video sequence data is then packetized and sent to both a protocol stack 230
and a delay
buffer 235. Protocol stack 230 includes at least UDP 230a and IP 230b. The
delay buffer 235
stores a copy of the packetized compressed video sequence data for an offset
time Td. The
delayed packetized compressed video sequence data is communicated to the
protocol stack
after offset time Td. The packetized compressed video sequence data (normal
and delayed data
packets) are communicated to the Ethernet interface 240, which
transmits/multicasts the
normal/original video data packets to a normal/original multicast group and
transmits/multicasts the delayed video packets to a delayed multicast group.
The components
described herein may be hardware, software or firmware or any combination
thereof including
RISC; ASIC and/or FPGA.
Fig. 3a is a flowchart of an exemplary mobile receiver/device implementation
for video
multicast over IP-based wireless networks in accordance with the present
invention. The
original/normal video packets and the delayed video packets are received from
different
multicast groups at 305. The normal video packets (video sequence data) and
delayed video
7

CA 02791231 2012-09-27
PU060061 A
packets (video sequence data) are separated into a normal video packet stream
and a delayed
video packet stream at 310. Error detection and correction is performed at
315. Error detection
is performed to determine whether packets were missing in the normal video
packet stream by
recognizing the gaps in received packet sequence number. The normal video
packet stream is
stored at 320. If the packet loss is detected in the normal video packet
stream, the packets in
the delayed video packet stream corresponding to the missing packets of the
normal video
packet stream are selected and inserted in the normal video packet steam in
the delay buffer to
recover/correct the packet loss in the normal video packet stream. The
recovered video
packets are depacketized. The depacketized video stream is decoded at 330.
Fig. 3b is a schematic diagram of an exemplary mobile receiver/device
implementation for video multicast over IP-based wireless networks in
accordance with the
present invention. An Ethernet/WLAN interface 335 receives video sequence data
(data
packets) from both a normal multicast group and a delayed multicast group. The
Ethernet/WLAN interface communicates the normal/original video sequence data
(data
packets) and the delayed video sequence data (data packets) to a protocol
stack 340, which
includes at least a UDP layer 340a and an IP layer 340b. The protocol stack
340 separates the
received video sequence data into a normal video packet stream and a delayed
video packet
stream and communicates the normal video packet stream and the delayed video
packet
stream to an error detection and correction module 345. Error detection is
performed by the
error detection and correction module 345 to determine whether packets were
missing in the
normal video packet stream by recognizing the gaps in received packet sequence
number. The
normal video packets are stored in a delay buffer 350 for a certain time
(offset time). If packet
loss is detected, the error detection and correction module 345 informs a
control module (not
shown). The control module sends a request (on behalf of the mobile device) to
the BS/AP to
join the delayed multicast group. The packets in the delayed video packet
stream
corresponding to the missing packets of the normal video packet stream are
inserted in the
normal video packet stream in the delay buffer 350 after they arrive. The
recovered video
sequence data are passed to the de-packetization module 355 and are
depacketized. The
depacketized video sequence data is communicated to a video decoder 360. The
video
decoder 360 decodes the depacketized recovered video. It is possible that the
control module
knows that a handoff/handover situation exists for the mobile device and sent
a request to join
the delayed multicast group to the BS/AP before the error detection and
correction module
informs the control module of any packet loss. The control module then does
not have to send
8

CA 02791231 2012-09-27
PU060061 A
a duplicate join request after receiving the error notice from the error
detection and correction
module 345.
Fig. 4 is an example of a packet loss recovery using staggercasting. Packets 4
through
8 in the normal video stream are lost due to handoff. The mobile device
requests the delayed
video stream (time shifted by an offset time Td) from the BS/AP. When the
delayed video
stream arrives at the mobile device, packets 4 to 8 in the delayed video
stream are inserted
into the normal video stream.
After the packet loss is recovered, the error detection and correction module
can
inform the control module that the delayed recovery stream is no longer
needed. The control
module may send a request to the BS/AP to leave/unsubscribe/exit the delayed
video multicast
group. If this is the last mobile device that leaves the delayed multicast
group, i.e. no mobile
device wants the data in this delayed multicast group, the BS/AP will stop
sending data to this
delayed multicast group. It is noted that the present invention can also be
used to recover from
packet loss caused by other reasons such as shadowing and interference.
The time shift (offset time Td) between the normal video packet stream and the
delayed video packet recovery stream is a design parameter. The time shift is
selected based
on the length of packet loss burst due to handover. The length of handover
loss should be less
than Td. The time shift can be the expected or average length of handover or
it can be the
maximum length of a handover.
An alternative embodiment is that instead of transmitting the duplicate video
packet
stream, a lower bit rate version of the normal video packet stream with
reduced
resolution/frame rate/quality video is transmitted in the delayed video
multicast group. This
method reduces the overhead. When the normal video data packets are lost
during handoff, a
lower quality version of the video is used by the mobile device to recover the
lost packets,
which allows for graceful degradation during handoff/handover situations.
Fig. 5a is a flowchart of an exemplary video server/sender implementation for
video
multicast over IP-based wireless networks using the reduced quality video in
the delayed
recovery IP multicast group. Video sequence data is received and
encoded/transcoded/compressed at 505 and at 510. The difference is that at 505
the
encoding/transcoding/compression of the video sequence data occurs at a lower
bit rate to
conserve bandwidth and provide graceful degradation of video in the event of
handoff/handover packet loss. The encoding/transcoding/compression of the
video sequence
data at 510 occurs at the normal or standard bit rate for transmission of the
video data. The
9

CA 02791231 2012-09-27
PU060061 A
encoded/transcoded/compressed video sequence data is packetized at 515 and
520. Once
again the difference is that at 515 the packetization is performed on the
lower bit rate video
sequence data and at 520 the packetization is performed on the normal bit rate
video sequence
data. The encoded/transcoded/compressed packetized lower bit rate video
sequence data is
stored at 525 for an offset time Td. Both the encoded/transcoded/compressed
packetized
normal bit rate video sequence data (data packets) and the
encoded/transcoded/compressed
packetized delayed (time shifted) lower bit rate video sequence data (data
packets) are
transmitted/multicast at 530. The delayed lower bit rate version of the video
packets are
transmitted/multicast to another IP multicast group (delayed recovery
multicast group). The
normal/original data packets are transmitted/multicast to an original/normal
multicast group.
Fig. 5b is a schematic diagram of an exemplary video server/sender
implementation
for video multicast over IP-based wireless networks using the reduced quality
video in the
delayed recovery IP multicast group. Video sequence data is received and
encoded/transcoded/compressed by two source encoders/transcoders 535 and 540.
Encoder/transcoder/compresser 535 is for the normal video and
encoder/transcoder/compresser
540 is for the lower quality (lower bit rate) recovery video. The normal
compressed video
stream is packetized after compression by packetizer 545 and the packets are
transmitted/multicast in an IP multicast group (normal video multicast group)
through the
UDP/EP stack 560 and Ethernet interface 565. The lower quality (lower bit
rate) video is
packetized by packetizer 550 after compression. The lower quality (lower bit
rate) packets are
stored in delay buffer 555 for an offset time Td. The delayed (time shifted)
lower quality
(lower bit rate) video packets are transmitted/multicast to another IP
multicast group (delayed/
recovery multicast group) through the UDP/IP stack 560 and Ethernet interface
565 after
delay. The protocol stack includes at least UDP layer 560a and IP layer 560b.
Note that
separate encoders may be implemented with one encoder selectably running with
a higher
processing speed to encode both normal video stream and lower quality recovery
video
stream. The components described herein may be hardware, software or firmware
or any
combination thereof including RISC, ASIC and/or FPGA.
Fig. 6a is a flowchart of an exemplary mobile receiver/device implementation
for
video multicast over IP-based wireless networks using the reduced quality
video in the
delayed recovery IP multicast group. The normal video packets and the delayed
video packets
are received from different multicast groups at 605. The normal video packets
(video
sequence data) and delayed video packets (video sequence data) are separated
into a normal

CA 02791231 2012-09-27
PU060061 A
video packet stream and a delayed video packet stream at 610. Error detection
is performed at
615. Error detection is performed to determine whether packets were missing in
the normal
video packet stream by recognizing the gaps in received packet sequence number
for the
normal video packet stream. It should be noted that one transmission error may
result in
multiple pictures decoded in error due to error propagation nature in
compressed video
sequence. Error detection is also performed to determine whether packets were
missing in the
delayed video packet stream by recognizing the gaps in received packet
sequence number for
the delayed video packet stream.
The normal video packet stream is depacketized at 620 and the delayed video
packet
stream is depacketized at 625. The depacketized normal video stream is decoded
at 630 and
the depacketized delayed video stream is decoded at 635. Copies of the decoded
normal video
stream are stored at 640 and copies of the decoded delayed video stream are
stored at 645. A
selection is made at 650 to determine from which stream (normal or delayed)
the decoded
pictures are displayed. If a normal picture is decoded without error, it is
always selected for
display. If errors occur in the normal video stream and the corresponding
delayed picture is
decoded without error, the decoded delayed picture is selected for display. If
both the normal
picture and the corresponding delayed picture are decoded in error, other
technique such as
error concealment can be used for the normal picture and the concealed normal
picture is
selected for display.
Fig. 6b is a schematic diagram of an exemplary mobile receiver/device
implementation for video multicast over IP-based wireless networks using the
reduced quality
video in the delayed recovery IP multicast group. The normal video packets and
the delayed
video packets are received from different multicast groups at an Ethernet/WLAN
interface
655. The normal video packets (video sequence data) and delayed video packets
(video
sequence data) are separated into a normal video packet stream and a delayed
video packet
stream at protocol stack 660. Protocol stack includes at least UDP layer 660a
and IP layer
660b. Error detection is performed by error detection module 665 to determine
whether
packets were missing in the normal video packet stream by recognizing the gaps
in received
packet sequence number for the normal video packet stream. It should be noted
that one
transmission error may result in multiple pictures decoded in error due to
error propagation
nature in compressed video sequence. Error detection is also performed to
determine whether
packets were missing in the delayed video packet stream by recognizing the
gaps in received
packet sequence number for the delayed video packet stream.
11

CA 02791231 2012-09-27
PU06006I-A
The normal video packet stream is communicated to depacketizer 670 and the
delayed
video packet stream is communicated to depacketizer at 675. Depacketizers 670
and 675
depacketize the error detected normal video stream and the error detected
delayed video stream
respectively. The depacketized error detected normal video packet stream is
communicated to
normal video decoder 680 and the depacketized delayed video packet stream is
communicated
to delayed/recovery video decoder at 685. Decoders 680 and 685 decode the
error detected
depacketized normal video stream and the error detected depacketized delayed
video stream
respectively. Copies Of the decoded depacketized error detected normal video
stream are
stored in normal video buffer 690 and copies of the decoded depacketized error
detected
delayed video stream are stored in recovery/delay video buffer 695. Selector
697 determines
from which stream (normal or delayed) the decoded pictures are displayed. The
normal video
decoder knows which frames are in error in the normal video stream and informs
selector 697.
The delayed/recovery video decoder knows which frames are in error in the
delayed recovery
video stream and informs selector 697. If a normal picture is decoded without
error, it is
always selected for display. If errors occur in the normal video stream and
the corresponding
recovery picture is decoded without error, the decoded recovery picture is
selected for display.
If both the normal picture and the corresponding recovery picture are decoded
in error, other
technique such as error concealment can be used for the normal picture and the
concealed
normal picture is selected for display. It should be noted that the exemplary
separate decoders
may be implemented with one decoder running with a higher processing speed to
decode both
normal stream and recovery stream. The components described herein may be
hardware,
software or firmware or any combination thereof including RISC, ASIC and/or
FPGA.
Fig. 7 is an example packet loss recovery with lower quality video in the
delayed
recovery multicast group in accordance with the principles of the present
invention. When
packet loss occurs in the normal video stream due to handoff, the mobile
device requests the
delayed recovery video stream from the BS/AP. Video data from both the normal
stream and
the delayed recovery stream are decoded using the appropriate decoder. The
normal video
stream is delayed sufficiently at the normal video buffer that the
corresponding recovery
pictures are available at the recovery video buffer. Pictures 1-4 from the
normal video stream
are decoded without error so they are selected for display. Packet loss errors
were detected in
pictures 5 to 8 in the normal video stream. However, the corresponding
pictures in the
recovery video stream do not have packet loss errors so pictures 5 to 8 from
the recovery
video stream are selected for display.
12

CA 02791231 2012-09-27
PU060061 A
In an alternative embodiment instead of transmitting the duplicate video
stream or a
lower quality video stream, parity packets generated by a cross-packet forward
error
correction code (FEC) are transmitted to the delayed recovery IP multicast
group. A FEC code
is applied to the video data packets to generate the parity packets. The video
packet stream and
the parity packet stream are multicast with a time shift to different IP
multicast groups,
i.e. staggercasting the video stream and the parity stream for temporal
diversity.
Fig. 8a is a flowchart of an exemplary transmitter/server implementation for
video
multicast over wireless IP networks using the FEC parity packets in the
delayed recovery IP
multicast group. Uncompressed video sequence data is received and
encoded/transcoded/compressed at 805. The encoded/transcoded/compressed video
sequence
data is packetized and the packet header is added at 810. The packetized
encoded/transcoded/compressed video sequence data is then FEC encoded at 815
to form FEC
parity packets. The FEC codes are applied across video packets to. generate
the parity packets.
The header is added in the FEC packets containing FEC information. The extra
FEC related
header may also be added to the video data packets depending on the FEC coding
scheme. The
video data packets are then transmitted/multicast to an IP multicast group
(normal video
multicast group) at 825. The parity packets are stored at 820 for an offset
time Td. The FEC
parity packets are transmitted/multicast to another IP multicast group
(delayed/recovery
multicast group) at 825 after a delay/time shift Td.
Fig. 8b is a schematic diagram of an exemplary transmitter/server
implementation for
video multicast over wireless BP networks using the FEC parity packets in the
delayed
recovery IP multicast group. Video encoder/transcoder/compresser 830 receives
uncompressed video sequence data and encodes/transcodes/compresses the
uncompressed
video sequence data. The encoded/transcoded/compressed video sequence data is
communicated to packetizer 835, which packetizes the
encoded/transcoded/compressed video
sequence data to form data packets and add the packet header. The packetized
encoded/transcoded/compressed video sequence data is then communicated to FEC
encoder
840 to form parity packets. The FEC encoder is placed after the packetization,
but before the
protocol stack 850. The FEC codes are applied across the video packets to
generate the parity
packets. The header is added in the FEC packets containing FEC information.
The FEC
related header may also be added to the video data packets depending on the
FEC coding
scheme. The video data packets are transmitted/multicast to an IP multicast
group (normal
video multicast group) through the protocol stack 850 and Ethernet/WLAN
interface 855. The
13

CA 02791231 2012-09-27
PU060061 A
protocol stack 850 includes at least UDP layer 850a and IP layer 850b. The
parity packets are
stored in the delay buffer 845 for an offset time Td. The FEC parity packets
are
transmitted/multicast to another IP multicast group (delayed/recovery
multicast group) via the
protocol stack 850 and Ethernet/WLAN interface 855 after a delay/time shift
Td. The
components described herein may be hardware, software or firmware or any
combination
thereof including RISC, ASIC and/or FPGA.
Fig. 9 is an example of cross-packet encoding in accordance with the
principles of the
present invention. As shown in Fig. 9, K video packets are grouped together
and Reed-
Solomon (RS) (N, K) code is applied to the packet group to generate N-K parity
packets. The
header is added to the FEC packets containing FEC information including which
video
packets this FEC packet protects. The FEC related header may also be added to
the video
packets depending on the FEC coding scheme. The video data packets are
transmitted to an IP
multicast group (normal video multicast group) via the UDP/IP stack and
Ethernet interface.
The parity packets are then stored in a delay buffer for an offset time Td.
The FEC parity
packets are transmitted to another IP multicast group (delayed/recovery
multicast group) via
the UDP/IP and Ethernet interface after a delay/time shift Td.
Fig. 10a is a flowchart of an exemplary mobile receiver/device implementation
for
video multicast over IP-based wireless networks using the FEC parity packets
in the delayed/
recovery multicast group. Normal video data packets containing video sequence
data and the
delayed parity packets are received from different multicast groups at 1005.
They are
separated into video packets and parity packets at 1010. The received video
data packets are
stored at 1015. The erroneous video and parity packets are discarded by the
link layer (WLAN
interface). FEC erasure decoding is performed at 1020. The positions of lost
video data
packets or parity packets are detected through the sequence number in the
packet header by
the FEC erasure decoding process. The FEC header in the parity packets and/or
in the video
data packets is used to determine the FEC block information. With the RS (N,
K) code, as
long as any K or more packets out of N packets in the FEC coding block
(regardless whether
video data packets or parity packets) are correctly received, the FEC erasure
decoding process
can reconstruct the original (normal) video packets. The FEC erasure decoding
process is a
reverse process of the FEC encoding process, which is performed across the
packets with one
symbol from each packet to consist of the codeword. The FEC erasure decoded
video data
packets are depacketized at 1025. The depacketized video data packets are then
video
decoded at 1030 to produce decoded video for display.
14

CA 02791231 2012-09-27
PU060061 A
One embodiment uses a half-rate RS code. For the RS code with erasure
decoding,
each parity packet can recover any one lost packet in the coding block. When a
half-rate RS
(N, K) code (N = 2K) is applied to the K video packets, it generates K parity
packets. With the
half-rate RS code, even if video data packets are completely lost in a burst
during handover,
the lost data packets can be recovered from the corresponding parity packets
alone. In this
sense, the parity, packet stream generated by the half -rate RS code is an
alternative to the
original (normal) video packet stream. It should be noted that besides Reed-
Solomon (RS)
codes, other FEC codes can also be used to generate parity packets.
Fig. I Ob is a schematic diagram of an exemplary mobile receiver/device
implementation for video multicast over IP-based wireless networks using the
FEC parity
packets in the delayed/recovery multicast group. Normal video data packets and
the delayed
parity packets are received from different multicast groups at the
WLAN/Ethernet interface
1035. They are separated into video data packets and parity packets by
protocol stack 1040,
which includes at least UDP layer 1040a and IP layer 1040b. The received video
data packets
are delayed in buffer 1045. The erroneous video and parity packets are
discarded by the link
layer (WLAN interface). The FEC erasure decoding module 1050 is between the de-
packetization and UDP layer. The positions of lost video data packets or
parity packets are
detected through the sequence number in the packet header by the FEC erasure
decoding
module 1050, which is used for erasure decoding. The FEC header in the parity
packets and/or
in the video packets is used by FEC erasure decoding module 1050 to determine
the FEC
block information. With the RS (N, K) code, as long as any K or more packets
out of N
packets in the FEC coding block (regardless whether video data packets or
parity packets) are
correctly received, the FEC erasure decoding module 1050 can reconstruct the
original
(normal) video data packets. The FEC erasure decoding is a reverse process of
the FEC
encoding process, which is performed across the packets with one symbol from
each packet to
consist of the codeword. The FEC erasure decoded video data packets are
communicated to
depacketizer 1055, which depacketizes the video data packets. The depacketized
video data
packets are then communicated to video decoder module 1060. The components
described
herein may be hardware, software or firmware or any combination thereof
including RISC,
ASIC and/or FPGA.
If no return wireless channel from the mobile device to the BS/AP is available
and/or a
simple system implementation is preferred, the B S/ AP may always transmit the
normal video

CA 02791231 2012-09-27
PU060061 A
stream and delayed recovery stream in multicast over the wireless networks.
The mobile
receiver/device receives both streams without requesting them.
Another embodiment is to use staggercasting to layered/scalable video coding.
Only
the base layer for the scalable coder is staggered in time using the present
invention: The
normal base layer video data packets are sent multicast in the normal
multicast group as
described above. The duplicate base layer data or its parity data generated by
a cross-packet
FEC encoder is transmitted multicast with a time delay in the delayed
multicast group. The
normal enhancement layer data packets are sent in another multicast group
without delay. The
overhead associated with using staggercasting is thus reduced. When the normal
video (both
base layer and enhancement layer) is lost, the base layer recovered by the
packets in the
delayed recovery multicast group can provide a lower quality video. This leads
to a graceful
degradation during handoff.
It is to be understood that the present invention may be implemented in
various forms
of hardware, software, firmware, special purpose processors, or a combination
thereof.
Preferably, the present invention is implemented as a combination of hardware
and software.
Moreover, the software is preferably implemented as an application program
tangibly
embodied on a program storage device. The application program may be uploaded
to, and
executed by, a machine comprising any suitable architecture. Preferably, the
machine is
implemented on a computer platform having hardware such as one or more central
processing
units (CPU), a random access memory (RAM), and input/output (I/O)
interface(s). The
computer platform also includes an operating system and microinstruction code.
The various
processes and functions described herein may either be part of the
microinstruction code or
part of the application program (or a combination thereof), which is executed
via the operating
system. In addition, various other peripheral devices may be connected to the
computer
platform such as an additional data storage device and a printing device.
It is to be further understood that, because some of the constituent system
components
and method steps depicted in the accompanying figures are preferably
implemented in
software, the actual connections between the system components (or the process
steps) may
differ depending upon the manner in which the present invention is programmed.
Given the
teachings herein, one of ordinary skill in the related art will be able to
contemplate these and
similar implementations or configurations of the present invention.
16

Representative Drawing
A single figure which represents the drawing illustrating the invention.
Administrative Status

2024-08-01:As part of the Next Generation Patents (NGP) transition, the Canadian Patents Database (CPD) now contains a more detailed Event History, which replicates the Event Log of our new back-office solution.

Please note that "Inactive:" events refers to events no longer in use in our new back-office solution.

For a clearer understanding of the status of the application/patent presented on this page, the site Disclaimer , as well as the definitions for Patent , Event History , Maintenance Fee  and Payment History  should be consulted.

Event History

Description Date
Change of Address or Method of Correspondence Request Received 2023-01-16
Inactive: COVID 19 - Deadline extended 2020-03-29
Common Representative Appointed 2019-10-30
Common Representative Appointed 2019-10-30
Letter Sent 2019-05-15
Inactive: Multiple transfers 2019-04-29
Inactive: Multiple transfers 2019-04-25
Grant by Issuance 2015-09-01
Inactive: Cover page published 2015-08-31
Pre-grant 2015-06-22
Inactive: Final fee received 2015-06-22
Notice of Allowance is Issued 2014-12-24
Letter Sent 2014-12-24
4 2014-12-24
Notice of Allowance is Issued 2014-12-24
Inactive: Approved for allowance (AFA) 2014-11-21
Inactive: Q2 passed 2014-11-21
Amendment Received - Voluntary Amendment 2014-10-17
Inactive: S.30(2) Rules - Examiner requisition 2014-06-16
Inactive: Report - No QC 2014-06-02
Change of Address or Method of Correspondence Request Received 2014-05-07
Amendment Received - Voluntary Amendment 2013-09-12
Inactive: Cover page published 2012-11-16
Inactive: IPC assigned 2012-10-30
Inactive: First IPC assigned 2012-10-30
Inactive: IPC assigned 2012-10-30
Divisional Requirements Determined Compliant 2012-10-16
Letter sent 2012-10-16
Letter Sent 2012-10-16
Letter Sent 2012-10-16
Application Received - Regular National 2012-10-16
Application Received - Divisional 2012-09-27
Request for Examination Requirements Determined Compliant 2012-09-27
All Requirements for Examination Determined Compliant 2012-09-27
Application Published (Open to Public Inspection) 2007-11-15

Abandonment History

There is no abandonment history.

Maintenance Fee

The last payment was received on 2015-04-10

Note : If the full payment has not been received on or before the date indicated, a further fee may be required which may be one of the following

  • the reinstatement fee;
  • the late payment fee; or
  • additional fee to reverse deemed expiry.

Patent fees are adjusted on the 1st of January every year. The amounts above are the current amounts if received by December 31 of the current year.
Please refer to the CIPO Patent Fees web page to see all current fee amounts.

Owners on Record

Note: Records showing the ownership history in alphabetical order.

Current Owners on Record
INTERDIGITAL CE PATENT HOLDINGS, SAS
Past Owners on Record
HANG LIU
KUMAR RAMASWAMY
Past Owners that do not appear in the "Owners on Record" listing will appear in other documentation within the application.
Documents

To view selected files, please enter reCAPTCHA code :



To view images, click a link in the Document Description column (Temporarily unavailable). To download the documents, select one or more checkboxes in the first column and then click the "Download Selected in PDF format (Zip Archive)" or the "Download Selected as Single PDF" button.

List of published and non-published patent-specific documents on the CPD .

If you have any difficulty accessing content, you can call the Client Service Centre at 1-866-997-1936 or send them an e-mail at CIPO Client Service Centre.

({010=All Documents, 020=As Filed, 030=As Open to Public Inspection, 040=At Issuance, 050=Examination, 060=Incoming Correspondence, 070=Miscellaneous, 080=Outgoing Correspondence, 090=Payment})


Document
Description 
Date
(yyyy-mm-dd) 
Number of pages   Size of Image (KB) 
Claims 2014-10-16 2 46
Description 2012-09-26 16 1,034
Abstract 2012-09-26 1 26
Claims 2012-09-26 2 54
Drawings 2012-09-26 16 129
Representative drawing 2015-08-04 1 20
Acknowledgement of Request for Examination 2012-10-15 1 175
Courtesy - Certificate of registration (related document(s)) 2012-10-15 1 102
Commissioner's Notice - Application Found Allowable 2014-12-23 1 162
Correspondence 2012-10-15 1 38
Correspondence 2014-05-06 1 25
Final fee 2015-06-21 1 34