This application is based on and claims priority under 35 U.S.C. § 119 to Korean Patent Application No. 10-2016-0109986, filed on Aug. 29, 2016 in the Korean Intellectual Property Office, the disclosure of which is incorporated by reference herein in its entirety.
The present disclosure relates generally to a server device, a user terminal device, control methods thereof and a streaming system, and for example, to a server device configured to provide streaming service for a high capacity content, a user terminal device, control methods thereof and a streaming system.
High definition images such as full high definition (FHD) content and ultra high definition (UHD) content are supplied with development of the electronic technology. Specifically, a technology for not only compressing high definition content, but also providing streaming service in real time is supplied.
However, in order to provide high definition content, an image compression technology having high efficiency is necessary. For example, in order to process a RGB image having 8 bits per 1280×720 resolution (HD) component sample by 30 pages per second, it means that the 663,552,000 (1280×720×8×3×30) bps have to be processed, while, to process a RGB image having 8 bits per 3840×2160 resolution (UHD) component sample by 30 pages per second, it means that 5,971,968,000 (3840×2160×8×3×30) bps have to be processed. In other words, as resolution of content increases, bits to be processed increase exponentially, and there occurs difficulty of transmitting the content in real time.
Accordingly, a new technology to provide streaming service for high definition content in real time is necessary.
Example embodiments of the present disclosure address the above disadvantages and other disadvantages not described above.
According to an example embodiment, a server device which provides streaming service for a high capacity content, a user terminal device, control methods thereof and a streaming system are provided.
According to an example embodiment, a server device is provided, which may include a communicator comprising communication circuitry configured to perform communication with a user terminal device, a plurality of encoders configured to perform encoding in parallel, and a processor configured to sequentially allocate frames generated in real time to the plurality of encoders, and to control the communicator so that a plurality of encoded frames output in parallel from the plurality of encoders are streamed individually to the user terminal device.
The plurality of encoders may include a first encoder and a second encoder, and the processor may allocate odd-numbered frames of the frames generated in real time to the first encoder and allocate even-numbered frames to the second encoder.
When a re-request signal for a certain frame is received from the user terminal device, the processor may first re-transmit the certain frame if the certain frame is a frame encoded in a first encoding type, and if the certain frame is a frame encoded in a second encoding type, the processor may first re-transmit the frame encoded in the first encoding type after the certain frame of the encoded frames is output from the encoder that encodes the certain frame.
When a re-request signal for a certain frame is received from the user terminal device, the processor may first re-transmit the certain frame if the certain frame is an intra frame, and if the certain frame is an inter frame, the processor may first re-transmit an intra frame after the certain frame of the encoded frames is output from the encoder that encodes the certain frame.
When a frame including video data and a frame including UI data provided with the video data is generated, the processor may allocate a frame including the UI data to one of the plurality of encoders, and sequentially allocate a frame including the video data to rest of the plurality of encoders.
In an example embodiment, a user terminal device is provided, which may include a display, a communicator comprising communication circuitry configured to perform communication with a server device, a plurality of decoders configured to perform decoding in parallel, at least one buffer connected to the plurality of decoders, and a processor configured to sequentially allocate to a plurality of decoders a plurality of encoded frames output in parallel from a plurality of encoders provided in the server device and streamed individually from the server device, to store a plurality of decoded frames output in parallel from the plurality of decoders in at least one buffer, and to display the plurality of decoded frames in order on the display based on identification information included in the plurality of decoded frames stored in the at least one buffer.
The processor may transmit a re-request signal for a certain frame to the server device when an error occurs in the decoding of a certain frame, and display in order a plurality of frames output from rest decoders other than the decoder corresponding to the certain frame from among the plurality of decoders.
The processor may sequentially allocate to the plurality of decoders an encoded frame including video data individually streamed from the server device, and an encoded frame including UI data provided with the video data, synchronize the decoded video data frame with the decoded UI data frame output respectively from the plurality of decoders, and display a result.
In an example embodiment, a streaming system is provided, which may include a server comprising a plurality of encoders configured to perform encoding in parallel, and configured to sequentially allocate frames generated in real time to a plurality of encoders and individually stream a plurality of encoded frames output in parallel from the plurality of encoders to the user terminal device, and a user terminal device including a display, a plurality of decoders configured to perform decoding in parallel, and at least one buffer connected to the plurality of decoders, and configured to sequentially allocate a plurality of encoded frames streamed from the server device to the plurality of decoders, to store the plurality of decoded frames output in parallel from the plurality of decoders in at least one buffer, and to display in order the plurality of decoded frames on the display based on identification information included in the plurality of decoded frames stored in the at least one buffer.
In an example embodiment, a control method of a server device is provided, which may include sequentially allocating frames generated in real time to a plurality of encoders for performing encoding in parallel, and individually streaming a plurality of encoded frames output in parallel from the plurality of encoders to a user terminal device.
The plurality of encoders may include a first encoder and a second encoder, and the allocating may include allocating odd-numbered frames of the frames generated in real time to the first encoder and allocating even-numbered frames to the second encoder.
The control method may further include receiving a re-request signal for a certain frame from the user terminal device, and re-transmitting the certain frame when the certain frame is a frame encoded in a first encoding type, and when the certain frame is a frame encoded in a second encoding type, re-transmitting the frame encoded in the first encoding type after the certain frame of encoded frames is output from the encoder that encodes the certain frame.
The re-transmitting may include first re-transmitting the certain frame when the certain frame is an intra frame, and when the certain frame is an inter frame, first re-transmitting the intra frame after the certain frame of encoded frames is output from the encoder that encodes the certain frame.
When a frame including video data and a frame including UI data provided with the video data is generated, the allocating may include allocating the frame including the UI data to one of the plurality of encoders, and sequentially allocating the frame including the video data to rest of the plurality of encoders.
In an example embodiment, a control method of a user terminal device is provided, in which the user terminal device receives a plurality of encoded frames output in parallel from a plurality of encoders provided in a server device and streamed, and processes the same, and the control method includes allocating a plurality of individually-streamed, encoded frames from the server device sequentially to a plurality of decoders for performing decoding in parallel, storing a plurality of decoded frames output in parallel from the plurality of decoders in at least one buffer connected to the plurality of decoders, and displaying the plurality of decoded frames in order based on identification information included in the plurality of decoded frames stored in the at least one buffer.
The control method may further include transmitting a re-request signal for a certain frame to the server device when an error occurs in the decoding of the certain frame. The displaying may include displaying in order a plurality of frames output from rest decoders other than the decoder corresponding to the certain frame among the plurality of decoders.
The allocating may further include sequentially allocating an encoded frame including video data individually streamed from the server device and an encoded frame including UI data provided with the video data, synchronizing the decoded UI data frame output respectively from a plurality of decoders with the decoded video data frame, and displaying a result.
According to the above various example embodiments, the server device and the user terminal device may provide high quality of streaming service using a plurality of encoders and a plurality of decoders and processing high capacity content.
The above and/or other aspects, features and attendant advantages of the present disclosure will be more apparent and readily appreciated from the following detailed description, taken in conjunction with the accompanying drawings, in which like reference numerals refer to like elements, and wherein:
Referring to the attached drawings, various example embodiments of the present disclosure will be described in greater detail below. It should be understood that the matters defined in the description may not limit a scope of the disclosure, but include various modifications, equivalents and/or alternatives of the example embodiments. With respect to explanation of drawings, the same or similar drawing reference numerals may be used in similar constituent elements.
Further, when it is mentioned that one element (e.g., first element) is operatively or communicatively coupled with or connected to another element (e.g., second element), this should be understood as including all the examples where each of the elements is directly coupled or indirectly coupled via yet another element (e.g., third element). Meanwhile, when it is mentioned that one element (e.g., first element) is “directly coupled” with or “directly connected to” another element (e.g., second element), it may be understood that there is no element (e.g., third element) present between one element and another element.
Terms used in the present disclosure are provided to explain example embodiments, and are not be intended to limit a scope of other embodiments. Further, while a singular expression may be used herein for convenience of explanation, unless specified otherwise in the context, it may be interpreted as including a plural expression. Further, terms used in the present disclosure may have same meaning as being understood generally by a person skilled in the art. Terms used in the present disclosure and defined in a general dictionary may be interpreted as having a same or similar meaning according to the context of the related technology, and unless specifically defined otherwise herein, cannot be interpreted as an ideological or excessively formal meaning. Depending on cases, even the terms defined in the present disclosure should not be interpreted as excluding the embodiments of the present disclosure.
Hereinbelow, various example embodiments of the present disclosure will be described in greater detail with reference to the accompanying drawings.
The server device 100 may perform communication with the user terminal device 200. The server device 100 may transmit content to be provided from the user terminal device 200 in real time. Meanwhile, the server device 100 may receive a re-request signal for a certain frame from the user terminal device 200.
The server device 100 may include a plurality of encoders. A plurality of encoders may perform encoding in parallel. For example, a plurality of encoders may encode in parallel one content divided into a plurality of content. Alternatively, each of a plurality of encoders may encode a plurality of contents in parallel.
The server device 100 may sequentially allocate a plurality of encoders with frames generated in real time. For example, when the server device 100 includes two encoders, the server device 100 may alternately allocate frames generated in real time to the two encoders. Alternatively, the server device 100 may allocate frames in such a manner in which a first frame and a second frame generated in real time are allocated to the first encoder of the two encoders, and a third frame and a fourth frame generated in real time are allocated to the second encoder of the two encoders.
The server device 100 may individually stream a plurality of encoded frames output in parallel from a plurality of encoders to the user terminal device. For example, the server device 100 may individually stream a plurality of encoded frames output in parallel from a plurality of encoders to the user terminal device through a plurality of channels.
The user terminal device 200 may, for example, and without limitation, be any of various electronic devices. For example, it may be implemented as digital camera, MP3 player, PMP, smart phone, cellular phone, smart glasses, tablet PC, smart watch, or various other devices. For example, the user terminal device 200 may be a device equipped with a display.
The user terminal device 200 may perform communication with the server device 100. The user terminal device 200 may receive content provided from the server device 100 in real time. Meanwhile, the user terminal device 200 may transmit a re-request signal for a certain frame to the server device 100.
The user terminal device 200 may include a plurality of decoders. A plurality of decoders may perform decoding in parallel. For example, a plurality of decoders may decode one content, which is divided into a plurality of contents, in parallel. Alternatively, a plurality of decoders may respectively decode a plurality of contents in parallel.
The user terminal device 200 may sequentially allocate a plurality of decoders with a plurality of encoded frames output in parallel from a plurality of encoders provided in the server device 100 and streamed individually from the server device 100.
The user terminal device 200 may store a plurality of decoded frames output in parallel from a plurality of decoders into at least one buffer connected to a plurality of decoders. The user terminal device 200 may display a plurality of decoded frames in order on the display based on identification information included in a plurality of decoded frames stored in at least one buffer.
As described above, the server device 100 may individually stream a plurality of encoded frames to the user terminal device 200. The user terminal device 200 may decode a plurality of individually-streamed, encoded frames and display them in order. In other words, the user terminal device 200 may provide high-capacity content streaming service by dividing one content into a plurality of contents, performing encoding and decoding, and transmitting a result through a plurality of channels.
As illustrated in
Meanwhile,
The communicator 110 may include various communication circuitry and perform communication with the user terminal device 200. Further, the communicator 110 may transmit content to be provided from the user terminal device 200 in real time. Specifically, the communicator 110 may individually transmit a plurality of encoded frames obtained from the content to the user terminal device 200 through a plurality of channels.
The communicator 110 may transmit quality of service (QoS) information to the user terminal device 200. The QoS information will be described in a later part of the present disclosure.
The communicator 110 may receive a re-request signal for a certain frame from the user terminal device 200. In this case, the communicator 110 may only stop transmission through channels corresponding to a certain frame, while the other channels may keep transmission state irrespective of a re-request signal.
The communicator 110 may perform communication with the user terminal device 200 through various communication methods such as BlueTooth (BT), Bluetooth Low Energy (BLE), Wireless Fidelity (WI-FI), Zigbee, IR (Infrared), Serial Interface, Universal Serial Bus (USB), Near Field Communication (NFC), and so on. Among them, the NFC chip refers to a chip operating in the NFC method which uses 13.56 MHz bandwidth among various RF-ID frequency bandwidths such as 135 kHz, 13.56 MHz, 433 MHz, 860-960 MHz, 2.45 GHz, or the like. When the WI-FI chip or the Bluetooth chip is used, various connection information such as SSID and session key may be first exchanged, communication may be connected by using the connection information, and various information may be exchanged. A wireless communication chip refers to a chip performing communication according to various communication standards such as IEEE, Zigbee, 3rd Generation (3G), 3rd Generation Partnership Project (3GPP), Long Term Evolution (LTE), and so on.
Meanwhile, although it is described above that the communicator 110 is one of the elements, it may be implemented such that a first communicator (not illustrated) for performing communication with the user terminal device 200 and a second communicator (not illustrated) for performing communication with another user terminal device (not illustrated), each including various communication circuitry, are separately provided. Further, a method for communicating with the first communicator may be same as a method for communicating with the second communicator, or they may be different from each other.
A plurality of encoders 120 may perform encoding in parallel. Specifically, a plurality of encoders 120 may encode frames generated in real time in parallel, and convert into another signal form.
A plurality of encoders 120 may perform encoding by dividing each of the frames generated in real time into a plurality of blocks. A plurality of encoders 120 may perform encoding by a series of time or dimension prediction, conversion, quantification, filtering, entropy-encoding, and so on. Specific operation of the encoder is out of a scope of the present disclosure, which will not be specifically explained herein.
A plurality of encoders 120 may be of different types from each other. For example, the first encoder of a plurality of encoders 120 may be HEVC encoder, and the other encoders of a plurality of encoders 120 may be H.264 encoders. However, this may be one embodiment, and constitution of a plurality of encoders 120 may be modified as desired. Further, a plurality of encoders 120 may be all the same as each other.
Each of the encoders may perform intra-encoding or inter-encoding for each of the frames.
The intra-encoding may refer, for example, to an operation of performing encoding through in-screen prediction. Specifically, the intra-encoding may refer, for example, to an operation of performing encoding by spatial prediction from adjacent pixels in the current frame.
The inter-encoding may refer, for example, to an operation of performing encoding through prediction between screens. The encoder may store some reference frames having high correlativity with a frame to be currently encoded, and perform prediction between screens by using the stored frames. In other words, the encoder may perform encoding by time prediction from reference frames of previous frames.
For example, the intra frame may be able to be decoded without reference of another frame during the decoding, while the inter frame is possibly decoded only with reference of another frame during the decoding.
A processor 130 may include various processing circuitry and generally controls the overall operation of the server device 100.
The processor 130 may generate frames to be provided to the user terminal device 200 in real time. For example, the server device 100 may generate frames related with a cloud game running on the user terminal device 200 in real time. In this case, the user terminal device 200 may receive frames from the server device 200 and display them.
The processor 130 may sequentially allocate frames generated in real time to a plurality of encoders 120. For example, a plurality of encoders 120 may include a first encoder and a second encoder, and the processor 130 may allocate odd-numbered frames of the frames generated in real time to the first encoder, and even-numbered frames to the second encoder.
However, this is merely an example embodiment. The processor 130 may allocate a preset number of consecutive frames to the first encoder, and a preset number of consecutive frames to the second encoder. For example, the processor 130 may allocate first to fifth frames to the first encoder, and sixth to tenth frames to the second encoder. Meanwhile, the number of a plurality of encoders 120 may be different.
The processor 130 may control the communicator 110 so that a plurality of encoded frames output from a plurality of encoders 120 in parallel are individually streamed to the user terminal device 200. For example, the processor 130 may transmit the encoded frames output from the first encoder to the user terminal device 200 through a first channel, and transmit the encoded frames output from the second encoder to the user terminal device 200 through a second channel.
Meanwhile, when a re-request signal for a certain frame is received from the user terminal device 200 and when a certain frame is an encoded frame of a first encoding type, the processor 130 may first re-transmit the certain frame. When a certain frame is an encoded frame of a second encoding type, the processor 130 may first re-transmit the encoded frame of a first encoding type after the certain frame among the encoded frames output from the encoder that encodes the certain frame.
Specifically, when a re-request signal for a certain frame is received from the user terminal device 200, the processor 130 may first re-transmit the certain frame when the certain frame is an intra frame, while when the certain frame is an inter frame, first re-transmit an intra frame after the certain frame of encoded frames output from the encoder that encodes the certain frame. In other words, the processor 130 may not perform unnecessary operation of only transmitting an inter frame which it cannot decode itself
Meanwhile, the processor 130 may generate a frame including video data and a frame including UI data provided with the video data. In an example, the video data may be data displayed on one region of the screen including UI data.
When a frame including video data and a frame including UI data provided with the video data are generated, the processor 130 may allocate the frame including UI data to one of a plurality of encoders 120, and sequentially allocate a frame including the video data to the rest of a plurality of encoders 120.
Specifically, because a frame including UI data does not show big difference between frames, it may be efficient to process this with one encoder. Operation of sequentially allocating a frame including video data to the rest of a plurality of encoders 120 is same as described above.
A splitter (e.g., including splitting circuitry) 310 is one of elements of the processor 130, and may sequentially allocate frames generated in real time in the server device 100 to the first encoder 320-1 and the second encoder 320-2. For example, the splitter 310 may allocate odd-numbered frames of the frames generated in real time to the first encoder 320-1, and allocate even-numbered frames to the second encoder 320-2. In an example, the splitter 310 may be referred to as a ‘mapper’.
The first encoder 320-1 and the second encoder 320-2 may sequentially encode frames as these are input respectively. In an example, the first encoder 320-1 and the second encoder 320-2 may be different encoders from each other. For example, the first encoder 320-1 may be HEVC encoder and the second encoder 320-2 may be H.264 encoder, but the present disclosure is not limited thereto.
A forward error correction (FEC) 1 block 330-1 may apply forward error correction algorithms to the encoded frames output from the first encoder 320-1. A FEC 2 block 330-2 may apply the forward error correction algorithms to the encoded frames output from the second encoder 320-2. In an example, the FEC 1 block 330-1 and the FEC 2 block 330-2 may be elements of the processor 130.
The FEC 1 block 330-1 and the FEC 2 block 330-2 may respectively apply different forward error correction algorithms from each other based on types of the first encoder 320-1 and the second encoder 320-2. For example, when the first encoder 320-1 is HEVC encoder and the second encoder 320-2 is H.264 encoder, the FEC 1 block 330-1 may apply the forward error correction algorithms having higher reliability than the FEC 2 block 330-2.
Specifically, the output encoded frames may have a lower capacity since the HEVC encoder has a higher efficiency than the H.264 encoder. In this case, encoded frames output from the HEVC encoder may be added with more error correction signs than encoded frames output from the H.264 encoder. Specifically, for the transmission channels respectively having uniform capacity, transmission speed may not be greatly varied from each other even if encoded frames output from the HEVC encoder are added with more error correction signs than encoded frames output from the H.264 encoder.
Alternatively, the forward error correction algorithms of each of the FEC 1 block 330-1 and the FEC 2 block 330-2 may be determined based on processing speed of each encoder. For example, when the first encoder 320-1 is the HEVC encoder and the second encoder 320-2 is the H.264 encoder, the FEC 1 block 330-1 may apply the forward error correction algorithms having a faster processing speed than the FEC 2 block 330-2.
Specifically, the HEVC encoder may have a slower processing speed because of a higher complexity than the H.264 encoder. In this case, the FEC 1 block 330-1 may reduce difference in the transmission speed by applying the forward error correction algorithms having a faster processing speed than the FEC 2 block 330-2.
However, this is merely one example embodiment. The FEC block may determine a type of the forward error correction algorithms based on types of encoded frames output from the encoder. For example, types of the forward error correction algorithms applied to an intra frame and an inter frame may be different from each other.
A streamer 1340-1 and a streamer 2340-2 may individually stream respectively input encoded frames applied with the forward error correction algorithms to the user terminal device 200 through a network 1350-1 (N/W 1) and a network 2350-2 (N/W 2). In an example, the network 1350-1 and the network 2350-2 may be referred to respectively as channel 1 and channel 2.
Meanwhile, the processor 130 may transmit QoS information to the user terminal device 200. In an example, QoS information may include information regarding a type of the encoder applied to the encoded frames transmitted through each network and a type of the forward error correction algorithms.
Although
When a re-request signal for a certain frame is received from the user terminal device 200, the processor 130 may first re-transmit a certain frame when the certain frame is an encoded frame of a first encoding type, and when the certain frame is an encoded frame of a second encoding type, first re-transmit an encoded frame of a first encoding type after the certain frame of encoded frames output from the encoder that encodes the certain frame.
Specifically, when a re-request signal for a certain frame is received from the user terminal device 200, the processor 130 may first re-transmit the certain frame when the certain frame is an intra frame, and first re-transmit an intra frame after the certain frame of encoded frames output from the encoder that encodes the certain frame when the certain frame is an inter frame.
For example, as illustrated in
When a re-request signal for the eighth encoded frame is received from the user terminal device 200, the processor 130 may sequentially re-transmit the eighth encoded frame because the eighth encoded frame is an intra frame. The processor 130 may continuously transmit encoded frames output from the first encoder 410-1 and the third encoder 410-3 to the user terminal device 200.
Meanwhile, when a re-request signal for the fifth encoded frame is received from the user terminal device 200, the processor 130 may sequentially re-transmit the eighth encoded frame which is an intra frame after the fifth encoded frame because the fifth encoded frame is an inter frame. In this case, the processor 130 may continuously transmit encoded frames output from the first encoder 410-1 and the third encoder 410-3 to the user terminal device 200 irrespective of a re-request signal.
Alternatively, when a re-request signal for the sixth encoded frame is received from the user terminal device 200, the processor 130 may sequentially re-transmit the twelfth encoded frame which is an intra frame after the sixth encoded frame because the sixth encoded frame is an inter frame. In this case, the processor 130 may continuously transmit encoded frames output from the first encoder 410-1 and the second encoder 410-2 to the user terminal device 200 irrespective of a re-request signal.
Meanwhile, although
Again, in this case, the processor 130 may transmit the output encoded frames to the user terminal device 200 through a FEC block without waiting for outputting of the other encoded frames. The user terminal device 200 may receive a plurality of encoded frames irrespective of an order of frames; however, it may display decoded frames in order by using a buffer to be described below.
The multi-window frame may include a frame including video data and a frame including UI data provided with the video data. For example, as illustrated in
As illustrated in
For example, the splitter 530, which may be one of the elements of the processor 130, may allocate the frame 520 including UI data to the first encoder 540-1 of a plurality of encoders. At this process, the processor 130 may process with a preset color a region of the frame 520 including UI data where the video data is to be displayed, and allocate a result to the first encoder 540-1. Since UI data shows no significant changes from the frame 520 including UI data, and a region displaying the video data is uniformly processed with a preset color in all the frames, real-time streaming may be possibly processed even if one encoder is used.
Meanwhile, the splitter 530 may sequentially allocate the frame 510 including the video data to the rest of a plurality of encoders. Because this is same as or similar to the description provided above with reference to
The processor 130 may transmit a plurality of encoded frames to the user terminal device 200 through a plurality of networks. Further, the processor 130 may transmit to the user terminal device 200 the information regarding a network over which an encoded frame corresponding to the frame 520 including UI data is transmitted and information regarding a network over which a plurality of encoded frames corresponding to the frame 510 including video data is transmitted. Further, the processor 130 may transmit to the user terminal device 200 the information regarding a region that displays video data in the frame 520 including UI data.
As illustrated in
Meanwhile,
The display 210 may display a plurality of decoded frames in order under control of the processor 250. For example, the display 210 may display in order a first decoded frame, a second decoded frame, and then on.
However, example embodiments may not be limited to any specific embodiment. Accordingly, the display 210 may skip some frames, while displaying the rest of the frames in order. For example, the display 210 may display in order a first decoded frame, a second decoded frame, a fourth decoded frame, a fifth decoded frame, and then on.
Meanwhile, the display 210 may be implemented as a liquid crystal display panel (LCD), an organic light emitting diodes (OLED), and or the like, but not limited thereto. Further, the display 210 may be implemented as a flexible display, a transparent display, or the like, depending on cases.
The communicator 220 may include various communication circuitry and perform communication with the server device 100. Further, the communicator 220 may receive content provided from the server device 100 in real time. Specifically, the communicator 220 may individually receive a plurality of encoded frames encoded from the content from the server device 100 through a plurality of channels.
The communicator 220 may receive QoS information from the server device 100.
The communicator 220 may transmit a re-request signal for a certain frame to the server device 100. In this case, irrespective of a re-request signal, transmission state may be maintained for the rest channels other than a channel corresponding to the certain frame.
The communicator 220 may perform communication with the user terminal device 200 with various communication methods such as BT, BLE, WI-FI, Zigbee, IR, serial interface, USB, NFC, and so on. The NFC chip refers to a chip operating with the NFC method using 13.56 MHz bandwidth among various RF-ID frequency bandwidths such as 135 kHz, 13.56 MHz, 433 MHz, 860-960 MHz, 2.45 GHz, or the like. When the WI-FI chip or the Bluetooth chip is used, various connection information such as SSID and session key may be first exchanged, communication may be connected by using the connection information, and various information may be exchanged. The wireless communication chip refers to a chip performing communication according to various communication standards such as IEEE, Zigbee, 3G, 3GPP, LTE, and so on.
Meanwhile, although it is described above that the communicator 220 is one of the elements, in another implementation, the first communicator (not illustrated) for performing communication with the server device 100 and the second communicator (not illustrated) for performing communication with another server device (not illustrated) may be individually provided. Further, a method for communicating with the first communicator may be same as a method for communicating with the second communicator or different from each other.
A plurality of decoders 230 may perform decoding in parallel. Specifically, a plurality of decoders 230 may decode a plurality of encoded frames received in real time in parallel to convert them into another signal form.
A plurality of decoders 230 may perform decoding on a block basis through entropy decoding, dequantization, inverse transformation, filtering, or the like, but is not limited thereto.
A plurality of decoders 230 may be different types from each other. For example, the first decoder of a plurality of decoders 230 may be HEVC decoder, and the other decoders of a plurality of decoders 230 may be H.264 decoder. However, this is merely an example embodiment, and accordingly, the plurality of decoders 230 may be modified as desired. Further, a plurality of decoders 230 may be same as each other.
Each of the decoders may perform intra decoding or inter decoding for each of the frames.
The intra decoding may refer, for example, to an operation of performing decoding by referring to adjacent pixels in a current frame spatially.
The inter decoding may refer, for example, to an operation of performing decoding by referring between the screens. The decoder may restore some reference frames having high correlativity with a frame to be encoded currently, and referring between the screens by using the restored ones. In other words, the decoder may perform decoding by referring temporally to the reference frames of the previous frames.
At least one buffer 240 may be connected to a plurality of decoders 230. In an example, at least one buffer 240 may temporally store decoded frames output from a plurality of decoders 230.
The processor 250 may include various processing circuitry and control the overall operation of the user terminal device 200.
The processor 250 may sequentially allocate to a plurality of decoders 230 a plurality of encoded frames output in parallel from a plurality of encoders provided in the server device 100 and individually streamed from the server device 100. For example, the processor 250 may allocate encoded frames received from the first channel to the first decoder, and allocate encoded frames received from the second channel to the second decoder.
Meanwhile, there may be provided any number of decoders 230. However, only some of a plurality of decoders 230 may be used. For example, the decoders as many as channels used in the streaming may only be used among a plurality of decoders 230.
The processor 250 may store a plurality of decoded frames output in parallel from a plurality of decoders 230 in at least one buffer 240, and display a plurality of decoded frames in order on the display 210 based on identification information included in a plurality of decoded frames stored in at least one buffer 240.
Meanwhile, when an error occurs in the decoding of a certain frame, the processor 250 may transmit a re-request signal for a certain frame to the server device 100, and display a plurality of frames output from the rest decoders other than the decoder corresponding to a certain frame in order.
Meanwhile, the processor 250 may sequentially allocate encoded frames including video data streamed individually from the server device 100 and encoded frames including UI data provided with the video data, and synchronize the decoded UI data frame output respectively from a plurality of decoders 230 with the decoded video data frame and display a result.
The streamer 1 720-1 and the streamer 2720-2 may receive a plurality of individually-streamed, encoded frames from the server device 100 through the network 1710-1 (N/W 1) and the network 2720-2 (N/W 2), respectively.
An error correction block 730-1 using FEC 1 may correct errors by using error correction signs included in the encoded frame received from the streamer 1720-1. An error correction block 730-2 using FEC 2 may correct errors using error correction signals included in the encoded frames received from the streamer 1720-2. In this example, the error correction block 730-1 using FEC 1 and the error correction block 730-2 using FEC 2 may be elements of the processor 250.
The processor 250 may allocate the error correction block using FEC respectively corresponding to encoded frames based on the QoS information received from the server device. At this process, QoS information may include information regarding a type of the encoder and a type of the forward error correction algorithms, which are respectively applied to encoded frames.
The first decoder 740-1 and the second decoder 740-2 may sequentially decode encoded respectively input frames. In an example, the first decoder 740-1 and the second decoder 740-2 may be different decoders from each other. For example, the first decoder 740-1 may be HEVC decoder, and the second decoder 740-2 may be H.264 decoder.
The processor 250 may allocate the decoder respectively corresponding to encoded frames based on the QoS information received from the server device 100.
A mixer 750 may be one element of the processor 250 and at least one buffer 240. The mixer 750 may output a plurality of decoded frames output in parallel from the first decoder 740-1 and the second decoder 740-2 in order based on each identification information. In an example, the mixer 750 may be referred to as a ‘joiner’. Decoded frames may include identification information. For example, decoded frames may include presentation time stamp (PTS) information.
Meanwhile, the streamer 1720-1 and the streamer 2720-2 may receive a plurality of individually-streamed, encoded frames from the server device 100; however, receiving time may be different from each other in a plurality of encoded frames. Further, the error correction block 730-1 using FEC 1 and the error correction block 730-2 using FEC 2 may have different error correction time from each other, and respective time for processing one frame may be different. Further, respective decoding time may be different from each other in the first decoder 740-1 and the second decoder 740-2, and respective time for processing one frame may be different. In other words, the mixer 750 may receive a plurality of decoded frames irrespective of an order. Accordingly, the mixer 750 may temporally store some frames, and output the frames in order based on the order of displaying to a user.
Meanwhile, although
As illustrated in
In an example, the processor 250 may display a plurality of frames output from the rest decoders other than the decoder corresponding to the certain frame in order. For example, when an error occurs in a decoding process of the second encoded frame, the processor 250 may transmit a re-request signal for the second encoded frame to the server device 100, and display the first decoded frame, the third decoded frame, the fourth decoded frame, the sixth decoded frame, and then on in order.
In an example, the first decoded frame and the fourth decoded frame may be frames output from the first decoder 810-1, and the third decoded frame and the sixth decoded frame may be frames output from the third decoder 810-3.
The second decoder 810-2 is supposed to sequentially output the second decoded frame, the fifth decoded frame, and then on, but the subsequent frames may not be output as the second decoded frame is not output.
However, the present disclosure may not be limited to the examples discussed herein. Accordingly, the processor 250 may transmit a re-request signal for a certain frame, and display the frames including the certain frame in order when the certain frame is received from the server device 100 and decoded before displaying.
For example, in the above embodiment, when the second decoded frame is received from the server device 100 and decoded before displaying, the processor may display in order the first decoded frame, the second decoded frame, the third decoded frame, the fourth decoded frame, the fifth decoded frame, the sixth decoded frame, and then on.
As illustrated in
The processor 250 may synchronize decoded UI data frame respectively output from a plurality of decoders with the decoded video data frame and display a result. In an example, the processor 250 may divide the decoded UI data frame and the decoded video data frame based on information received from the server device 100, e.g., based on the information regarding a network over which the encoded frame corresponding to the frame 520 including UI data is transmitted, and the information regarding a network over which a plurality of encoded frames corresponding to the frame 510 including the video data is transmitted.
The mixer 920 may sequentially output a plurality of decoded video data frames output from the second decoder 910-2, . . . , the Nth decoder 910-N. The outputting may be same as described above with reference to
The processor 250 may synchronize the decoded UI data frame and the decoded video data frame based on the information received from the server device 100 regarding a region of the frame including UI data where the video is to be displayed.
However, the present disclosure may not be limited to the above. Accordingly, when one region of the decoded UI data frame is processed with a preset color, the processor 250 may determine the region processed with the preset color to be a region where the video data is to be displayed. In this case, the processor 250 may not receive from the frame including UI data from the server device 100 information regarding a region where the video data is to be displayed.
At S1010, frames generated in real time may be sequentially allocated to a plurality of encoders for performing encoding in parallel. Further, a plurality of encoded frames output in parallel from a plurality of encoders may be individually streamed by the user terminal device, at S1020.
In an example, a plurality of encoders may include a first encoder and a second encoder, and the allocating at S1010 may allocate odd-numbered frames of the real-time generated frames to the first encoder and even-numbered frames to the second encoder.
Meanwhile, the control method may further include receiving a re-request signal for a certain frame from the user terminal device and re-transmitting the certain frame when the certain frame is encoded in a first encoding type and when the certain frame is encoded in a second encoding type, re-transmitting a frame encoded in a first encoding type after the certain frame of encoded frames output from the encoder that encodes the certain frame.
In an example, the re-transmitting may first re-transmit the certain frame when the certain frame is an intra frame, while, when the certain frame is an inter frame and, the re-transmitting may first re-transmit an intra frame after the certain frame of encoded frames output from the encoder that encodes the certain frame.
Meanwhile, when a frame including video data and a frame including UI data provided with the video data are generated, the allocating at S1010 may allocate a frame including UI data to one of a plurality of encoders and sequentially allocate a frame including video data to the rest of a plurality of encoders.
A plurality of encoded frames output in parallel from a plurality of encoders provided in the server device and individually streamed from the server device may be sequentially allocated to a plurality of decoders performing decoding in parallel, at S1110. Further, a plurality of decoded frames output in parallel from a plurality of decoders may be stored in at least one buffer connected to a plurality of decoders, at S1120. Further, a plurality of decoded frames may be displayed in order based on identification information included in a plurality of decoded frames stored in at least one buffer, at S1130.
In an example, the control method may further include transmitting a re-request signal for a certain frame to the server device when an error occurs during the decoding of a certain frame, and the displaying at S1130 may display in order a plurality of frames output from the rest decoders other than the decoder corresponding to a certain frame among a plurality of decoders.
Meanwhile, the allocating at S1110 may further include allocating sequentially the encoded frame including video data individually streamed from the server device and the encoded frame including UI data provided with the video data to a plurality of decoders, and the synchronizing the decoded UI data frame respectively output from a plurality of decoders with the decoded video data frame and displaying a result.
According to the above various example embodiments, the server device and the user terminal device may provide high quality streaming service as high capacity content are processed by using a plurality of encoders and a plurality of decoders.
Meanwhile, although it is described above that the server device and the user terminal device are described separately from each other, the server device and the user terminal device may be configured as one system.
Meanwhile, although it is described above that a plurality of encoders and a plurality of decoders are implemented as hardware, the present disclosure may not be limited herein. For example, the processor may perform operation of a plurality of encoders and a plurality of decoders using software, hardware or any combination thereof
Meanwhile, the method according to the above various example embodiments may be stored in various recording media. Accordingly, the methods according to the various embodiments may be implemented in various types of electronic devices implementing recording media.
Specifically, there may be provided a non-transitory computer readable recording medium stored with programs for sequentially performing the control method described above.
The non-transitory computer readable recording medium refers to a medium that stores data and that can be read by devices. Specifically, the various applications or programs described above may be stored and provided on non-transitory computer readable recording medium such as CD, DVD, hard disk, Blu-ray disk, USB, memory card, or ROM.
The foregoing example embodiments and advantages are merely examples and are not to be construed as limiting the example embodiments or the present disclosure. The present teaching can be readily applied to other types of devices. Also, the description of the example embodiments of the present disclosure is intended to be illustrative, and not to limit the scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2016-0109986 | Aug 2016 | KR | national |