WO2017039021A1 - Content transmission method supporting scalable encoding and streaming server therefor - Google Patents
Content transmission method supporting scalable encoding and streaming server therefor Download PDFInfo
- Publication number
- WO2017039021A1 WO2017039021A1 PCT/KR2015/009091 KR2015009091W WO2017039021A1 WO 2017039021 A1 WO2017039021 A1 WO 2017039021A1 KR 2015009091 W KR2015009091 W KR 2015009091W WO 2017039021 A1 WO2017039021 A1 WO 2017039021A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- content
- terminal
- substream
- present
- information
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 69
- 230000005540 biological transmission Effects 0.000 title claims abstract description 31
- 239000012634 fragment Substances 0.000 claims description 16
- 238000002716 delivery method Methods 0.000 claims description 5
- 230000006870 function Effects 0.000 description 25
- 238000004891 communication Methods 0.000 description 24
- 238000012545 processing Methods 0.000 description 15
- 238000010586 diagram Methods 0.000 description 10
- 238000004590 computer program Methods 0.000 description 3
- 238000010295 mobile communication Methods 0.000 description 3
- 230000003044 adaptive effect Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000014509 gene expression Effects 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 238000000926 separation method Methods 0.000 description 2
- 229920001621 AMOLED Polymers 0.000 description 1
- 230000001133 acceleration Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 239000012141 concentrate Substances 0.000 description 1
- 239000013256 coordination polymer Substances 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 239000011159 matrix material Substances 0.000 description 1
- 239000012092 media component Substances 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 229920001690 polydopamine Polymers 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 239000010409 thin film Substances 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/30—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using hierarchical techniques, e.g. scalability
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/20—Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
- H04N21/23—Processing of content or additional data; Elementary server operations; Server middleware
- H04N21/234—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
- H04N21/2343—Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
Definitions
- the present invention relates to a content transmission method, and more particularly, when encoding content in a scalable encoding method, by dividing a bitstream of each layer into a predetermined number or more of substreams and assigning an index to each substream.
- the present invention relates to a content transmission method that supports scalable encoding that can be used for content transmission by defining metadata for the content transmission, and a streaming server therefor.
- SHVC Scalable High Efficiency Video Coding
- SHVC codes content into multiple layers of base layer (BL) and enhancement layer (EL) to reduce data size and separate bitstreams to adaptively receive and play content according to user network bandwidth.
- BL base layer
- EL enhancement layer
- the terminal receives and decodes the base layer and the enhancement layer together to restore the resolution of the original content.
- the scalable encoding method up to now has a problem in that it is impossible to efficiently use the storage space by storing data for each bitstream, and multiple transmissions are impossible because any one server concentrates and stores the bitstream.
- the present invention has been proposed to solve the above-described problems.
- an index for each substream is assigned. It is an object of the present invention to provide a content transmission method for supporting scalable encoding that can be used for content transmission by defining metadata for the index and a streaming server for the same.
- a content transmission method supporting scalable encoding includes a bitstream of a base layer and an enhancement layer layered in any one content. Generating by dividing a predetermined number or more of substreams; Assigning and storing an index corresponding to each of the generated substreams; And generating the metadata for the index and transmitting the metadata to the terminal requesting the content, and transmitting the substream of the content to the terminal according to the request of the terminal.
- the dividing step may include generating bits of each layer in consideration of at least one of state information of a network, performance information of a terminal requesting the content, and performance information of a storage location capable of storing the substream.
- the stream may be generated by dividing the stream into a predetermined number or more of substreams.
- the index may include at least one of identification information for identifying the substream, fragment identification information including the substream, and identification information on a storage location where the substream is stored.
- the metadata may include a plurality of metadata generated corresponding to the performance information of the terminal or limiting elements that can be received in consideration of the performance of the terminal.
- the present invention can provide a computer readable recording medium having recorded thereon a program for executing a content transmission method supporting scalable encoding as described above.
- a streaming server for achieving the above object is a layering to generate a bitstream for each layer by layering any content into a base layer and an enhancement layer part;
- a substream generator for dividing the bitstreams of the layered layers into a predetermined number or more of substreams;
- an index management unit for assigning an index corresponding to each of the generated substreams.
- the streaming server generates metadata corresponding to the index, and the substream of the content is cached in any one cache device in which the substream delivered to the requesting terminal is distributed in the vicinity of the terminal.
- the MPD generation module may be further configured to receive the caching information from the cache device and to modify the metadata according to the received caching information.
- the bitstream of each layer is divided into a predetermined number of substreams and an index for each substream. After defining the metadata for the index, even if each substream is located in a different storage location, the terminal can easily receive and use the content with reference to the index for the substream.
- the storage space can be utilized more efficiently, and the terminal can be connected through a plurality of channels, thereby enabling multiple transmission. This allows for more efficient use of network traffic.
- high-capacity content can be partitioned and cached, thereby enabling application of a CDN (Contents Delivery Network) service that is difficult to support high-capacity caching.
- CDN Contents Delivery Network
- FIG. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
- FIG. 2 is a block diagram showing a main configuration of a terminal according to an embodiment of the present invention.
- FIG. 3 is a block diagram showing the main configuration of a streaming server according to an embodiment of the present invention.
- FIG. 4 is a block diagram illustrating a main configuration of an encoding module according to an embodiment of the present invention.
- FIG. 5 is a flowchart illustrating a content transmission method according to an embodiment of the present invention.
- 6 to 8 are exemplary diagrams for describing a content transmission method according to an embodiment of the present invention.
- FIG. 9 is a flowchart illustrating a content reproduction method in a terminal according to an embodiment of the present invention.
- first and second are used to describe various components, and are used only to distinguish one component from another component, and to limit the components. Not used.
- the second component may be referred to as the first component, and similarly, the first component may also be referred to as the second component.
- a component when referred to as being "connected” or “connected” to another component, it means that it may be connected or connected logically or physically. In other words, although a component may be directly connected or connected to other components, it should be understood that other components may exist in the middle, and may be connected or connected indirectly.
- embodiments within the scope of the present invention include computer readable media having or conveying computer executable instructions or data structures stored on the computer readable medium.
- Such computer readable media can be any available media that can be accessed by a general purpose or special purpose computer system.
- Such computer readable media may be in the form of RAM, ROM, EPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage, or computer executable instructions, computer readable instructions or data structures. And may include, but are not limited to, any other medium that can be used to store or deliver certain program code means, and can be accessed by a general purpose or special purpose computer system. .
- network is defined as one or more data links that enable the transfer of electronic data between computer systems and / or modules.
- this connection can be understood as a computer-readable medium.
- Computer-readable instructions include, for example, instructions and data that cause a general purpose or special purpose computer system to perform a particular function or group of functions.
- the computer executable instructions may be, for example, binary, intermediate format instructions such as assembly language, or even source code.
- the present invention relates to personal computers, laptop computers, handheld devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile phones, PDAs, pagers It may be practiced in a network computing environment having various types of computer system configurations, including (pager) and the like.
- the terminal described in the specification of the present invention may be implemented in various forms.
- mobile terminals such as smart phones, tablet PCs, personal digital assistants, portable multimedia players, and MP3 players, as well as smart TVs and desktop computers.
- a fixed terminal may be used, and any terminal can be used as a terminal of the present invention as long as the terminal can be used by uploading or downloading content to a content server through a network.
- any content described in the specification of the present invention may be included in the content of the present invention as long as it can be expressed by a specific address (eg, a URL) on the network.
- a specific address eg, a URL
- the entire web site is represented by one URL, it can be distributed through the system of the present invention as one content.
- the invention may also be practiced in distributed system environments where both local and remote computer systems that are linked via wired networks, wireless data links, or combinations of wired and wireless data links perform tasks.
- program modules may be located in both local and remote memory storage devices.
- FIG. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
- a content delivery system may include a terminal 100 and a streaming server 200.
- the terminal 100 refers to a device that requests specific content to the streaming server 200 through the network 300 according to a user's request, and receives and uses the content provided from the streaming server 200. More specifically, the terminal 100 of the present invention confirms a request for specific content from the user.
- the request for the specific content may include an execution process of a browser, a playback application, etc. that may receive and use the content provided by the streaming server 200.
- the terminal 100 receives metadata about the content from the streaming server 200, checks the location of the storage location holding the content based on the metadata, requests the content from the storage location, and receives the content. You can do it.
- the terminal 100 accesses a name server such as a domain name server (DNS) and provides the corresponding content. It obtains the address information (IP address) of the storage location, and requests the storage location to use the content.
- DNS domain name server
- the terminal 100 may receive the content on a sub-stream basis from a storage location that stores the corresponding content, for example, the streaming server 200.
- the terminal 100 according to the present invention may request and receive content in units of fragments, which are sets of a plurality of substreams, after checking metadata, and may decode the received substreams and play them in units of fragments. .
- the streaming server 200 is to provide various contents such as photographs, videos, audio, applications, etc. to the terminal 100, or to receive and provide contents related services.
- the content provider (CP; Contents) At least one content is provided from the provider and managed, and serves to provide content to the plurality of terminals 100 through the network 300.
- the streaming server 200 of the present invention supports scalable encoding of content, and supports a process of dividing a layered bitstream into substreams and storing the divided substreams.
- the streaming server 200 of the present invention may support the process of assigning an index for each substream and defining metadata for the index and then distributing it to the terminal 100.
- a plurality of streaming servers 200 of the present invention may exist.
- any one streaming server 200 performs scalable encoding of content, and the other server may play a role of a database server.
- the present invention can be applied to the CDN service. That is, as shown in FIG. 1, the network 300 of the present invention may include a plurality of cache devices 350 distributed in a distributed manner. At this time, the plurality of cache devices 350 is preferably located between the access network 330 and the core network 320, but is not fixed to the location, the packet transmitted and received between the terminal 100 and the streaming server 200 If you can monitor and control the flow of content, it can be distributed in various forms.
- the cache apparatus 350 applied to the CDN service up to now has a problem that it is difficult to store high-capacity content because of a small storage space.
- the present invention is to solve this problem, the streaming server 200 may support the process of dividing the content into a plurality of substreams in the encoding process is stored in the distributed cache device 350, a plurality of cache devices Each 350 may be connected to the terminal 100 through a separate channel to simultaneously transmit a corresponding substream to the terminal 100 according to a request of the terminal 100.
- the cache apparatus 350 of the present invention may monitor and detect a substream transmitted from the streaming server 200 to the terminal 100, and store the detected substream, and may transmit information about this to the streaming server 200. By transmitting to the streaming server 200 may support the process of changing the metadata is made.
- the network 300 in which the plurality of cache devices 350 of the present invention are distributed and distributed at a main point means a communication network for transmitting and receiving information between the terminal 100 and the streaming server 200, and in particular, a single network.
- a communication network implemented using various types of wired and wireless communication technologies such as an intranet network, a mobile communication network, and a satellite communication network may be mixed.
- the network 300 may be configured to include an external network, for example, an internet network 310 connected to a mobile network including a plurality of wired / wireless access networks 330 and a core network 320.
- the wired / wireless access network 330 constituting the mobile network is an access network performing wired / wireless communication with the terminal 100.
- the base station may be implemented as a base station controller such as a base station controller (BSC) and a radio network controller (RNC).
- BSC base station controller
- RNC radio network controller
- a digital signal processor and a wireless signal processor which are integrally implemented in the base station, are divided into digital units (hereinafter referred to as DUs and radio units (hereinafter referred to as RUs)).
- DUs and radio units hereinafter referred to as RUs
- Each of the plurality of RUs may be installed in the region of the plurality, and the plurality of RUs (not shown) may be configured by connecting with a centralized DU (not shown).
- the core network 320 constituting the mobile network together with the wired / wireless access network 330 serves to connect the wired / wireless access network 330 with an external network, for example, the internet network 310.
- the core network 320 is a network system that performs a main function for a mobile communication service such as mobility control and switching between wired and wireless access networks 330, and includes circuit switching or packet switching. It manages and controls packet flow in mobile network.
- the core network 320 may manage inter-frequency mobility and may play a role for interworking with traffic in the access network 330 and the core network 320 and other networks, such as the Internet network 310.
- the core network 320 may further include a mobile switching center (MSC), a home location register (HLR), a mobile mobility entity (MME), a home subscriber server (HSS), and the like.
- MSC mobile switching center
- HLR home location register
- MME mobile mobility entity
- HSS home subscriber server
- the Internet network 310 refers to a conventional public communication network, that is, a public network, through which information is exchanged according to the TCP / IP protocol, and is connected to the streaming server 200 and provided from the streaming server 200. May be provided to the terminal 100 via the core network 320 and the wired / wireless access network 330, or may be provided to the plurality of cache devices 350 according to a predetermined distribution policy.
- the network 300 is coupled to the cache device 350 to store computing resources such as hardware and software, and corresponds to the computing resources required by the client.
- It may include a cloud computing network that can be provided to the terminal.
- cloud computing refers to a computer environment in which information is permanently stored on a server on the Internet and temporarily stored in client terminals such as desktops, tablet computers, laptops, netbooks, and smartphones. It refers to a computer environment access network that stores a server on the Internet and makes this information available anytime, anywhere through various IT devices.
- the network 300 may include a closed network such as a local area network (LAN), a wide area network (WAN), an open network such as the Internet, and code division multiple access (CDMA) and wideband code division (WCDMA).
- LAN local area network
- WAN wide area network
- CDMA code division multiple access
- WCDMA wideband code division
- GSM multiple access
- GSM global system for mobile communications
- LTE long term evolution
- EPC evolved packet core
- a processor mounted in each device may process a program command for executing a method according to the present invention.
- this processor may be a single-threaded processor, and in another implementation, the processor may be a multithreaded processor.
- the processor is capable of processing instructions stored on memory or storage devices.
- FIG. 2 is a block diagram showing a main configuration of a terminal according to an embodiment of the present invention.
- the terminal 100 includes a communication unit 110, an input unit 120, a control unit 130, an output unit 140, and a storage unit 150. Can be configured.
- the communication unit 110 performs a role of transmitting and receiving information with the streaming server 200 through the network (300).
- the communication unit 110 of the present invention may perform a procedure of accessing the network 300.
- the communication unit 110 searches for a base station (not shown) located within a predetermined radius and requests a connection of the discovered base station (not shown).
- the access network 330 may be connected.
- the process of connecting the communication unit 110 of the terminal 100 to the base station (not shown) of the access network 330 may employ a variety of well-known configuration, a detailed description thereof will be omitted.
- the communication unit 110 may transmit user information when performing a communication procedure with a base station (not shown).
- a terminal identification number such as an International Mobile Subscriber Identity (IMSI)
- IMSI International Mobile Subscriber Identity
- the communication unit 110 when the communication unit 110 according to an embodiment of the present invention normally connects to the core network 320 through a base station (not shown) of the access network 330, the communication unit 110 may request and receive content.
- the input unit 120 transmits a variety of information such as numeric and text information input from a user, a signal input in connection with various function settings and function control of the terminal 100, to the controller 130.
- the input unit 120 of the present invention may support a user input necessary for accessing the streaming server 200.
- the input unit 120 includes a key input means such as a keyboard or a keypad, a touch input means such as a touch sensor or a touch pad, a voice input means, a gyro sensor, a geomagnetic sensor, an acceleration sensor and a proximity sensor, and a camera. It may also include a gesture input means comprising at least one or more.
- it may include all types of input means that are currently under development or may be developed in the future.
- the controller 130 performs overall control of the terminal 100, and includes at least one processor including a central processing unit (CPU) and an execution memory (eg, a register and at least one memory loading data) loaded in hardware. And / or a random access memory (RAM) and a bus that inputs and outputs at least one data into the processor and memory.
- processor including a central processing unit (CPU) and an execution memory (eg, a register and at least one memory loading data) loaded in hardware. And / or a random access memory (RAM) and a bus that inputs and outputs at least one data into the processor and memory.
- it may include a predetermined program routine (Routine) or program data that is loaded into the execution memory from a predetermined recording medium to be performed by the processor to perform a function defined in the terminal 100 by software.
- a component that can be processed by software may be determined as the function of the controller 130.
- the controller 130 of the present invention is functionally connected to at least one component provided for content transmission and playback processing according to an embodiment of the present invention. That is, the controller 130 is functionally connected to the communication unit 110, the input unit 120, the storage unit 140, and the output unit 150, and controls the flow of signals for supplying power and performing functions to the components. Control.
- the controller 130 may include a content reproduction processing module 131 and a decoding module 132.
- the content reproduction processing module 131 controls overall contents related to content request, reception, and reproduction.
- the content reproduction processing module 131 may execute a reproduction application.
- the playback application performs a function of playing back the content provided by the streaming server 200.
- it may be an application capable of playing high quality content provided by the streaming server 200.
- the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
- the content reproduction processing module 131 checks the MPD information, which is metadata. Through the MPD, the content reproduction processing module 131 of the present invention may check address information (URL) for each substream, and may request and receive a substream from a corresponding device. In this case, the content reproduction processing module 131 of the present invention may check the sub-index information for each sub-stream, and simultaneously request and receive the sub-stream when the sub-index information is the same.
- the substreams of the present invention may be stored in different places, for example, the substreams may be stored in a cache device 350 distributed in the vicinity of the terminal 100 and the streaming server 200 or the streaming server 200 ) Can be distributed and stored in a database server that can interoperate with.
- the content reproduction processing module 131 of the present invention may simultaneously request and simultaneously receive content for each substream having the same subindex, and transmit the received substream to the decoding module 132 to request decoding.
- the decoding module 132 of the present invention decodes a substream delivered from the content reproduction processing module 131 and transmits the result thereof to the content reproduction processing module 131 to support the reproduction of the content.
- the storage 140 may temporarily store various data generated during execution of the application program, including an application program required for operating a function according to an embodiment of the present invention.
- the storage 140 according to an embodiment of the present invention can store and manage information related to the playback application 151 that can execute the content provided by the streaming server 200, and store the received substream. And manage.
- the storage 140 may largely include a program area and a data area.
- the program area stores related information for driving the terminal 100 such as an operating system (OS) for booting the terminal 100.
- the data area is an area in which data generated according to the use of the terminal 100 is stored, and as described above, a substream delivered from the reproduction application and the network 300 may be stored.
- the storage unit 140 may include a flash memory, a hard disk, a multimedia card micro type memory (eg, SD or XD memory, etc.), a RAM, a ROM, and the like. ROM) and a storage medium.
- the output unit 150 displays information on a series of operation states and operation results that occur during the functioning of the terminal 100.
- the output unit 150 of the present invention may display various information related to the execution of the playback application.
- the output unit 150 may be implemented in the form of a single touch panel (or touch screen) together with the input unit 120, and when implemented together with the input unit 120, a user's touch operation.
- Various information generated according to the present invention can be displayed.
- the output unit 150 of the present invention is a liquid crystal display (LCD), thin film transistor LCD (TFT-LCD), organic light emitting diodes (OLED), light emitting diodes (LED), AMOLED (Active Matrix) Organic LED), a flexible display (Flexible display) and a three-dimensional display (3 Dimension) and the like.
- LCD liquid crystal display
- TFT-LCD thin film transistor LCD
- OLED organic light emitting diodes
- LED light emitting diodes
- AMOLED Active Matrix Organic LED
- a flexible display Flexible display
- three-dimensional display 3 Dimension
- Some of these displays may also be configured to be transparent or light transmissive so that they can be seen from the outside. It may be configured in the form of a transparent display including a transparent OLED (TOLED).
- TOLED transparent OLED
- the terminal 100 may further include a sound source output unit (not shown) for converting a sound source, which is an electrical signal, into an analog signal and outputting the analog signal.
- a sound source output unit (not shown) for converting a sound source, which is an electrical signal, into an analog signal and outputting the analog signal.
- FIG 3 is a block diagram showing a main configuration of a streaming server according to an embodiment of the present invention
- Figure 4 is a block diagram showing a main configuration of an encoding module according to an embodiment of the present invention.
- the streaming server 200 may include a server communication unit 210, a server control unit 220, and a server storage unit 230.
- the server communication unit 210 serves to transmit and receive the necessary information with the terminal 100 through the communication network (300).
- the server controller 220 includes an encoding module 221, an MPD generation module 222, and a service support module 223.
- the 'module' is a component that performs a predetermined function, respectively, can be implemented in hardware, software, or a combination of hardware and software.
- the 'module' may mean a program module, which is executed by a processor to perform a predetermined function, software components, object-oriented software components, class components and Components such as task components, processes, functions, properties, procedures, subroutines, segments of program code, drivers, data, databases, data structures, tables, arrays , And variables.
- the functionality provided in the components and 'modules' may be combined into a smaller number of components and ' ⁇ modules' or further separated into additional components and ' ⁇ modules'.
- the encoding module 221 may be configured to include a layering unit 221a, a substream generator 221b, and an index manager 221c, as shown in FIG. 4, wherein the layering unit 221a may be any one.
- the bitstream for each layer may be generated by layering the content of the layer into a base layer and an enhancement layer.
- the substream generator 221b may divide and generate the bitstreams of the layered layers into a predetermined number or more of substreams.
- the index manager 221c may assign an index to each of the generated substreams.
- the MPD generation module 223 generates metadata corresponding to the index, and the substream of the content is cached in any one cache device in which the substream delivered to the requesting terminal is distributed in the vicinity of the terminal. If so, it receives the caching information from the cache device, and serves to modify the metadata according to the received caching information.
- the service support module 223 may control the overall process for transmitting content to the terminal 100 at the request of the terminal 100. For example, if content is transmitted to registered users, membership authentication may be performed. In addition, it plays a role of transmitting metadata to the terminal 100, and may support a process of smoothly transferring the substreams stored in the plurality of cache apparatuses 250 or the database server to the terminal 100.
- the server storage unit 230 stores information related to performance of the streaming server 200 of the present invention, and in particular, may store and manage the MPD information 231.
- the streaming server 200 of the present invention provides a service to a registered user
- personal information for membership registration and authentication may be stored and managed.
- a substream in a storage location in the streaming server 2000 of the present invention it may include the corresponding substream.
- FIGS. 6 to 8 are exemplary diagrams for describing a content delivery method according to an embodiment of the present invention.
- the streaming server 200 is assumed to be a set of a plurality of server types.
- a server capable of performing an encoding process including an encoding module among a plurality of servers is referred to as the streaming server 200 of the present invention, and the remaining servers store the divided sub-screens under the control of the streaming server 200.
- the database server is a server.
- the present invention is not limited to the above structure, and the streaming server 200 may include a plurality of storage locations, and the streaming server 200 may directly store the subscription.
- the streaming server 200 encodes and stores the content in order to use the storage space more efficiently and maximizes network traffic, and then transmits the content.
- the process of storing the content in the form of a plurality of substreams may be performed.
- the streaming server 200 of the present invention performs scalable encoding of any one content.
- Scalable encoding means generating a bitstream by layering layers at different frame rates.
- SHVC scalable high efficiency video coding
- the present invention is not limited thereto and various scalable encoding techniques may be used.
- the streaming server 200 of the present invention may generate a bitstream by layering a base layer having a lower frame rate than the original picture and an enhancement layer obtained by combining the base layer with the base layer to obtain the original picture. (S101).
- the streaming server 200 may layer into various layers according to frame rates other than the two layers. For example, one base layer may be generated, but a plurality of enhancement layers may be generated for each frame rate.
- the streaming server 200 divides the base layer bitstream and the enhancement layer bitstream into a predetermined number of substreams to generate a substream (S103). This will be described in detail with reference to FIG. 6.
- the encoding module of the streaming server 200 of the present invention generates a bitstream by layering original content into at least two layers. If the method of generating and layering original content into a base layer bitstream and an enhancement layer bitstream is a general scalable encoding technology, the encoding module of the streaming server 200 of the present invention divides each bitstream into substreams having a variable size. Its characteristics are that it produces.
- the streaming server 200 of the present invention checks the network status (connection status with the terminal, average speed and delay amount, bandwidth availability, the number of connected terminals, etc.), and varies the size of the substream according to the confirmed network status Can be set to In addition, if any one of the terminal 100 has requested the content and the performance information (available buffer amount, etc.) of the decoding module that can be processed by the terminal 100 can be checked, the performance information of the decoding module is considered. A variable sized substream may be generated.
- the streaming server 200 of the present invention may generate a variable sized subscription according to the information on the storage location.
- the storage location of the streaming server A can be processed in units of 4 kb
- the storage location of the streaming server B can be processed in units of 8 kb.
- the streaming server 200 that performs encoding may generate a subscription in consideration of the processing unit of the storage location.
- the streaming server 200 assigns an index to each substream (S105).
- the index is used to identify the substreams and may include identification information (ID) for identifying each substream.
- the substreams of the present invention can be grouped into a plurality of fragments (fragments), the fragments of the present invention may be a condition that is grouped by a specific reference unit.
- the video content may be grouped in units of scenes, and a corresponding group may be assigned a fragment ID, and an index may be set to recognize that the substream is the same fragment.
- the index of the present invention may include identification information on a storage location.
- the first substream may be stored in the first streaming server, and the second substream may be stored in the third streaming server, so that the terminal 100 may receive and use the substream at a corresponding storage location later.
- the index of the present invention may be configured to include identification information about a storage location.
- the base layer bitstream is divided into 19 or more substreams, and each substream is identification information and a substream for substream identification.
- Sub-indexes used to distinguish fragments, which are groups, and index information of identification information (d) of a storage location may be provided, and each substream may be given a URL based on the index information. .
- the streaming server 200 stores each substream (S107).
- the streaming server 200 of the present invention may store each substream divided in any one bitstream in different storage locations.
- A1, A3, and A5 represent the first streaming server
- A2, A3, A4, A6 and A10 may be stored in the second streaming server
- A7, A8 and A9 may be stored in the third streaming server.
- the streaming server 200 of the present invention may modify the storage location identification information of the index given in step S105 when the storage location of each substream is changed or needs to be modified.
- the streaming server 200 of the present invention may interwork with a plurality of cache devices 350 distributed in the vicinity of the terminal 100, and any one of the cache devices in the process of transmitting a substream to the terminal 100.
- the streaming server 200 may modify metadata information so that the cache device 350 provides the substream.
- the streaming server 200 modifies the metadata accordingly. Afterwards, the CDN service is more easily applied to the terminal 100 through the distribution process.
- the streaming server 200 of the present invention will generate the metadata for the index generated corresponding to each substream (S109).
- the metadata of the present invention means media presentation description (MPD) of content.
- MPD means a stylized description of a media presentation
- the MPD of the present invention may be MPD of Dynamic and Adaptive HTTP Streaming of MEPG of MPEG.
- the streaming server 200 may generate a plurality of metadata corresponding to any one content. That is, a plurality of metadata is generated in consideration of the performance of the terminal 100.
- the streaming server 200 of the present invention may generate a bitstream by layering content into a plurality of layers.
- the metadata may include information about all layers constituting the original content.
- the terminal 100 receives the base layer only by configuring the metadata including only the information on the base layer Can be processed to play.
- FIG. 1 One example of the metadata of the present invention is shown in FIG. 1
- the MPD is a description of a representation (or representation) of media to be delivered to the terminal 100 as described above. description). That is, the MPD describes combinations of video, audio, and language that the terminal 100 can access.
- the MPD may define a format for indicating resource identifiers for a segment.
- the MPD may provide a context for the identified resources in the media presentation, where the resource identifiers are HTTP-URLs and may be limited by the byte range attribute.
- Segment is a term for Generation Partnership Project (3GPP) adaptive HTTP streaming.
- 3GPP Generation Partnership Project
- a fragment is a part of a response to an HTTP / 1.1 GET request for an HTTP-URL (or a GET request for a portion indicated by a byte range), as defined in RFC 2616, for example.
- a sub-segment may refer to the smallest unit in segments that can be indexed by the segment index at the segment level. have.
- one period may include two or more fragment sets, and each of the sets of fragments may be referred to as a representation.
- the representation may be referred to as an alternative.
- Representation is a structured collection of one or more media components within one period.
- Representation is an alternative to media content or a subset of media content, with different encoding choices, such as bitrate, resolution, language, codec, and the like. alternative) may be one of the choices. That is, the representation may represent a combination of video, audio, language, and the like that may constitute media.
- the MPD (or MPD element) provides descriptive information that enables the terminal 100 to select one or more representations, in other words suitable for accessing segments and providing streaming services to the user. (appropriate) A document containing metadata required by the DASH client to construct HTTP-URLs. HTTP-URLs can be absolute or relative.
- Such an MPD may be implemented in the form of an XML-document, and the MPD may include various MPD elements as described above, but may include only one MPD element.
- the MPD of the present invention must include segment address information, subindex identification information, and integer type storage location identification information among the above-described elements.
- the streaming server 200 of the present invention transmits the metadata to the corresponding terminal 100 (S111).
- suitable metadata may be selected and transmitted to the terminal 100 according to the specification of the terminal 100.
- the streaming server 200 of the present invention may transmit a substream to the terminal 100 according to the request of the terminal 100.
- the streaming server 200 of the present invention is implemented as a streaming server for encoding and a database server for storing a substream
- the terminal 100 is stored in a database server in which the streaming server for encoding stores a substream.
- the substream may be delivered to the terminal 100 directly from the corresponding database server by transmitting a request of the ().
- the cache device 350 located in the process of transmitting the substream from the streaming server 200 to the corresponding terminal 100 may cache and store the substream and transmit the same to the streaming server 200.
- the streaming server 200 that has received this report may modify and edit the metadata of the content, and when another terminal 100 requests the corresponding content, the streaming server 200 may manage to receive the content from the cache device 350.
- FIG. 9 is a flowchart illustrating a content reproduction method in a terminal according to an embodiment of the present invention.
- the terminal 100 executes the playback application provided (S201).
- the playback application performs a function of playing back the content provided by the streaming server 200.
- it may be an application capable of playing high quality content provided by the streaming server 200.
- the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
- the playback application of the present invention is preferably downloaded in advance from the streaming server 200 or a separate content store is installed in the terminal 100, but is not limited thereto, and may execute the playback application in a cloud manner. .
- the terminal 100 of the present invention checks the MPD which is the metadata file (S203). Through the MPD, the terminal 100 of the present invention may check address information (URL) for each substream, and may request and receive a substream from a corresponding device (S205 to S207). At this time, the terminal 100 of the present invention may check the sub-index information for each sub-stream, and if the sub-index information is the same, it can request and receive the sub-stream at the same time.
- the substreams of the present invention may be stored in different places, for example, the substreams may be stored in a cache device 350 distributed in the vicinity of the terminal 100 and the streaming server 200 or the streaming server 200 ) Can be distributed and stored in a database server that can interoperate with.
- the terminal 100 of the present invention may simultaneously request and simultaneously receive content for each substream having the same subindex (S205 to S207), and decode the received substream to be reproduced in units of fragments (S209).
- the terminal 100 of the present invention may selectively request a content substream using metadata of the content. For example, when the state of the terminal 100 or the network state is unstable, the terminal 100 checks the metadata of the content and selectively requests the content stream so that only the low-capacity content is received and reproduced even if the content is high-capacity.
- the content transmission method supporting scalable encoding of the present invention as described above is generated by dividing a bitstream of a base layer and an enhancement layer layered in any one content into a predetermined number or more of substreams. And assigning and storing an index corresponding to each of the generated substreams, generating metadata for the index, and transmitting the metadata to the terminal that requested the content, and at the request of the terminal. And transmitting the substream of the content to the terminal.
- Such computer-readable media suitable for storing computer program instructions and data include, for example, recording media comprising magnetic media, such as hard disks, floppy disks, and magnetic tape, and compact disk read only memory (CD-ROM). , Optical media such as Digital Video Disk (DVD), magneto-optical media such as Floppy Disk, and ROM (Read Only Memory), RAM And a semiconductor memory such as a random access memory, a flash memory, an erasable programmable ROM (EPROM), and an electrically erasable programmable ROM (EEPROM).
- the processor and memory can be supplemented by or integrated with special purpose logic circuitry.
- the computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
- a functional program for implementing the present invention codes and code segments associated therewith may be used in consideration of a system environment of a computer that reads a recording medium and executes the program. It may be easily inferred or changed by.
- the computer program recorded on the computer-readable recording medium as described above includes instructions for performing the functions as described above, distributed and distributed through the recording medium to be read and installed on a specific device, a specific computer, and executed.
- the above functions can be executed.
- the above-described computer program is a C, C ++ that can be read by the computer's processor (CPU) through the computer's device interface (Interface) Code for a program instruction coded in a computer language such as JAVA, machine language, or the like may be included.
- Such code may include a function code associated with a function or the like that defines the above-described functions, and may include execution procedure-related control code necessary for a processor of the computer to execute the above-described functions according to a predetermined procedure.
- the code may further include memory reference-related code for additional information or media required for a processor of the computer to execute the above-described functions at which location (address address) of the computer's internal or external memory. .
- the code may be used to determine which computer the processor of the computer uses the communication module of the computer on the remote. It may further include communication-related codes such as how to communicate with other computers or servers, and what information or media should be transmitted and received during communication.
- the present invention relates to a content transmission method, and more particularly, when encoding content in a scalable encoding method, by dividing a bitstream of each layer into a predetermined number or more of substreams and assigning an index to each substream.
- the present invention relates to a content transmission method that supports scalable encoding that can be used for content transmission by defining metadata for the content transmission, and a streaming server therefor.
- the terminal when encoding content by a scalable encoding method, by dividing a bitstream of each layer into a predetermined number or more of substreams, assigning an index to each substream, and defining metadata for the index. Even if the substreams are located in different storage locations, the terminal can easily receive and use contents by referring to the indexes of the substreams, thereby contributing to the development of the service industry.
- the present invention has industrial applicability because the present invention is not only sufficiently commercially available or commercially viable, but also practically clearly implemented.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
Abstract
The present invention relates to a content transmission method and, more particularly, to a content transmission method supporting scalable encoding, and a streaming server for the same, wherein, when a content is encoded using a scalable encoding method, a bit stream of each layer is divided into at least a certain number of substreams, each substream is assigned an index, and then metadata for the index is defined, so that a terminal can easily receive and use the content by making reference to the indexes of the substreams even when each substream is located at a different storage location.
Description
본 발명은 컨텐츠 전송 방법에 관한 것으로, 더욱 상세하게는 스케일러블 인코딩 방식으로 컨텐츠를 인코딩 시, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 각 서브스트림에 대한 인덱스를 부여한 후 상기 인덱스에 대한 메타데이터를 정의하여 컨텐츠 전송에 활용할 수 있는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법 및 이를 위한 스트리밍 서버에 관한 것이다. The present invention relates to a content transmission method, and more particularly, when encoding content in a scalable encoding method, by dividing a bitstream of each layer into a predetermined number or more of substreams and assigning an index to each substream. The present invention relates to a content transmission method that supports scalable encoding that can be used for content transmission by defining metadata for the content transmission, and a streaming server therefor.
이 부분에 기술된 내용은 단순히 본 실시 예에 대한 배경 정보를 제공할 뿐 종래기술을 구성하는 것은 아니다.The contents described in this section merely provide background information on the present embodiment and do not constitute a prior art.
최근 각광받고 있는 UHD(Ultra High Definition) 방송 컨텐츠를 실시간 스트리밍하기 위해서는 큰 네트워크 대역폭과 대용량의 저장 공간이 필요하다.In order to stream UHD (Ultra High Definition) broadcast contents, which are in the spotlight recently, a large network bandwidth and a large storage space are required.
그러나 단말과 서버 간의 단일 채널을 통한 단일 전송만으로는 네트워크 대역폭을 효율적으로 사용하지 못한다는 문제점이 있다. However, there is a problem that a single transmission through a single channel between the terminal and the server does not use the network bandwidth efficiently.
반면, 대용량의 저장 공간이 필요한 문제점을 해결하기 위해 다양한 인코딩 기술이 적용되고 있다. 현재 가장 널리 사용되고 있는 인코딩 방식은 스케일러블(Scalable) 인코딩 기술의 하나인 SHVC(Scalable High efficiency Video Coding) 방식이다. On the other hand, various encoding techniques are applied to solve the problem of requiring a large storage space. Currently, the most widely used encoding scheme is Scalable High Efficiency Video Coding (SHVC), which is one of scalable encoding techniques.
SHVC는 컨텐츠를 기본 레이어(BL; Base Layer)와 향상 레이어(EL; Enhancement Layer)의 다계층으로 코딩하여 데이터의 크기를 줄이고 비트스트림을 분리하여 사용자 네트워크 대역폭에 따라 적응적으로 컨텐츠를 수신하고 재생하도록 지원하는 코딩 방식을 의미한다. 이때, 단말은 원본 컨텐츠의 해상도 그대로 복원하기 위해서는 기본 레이어와 향상 레이어를 함께 수신하여 복호화하게 된다. SHVC codes content into multiple layers of base layer (BL) and enhancement layer (EL) to reduce data size and separate bitstreams to adaptively receive and play content according to user network bandwidth. Refers to a coding scheme that supports it. In this case, the terminal receives and decodes the base layer and the enhancement layer together to restore the resolution of the original content.
그러나 현재까지의 스케일러블 인코딩 방식은 비트스트림별로 데이터를 저장함으로써 저장 공간의 효율적 사용이 불가능하며, 어느 하나의 서버가 비트스트림을 집중하여 저장하고 있어 다중 전송이 불가능하다는 문제점이 있다. However, the scalable encoding method up to now has a problem in that it is impossible to efficiently use the storage space by storing data for each bitstream, and multiple transmissions are impossible because any one server concentrates and stores the bitstream.
본 발명은 상기한 종래의 문제점을 해결하기 위해 제안된 것으로서, 특히 스케일러블 인코딩 방식으로 컨텐츠를 인코딩 시, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 각 서브스트림에 대한 인덱스를 부여한 후 상기 인덱스에 대한 메타데이터를 정의하여 컨텐츠 전송에 활용할 수 있는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법 및 이를 위한 스트리밍 서버를 제공하는 데 목적이 있다. The present invention has been proposed to solve the above-described problems. In particular, when encoding content using a scalable encoding method, after dividing a bitstream of each layer into a predetermined number or more of substreams, an index for each substream is assigned. It is an object of the present invention to provide a content transmission method for supporting scalable encoding that can be used for content transmission by defining metadata for the index and a streaming server for the same.
다시 말해, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 각 서브스트림별로 인덱스를 부여한 후 상기 인덱스에 대한 메타데이터를 정의함으로써, 각각의 서브스트림이 서로 다른 저장 장소에 위치하고 있더라도 상기 서브스트림에 대한 인덱스를 참조하여 단말이 쉽게 컨텐츠를 수신하여 이용할 수 있는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법 및 이를 위한 스트리밍 서버를 제공하는 데 그 목적이 있다. In other words, by dividing the bitstreams of each layer into more than a certain number of substreams, assigning indexes for each substream, and defining metadata for the indexes, even if each substream is located in a different storage location, the substreams It is an object of the present invention to provide a method for transmitting a content and a streaming server for supporting the scalable encoding that a terminal can easily receive and use the content with reference to the index.
그러나, 이러한 본 발명의 목적은 상기의 목적으로 제한되지 않으며, 언급되지 않은 또 다른 목적들은 아래의 기재로부터 명확하게 이해될 수 있을 것이다.However, the object of the present invention is not limited to the above object, and other objects not mentioned will be clearly understood from the following description.
상술한 바와 같은 목적을 달성하기 위한 본 발명의 실시 예에 따른 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법은 어느 하나의 컨텐츠에서 계층화된 기본 레이어(base layer) 및 향상 레이어(enhancement layer)의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성하는 단계; 상기 생성된 각각의 서브스트림에 대응하여 인덱스를 부여하고 저장하는 단계; 및 상기 인덱스에 대한 메타데이터를 생성한 후 상기 컨텐츠를 요청한 단말로 상기 메타데이터를 전송하고, 상기 단말의 요청에 따라 상기 컨텐츠의 서브스트림을 상기 단말로 전송하는 단계;를 포함하여 이뤄질 수 있다. According to an embodiment of the present invention, a content transmission method supporting scalable encoding includes a bitstream of a base layer and an enhancement layer layered in any one content. Generating by dividing a predetermined number or more of substreams; Assigning and storing an index corresponding to each of the generated substreams; And generating the metadata for the index and transmitting the metadata to the terminal requesting the content, and transmitting the substream of the content to the terminal according to the request of the terminal.
이때, 상기 분할하여 생성하는 단계는 네트워크의 상태 정보, 상기 컨텐츠를 요청한 단말의 성능 정보 및 상기 서브스트림을 저장할 수 있는 저장 장소의 성능 정보 중 적어도 어느 하나 이상을 고려하여 상기 계층화된 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성할 수 있다. In this case, the dividing step may include generating bits of each layer in consideration of at least one of state information of a network, performance information of a terminal requesting the content, and performance information of a storage location capable of storing the substream. The stream may be generated by dividing the stream into a predetermined number or more of substreams.
이때, 상기 인덱스는 상기 서브스트림을 식별하기 위한 식별 정보, 상기 서브스트림을 포함하는 프래그먼트 식별 정보 및 상기 서브스트림이 저장되는 저장 장소에 대한 식별 정보 중 적어도 어느 하나를 포함할 수 있다. In this case, the index may include at least one of identification information for identifying the substream, fragment identification information including the substream, and identification information on a storage location where the substream is stored.
또한, 상기 메타데이터는 상기 단말의 성능 정보에 대응하여 복수 개 생성되거나, 상기 단말의 성능을 고려하여 수신할 수 있는 요소를 한정하는 정보를 포함할 수 있다. In addition, the metadata may include a plurality of metadata generated corresponding to the performance information of the terminal or limiting elements that can be received in consideration of the performance of the terminal.
또한, 상기 전송하는 단계 이후에, 상기 단말 인근에 분산 배치된 어느 하나의 캐시 장치에 상기 컨텐츠의 서브스트림이 캐싱되는 경우, 상기 캐시 장치로부터 상기 캐싱 정보를 수신하는 단계; 및 상기 수신된 캐싱 정보에 따라 상기 메타데이터를 수정하는 단계;를 포함하여 이뤄질 수 있다. In addition, after the transmitting, if the substream of the content is cached in any one cache device distributed in the vicinity of the terminal, receiving the caching information from the cache device; And modifying the metadata according to the received caching information.
추가로 본 발명은 상술한 바와 같은 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법을 실행하는 프로그램을 기록한 컴퓨터 판독 가능한 기록 매체를 제공할 수 있다.In addition, the present invention can provide a computer readable recording medium having recorded thereon a program for executing a content transmission method supporting scalable encoding as described above.
상술한 바와 같은 목적을 달성하기 위한 본 발명의 실시 예에 따른 스트리밍 서버는 어느 하나의 컨텐츠를 기본 레이어(base layer) 및 향상 레이어(enhancement layer)으로 계층화하여 각 레이어에 대한 비트스트림을 생성하는 계층화부; 상기 계층화된 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성하는 서브스트림 생성부; 및 상기 생성된 각각의 서브스트림에 대응하여 인덱스를 부여하는 인덱스 관리부;로 구성되는 인코딩 모듈을 포함할 수 있다. A streaming server according to an embodiment of the present invention for achieving the above object is a layering to generate a bitstream for each layer by layering any content into a base layer and an enhancement layer part; A substream generator for dividing the bitstreams of the layered layers into a predetermined number or more of substreams; And an index management unit for assigning an index corresponding to each of the generated substreams.
이때, 상기 스트리밍 서버는 상기 인덱스에 대응한 메타데이터를 생성하며, 상기 컨텐츠를 요청한 단말로 전달되는 상기 서브스트림이 상기 단말 인근에 분산 배치된 어느 하나의 캐시 장치에 상기 컨텐츠의 서브스트림이 캐싱되는 경우, 상기 캐시 장치로부터 상기 캐싱 정보를 수신하고, 상기 수신된 캐싱 정보에 따라 상기 메타데이터를 수정하는 MPD 생성 모듈;을 더 포함하여 구성될 수 있다. In this case, the streaming server generates metadata corresponding to the index, and the substream of the content is cached in any one cache device in which the substream delivered to the requesting terminal is distributed in the vicinity of the terminal. In this case, the MPD generation module may be further configured to receive the caching information from the cache device and to modify the metadata according to the received caching information.
본 발명의 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법 및 이를 위한 스트리밍 서버에 의하면, 스케일러블 인코딩 방식으로 컨텐츠를 인코딩 시, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 각 서브스트림에 대한 인덱스를 부여한 후 상기 인덱스에 대한 메타데이터를 정의함으로써, 각각의 서브스트림이 서로 다른 저장 장소에 위치하고 있더라도 상기 서브스트림에 대한 인덱스를 참조하여 단말이 쉽게 컨텐츠를 수신하여 이용할 수 있게 된다. According to a content transmission method and a streaming server for supporting the scalable encoding of the present invention, when encoding a content using the scalable encoding method, the bitstream of each layer is divided into a predetermined number of substreams and an index for each substream. After defining the metadata for the index, even if each substream is located in a different storage location, the terminal can easily receive and use the content with reference to the index for the substream.
또한, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 서로 다른 저장 장소에 저장함으로써, 저장 공간을 보다 효율적으로 활용할 수 있으며, 단말과 복수 개의 채널을 통해 연결될 수 있어 다중 전송이 가능하며 이를 통해 네트워크 트래픽을 보다 효율적으로 활용할 수 있게 된다. In addition, by dividing the bitstream of each layer into a predetermined number or more of substreams and storing them in different storage locations, the storage space can be utilized more efficiently, and the terminal can be connected through a plurality of channels, thereby enabling multiple transmission. This allows for more efficient use of network traffic.
또한, 고용량 컨텐츠를 분할하여 캐싱 처리할 수 있어 고용량 캐싱 지원이 어려운 CDN(Contents Delivery Network, 컨텐츠 전송 네트워크) 서비스 적용이 가능하게 된다.In addition, high-capacity content can be partitioned and cached, thereby enabling application of a CDN (Contents Delivery Network) service that is difficult to support high-capacity caching.
아울러, 상술한 효과 이외의 다양한 효과들이 후술될 본 발명의 실시 예에 따른 상세한 설명에서 직접적 또는 암시적으로 개시될 수 있다.In addition, various effects other than the above-described effects may be directly or implicitly disclosed in the detailed description according to the embodiment of the present invention to be described later.
도 1은 본 발명의 실시 예에 따른 컨텐츠 전송 시스템을 도시한 구성도이다. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
도 2는 본 발명의 실시 예에 따른 단말의 주요 구성을 도시한 블록도이다.2 is a block diagram showing a main configuration of a terminal according to an embodiment of the present invention.
도 3은 본 발명의 실시 예에 따른 스트리밍 서버의 주요 구성을 도시한 블록도이다. 3 is a block diagram showing the main configuration of a streaming server according to an embodiment of the present invention.
도 4는 본 발명의 실시 예에 따른 인코딩 모듈의 주요 구성을 도시한 블록도이다. 4 is a block diagram illustrating a main configuration of an encoding module according to an embodiment of the present invention.
도 5는 본 발명의 실시 예에 따른 컨텐츠 전송 방법을 설명하기 위한 흐름도이다. 5 is a flowchart illustrating a content transmission method according to an embodiment of the present invention.
도 6 내지 도 8은 본 발명의 실시 예에 따른 컨텐츠 전송 방법을 설명하기 위한 예시도이다.6 to 8 are exemplary diagrams for describing a content transmission method according to an embodiment of the present invention.
도 9는 본 발명의 실시 예에 따른 단말에서의 컨텐츠 재생 방법을 설명하기 위한 흐름도이다. 9 is a flowchart illustrating a content reproduction method in a terminal according to an embodiment of the present invention.
본 발명의 과제 해결 수단의 특징 및 이점을 보다 명확히 하기 위하여, 첨부된 도면에 도시된 본 발명의 특정 실시 예를 참조하여 본 발명을 더 상세하게 설명한다. BRIEF DESCRIPTION OF THE DRAWINGS To make the features and advantages of the present invention more clear, the present invention will be described in more detail with reference to specific embodiments shown in the accompanying drawings.
다만, 하기의 설명 및 첨부된 도면에서 본 발명의 요지를 흐릴 수 있는 공지 기능 또는 구성에 대한 상세한 설명은 생략한다. 또한, 도면 전체에 걸쳐 동일한 구성 요소들은 가능한 한 동일한 도면 부호로 나타내고 있음에 유의하여야 한다.However, in the following description and the accompanying drawings, detailed descriptions of well-known functions or configurations that may obscure the subject matter of the present invention will be omitted. In addition, it should be noted that like elements are denoted by the same reference numerals as much as possible throughout the drawings.
이하의 설명 및 도면에서 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위한 용어의 개념으로 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서 본 명세서에 기재된 실시 예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시 예에 불과할 뿐이고, 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형 예들이 있을 수 있음을 이해하여야 한다.The terms or words used in the following description and drawings should not be construed as being limited to the ordinary or dictionary meanings, and the inventors may appropriately define the concept of terms for explaining their own invention in the best way. It should be interpreted as meaning and concept corresponding to the technical idea of the present invention based on the principle that the present invention. Therefore, the embodiments described in the present specification and the configuration shown in the drawings are only the most preferred embodiments of the present invention, and do not represent all of the technical ideas of the present invention, and various alternatives may be substituted at the time of the present application. It should be understood that there may be equivalents and variations.
또한, 제1, 제2 등과 같이 서수를 포함하는 용어는 다양한 구성요소들을 설명하기 위해 사용하는 것으로, 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용될 뿐, 상기 구성요소들을 한정하기 위해 사용되지 않는다. 예를 들어, 본 발명의 권리 범위를 벗어나지 않으면서 제2 구성요소는 제1 구성요소로 명명될 수 있고, 유사하게 제1 구성요소도 제2 구성요소로 명명될 수 있다.In addition, terms including ordinal numbers, such as first and second, are used to describe various components, and are used only to distinguish one component from another component, and to limit the components. Not used. For example, without departing from the scope of the present invention, the second component may be referred to as the first component, and similarly, the first component may also be referred to as the second component.
더하여, 어떤 구성요소가 다른 구성요소에 "연결되어" 있다거나 "접속되어" 있다고 언급할 경우, 이는 논리적 또는 물리적으로 연결되거나, 접속될 수 있음을 의미한다. 다시 말해, 구성요소가 다른 구성요소에 직접적으로 연결되거나 접속되어 있을 수 있지만, 중간에 다른 구성요소가 존재할 수도 있으며, 간접적으로 연결되거나 접속될 수도 있다고 이해되어야 할 것이다.In addition, when a component is referred to as being "connected" or "connected" to another component, it means that it may be connected or connected logically or physically. In other words, although a component may be directly connected or connected to other components, it should be understood that other components may exist in the middle, and may be connected or connected indirectly.
또한, 본 명세서에서 사용한 용어는 단지 특정한 실시 예를 설명하기 위해 사용된 것으로, 본 발명을 한정하려는 의도가 아니다. 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 또한, 본 명세서에서 기술되는 포함 한다" 또는 "가지다" 등의 용어는 명세서상에 기재된 특징, 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것이 존재함을 지정하려는 것이지, 하나 또는 그 이상의 다른 특징들이나 숫자, 단계, 동작, 구성요소, 부품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.In addition, the terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. Singular expressions include plural expressions unless the context clearly indicates otherwise. In addition, the terms "include" or "having" described herein are intended to indicate that there is a feature, number, step, operation, component, part, or combination thereof described in the specification, and one or more of them. It is to be understood that it does not exclude in advance the possibility of the presence or addition of other features or numbers, steps, operations, components, components or combinations thereof.
아울러, 본 발명의 범위 내의 실시 예들은 컴퓨터 실행가능 명령어 또는 컴퓨터 판독가능 매체에 저장된 데이터 구조를 가지거나 전달하는 컴퓨터 판독가능 매체를 포함한다. 이러한 컴퓨터 판독가능 매체는, 범용 또는 특수 목적의 컴퓨터 시스템에 의해 액세스 가능한 임의의 이용 가능한 매체일 수 있다. 예로서, 이러한 컴퓨터 판독가능 매체는 RAM, ROM, EPROM, CD-ROM 또는 기타 광 디스크 저장장치, 자기 디스크 저장장치 또는 기타 자기 저장장치, 또는 컴퓨터 실행가능 명령어, 컴퓨터 판독가능 명령어 또는 데이터 구조의 형태로 된 소정의 프로그램 코드 수단을 저장하거나 전달하는 데에 이용될 수 있고, 범용 또는 특수 목적 컴퓨터 시스템에 의해 액세스 될 수 있는 임의의 기타 매체와 같은 물리적 저장 매체를 포함할 수 있지만, 이에 한정되지 않는다.In addition, embodiments within the scope of the present invention include computer readable media having or conveying computer executable instructions or data structures stored on the computer readable medium. Such computer readable media can be any available media that can be accessed by a general purpose or special purpose computer system. By way of example, such computer readable media may be in the form of RAM, ROM, EPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage, or computer executable instructions, computer readable instructions or data structures. And may include, but are not limited to, any other medium that can be used to store or deliver certain program code means, and can be accessed by a general purpose or special purpose computer system. .
이하의 설명 및 특허 청구 범위에서, "네트워크"는 컴퓨터 시스템들 및/또는 모듈들 간의 전자 데이터를 전송할 수 있게 하는 하나 이상의 데이터 링크로서 정의된다. 정보가 네트워크 또는 다른 (유선, 무선, 또는 유선 또는 무선의 조합인) 통신 접속을 통하여 컴퓨터 시스템에 전송되거나 제공될 때, 이 접속은 컴퓨터-판독가능매체로서 이해될 수 있다. 컴퓨터 판독가능 명령어는, 예를 들면, 범용 컴퓨터 시스템 또는 특수 목적 컴퓨터 시스템이 특정 기능 또는 기능의 그룹을 수행하도록 하는 명령어 및 데이터를 포함한다. 컴퓨터 실행가능 명령어는, 예를 들면, 어셈블리어, 또는 심지어는 소스코드와 같은 이진, 중간 포맷 명령어일 수 있다.In the following description and claims, “network” is defined as one or more data links that enable the transfer of electronic data between computer systems and / or modules. When information is transmitted or provided to a computer system via a network or other (wired, wireless, or a combination of wired or wireless) communication connections, this connection can be understood as a computer-readable medium. Computer-readable instructions include, for example, instructions and data that cause a general purpose or special purpose computer system to perform a particular function or group of functions. The computer executable instructions may be, for example, binary, intermediate format instructions such as assembly language, or even source code.
아울러, 본 발명은 퍼스널 컴퓨터, 랩탑 컴퓨터, 핸드헬드 장치, 멀티프로세서 시스템, 마이크로프로세서-기반 또는 프로그램 가능한 가전제품(programmable consumer electronics), 네트워크 PC, 미니컴퓨터, 메인프레임 컴퓨터, 모바일 전화, PDA, 페이저(pager) 등을 포함하는 다양한 유형의 컴퓨터 시스템 구성을 가지는 네트워크 컴퓨팅 환경에서 실시될 수 있다. In addition, the present invention relates to personal computers, laptop computers, handheld devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile phones, PDAs, pagers It may be practiced in a network computing environment having various types of computer system configurations, including (pager) and the like.
또한 본 발명의 명세서에서 기술되는 단말은 다양한 형태로 구현될 수 있다. 예를 들어, 스마트 폰(smart phone), 타블렛 PC(Tablet PC), PDA(Personal Digital Assistants), PMP(Portable Multimedia Player), MP3 Player 등의 이동 단말기는 물론, 스마트 TV(Smart TV), 데스크탑 컴퓨터 등과 같은 고정 단말기가 사용될 수 있으며, 네트워크를 통해 컨텐츠 서버로 컨텐츠를 업로드하거나 다운로드를 요청하여 이용할 수 있는 단말이라면, 그 어떠한 단말도 본 발명의 단말로 적용 가능하다.In addition, the terminal described in the specification of the present invention may be implemented in various forms. For example, mobile terminals such as smart phones, tablet PCs, personal digital assistants, portable multimedia players, and MP3 players, as well as smart TVs and desktop computers. A fixed terminal may be used, and any terminal can be used as a terminal of the present invention as long as the terminal can be used by uploading or downloading content to a content server through a network.
또한, 본 발명의 명세서에서 기술하는 컨텐츠는 네트워크 상에서 특정 주소(예컨대, URL)로 표현될 수 있는 것이라면 그 어떠한 것도 본 발명의 컨텐츠에 포함될 수 있다. 예컨대, 웹 사이트 전체도 하나의 URL로 표현되는 경우, 하나의 컨텐츠로써, 본 발명의 시스템을 통해 배포될 수 있다. In addition, any content described in the specification of the present invention may be included in the content of the present invention as long as it can be expressed by a specific address (eg, a URL) on the network. For example, when the entire web site is represented by one URL, it can be distributed through the system of the present invention as one content.
본 발명은 또한 네트워크를 통해 유선 데이터 링크, 무선 데이터 링크, 또는 유선 및 무선 데이터 링크의 조합으로 링크된 로컬 및 원격 컴퓨터 시스템 모두가 태스크를 수행하는 분산형 시스템 환경에서 실행될 수 있다. 분산형 시스템 환경에서, 프로그램 모듈은 로컬 및 원격 메모리 저장 장치에 위치될 수 있다.The invention may also be practiced in distributed system environments where both local and remote computer systems that are linked via wired networks, wireless data links, or combinations of wired and wireless data links perform tasks. In a distributed system environment, program modules may be located in both local and remote memory storage devices.
이제, 본 발명의 실시 예에 따른 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법 및 이를 위한 스트리밍 서버에 대하여 도면을 참조하여 상세하게 설명하도록 한다. Now, a content transmission method and a streaming server for supporting scalable encoding according to an embodiment of the present invention will be described in detail with reference to the accompanying drawings.
먼저, 본 발명의 실시 예에 따른 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법을 지원하는 컨텐츠 전송 시스템에 대해 설명하도록 한다.First, a content delivery system supporting a content delivery method supporting scalable encoding according to an embodiment of the present invention will be described.
도 1은 본 발명의 실시 예에 따른 컨텐츠 전송 시스템을 도시한 구성도이다. 1 is a block diagram showing a content delivery system according to an embodiment of the present invention.
도 1을 참조하면, 본 발명의 실시 예에 따른 컨텐츠 전송 시스템은 단말(100) 및 스트리밍 서버(200)를 포함하여 구성될 수 있다. Referring to FIG. 1, a content delivery system according to an exemplary embodiment of the present invention may include a terminal 100 and a streaming server 200.
먼저, 단말(100)은 사용자의 요청에 따라 네트워크(300)를 통해 스트리밍 서버(200)로 특정 컨텐츠를 요청하고, 스트리밍 서버(200)로부터 제공되는 컨텐츠를 수신하여 이용하고자 하는 장치를 의미한다. 보다 구체적으로, 본 발명의 단말(100)은 사용자로부터 특정 컨텐츠에 대한 요청을 확인한다. 상기 특정 컨텐츠에 대한 요청은 상기 스트리밍 서버(200)가 제공하는 컨텐츠를 수신하여 이용할 수 있는 브라우저, 재생 어플리케이션 등의 실행 과정을 포함할 수 있다. 이후 단말(100)은 스트리밍 서버(200)로부터 컨텐츠에 대한 메타데이터를 수신하며, 상기 메타데이터를 기초로 해당 컨텐츠를 보유하고 있는 저장 장소의 위치를 확인하고, 해당 저장 장소로 컨텐츠를 요청하여 수신할 수 있게 된다. First, the terminal 100 refers to a device that requests specific content to the streaming server 200 through the network 300 according to a user's request, and receives and uses the content provided from the streaming server 200. More specifically, the terminal 100 of the present invention confirms a request for specific content from the user. The request for the specific content may include an execution process of a browser, a playback application, etc. that may receive and use the content provided by the streaming server 200. Thereafter, the terminal 100 receives metadata about the content from the streaming server 200, checks the location of the storage location holding the content based on the metadata, requests the content from the storage location, and receives the content. You can do it.
이때, 상기 메타데이터를 기초로 확인된 해당 컨텐츠를 보유하고 있는 저장 장소의 위치가 URL 형태로 확인되는 경우, 단말(100)은 DNS(Domain Name Server) 등의 네임서버에 액세스하여 해당 컨텐츠를 제공하는 저장 장소의 주소 정보(IP address)를 획득하고, 해당 저장 장소에 요청하여 컨텐츠를 이용할 수 있게 된다. At this time, when the location of the storage location that holds the identified content based on the metadata is identified in the form of a URL, the terminal 100 accesses a name server such as a domain name server (DNS) and provides the corresponding content. It obtains the address information (IP address) of the storage location, and requests the storage location to use the content.
또한, 본 발명의 실시 예에 따른 단말(100)은 해당 컨텐츠를 저장하고 있는 저장 장소, 예컨대 스트리밍 서버(200)로부터 서브스트림 단위로 컨텐츠를 수신할 수 있다. 이때, 본 발명의 단말(100)은 메타데이터를 확인한 후 복수 개의 서브스트림의 집합인 프래그먼트 단위로 컨텐츠를 요청하여 수신하여 이용할 수 있으며, 수신되는 서브스트림을 복호화한 후 이를 프래그먼트 단위로 재생할 수 있다. In addition, the terminal 100 according to an embodiment of the present invention may receive the content on a sub-stream basis from a storage location that stores the corresponding content, for example, the streaming server 200. In this case, the terminal 100 according to the present invention may request and receive content in units of fragments, which are sets of a plurality of substreams, after checking metadata, and may decode the received substreams and play them in units of fragments. .
스트리밍 서버(200)는 단말(100)로 다양한 컨텐츠, 예컨대, 사진, 비디오, 오디오, 어플리케이션 등과 같은 다양한 컨텐츠를 제공하거나, 컨텐츠를 수신하고 이와 관련된 서비스를 제공하기 위한 것으로, 컨텐츠 제공자(CP; Contents Provider)로부터 적어도 하나의 컨텐츠를 제공받아 관리하며, 네트워크(300)를 통해서 다수의 단말(100)로 컨텐츠를 제공하는 역할을 수행할 수 있다. 이때, 본 발명의 스트리밍 서버(200)는 컨텐츠에 대한 스케일러블 인코딩을 지원하며, 계층화된 비트스트림을 서브스트림으로 분할하고 분할된 서브스트림이 저장되는 과정을 지원한다. 또한, 본 발명의 스트리밍 서버(200)는 각각의 서브스트림에 대한 인덱스를 부여하고 상기 인덱스에 대한 메타데이터를 정의한 후 단말(100)로 배포하는 과정을 지원할 수 있다. The streaming server 200 is to provide various contents such as photographs, videos, audio, applications, etc. to the terminal 100, or to receive and provide contents related services. The content provider (CP; Contents) At least one content is provided from the provider and managed, and serves to provide content to the plurality of terminals 100 through the network 300. In this case, the streaming server 200 of the present invention supports scalable encoding of content, and supports a process of dividing a layered bitstream into substreams and storing the divided substreams. In addition, the streaming server 200 of the present invention may support the process of assigning an index for each substream and defining metadata for the index and then distributing it to the terminal 100.
또한, 본 발명의 스트리밍 서버(200)는 복수 개 존재할 수 있다. 복수 개 존재하는 경우 어느 하나의 스트리밍 서버(200)가 컨텐츠의 스케일러블 인코딩을 수행하며 다른 서버는 데이터베이스 서버의 역할을 수행할 수 있다.In addition, a plurality of streaming servers 200 of the present invention may exist. When there is a plurality, any one streaming server 200 performs scalable encoding of content, and the other server may play a role of a database server.
본 발명의 실시 예에 따른 단말(100) 및 스트리밍 서버(200)의 주요 구성 및 동작에 대해서는 후술하도록 하며, 본 발명은 CDN 서비스에 적용될 수 있다. 즉, 도 1에 도시된 바와 같이, 본 발명의 네트워크(300)는 분산 배치된 다수의 캐시 장치(350)를 포함하여 구성될 수 있다. 이때, 다수의 캐시 장치(350)는 접속망(330)과 코어망(320) 사이에 위치하는 것이 바람직하나 상기 위치에 고정되는 것은 아니며, 단말(100)과 스트리밍 서버(200) 사이에 송수신되는 패킷을 모니터링하고 컨텐츠 흐름을 제어할 수 있다면, 다양한 형태로 분산 배치될 수 있다. The main configuration and operation of the terminal 100 and the streaming server 200 according to an embodiment of the present invention will be described later, the present invention can be applied to the CDN service. That is, as shown in FIG. 1, the network 300 of the present invention may include a plurality of cache devices 350 distributed in a distributed manner. At this time, the plurality of cache devices 350 is preferably located between the access network 330 and the core network 320, but is not fixed to the location, the packet transmitted and received between the terminal 100 and the streaming server 200 If you can monitor and control the flow of content, it can be distributed in various forms.
현재까지의 CDN 서비스에 적용되는 캐시 장치(350)는 저장 공간이 작아 고용량 컨텐츠 저장이 어렵다는 문제점이 있었다. 본 발명은 이러한 문제점을 해결하기 위한 것으로, 스트리밍 서버(200)는 컨텐츠를 인코딩 과정에서 복수 개의 서브스트림으로 분할하여 분산 배치된 캐시 장치(350)에 저장되는 과정을 지원할 수 있으며, 복수 개의 캐시 장치(350)는 각각 별도의 채널을 통해 단말(100)과 연결되어 단말(100)의 요청에 따라 해당하는 서브스트림을 동시에 단말(100)로 전송할 수 있게 된다. The cache apparatus 350 applied to the CDN service up to now has a problem that it is difficult to store high-capacity content because of a small storage space. The present invention is to solve this problem, the streaming server 200 may support the process of dividing the content into a plurality of substreams in the encoding process is stored in the distributed cache device 350, a plurality of cache devices Each 350 may be connected to the terminal 100 through a separate channel to simultaneously transmit a corresponding substream to the terminal 100 according to a request of the terminal 100.
또한, 본 발명의 캐시 장치(350)는 스트리밍 서버(200)에서 단말(100)로 전달되는 서브스트림을 모니터링하여 검출하고, 검출된 서브스트림을 저장할 수 있으며, 이에 대한 정보를 스트리밍 서버(200)로 전송하여 스트리밍 서버(200)가 메타데이터를 변경하는 과정이 이뤄지도록 지원할 수 있다. In addition, the cache apparatus 350 of the present invention may monitor and detect a substream transmitted from the streaming server 200 to the terminal 100, and store the detected substream, and may transmit information about this to the streaming server 200. By transmitting to the streaming server 200 may support the process of changing the metadata is made.
아울러, 본 발명의 다수의 캐시 장치(350)가 주요 지점에 분산 배치되어 있는 네트워크(300)는 단말(100)과 스트리밍 서버(200) 간의 정보의 송수신을 위한 통신망을 의미하는 것으로, 특히, 단일의 통신망 형태보다는 다양한 종류, 예컨대 인트라넷망, 이동통신망, 위성 통신망 등 다양한 종류의 유무선 통신 기술을 이용하여 구현된 통신망이 혼합된 형태일 수 있다. In addition, the network 300 in which the plurality of cache devices 350 of the present invention are distributed and distributed at a main point means a communication network for transmitting and receiving information between the terminal 100 and the streaming server 200, and in particular, a single network. Rather than a communication network type, a communication network implemented using various types of wired and wireless communication technologies such as an intranet network, a mobile communication network, and a satellite communication network may be mixed.
여기서, 네트워크(300)는 다수의 유무선 접속망(330) 및 코어망(320)을 포함하는 모바일 망과 연결되 외부망, 예컨대 인터넷망(310)을 포함하여 구성될 수 있다. 여기서, 모바일 망을 구성하는 유무선 접속망(330)은 단말(100)과 유무선 통신을 수행하는 접속망으로서, 예를 들어, BS(Base Station), BTS(Base Transceiver Station), NodeB, eNodeB 등과 같은 다수의 기지국과, BSC(Base Station Controller), RNC(Radio Network Controller)와 같은 기지국 제어기로 구현될 수 있다.Here, the network 300 may be configured to include an external network, for example, an internet network 310 connected to a mobile network including a plurality of wired / wireless access networks 330 and a core network 320. Here, the wired / wireless access network 330 constituting the mobile network is an access network performing wired / wireless communication with the terminal 100. For example, a plurality of base stations (BS), a base transceiver station (BTS), NodeB, eNodeB, etc. The base station may be implemented as a base station controller such as a base station controller (BSC) and a radio network controller (RNC).
또 다른 방식으로는, 상기 기지국에 일체로 구현되어 있던 디지털 신호 처리부와 무선 신호 처리부를 각각 디지털 유니트(Digital Unit, 이하 DU라 함과 무선 유니트(Radio Unit, 이하 RU라 함)으로 구분하여, 다수의 영역에 각각 다수의 RU(미도시)를 설치하고, 다수의 RU(미도시)를 집중화된 DU(미도시)와 연결하여 구성할 수도 있다.As another method, a digital signal processor and a wireless signal processor, which are integrally implemented in the base station, are divided into digital units (hereinafter referred to as DUs and radio units (hereinafter referred to as RUs)). Each of the plurality of RUs (not shown) may be installed in the region of the plurality, and the plurality of RUs (not shown) may be configured by connecting with a centralized DU (not shown).
또한, 유무선 접속망(330)와 함께 모바일 망을 구성하는 코어망(320)은 유무선 접속망(330)과 외부 망, 예컨대, 인터넷망(310)을 연결하는 역할을 수행한다.In addition, the core network 320 constituting the mobile network together with the wired / wireless access network 330 serves to connect the wired / wireless access network 330 with an external network, for example, the internet network 310.
이러한 코어망(320)은 앞서 설명한 바와 같이, 유무선 접속망(330) 간의 이동성 제어 및 스위칭 등의 이동통신 서비스를 위한 주요 기능을 수행하는 네트워크 시스템으로서, 서킷 교환(circuit switching) 또는 패킷 교환(packet switching)을 수행하며, 모바일 망 내에서의 패킷 흐름을 관리 및 제어한다. 또한, 코어망(320)은 주파수간 이동성을 관리하고, 접속망(330) 및 코어망(320) 내의 트래픽 및 다른 네트워크, 예컨대 인터넷망(310)과의 연동을 위한 역할을 수행할 수도 있다. 코어망(320)은 상술한 구성 이외도 MSC(Mobile Switching Center), HLR(Home Location Register), MME(Mobile Mobility Entity)와 HSS(Home Subscriber Server) 등을 더 포함하여 구성될 수도 있다.As described above, the core network 320 is a network system that performs a main function for a mobile communication service such as mobility control and switching between wired and wireless access networks 330, and includes circuit switching or packet switching. It manages and controls packet flow in mobile network. In addition, the core network 320 may manage inter-frequency mobility and may play a role for interworking with traffic in the access network 330 and the core network 320 and other networks, such as the Internet network 310. In addition to the above-described configuration, the core network 320 may further include a mobile switching center (MSC), a home location register (HLR), a mobile mobility entity (MME), a home subscriber server (HSS), and the like.
또한, 인터넷망(310)은 TCP/IP 프로토콜에 따라서 정보가 교환되는 통상의 공개된 통신망, 즉 공용망을 의미하는 것으로, 스트리밍 서버(200)와 연결되어, 스트리밍 서버(200)로부터 제공되는 컨텐츠를 코어망(320) 및 유무선 접속망(330)을 거쳐, 단말(100)로 제공하거나, 기 설정된 분산 정책에 따라 다수의 캐시 장치(350)로 제공할 수도 있다.In addition, the Internet network 310 refers to a conventional public communication network, that is, a public network, through which information is exchanged according to the TCP / IP protocol, and is connected to the streaming server 200 and provided from the streaming server 200. May be provided to the terminal 100 via the core network 320 and the wired / wireless access network 330, or may be provided to the plurality of cache devices 350 according to a predetermined distribution policy.
이상으로 본 발명의 네트워크(300) 구조에 대해 간략히 설명하였으며, 이러한 네트워크(300)는 캐시 장치(350)와 결합되어 하드웨어, 소프트웨어 등의 컴퓨팅 자원을 저장하고, 클라이언트가 필요로 하는 컴퓨팅 자원을 해당 단말기로 제공할 수 있는 클라우드 컴퓨팅망을 포함할 수 있다. 여기서, 클라우드 컴퓨팅이란 정보가 인터넷 상의 서버에 영구적으로 저장되고, 데스크톱, 태블릿 컴퓨터, 노트북, 넷북, 스마트폰 등의 클라이언트 단말기에는 일시적으로 보관되는 컴퓨터 환경을 의미하며, 클라우드 컴퓨팅은 이용자의 모든 정보를 인터넷 상의 서버에 저장하고, 이 정보를 각종 IT 기기를 통하여 언제 어디서든 이용할 수 있도록 하는 컴퓨터 환경 접속망을 의미한다. 이러한, 네트워크(300)는 LAN(Local Area Network), WAN(Wide Area Network) 등의 폐쇄형 네트워크, 인터넷(Internet)과 같은 개방형 네트워크뿐만 아니라, CDMA(Code Division Multiple Access), WCDMA(Wideband Code Division Multiple Access), GSM(Global System for Mobile Communications), 최근 주목 받고 있는 LTE(Long Term Evolution), EPC(Evolved Packet Core) 등의 네트워크와 향후 구현될 차세대 네트워크 및 클라우드 컴퓨팅 네트워크를 모두 포함하는 개념이다.As described above, the structure of the network 300 of the present invention has been briefly described. The network 300 is coupled to the cache device 350 to store computing resources such as hardware and software, and corresponds to the computing resources required by the client. It may include a cloud computing network that can be provided to the terminal. Here, cloud computing refers to a computer environment in which information is permanently stored on a server on the Internet and temporarily stored in client terminals such as desktops, tablet computers, laptops, netbooks, and smartphones. It refers to a computer environment access network that stores a server on the Internet and makes this information available anytime, anywhere through various IT devices. The network 300 may include a closed network such as a local area network (LAN), a wide area network (WAN), an open network such as the Internet, and code division multiple access (CDMA) and wideband code division (WCDMA). The concept includes both networks such as multiple access (GSM), global system for mobile communications (GSM), long term evolution (LTE), and evolved packet core (EPC), as well as next-generation and cloud computing networks.
또한, 본 발명의 실시 예에 따른 각 장치에 탑재되는 프로세서는 본 발명에 따른 방법을 실행하기 위한 프로그램 명령을 처리할 수 있다. 일 구현 예에서, 이 프로세서는 (Single-threaded) 프로세서일 수 있으며, 다른 구현 예에서 본 프로세서는 멀티 쓰레드(Multithreaded) 프로세서일 수 있다. 나아가 본 프로세서는 메모리 혹은 저장 장치 상에 저장된 명령을 처리하는 것이 가능하다.In addition, a processor mounted in each device according to an embodiment of the present invention may process a program command for executing a method according to the present invention. In one implementation, this processor may be a single-threaded processor, and in another implementation, the processor may be a multithreaded processor. Furthermore, the processor is capable of processing instructions stored on memory or storage devices.
이하, 본 발명의 실시 예에 따른 단말(100)의 구성 및 동작 방법에 대해 도 2를 참조하여 설명하도록 한다.Hereinafter, the configuration and operation method of the terminal 100 according to an embodiment of the present invention will be described with reference to FIG. 2.
도 2는 본 발명의 실시 예에 따른 단말의 주요 구성을 도시한 블록도이다.2 is a block diagram showing a main configuration of a terminal according to an embodiment of the present invention.
도 1 및 도 2를 참조하면, 본 발명의 실시 예에 따른 단말(100)은 통신부(110), 입력부(120), 제어부(130), 출력부(140) 및 저장부(150)를 포함하여 구성될 수 있다. 1 and 2, the terminal 100 according to an embodiment of the present invention includes a communication unit 110, an input unit 120, a control unit 130, an output unit 140, and a storage unit 150. Can be configured.
각 구성 요소에 대해 보다 구체적으로 설명하면, 먼저, 통신부(110)는 네트워크(300)을 통해 스트리밍 서버(200)와 정보를 송수신하는 역할을 수행한다. 이를 위해 본 발명의 통신부(110)는 네트워크(300)에 접속하는 절차를 수행할 수 있는데, 일정 반경 내 위치하는 기지국(미도시)을 탐색하고, 탐색된 기지국(미도시)의 접속 요청을 하여, 기지국(미도시)과 접속되는 과정을 지원함으로써 접속망(330)에 접속될 수 있다. 여기서, 단말(100)의 통신부(110)가 접속망(330)의 기지국(미도시)에 접속되는 과정은 공지된 다양한 구성을 채용할 수 있으므로, 구체적인 설명은 생략하도록 한다. 아울러, 통신부(110)가 기지국(미도시)과 통신 절차를 수행 시 사용자 정보를 전송할 수 있다. 기본적으로 IMSI(International Mobile Subscriber Identity) 등과 같은 단말 식별번호 등을 기지국(미도시)에 전송할 수 있으며, 기지국(미도시)이 코어망(320)과의 접속 절차를 수행하는 동안, 단말 식별번호 등을 이용하여 가입자 정보를 확인할 수 있게 된다. In more detail with respect to each component, first, the communication unit 110 performs a role of transmitting and receiving information with the streaming server 200 through the network (300). To this end, the communication unit 110 of the present invention may perform a procedure of accessing the network 300. The communication unit 110 searches for a base station (not shown) located within a predetermined radius and requests a connection of the discovered base station (not shown). By supporting the process of accessing the base station (not shown), the access network 330 may be connected. Here, the process of connecting the communication unit 110 of the terminal 100 to the base station (not shown) of the access network 330 may employ a variety of well-known configuration, a detailed description thereof will be omitted. In addition, the communication unit 110 may transmit user information when performing a communication procedure with a base station (not shown). Basically, a terminal identification number, such as an International Mobile Subscriber Identity (IMSI), may be transmitted to a base station (not shown), and while the base station (not shown) performs an access procedure with the core network 320, the terminal identification number, etc. By using the subscriber information can be confirmed.
아울러, 본 발명의 실시 예에 따른 통신부(110)은 접속망(330)의 기지국(미도시)을 통해 정상적으로 코어망(320)에 접속하게 되면, 컨텐츠를 요청하고 이를 수신할 수 있게 된다. In addition, when the communication unit 110 according to an embodiment of the present invention normally connects to the core network 320 through a base station (not shown) of the access network 330, the communication unit 110 may request and receive content.
입력부(120)는 사용자로부터 입력되는 숫자 및 문자 정보 등의 다양한 정보, 각종 기능 설정 및 단말(100)의 기능 제어와 관련하여 입력되는 신호를 제어부(130)로 전달한다. 특히, 본 발명의 입력부(120)는 스트리밍 서버(200)에 접속하기 위한 필요한 사용자 입력을 지원할 수 있다. The input unit 120 transmits a variety of information such as numeric and text information input from a user, a signal input in connection with various function settings and function control of the terminal 100, to the controller 130. In particular, the input unit 120 of the present invention may support a user input necessary for accessing the streaming server 200.
이러한 입력부(120)는 상술한 바와 같이, 키보드나 키패드와 같은 키 입력 수단, 터치센서나 터치 패드와 같은 터치 입력 수단, 음성 입력 수단, 자이로 센서, 지자기 센서, 가속도 센서와 근접 센서, 그리고 카메라 중 적어도 하나 이상을 포함하여 이루어지는 제스처 입력 수단을 포함할 수도 있다.As described above, the input unit 120 includes a key input means such as a keyboard or a keypad, a touch input means such as a touch sensor or a touch pad, a voice input means, a gyro sensor, a geomagnetic sensor, an acceleration sensor and a proximity sensor, and a camera. It may also include a gesture input means comprising at least one or more.
이 외에도 현재 개발 중이거나 향후 개발될 수 있는 모든 형태의 입력 수단이 포함될 수 있다.In addition, it may include all types of input means that are currently under development or may be developed in the future.
제어부(130)는 단말(100)의 전반적인 제어를 수행하는 것으로, 하드웨어적으로 CPU(Central Processing Unit)를 포함하는 적어도 하나 이상의 프로세서와 적어도 하나 이상의 메모리 로딩 데이터가 로딩되는 실행 메모리(예컨대, 레지스터 및/또는 RAM(Random Access Memory)) 및 상기 프로세서와 메모리로 적어도 하나 이상의 데이터들을 입출력하는 버스(BUS)를 포함하여 이루어질 수 있다. 또한 소프트웨어적으로 단말(100)에 정의된 기능을 수행하기 위해 소정의 기록매체로부터 상기 실행 메모리로 로딩되어 상기 프로세서에 의해 연산 처리되는 소정의 프로그램 루틴(Routine) 또는 프로그램 데이터를 포함하여 이루어질 수 있다. 다시 말해, 본 발명의 컨텐츠 전송 및 재생 처리를 지원하기 위해 단말(100)에 구비되는 기능 중 소프트웨어적으로 처리가 가능한 구성 요소를 제어부(130)의 기능으로 판단할 수 있다. The controller 130 performs overall control of the terminal 100, and includes at least one processor including a central processing unit (CPU) and an execution memory (eg, a register and at least one memory loading data) loaded in hardware. And / or a random access memory (RAM) and a bus that inputs and outputs at least one data into the processor and memory. In addition, it may include a predetermined program routine (Routine) or program data that is loaded into the execution memory from a predetermined recording medium to be performed by the processor to perform a function defined in the terminal 100 by software. . In other words, among the functions provided in the terminal 100 to support the content transmission and reproduction processing of the present invention, a component that can be processed by software may be determined as the function of the controller 130.
이러한, 본 발명의 제어부(130)는 본 발명의 실시 예에 따른 컨텐츠 전송 및 재생 처리를 위해 구비되는 적어도 하나 이상의 구성 요소와 기능적으로 연결된다. 즉, 제어부(130)는 통신부(110), 입력부(120), 저장부(140) 및 출력부(150)와 기능적으로 연결되며, 상기 각 구성 요소에 전원 공급 및 기능 수행을 위한 신호의 흐름을 제어하게 된다.As such, the controller 130 of the present invention is functionally connected to at least one component provided for content transmission and playback processing according to an embodiment of the present invention. That is, the controller 130 is functionally connected to the communication unit 110, the input unit 120, the storage unit 140, and the output unit 150, and controls the flow of signals for supplying power and performing functions to the components. Control.
특히, 본 발명의 실시 예에 따른 제어부(130)는 컨텐츠 재생 처리 모듈(131) 및 디코딩 모듈(132)을 포함하여 구성될 수 있다. In particular, the controller 130 according to an embodiment of the present invention may include a content reproduction processing module 131 and a decoding module 132.
컨텐츠 재생 처리 모듈(131)은 컨텐츠 요청 및 수신, 재생과 관련된 전반을 제어한다. 예컨대, 컨텐츠 재생 처리 모듈(131)은 재생 어플리케이션을 실행을 수행할 수 있다. 여기서 재생 어플리케이션은 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 기능을 수행한다. 예를 들어, 스트리밍 서버(200)가 제공하는 고화질의 컨텐츠를 재생할 수 있는 어플리케이션이 될 수 있다. 그러나 이에 한정되는 것은 아니며 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 것이라면 그 어떠한 어플리케이션(예컨대 브라우저)도 본 발명의 재생 어플리케이션이 될 수 있다. The content reproduction processing module 131 controls overall contents related to content request, reception, and reproduction. For example, the content reproduction processing module 131 may execute a reproduction application. Here, the playback application performs a function of playing back the content provided by the streaming server 200. For example, it may be an application capable of playing high quality content provided by the streaming server 200. However, the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
그리고 컨텐츠 재생 처리 모듈(131)은 메타데이터인 MPD 정보를 확인한다. 상기 MPD를 통해 본 발명의 컨텐츠 재생 처리 모듈(131)은 각 서브스트림별 주소 정보(URL)을 확인할 수 있으며, 해당 장치로 서브스트림을 요청하여 수신할 수 있다. 이때, 본 발명의 컨텐츠 재생 처리 모듈(131)은 각 서브스트림에 대한 서브인덱스 정보를 확인하고, 서브인덱스 정보가 동일할 경우 동시에 서브스트림을 요청하여 수신할 수 있다. 아울러, 본 발명의 서브스트림은 서로 다른 장소에 저장될 수 있는데, 예컨대 단말(100) 인근에 분산 배치된 캐시 장치(350)에 서브스트림이 저장될 수 있으며 스트리밍 서버(200) 또는 스트리밍 서버(200)와 연동 가능한 데이터베이스 서버에 분산되어 저장될 수 있다. The content reproduction processing module 131 checks the MPD information, which is metadata. Through the MPD, the content reproduction processing module 131 of the present invention may check address information (URL) for each substream, and may request and receive a substream from a corresponding device. In this case, the content reproduction processing module 131 of the present invention may check the sub-index information for each sub-stream, and simultaneously request and receive the sub-stream when the sub-index information is the same. In addition, the substreams of the present invention may be stored in different places, for example, the substreams may be stored in a cache device 350 distributed in the vicinity of the terminal 100 and the streaming server 200 or the streaming server 200 ) Can be distributed and stored in a database server that can interoperate with.
본 발명의 컨텐츠 재생 처리 모듈(131)은 동일 서브인덱스를 가진 서브스트림별로 컨텐츠를 동시 요청하고 동시 수신할 수 있으며, 수신된 서브스트림을 디코딩 모듈(132)로 전달하여 디코딩을 요청한다. The content reproduction processing module 131 of the present invention may simultaneously request and simultaneously receive content for each substream having the same subindex, and transmit the received substream to the decoding module 132 to request decoding.
본 발명의 디코딩 모듈(132)은 컨텐츠 재생 처리 모듈(131)로부터 전달되는 서브스트림을 디코딩을 수행하고 이에 대한 결과를 컨텐츠 재생 처리 모듈(131)로 전달하여 컨텐츠가 재생되도록 지원하게 된다. The decoding module 132 of the present invention decodes a substream delivered from the content reproduction processing module 131 and transmits the result thereof to the content reproduction processing module 131 to support the reproduction of the content.
저장부(140)는 본 발명의 실시 예에 따른 기능 동작에 필요한 응용 프로그램을 비롯하여, 그 응용 프로그램 실행 중에 발생되는 다양한 데이터를 일시적으로 저장할 수 있다. 특히, 본 발명의 실시 예에 따른 저장부(140)는 스트리밍 서버(200)가 제공하는 컨텐츠를 실행할 수 있는 재생 어플리케이션(151)과 관련된 정보를 저장하고 관리할 수 있으며, 수신되는 서브스트림을 저장하고 관리할 수 있다. The storage 140 may temporarily store various data generated during execution of the application program, including an application program required for operating a function according to an embodiment of the present invention. In particular, the storage 140 according to an embodiment of the present invention can store and manage information related to the playback application 151 that can execute the content provided by the streaming server 200, and store the received substream. And manage.
이러한 저장부(140)는 크게 프로그램 영역과 데이터 영역을 포함할 수 있다. 프로그램 영역은 단말(100)을 부팅시키는 운영체제(OS)와 같은 단말(100) 구동을 위한 관련된 정보들을 저장한다. 데이터 영역은 단말(100)의 사용에 따라 발생되는 데이터가 저장되는 영역으로, 상술한 바와 같이 재생 어플리케이션 및 네트워크(300)로부터 전달되는 서브스트림이 저장될 수 있다. 이러한, 저장부(140)는 플래시 메모리(flash memory), 하드디스크(hard disk), 멀티미디어 카드 마이크로(multimedia card micro) 타입의 메모리(예컨대, SD 또는 XD 메모리 등), 램(RAM), 롬(ROM) 등의 저장매체를 포함하여 구성될 수 있다.The storage 140 may largely include a program area and a data area. The program area stores related information for driving the terminal 100 such as an operating system (OS) for booting the terminal 100. The data area is an area in which data generated according to the use of the terminal 100 is stored, and as described above, a substream delivered from the reproduction application and the network 300 may be stored. The storage unit 140 may include a flash memory, a hard disk, a multimedia card micro type memory (eg, SD or XD memory, etc.), a RAM, a ROM, and the like. ROM) and a storage medium.
출력부(150)는 단말(100)의 기능 수행 중에 발생하는 일련의 동작 상태 및 동작 결과 등에 대한 정보를 표시한다. 특히, 본 발명의 출력부(150)는 재생 어플리케이션 실행과 관련된 다양한 정보를 표시할 수 있다. The output unit 150 displays information on a series of operation states and operation results that occur during the functioning of the terminal 100. In particular, the output unit 150 of the present invention may display various information related to the execution of the playback application.
이러한, 출력부(150)는 상술한 바와 같이 입력부(120)와 함께 하나의 터치패널(또는 터치스크린)의 형태로 구현될 수도 있으며, 상기 입력부(120)와 함께 구현되는 경우, 사용자의 터치 동작에 따라 발생되는 다양한 정보들을 표시할 수 있다.As described above, the output unit 150 may be implemented in the form of a single touch panel (or touch screen) together with the input unit 120, and when implemented together with the input unit 120, a user's touch operation. Various information generated according to the present invention can be displayed.
또한, 상술한 바와 같은 본 발명의 출력부(150)는 LCD(Liquid Crystal Display), TFT-LCD(Thin Film Transistor LCD), OLED(Organic Light Emitting Diodes), 발광다이오드(LED), AMOLED(Active Matrix Organic LED), 플렉시블 디스플레이(Flexible display) 및 3차원 디스플레이(3 Dimension) 등으로 구성될 수 있다. 또한 이들 중 일부 디스플레이는 그를 통해 외부를 볼 수 있도록 투명형 또는 광투과형으로 구성될 수 있다. 이는 TOLED(Transparant OLED)를 포함하는 투명 디스플레이 형태로 구성될 수 있다.In addition, the output unit 150 of the present invention as described above is a liquid crystal display (LCD), thin film transistor LCD (TFT-LCD), organic light emitting diodes (OLED), light emitting diodes (LED), AMOLED (Active Matrix) Organic LED), a flexible display (Flexible display) and a three-dimensional display (3 Dimension) and the like. Some of these displays may also be configured to be transparent or light transmissive so that they can be seen from the outside. It may be configured in the form of a transparent display including a transparent OLED (TOLED).
이와 같이, 도 2를 통해 단말(100)의 주요 구성요소에 대해 설명하였다. 그러나 도 2를 통해 도시된 구성요소가 모두 필수 구성요소인 것은 아니며, 도시된 구성요소보다 많은 구성 요소에 의해 단말(100)이 구현될 수도 있고, 그 보다 적은 구성요소에 의해 단말(100)이 구현될 수도 있다. 예컨대, 단말(100)은 전기적인 신호인 음원을 아날로그 신호로 변환하여 출력하는 음원 출력부(미도시)를 더 포함하여 구성될 수도 있다. As described above, main components of the terminal 100 have been described with reference to FIG. 2. However, not all components illustrated in FIG. 2 are essential components, and the terminal 100 may be implemented by more components than the illustrated components, and the terminal 100 may be implemented by fewer components. It may be implemented. For example, the terminal 100 may further include a sound source output unit (not shown) for converting a sound source, which is an electrical signal, into an analog signal and outputting the analog signal.
또한, 도 2를 통해 도시된 단말(100)의 주요 구성요소의 위치는 얼마든지 편의상 또는 다른 이유로 바뀔 수 있음이 물론이다. In addition, the position of the main components of the terminal 100 shown in FIG. 2 may be changed for convenience or other reasons.
또한, 본 발명의 실시 예에 따른 단말(100)의 구체적인 동작은 후술하는 흐름도를 통해 보다 명확하게 이해될 수 있을 것이다. In addition, the specific operation of the terminal 100 according to an embodiment of the present invention will be more clearly understood through the flowchart described below.
이하, 본 발명의 실시 예에 따른 스트리밍 서버(200)의 주요 구성 및 동작 방법에 대해 설명하도록 한다. Hereinafter, the main configuration and operation method of the streaming server 200 according to an embodiment of the present invention.
도 3은 본 발명의 실시 예에 따른 스트리밍 서버의 주요 구성을 도시한 블록도이며, 도 4는 본 발명의 실시 예에 따른 인코딩 모듈의 주요 구성을 도시한 블록도이다. 3 is a block diagram showing a main configuration of a streaming server according to an embodiment of the present invention, Figure 4 is a block diagram showing a main configuration of an encoding module according to an embodiment of the present invention.
먼저, 도 1 및 도 3을 참조하면, 본 발명의 실시 예에 따른 스트리밍 서버(200)는 서버 통신부(210), 서버 제어부(220) 및 서버 저장부(230)를 포함하여 구성될 수 있다.First, referring to FIGS. 1 and 3, the streaming server 200 according to an embodiment of the present invention may include a server communication unit 210, a server control unit 220, and a server storage unit 230.
각 구성 요소에 대해 보다 구체적으로 설명하면, 서버 통신부(210)는 통신망(300)을 통해 단말(100)과 필요한 정보를 송수신하는 역할을 수행한다. In more detail with respect to each component, the server communication unit 210 serves to transmit and receive the necessary information with the terminal 100 through the communication network (300).
서버 제어부(220)는 인코딩 모듈(221), MPD 생성 모듈(222) 및 서비스 지원 모듈(223)을 포함하여 구성된다. The server controller 220 includes an encoding module 221, an MPD generation module 222, and a service support module 223.
여기서, '모듈'은 각각 소정의 기능을 수행하는 구성 요소로서, 하드웨어, 소프트웨어, 혹은 하드웨어와 소프트웨어의 조합으로 구현될 수 있다. 예를 들어, 상기 '모듈'은 프로그램 모듈을 의미할 수 있으며, 이는 프로세서(Processor)에 의해 실행되어 소정의 기능을 수행하는, 소프트웨어 구성요소들, 객체지향 소프트웨어 구성요소들, 클래스 구성요소들 및 태스크 구성요소들과 같은 구성요소들과, 프로세스들, 함수들, 속성들, 프로시저들, 서브루틴들, 프로그램 코드의 세그먼트들, 드라이버들, 데이터, 데이터베이스, 데이터 구조들, 테이블들, 어레이들, 및 변수들을 포함한다. 또한, 구성요소들과 '모듈'들 안에서 제공되는 기능은 더 작은 수의 구성요소들 및 '~모듈'들로 결합되거나 추가적인 구성요소들과 '~모듈'들로 더 분리될 수 있다.Here, the 'module' is a component that performs a predetermined function, respectively, can be implemented in hardware, software, or a combination of hardware and software. For example, the 'module' may mean a program module, which is executed by a processor to perform a predetermined function, software components, object-oriented software components, class components and Components such as task components, processes, functions, properties, procedures, subroutines, segments of program code, drivers, data, databases, data structures, tables, arrays , And variables. In addition, the functionality provided in the components and 'modules' may be combined into a smaller number of components and '~ modules' or further separated into additional components and '~ modules'.
먼저, 인코딩 모듈(221)은 도 4에 도시된 바와 같이 계층화부(221a), 서브스트림 생성부(221b) 및 인덱스 관리부(221c)를 포함하여 구성될 수 있는데, 계층화부(221a)는 어느 하나의 컨텐츠를 기본 레이어(base layer) 및 향상 레이어(enhancement layer)으로 계층화하여 각 레이어에 대한 비트스트림을 생성할 수 있다. 서브스트림 생성부(221b)은 상기 계층화된 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성할 수 있다. First, the encoding module 221 may be configured to include a layering unit 221a, a substream generator 221b, and an index manager 221c, as shown in FIG. 4, wherein the layering unit 221a may be any one. The bitstream for each layer may be generated by layering the content of the layer into a base layer and an enhancement layer. The substream generator 221b may divide and generate the bitstreams of the layered layers into a predetermined number or more of substreams.
그리고 인덱스 관리부(221c)는 상기 생성된 각각의 서브스트림에 대응하여 인덱스를 부여할 수 있다. The index manager 221c may assign an index to each of the generated substreams.
MPD 생성 모듈(223)은 상기 인덱스에 대응한 메타데이터를 생성하며, 상기 컨텐츠를 요청한 단말로 전달되는 상기 서브스트림이 상기 단말 인근에 분산 배치된 어느 하나의 캐시 장치에 상기 컨텐츠의 서브스트림이 캐싱되는 경우, 상기 캐시 장치로부터 상기 캐싱 정보를 수신하고, 상기 수신된 캐싱 정보에 따라 상기 메타데이터를 수정하는 역할을 수행한다. The MPD generation module 223 generates metadata corresponding to the index, and the substream of the content is cached in any one cache device in which the substream delivered to the requesting terminal is distributed in the vicinity of the terminal. If so, it receives the caching information from the cache device, and serves to modify the metadata according to the received caching information.
서비스 지원 모듈(223)은 단말(100)의 요청에 따라 상기 단말(100)로 컨텐츠를 전송하기 위한 과정 전반을 제어할 수 있다. 예를 들어, 등록된 사용자를 대상으로 컨텐츠를 전송한다면 회원 가입 인증을 수행할 수 있다. 또한, 단말(100)로 메타데이터를 전달하는 역할을 수행하며, 복수 개의 캐시 장치(250) 또는 데이터베이스 서버에 저장된 서브스트림이 단말(100)로 원활히 전달되는 과정을 지원할 수 있다. The service support module 223 may control the overall process for transmitting content to the terminal 100 at the request of the terminal 100. For example, if content is transmitted to registered users, membership authentication may be performed. In addition, it plays a role of transmitting metadata to the terminal 100, and may support a process of smoothly transferring the substreams stored in the plurality of cache apparatuses 250 or the database server to the terminal 100.
서버 저장부(230)는 본 발명의 스트리밍 서버(200)의 동작 수행과 관련된 정보를 저장하는 것으로 특히, MPD 정보(231)을 저장하고 관리할 수 있다. The server storage unit 230 stores information related to performance of the streaming server 200 of the present invention, and in particular, may store and manage the MPD information 231.
또한, 도면에는 도시되지 않았으나, 본 발명의 스트리밍 서버(200)가 등록된 사용자를 대상으로 서비스를 제공하는 경우, 회원 가입 및 인증을 위한 인적 정보 등을 저장하고 관리할 수 있다. 또한 본 발명의 스트리밍 서버(2000 내 저장 장소에 서브스트림을 저장하고 관리할 경우, 해당 서브스트림을 포함할 수 있다. In addition, although not shown in the drawing, when the streaming server 200 of the present invention provides a service to a registered user, personal information for membership registration and authentication may be stored and managed. In addition, when storing and managing a substream in a storage location in the streaming server 2000 of the present invention, it may include the corresponding substream.
이러한 본 발명의 실시 예에 따른 스트리밍 서버(200)의 구체적인 동작은 후술하는 흐름도를 통해 보다 명확하게 이해될 수 있을 것이다. The specific operation of the streaming server 200 according to an embodiment of the present invention will be more clearly understood through the flow chart described below.
이하, 본 발명의 실시 예에 따른 컨텐츠 전송 방법에 대해 도 5 내지 도 8을 참조하여 설명하도록 한다. Hereinafter, a content transmission method according to an embodiment of the present invention will be described with reference to FIGS. 5 to 8.
도 5는 본 발명의 실시 예에 따른 컨텐츠 전송 방법을 설명하기 위한 흐름도이며, 도 6 내지 도 8은 본 발명의 실시 예에 따른 컨텐츠 전송 방법을 설명하기 위한 예시도이다.5 is a flowchart illustrating a content delivery method according to an embodiment of the present invention, and FIGS. 6 to 8 are exemplary diagrams for describing a content delivery method according to an embodiment of the present invention.
도 5를 참조하여 본 발명의 실시 예에 따른 컨텐츠 전송 방법을 설명하기에 앞서, 본 발명의 실시 예에 따른 스트리밍 서버(200)는 복수 개의 서버 형태의 집합인 것을 가정하여 설명하도록 한다. 이때, 복수 개의 서버 중 인코딩 모듈을 포함하여 인코딩 과정을 수행할 수 있는 서버를 본 발명의 스트리밍 서버(200)로 지칭하며, 나머지 서버는 분할된 서브스크림을 스트리밍 서버(200)의 제어에 따라 저장하는 데이터베이스 서버인 것을 가정하여 설명하도록 한다. 그러나 상기 구조에 한정되는 것은 아니며 스트리밍 서버(200)가 복수 개의 저장 장소를 포함하여 구현될 수도 있으며, 스트리밍 서버(200)가 직접 서브스크림을 저장할 수도 있다. Before describing a content transmission method according to an exemplary embodiment of the present disclosure with reference to FIG. 5, the streaming server 200 according to an exemplary embodiment of the present disclosure is assumed to be a set of a plurality of server types. In this case, a server capable of performing an encoding process including an encoding module among a plurality of servers is referred to as the streaming server 200 of the present invention, and the remaining servers store the divided sub-screens under the control of the streaming server 200. It is assumed that the database server is a server. However, the present invention is not limited to the above structure, and the streaming server 200 may include a plurality of storage locations, and the streaming server 200 may directly store the subscription.
이러한 본 발명의 실시 예에 따른 컨텐츠 전송 방법은 스트리밍 서버(200)가 저장 공간을 보다 효율적으로 활용하고 네트워크 트래픽을 최대한 활용하기 위해 인코딩하여 저장한 후 컨텐츠를 전송하게 되는 데, 상기 인코딩하여 저장 시 컨텐츠를 복수 개의 서브스트림 형태로 저장하는 과정을 수행할 수 있다. In the content transmission method according to an embodiment of the present invention, the streaming server 200 encodes and stores the content in order to use the storage space more efficiently and maximizes network traffic, and then transmits the content. The process of storing the content in the form of a plurality of substreams may be performed.
도 1 및 도 5를 참조하면, 본 발명의 스트리밍 서버(200)는 어느 하나의 컨텐츠를 스케일러블 인코딩을 수행한다. 스케일러블 인코딩이란 서로 다른 프레임 레이트의 레이어로 계층화하여 비트스트림을 생성하는 것을 의미한다. 본 발명의 일 실시 예에서는 스케일러블 인코딩 기술 중 하나인 SHVC(Scalable High efficiency Video Coding) 방식을 이용하는 것을 가정하여 설명하도록 하나 이에 한정되는 것은 아니며, 다양한 방식의 스케일러블 인코딩 기술을 이용할 수 있다. 1 and 5, the streaming server 200 of the present invention performs scalable encoding of any one content. Scalable encoding means generating a bitstream by layering layers at different frame rates. According to an embodiment of the present invention, it is assumed that the scalable high efficiency video coding (SHVC) scheme, which is one of scalable encoding techniques, is used. However, the present invention is not limited thereto and various scalable encoding techniques may be used.
본 발명의 스트리밍 서버(200)는 원래의 화상보다 낮은 프레임 레이트인 기본 레이어(base layer)와 상기 기본 레이어와 합성하여 원래의 화상이 얻어지는 향상 레이어(enhancement layer)로 계층화하여 비트스트림을 생성할 수 있다(S101). 여기서 본 발명의 실시 예에 따른 스트리밍 서버(200)는 상기 두 가지의 계층 이외의 프레임 레이트에 따라 다양한 레이어로 계층화할 수도 있다. 예를 들어, 기본 레이어는 1개이나 향상 레이어는 프레임 레이트별로 복수 개 생성될 수 있다. The streaming server 200 of the present invention may generate a bitstream by layering a base layer having a lower frame rate than the original picture and an enhancement layer obtained by combining the base layer with the base layer to obtain the original picture. (S101). Here, the streaming server 200 according to an embodiment of the present invention may layer into various layers according to frame rates other than the two layers. For example, one base layer may be generated, but a plurality of enhancement layers may be generated for each frame rate.
이후 스트리밍 서버(200)는 기본 레이어 비트스트림과 향상 레이어 비트스트림을 일정 개수의 서브스트림으로 분할하여 서브스트림을 생성하게 된다(S103). 이에 대해 도 6을 참조하여 부연 설명하면, 본 발명의 스트리밍 서버(200)의 인코딩 모듈은 원본 컨텐츠를 적어도 둘 이상의 레이어로 계층화하여 비트스트림을 생성하게 된다. 원본 컨텐츠를 기본 레이어 비트스트림과 향상 레이어 비트스트림으로 계층화하여 생성하는 방식이 일반적인 스케일러블 인코딩 기술이라면 본 발명의 스트리밍 서버(200)의 인코딩 모듈은 각각의 비트스트림을 가변 크기의 서브스트림으로 분할하여 생성한다는 점에 그 특징이 있다. Thereafter, the streaming server 200 divides the base layer bitstream and the enhancement layer bitstream into a predetermined number of substreams to generate a substream (S103). This will be described in detail with reference to FIG. 6. The encoding module of the streaming server 200 of the present invention generates a bitstream by layering original content into at least two layers. If the method of generating and layering original content into a base layer bitstream and an enhancement layer bitstream is a general scalable encoding technology, the encoding module of the streaming server 200 of the present invention divides each bitstream into substreams having a variable size. Its characteristics are that it produces.
아울러, 본 발명의 스트리밍 서버(200)는 네트워크 상태(단말과의 접속 상태, 평균 속도 및 지연량, 대역폭 가용성, 연결된 단말 수 등)를 확인하고, 확인된 네트워크 상태에 따라 서브스트림의 크기를 가변적으로 설정하여 수행할 수 있다. 또한, 어느 하나의 단말(100)이 컨텐츠를 요청한 상태이고, 상기 단말(100)에서 처리 가능한 디코딩 모듈의 성능 정보(가용 버퍼량 등)를 확인 가능한 상태라면, 상기 디코딩 모듈의 성능 정보를 고려하여 가변 크기의 서브스트림을 생성할 수 있다. In addition, the streaming server 200 of the present invention checks the network status (connection status with the terminal, average speed and delay amount, bandwidth availability, the number of connected terminals, etc.), and varies the size of the substream according to the confirmed network status Can be set to In addition, if any one of the terminal 100 has requested the content and the performance information (available buffer amount, etc.) of the decoding module that can be processed by the terminal 100 can be checked, the performance information of the decoding module is considered. A variable sized substream may be generated.
또한, 본 발명의 스트리밍 서버(200)는 저장 장소에 대한 정보에 따라 가변 크기의 서브스크림을 생성할 수 있다. 예를 들어 본 발명의 스트리밍 서버(200)가 A와 B의 스트리밍 서버로 구분되는 경우, 스트리밍 서버 A의 저장 장소가 4kb 단위로 처리 가능하며, 스트리밍 서버 B의 저장 장소가 8kb 단위로 처리 가능하다면, 인코딩을 수행하는 스트리밍 서버(200)는 상기 저장 장소의 처리 단위를 고려하여 서브스크림을 생성할 수 있게 된다. In addition, the streaming server 200 of the present invention may generate a variable sized subscription according to the information on the storage location. For example, when the streaming server 200 of the present invention is divided into streaming servers A and B, the storage location of the streaming server A can be processed in units of 4 kb, and the storage location of the streaming server B can be processed in units of 8 kb. The streaming server 200 that performs encoding may generate a subscription in consideration of the processing unit of the storage location.
이후에 스트리밍 서버(200)는 서브스트림 각각에 인덱스를 부여하게 된다(S105). 여기서 인덱스는 서브스트림을 구분하기 위한 것으로, 각 서브스트림을 구분하기 위한 식별 정보(ID)를 포함할 수 있다. 아울러, 본 발명의 서브스트림은 복수 개의 집합인 프래그먼트(fragment)로 그룹핑될 수 있는 데, 본 발명의 프래그먼트는 특정 기준 단위로 그룹핑되는 조건이 될 수 있다. 예컨대, 동영상 컨텐츠의 경우 장면(scence) 단위로 그룹화될 수 있으며, 해당 그룹은 프래그먼트 ID가 부여되어 서브스트림은 동일 프래그먼트 임을 인지할 수 있도록 인덱스가 설정될 수 있다. 또한, 본 발명의 인덱스는 저장 장소에 대한 식별 정보를 포함할 수 있다. 즉 제1 서브스트림은 제1 스트리밍 서버에 저장될 수 있으며, 제2 서브스트림은 제3 스트리밍 서버에 저장될 수 있는 데, 추후 단말(100)이 해당 저장 장소에서 서브스트림을 수신하여 이용할 수 있도록 본 발명의 인덱스는 저장 장소에 대한 식별 정보를 포함하여 구성될 수 있다. Thereafter, the streaming server 200 assigns an index to each substream (S105). In this case, the index is used to identify the substreams and may include identification information (ID) for identifying each substream. In addition, the substreams of the present invention can be grouped into a plurality of fragments (fragments), the fragments of the present invention may be a condition that is grouped by a specific reference unit. For example, the video content may be grouped in units of scenes, and a corresponding group may be assigned a fragment ID, and an index may be set to recognize that the substream is the same fragment. In addition, the index of the present invention may include identification information on a storage location. That is, the first substream may be stored in the first streaming server, and the second substream may be stored in the third streaming server, so that the terminal 100 may receive and use the substream at a corresponding storage location later. The index of the present invention may be configured to include identification information about a storage location.
도 7은 본 발명의 실시 예에 따른 서브스트림별로 인덱스가 부여된 것을 예시한 것으로, 기본 레이어 비트스트림은 19개 이상의 서브스트림으로 분할되고, 각 서브스트림은 서브스트림 식별을 위한 식별 정보와 서브스트림 그룹인 프래그먼트 구별을 위해 사용되는 서브인덱스(subIndex)와 저장 장소에 대한 식별 정보(d)에 대한 인덱스 정보를 부여 받을 수 있으며, 각 서브스트림은 상기 인덱스 정보를 기초로 URL을 부여받을 수 있게 된다. 7 illustrates that an index is assigned for each substream according to an embodiment of the present invention. The base layer bitstream is divided into 19 or more substreams, and each substream is identification information and a substream for substream identification. Sub-indexes used to distinguish fragments, which are groups, and index information of identification information (d) of a storage location may be provided, and each substream may be given a URL based on the index information. .
이후, 스트리밍 서버(200)는 각각의 서브스트림을 저장하게 된다(S107). 이때, 본 발명의 스트리밍 서버(200)는 전술한 바와 같이 어느 하나의 비트스트림에서 분할된 서브스트림 각각을 서로 다른 저장 장소에 저장할 수 있다. 예를 들어, 비트스트림에서 분할된 서브스트림이 A1, A2, A3, A4, A5, A6, A7, A8, A9, A10의 10개가 존재하는 경우, A1, A3, A5는 제1 스트리밍 서버, A2, A4, A6, A10은 제2 스트리밍 서버, A7, A8, A9는 제3 스트리밍 서버에 저장될 수 있다. Thereafter, the streaming server 200 stores each substream (S107). At this time, the streaming server 200 of the present invention may store each substream divided in any one bitstream in different storage locations. For example, when there are ten sub streams A1, A2, A3, A4, A5, A6, A7, A8, A9, and A10 divided in the bitstream, A1, A3, and A5 represent the first streaming server, A2. , A4, A6 and A10 may be stored in the second streaming server, and A7, A8 and A9 may be stored in the third streaming server.
또한, 본 발명의 스트리밍 서버(200)는 각각의 서브스트림의 저장 장소가 변경되거나 수정이 필요한 경우, S105 단계에서 부여된 인덱스의 저장 장소 식별 정보를 수정할 수도 있다.In addition, the streaming server 200 of the present invention may modify the storage location identification information of the index given in step S105 when the storage location of each substream is changed or needs to be modified.
또한, 본 발명의 스트리밍 서버(200)는 단말(100) 인근에 분산 배치되는 복수 개의 캐시 장치(350)와 연동할 수 있으며, 단말(100)로 서브스트림을 전달하는 과정에서 어느 하나의 캐시 장치(350)에 해당 서브스트림이 캐싱되어 이를 캐시 장치(350)로부터 전달받게 되면, 스트리밍 서버(200)는 이후 해당 캐시 장치(350)가 서브스트림을 제공하도록 메타데이터 정보를 수정하게 된다. 이와 같이 본 발명에 따르면, 캐시 장치(350)는 고용량의 컨텐츠 전부를 캐싱하는 것이 아니라 컨텐츠의 일부 만을 캐싱하고 이를 스트리밍 서버(200)로 통지하면, 스트리밍 서버(200)는 이에 따라 메타데이터를 수정한 후 단말(100)로 배포하는 과정을 거침으로써 CDN 서비스 적용이 보다 용이하게 된다. In addition, the streaming server 200 of the present invention may interwork with a plurality of cache devices 350 distributed in the vicinity of the terminal 100, and any one of the cache devices in the process of transmitting a substream to the terminal 100. When the substream is cached at 350 and received from the cache device 350, the streaming server 200 may modify metadata information so that the cache device 350 provides the substream. As described above, when the cache device 350 caches only a part of the content and notifies the streaming server 200 instead of caching all of the high-capacity content, the streaming server 200 modifies the metadata accordingly. Afterwards, the CDN service is more easily applied to the terminal 100 through the distribution process.
아울러, 본 발명의 스트리밍 서버(200)는 각각의 서브스트림에 대응하여 생성된 인덱스에 대한 메타데이터를 생성하게 된다(S109). 본 발명의 메타데이터는 컨텐츠의 미디어 정보(MPD; Media Presentation description)를 의미한다. 여기서 MPD는 미디어 프리젠테이션의 양식화된 설명(description)을 의미하는 것으로, 본 발명의 MPD는 MPEG의 동적 및 적응적 HTTP 스트리밍(DASH; Dynamic and Adaptive HTTP Streaming of MEPG)의 MPD일 수 있다. In addition, the streaming server 200 of the present invention will generate the metadata for the index generated corresponding to each substream (S109). The metadata of the present invention means media presentation description (MPD) of content. Here, MPD means a stylized description of a media presentation, and the MPD of the present invention may be MPD of Dynamic and Adaptive HTTP Streaming of MEPG of MPEG.
아울러, 본 발명의 실시 예에 따른 스트리밍 서버(200)는 어느 하나의 컨텐츠에 대응하여 복수 개의 메타데이터를 생성할 수도 있다. 즉, 단말(100)의 성능을 고려하여 복수 개의 메타데이터를 생성하게 되는 데, 전술한 바와 같이 본 발명의 스트리밍 서버(200)는 컨텐츠를 복수 개의 레이어로 계층화하여 비트스트림을 생성할 수 있는데, 단말(100)의 사양이 고사양일 경우 고화질의 원본 컨텐츠를 모두 재생할 수 있으므로, 이때의 메타데이터는 상기 원본 컨텐츠를 구성하는 모든 레이어에 대한 정보를 포함할 수 있다. 반면, 단말(100)의 사양이 저사양일 경우, 고화질의 원본 컨텐츠의 재생이 불가능할 수 있으므로, 기본 레이어에 대한 정보만을 포함하여 메타데이터를 구성하여 이를 수신한 단말(100)이 기본 레이어만 수신하여 재생할 수 있도록 처리할 수 있게 된다. In addition, the streaming server 200 according to an embodiment of the present invention may generate a plurality of metadata corresponding to any one content. That is, a plurality of metadata is generated in consideration of the performance of the terminal 100. As described above, the streaming server 200 of the present invention may generate a bitstream by layering content into a plurality of layers. When the specification of the terminal 100 is a high specification, all of the original content of high quality may be reproduced. In this case, the metadata may include information about all layers constituting the original content. On the other hand, if the specification of the terminal 100 is low, it may not be possible to reproduce the original content of high quality, so that the terminal 100 receives the base layer only by configuring the metadata including only the information on the base layer Can be processed to play.
본 발명의 메타데이터의 일 예시가 도 8에 도시되어 있다. One example of the metadata of the present invention is shown in FIG.
도 8에서 도시하고 있는 것은 MPD의 형식을 따라는 메타데이터의 일 예시로, MPD는 전술한 바와 같이 단말(100)에 전달하고자 하는 미디어의 레프리젠테이션(representation)(또는, 표현)의 설명(description)을 포함할 수 있다. 즉, MPD는 단말(100)이 접근할 수 있는 비디오, 오디오 및 언어 등의 조합들을 설명하고 있다. 8 illustrates an example of metadata along the format of the MPD. The MPD is a description of a representation (or representation) of media to be delivered to the terminal 100 as described above. description). That is, the MPD describes combinations of video, audio, and language that the terminal 100 can access.
이러한 MPD의 구조에 대해 개략적으로 설명하면, MPD는 세그먼트(segment)를 위한 자원 식별자들을 알리기 위한 포맷을 정의할 수 있다. MPD는 미디어 프리젠테이션 내에서의 식별된 자원들에 대한 컨텍스트(context)를 제공할 수 있으며 이때의 자원 식별자들은 HTTP-URL이며, 바이트 범위(byte range) 속성에 의해 제한될 수 있다.Briefly describing the structure of the MPD, the MPD may define a format for indicating resource identifiers for a segment. The MPD may provide a context for the identified resources in the media presentation, where the resource identifiers are HTTP-URLs and may be limited by the byte range attribute.
각 주기(period)는 프래그먼트(fragment)들로 나뉘어지며, 여기서 프래그먼트는 세그먼트(segment)는 동일한 의미로 사용될 수 있다. 세그먼트는 3GPP(Generation Partnership Project) 적응적 HTTP 스트리밍의 용어이다. Each period is divided into fragments, where fragments may be used in the same sense. Segment is a term for Generation Partnership Project (3GPP) adaptive HTTP streaming.
프래그먼트(세그먼트)는 예컨대 RFC 2616에서 정의된, HTTP-URL에 대한 HTTP/1.1 GET 요청(또는, 바이트 범위(range)에 의해 가리켜진(indicated) 일부에 대한 GET 요청)에 대한 응답(response)의 객체(entity) 바디(body)를 의미하며, 부(sub)-세그먼트는 세그먼트 레벨에서의 세그먼트 인덱스(index)에 의해 인덱스될 수 있는 세그먼트들 내의 가장 작은(smallest) 유닛(unit)을 의미할 수 있다.A fragment (segment) is a part of a response to an HTTP / 1.1 GET request for an HTTP-URL (or a GET request for a portion indicated by a byte range), as defined in RFC 2616, for example. Refers to an entity body, and a sub-segment may refer to the smallest unit in segments that can be indexed by the segment index at the segment level. have.
또한 하나의 주기(period)는 두 개 이상의 프래그먼트 집합을 포함할 수 있으며, 프래그먼트의 집합들 각각을 리프리젠테이션(Representation)으로 지칭할 수 있다. 아울러 상기 리프리젠테이션(representation)은 대안(alternative)으로 지칭될 수도 있다. In addition, one period may include two or more fragment sets, and each of the sets of fragments may be referred to as a representation. In addition, the representation may be referred to as an alternative.
리프리젠테이션은 하나의 주기 내의 하나 이상의 미디어 컴포넌트들의 구조화된(structured) 컬렉션이다. 리프리젠테이션은, 비트레이트(bitrate), 해상도(resolution), 언어(language) 및 코덱(codec) 등과 같은 인코딩(encoding) 선택(choice)이 상이한, 미디어 콘텐츠 또는 미디어 콘텐츠의 부분집합의 대안적인(alternative) 선택(choice)들 중 하나일 수 있다. 즉, 리프리젠테이션은 미디어를 구성할 수 있는 비디오, 오디오 및 언어 등의 조합을 나타낼 수 있다.Representation is a structured collection of one or more media components within one period. Representation is an alternative to media content or a subset of media content, with different encoding choices, such as bitrate, resolution, language, codec, and the like. alternative) may be one of the choices. That is, the representation may represent a combination of video, audio, language, and the like that may constitute media.
MPD(또는, MPD 요소)는 단말(100)이 하나 이상의 리프리젠테이션을 선택하는 것을 가능하게 하는 설명적인 정보를 제공하는 것으로, 다시 말해, 세그먼트들을 접근하고, 사용자에게 스트리밍 서비스를 제공하기 위해 적합한(appropriate) HTTP-URL들을 구성하기 위해 DASH 클라이언트에게 요구되는 메타데이터를 포함하는 문서이다. HTTP-URL들은 절대적이거나 상대적일 수 있다. 이러한 MPD는 XML-문서 형태로 구현될 수 있으며, MPD는 상술한 바와 같은 다양한 MPD 요소(element)를 포함할 수 있으며, 반면에 어느 하나의 MPD 요소만을 포함할 수도 있다. The MPD (or MPD element) provides descriptive information that enables the terminal 100 to select one or more representations, in other words suitable for accessing segments and providing streaming services to the user. (appropriate) A document containing metadata required by the DASH client to construct HTTP-URLs. HTTP-URLs can be absolute or relative. Such an MPD may be implemented in the form of an XML-document, and the MPD may include various MPD elements as described above, but may include only one MPD element.
특히, 본 발명의 MPD는 상술한 요소 중 세그먼트 주소 정보, 서브인덱스 식별 정보 및 정수 타입의 저장 장소의 식별 정보를 반드시 포함하고 있어야 한다. In particular, the MPD of the present invention must include segment address information, subindex identification information, and integer type storage location identification information among the above-described elements.
이러한 메타데이터 생성이 완료되면, 본 발명의 스트리밍 서버(200)는 해당 단말(100)로 메타데이터를 전송하게 된다(S111). 이때, 전술한 바와 같이 단말(100)의 사양에 따라 적합한 메타데이터를 선택하여 단말(100)로 전송할 수 있다. When the metadata generation is completed, the streaming server 200 of the present invention transmits the metadata to the corresponding terminal 100 (S111). In this case, as described above, suitable metadata may be selected and transmitted to the terminal 100 according to the specification of the terminal 100.
그리고, 본 발명의 스트리밍 서버(200)는 상기 단말(100)의 요청에 따라 서브스트림을 상기 단말(100)로 전송할 수 있게 된다. In addition, the streaming server 200 of the present invention may transmit a substream to the terminal 100 according to the request of the terminal 100.
이때, 본 발명의 스트리밍 서버(200)는 인코딩을 수행하는 스트리밍 서버와 서브스트림을 저장하는 데이터베이스 서버로 구현되는 경우, 인코딩을 수행하는 스트리밍 서버가 서브스트림을 저장하고 있는 데이터베이스 서버에 상기 단말(100)의 요청을 전달하여 해당 데이터베이스 서버에서 직접 단말(100)로 서브스트림이 전달될 수 있다. In this case, when the streaming server 200 of the present invention is implemented as a streaming server for encoding and a database server for storing a substream, the terminal 100 is stored in a database server in which the streaming server for encoding stores a substream. The substream may be delivered to the terminal 100 directly from the corresponding database server by transmitting a request of the ().
또한, 스트리밍 서버(200)에서 해당 단말(100)로 서브스트림이 전달되는 과정에 위치하고 있는 캐시 장치(350)는 상기 서브스트림을 캐싱하여 저장하고 이를 스트리밍 서버(200)로 전달할 수 있다. 이를 보고 받은 스트리밍 서버(200)는 상기 컨텐츠의 메타데이터를 수정 및 편집할 수 있으며, 추후 다른 단말(100)이 해당 컨텐츠를 요청한 경우, 캐시 장치(350)에서 전달받도록 관리할 수 있게 된다. In addition, the cache device 350 located in the process of transmitting the substream from the streaming server 200 to the corresponding terminal 100 may cache and store the substream and transmit the same to the streaming server 200. The streaming server 200 that has received this report may modify and edit the metadata of the content, and when another terminal 100 requests the corresponding content, the streaming server 200 may manage to receive the content from the cache device 350.
이하, 본 발명의 실시 예에 따른 단말(100)에서의 동작에 대해 설명하도록 한다. Hereinafter, an operation of the terminal 100 according to an exemplary embodiment of the present invention will be described.
도 9는 본 발명의 실시 예에 따른 단말에서의 컨텐츠 재생 방법을 설명하기 위한 흐름도이다. 9 is a flowchart illustrating a content reproduction method in a terminal according to an embodiment of the present invention.
도 1 및 도 9를 참조하면, 본 발명의 실시 예에 따른 단말(100)은 구비된 재생 어플리케이션을 실행한다(S201). 여기서 재생 어플리케이션은 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 기능을 수행한다. 예를 들어, 스트리밍 서버(200)가 제공하는 고화질의 컨텐츠를 재생할 수 있는 어플리케이션이 될 수 있다. 그러나 이에 한정되는 것은 아니며 스트리밍 서버(200)가 제공하는 컨텐츠를 재생할 수 있는 것이라면 그 어떠한 어플리케이션(예컨대 브라우저)도 본 발명의 재생 어플리케이션이 될 수 있다. 1 and 9, the terminal 100 according to an embodiment of the present invention executes the playback application provided (S201). Here, the playback application performs a function of playing back the content provided by the streaming server 200. For example, it may be an application capable of playing high quality content provided by the streaming server 200. However, the present invention is not limited thereto, and any application (for example, a browser) may be a playback application of the present invention as long as the streaming server 200 can play content provided by the streaming server 200.
아울러, 본 발명의 재생 어플리케이션은 미리 스트리밍 서버(200) 또는 별도의 컨텐츠 스토어로부터 미리 다운로드 받아 단말(100) 내 설치된 상태인 것이 바람직하나 이에 한정되는 것은 아니며, 클라우드 방식으로 상기 재생 어플리케이션을 실행할 수도 있다. In addition, the playback application of the present invention is preferably downloaded in advance from the streaming server 200 or a separate content store is installed in the terminal 100, but is not limited thereto, and may execute the playback application in a cloud manner. .
이후에 본 발명의 단말(100)은 메타데이터 파일인 MPD를 확인한다(S203). 상기 MPD를 통해 본 발명의 단말(100)은 각 서브스트림별 주소 정보(URL)을 확인할 수 있으며, 해당 장치로 서브스트림을 요청하여 수신할 수 있다(S205 ~ S207). 이때, 본 발명의 단말(100)은 각 서브스트림에 대한 서브인덱스 정보를 확인하고, 서브인덱스 정보가 동일할 경우 동시에 서브스트림을 요청하여 수신할 수 있다. 아울러, 본 발명의 서브스트림은 서로 다른 장소에 저장될 수 있는데, 예컨대 단말(100) 인근에 분산 배치된 캐시 장치(350)에 서브스트림이 저장될 수 있으며 스트리밍 서버(200) 또는 스트리밍 서버(200)와 연동 가능한 데이터베이스 서버에 분산되어 저장될 수 있다. Thereafter, the terminal 100 of the present invention checks the MPD which is the metadata file (S203). Through the MPD, the terminal 100 of the present invention may check address information (URL) for each substream, and may request and receive a substream from a corresponding device (S205 to S207). At this time, the terminal 100 of the present invention may check the sub-index information for each sub-stream, and if the sub-index information is the same, it can request and receive the sub-stream at the same time. In addition, the substreams of the present invention may be stored in different places, for example, the substreams may be stored in a cache device 350 distributed in the vicinity of the terminal 100 and the streaming server 200 or the streaming server 200 ) Can be distributed and stored in a database server that can interoperate with.
본 발명의 단말(100)은 동일 서브인덱스를 가진 서브스트림별로 컨텐츠를 동시 요청하고 동시 수신할 수 있으며(S205 ~ S207), 수신된 서브스트림을 디코딩하여 프래그먼트 단위로 재생할 수 있게 된다(S209).The terminal 100 of the present invention may simultaneously request and simultaneously receive content for each substream having the same subindex (S205 to S207), and decode the received substream to be reproduced in units of fragments (S209).
아울러, 본 발명의 단말(100)은 컨텐츠의 메타데이터를 이용하여 선택적으로 컨텐츠 서브스트림을 요청할 수도 있다. 예를 들어 단말(100)의 상태 또는 네트워크 상태가 불안정한 경우, 단말(100)은 컨텐츠의 메타데이터를 확인하여 고용량의 컨텐츠라 하더라도 저용량의 컨텐츠만 수신되어 재생되도록 선택적으로 컨텐츠 스트림을 요청하게 된다. In addition, the terminal 100 of the present invention may selectively request a content substream using metadata of the content. For example, when the state of the terminal 100 or the network state is unstable, the terminal 100 checks the metadata of the content and selectively requests the content stream so that only the low-capacity content is received and reproduced even if the content is high-capacity.
이상으로 본 발명의 실시 예에 따른 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법에 대해 설명하였다. In the above, a content transmission method supporting scalable encoding according to an embodiment of the present invention has been described.
상술한 바와 같은 본 발명의 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법은 어느 하나의 컨텐츠에서 계층화된 기본 레이어(base layer) 및 향상 레이어(enhancement layer)의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성하는 단계, 상기 생성된 각각의 서브스트림에 대응하여 인덱스를 부여하고 저장하는 단계 및 상기 인덱스에 대한 메타데이터를 생성한 후 상기 컨텐츠를 요청한 단말로 상기 메타데이터를 전송하고, 상기 단말의 요청에 따라 상기 컨텐츠의 서브스트림을 상기 단말로 전송하는 단계 등을 실행할 수 있다. The content transmission method supporting scalable encoding of the present invention as described above is generated by dividing a bitstream of a base layer and an enhancement layer layered in any one content into a predetermined number or more of substreams. And assigning and storing an index corresponding to each of the generated substreams, generating metadata for the index, and transmitting the metadata to the terminal that requested the content, and at the request of the terminal. And transmitting the substream of the content to the terminal.
이러한, 컴퓨터 프로그램 명령어와 데이터를 저장하기에 적합한 컴퓨터로 판독 가능한 매체는, 예컨대 기록매체는 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체(Magnetic Media), CD-ROM(Compact Disk Read Only Memory), DVD(Digital Video Disk)와 같은 광 기록 매체(Optical Media), 플롭티컬 디스크(Floptical Disk)와 같은 자기-광 매체(Magneto-Optical Media), 및 롬(ROM, Read Only Memory), 램(RAM, Random Access Memory), 플래시 메모리, EPROM(Erasable Programmable ROM), EEPROM(Electrically Erasable Programmable ROM)과 같은 반도체 메모리를 포함한다. 프로세서와 메모리는 특수 목적의 논리 회로에 의해 보충되거나, 그것에 통합될 수 있다. Such computer-readable media suitable for storing computer program instructions and data include, for example, recording media comprising magnetic media, such as hard disks, floppy disks, and magnetic tape, and compact disk read only memory (CD-ROM). , Optical media such as Digital Video Disk (DVD), magneto-optical media such as Floppy Disk, and ROM (Read Only Memory), RAM And a semiconductor memory such as a random access memory, a flash memory, an erasable programmable ROM (EPROM), and an electrically erasable programmable ROM (EEPROM). The processor and memory can be supplemented by or integrated with special purpose logic circuitry.
또한 컴퓨터가 읽을 수 있는 기록매체는 네트워크로 연결된 컴퓨터 시스템에 분산되어, 분산방식으로 컴퓨터가 읽을 수 있는 코드가 저장되고 실행될 수 있다. 그리고, 본 발명을 구현하기 위한 기능적인(Functional) 프로그램과 이와 관련된 코드 및 코드 세그먼트 등은, 기록매체를 읽어서 프로그램을 실행시키는 컴퓨터의 시스템 환경 등을 고려하여, 본 발명이 속하는 기술분야의 프로그래머들에 의해 용이하게 추론되거나 변경될 수도 있다.The computer readable recording medium can also be distributed over network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion. In addition, a functional program for implementing the present invention, codes and code segments associated therewith may be used in consideration of a system environment of a computer that reads a recording medium and executes the program. It may be easily inferred or changed by.
아울러, 상술한 바와 같은 컴퓨터가 읽을 수 있는 기록매체에 기록된 컴퓨터 프로그램은 상술한 바와 같은 기능을 수행하는 명령어를 포함하며 기록매체를 통해 배포되고 유통되어 특정 장치, 특정 컴퓨터에 읽히어 설치되고 실행됨으로써 전술한 기능들을 실행할 수 있다. In addition, the computer program recorded on the computer-readable recording medium as described above includes instructions for performing the functions as described above, distributed and distributed through the recording medium to be read and installed on a specific device, a specific computer, and executed. Thus, the above functions can be executed.
여기서, 컴퓨터가 기록매체에 기록된 프로그램을 읽어 들여 프로그램으로 구현된 기능들을 실행시키기 위하여, 전술한 컴퓨터 프로그램은 컴퓨터의 프로세서(CPU)가 컴퓨터의 장치 인터페이스(Interface)를 통해 읽힐 수 있는 C, C++, JAVA, 기계어 등의 컴퓨터 언어로 코드화된 프로그램 명령어에 대한 코드(Code)를 포함할 수 있다. Here, in order for a computer to read a program recorded on a recording medium and execute functions implemented as a program, the above-described computer program is a C, C ++ that can be read by the computer's processor (CPU) through the computer's device interface (Interface) Code for a program instruction coded in a computer language such as JAVA, machine language, or the like may be included.
이러한 코드는 전술한 기능들을 정의한 함수 등과 관련된 기능적인 코드(Function Code)를 포함할 수 있고, 전술한 기능들을 컴퓨터의 프로세서가 소정의 절차대로 실행시키는데 필요한 실행 절차 관련 제어 코드를 포함할 수도 있다. 또한, 이러한 코드는 전술한 기능들을 컴퓨터의 프로세서가 실행시키는데 필요한 추가 정보나 미디어가 컴퓨터의 내부 또는 외부 메모리의 어느 위치(주소 번지)에서 참조 되어야 하는지에 대한 메모리 참조 관련 코드를 더 포함할 수 있다. 또한, 컴퓨터의 프로세서가 전술한 기능들을 실행시키기 위하여 원격(Remote)에 있는 어떠한 다른 컴퓨터나 서버 등과 통신이 필요한 경우, 코드는 컴퓨터의 프로세서가 컴퓨터의 통신 모듈을 이용하여 원격(Remote)에 있는 어떠한 다른 컴퓨터나 서버 등과 어떻게 통신해야만 하는지, 통신 시 어떠한 정보나 미디어를 송수신해야 하는지 등에 대한 통신 관련 코드를 더 포함할 수도 있다.Such code may include a function code associated with a function or the like that defines the above-described functions, and may include execution procedure-related control code necessary for a processor of the computer to execute the above-described functions according to a predetermined procedure. In addition, the code may further include memory reference-related code for additional information or media required for a processor of the computer to execute the above-described functions at which location (address address) of the computer's internal or external memory. . In addition, if the processor of the computer needs to communicate with any other computer or server on the remote in order to execute the above functions, the code may be used to determine which computer the processor of the computer uses the communication module of the computer on the remote. It may further include communication-related codes such as how to communicate with other computers or servers, and what information or media should be transmitted and received during communication.
본 명세서는 다수의 특정한 구현물의 세부사항들을 포함하지만, 이들은 어떠한 발명이나 청구 가능한 것의 범위에 대해서도 제한적인 것으로서 이해되어서는 안되며, 오히려 특정한 발명의 특정한 실시형태에 특유할 수 있는 특징들에 대한 설명으로서 이해되어야 한다. 개별적인 실시형태의 문맥에서 본 명세서에 기술된 특정한 특징들은 단일 실시형태에서 조합하여 구현될 수도 있다. 반대로, 단일 실시형태의 문맥에서 기술한 다양한 특징들 역시 개별적으로 혹은 어떠한 적절한 하위 조합으로도 복수의 실시형태에서 구현 가능하다. 나아가, 특징들이 특정한 조합으로 동작하고 초기에 그와 같이 청구된 바와 같이 묘사될 수 있지만, 청구된 조합으로부터의 하나 이상의 특징들은 일부 경우에 그 조합으로부터 배제될 수 있으며, 그 청구된 조합은 하위 조합이나 하위 조합의 변형물로 변경될 수 있다.Although the specification includes numerous specific implementation details, these should not be construed as limiting to any invention or the scope of the claims, but rather as a description of features that may be specific to a particular embodiment of a particular invention. It must be understood. Certain features that are described in this specification in the context of separate embodiments may be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments individually or in any suitable subcombination. Furthermore, while the features may operate in a particular combination and may be initially depicted as so claimed, one or more features from the claimed combination may in some cases be excluded from the combination, the claimed combination being a subcombination Or a combination of subcombinations.
마찬가지로, 특정한 순서로 도면에서 동작들을 묘사하고 있지만, 이는 바람직한 결과를 얻기 위하여 도시된 그 특정한 순서나 순차적인 순서대로 그러한 동작들을 수행하여야 한다거나 모든 도시된 동작들이 수행되어야 하는 것으로 이해되어서는 안 된다. 특정한 경우, 멀티태스킹과 병렬 프로세싱이 유리할 수 있다. 또한, 상술한 실시형태의 다양한 시스템 컴포넌트의 분리는 그러한 분리를 모든 실시형태에서 요구하는 것으로 이해되어서는 안되며, 설명한 프로그램 컴포넌트와 시스템들은 일반적으로 단일의 소프트웨어 제품으로 함께 통합되거나 다중 소프트웨어 제품에 패키징 될 수 있다는 점을 이해하여야 한다.Likewise, although the operations are depicted in the drawings in a specific order, it should not be understood that such operations must be performed in the specific order or sequential order shown in order to obtain desirable results or that all illustrated operations must be performed. In certain cases, multitasking and parallel processing may be advantageous. Moreover, the separation of the various system components of the above-described embodiments should not be understood as requiring such separation in all embodiments, and the described program components and systems will generally be integrated together into a single software product or packaged into multiple software products. It should be understood that it can.
본 발명은 컨텐츠 전송 방법에 관한 것으로, 더욱 상세하게는 스케일러블 인코딩 방식으로 컨텐츠를 인코딩 시, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 각 서브스트림에 대한 인덱스를 부여한 후 상기 인덱스에 대한 메타데이터를 정의하여 컨텐츠 전송에 활용할 수 있는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법 및 이를 위한 스트리밍 서버에 관한 것이다. The present invention relates to a content transmission method, and more particularly, when encoding content in a scalable encoding method, by dividing a bitstream of each layer into a predetermined number or more of substreams and assigning an index to each substream. The present invention relates to a content transmission method that supports scalable encoding that can be used for content transmission by defining metadata for the content transmission, and a streaming server therefor.
본 발명에 의하면, 스케일러블 인코딩 방식으로 컨텐츠를 인코딩 시, 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 각 서브스트림에 대한 인덱스를 부여한 후 상기 인덱스에 대한 메타데이터를 정의함으로써, 각각의 서브스트림이 서로 다른 저장 장소에 위치하고 있더라도 상기 서브스트림에 대한 인덱스를 참조하여 단말이 쉽게 컨텐츠를 수신하여 이용할 수 있게 되며, 이를 통해 서비스 산업의 발전에 이바지할 수 있다.According to the present invention, when encoding content by a scalable encoding method, by dividing a bitstream of each layer into a predetermined number or more of substreams, assigning an index to each substream, and defining metadata for the index. Even if the substreams are located in different storage locations, the terminal can easily receive and use contents by referring to the indexes of the substreams, thereby contributing to the development of the service industry.
더불어, 본 발명은 시판 또는 영업의 가능성이 충분할 뿐만 아니라 현실적으로 명백하게 실시할 수 있는 정도이므로 산업상 이용가능성이 있다.In addition, the present invention has industrial applicability because the present invention is not only sufficiently commercially available or commercially viable, but also practically clearly implemented.
Claims (8)
- 어느 하나의 컨텐츠에서 계층화된 기본 레이어(base layer) 및 향상 레이어(enhancement layer)의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성하는 단계;Generating by dividing a bitstream of a base layer and an enhancement layer layered in any one content into a predetermined number or more of substreams;상기 생성된 각각의 서브스트림에 대응하여 인덱스를 부여하고 저장하는 단계; 및Assigning and storing an index corresponding to each of the generated substreams; And상기 인덱스에 대한 메타데이터를 생성한 후 상기 컨텐츠를 요청한 단말로 상기 메타데이터를 전송하고, 상기 단말의 요청에 따라 상기 컨텐츠의 서브스트림을 상기 단말로 전송하는 단계;Generating metadata for the index and transmitting the metadata to a terminal that has requested the content, and transmitting a substream of the content to the terminal at the request of the terminal;를 포함하는 것을 특징으로 하는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법.Content delivery method that supports scalable encoding comprising a.
- 제1항에 있어서, The method of claim 1,상기 분할하여 생성하는 단계는The dividing step네트워크의 상태 정보, 상기 컨텐츠를 요청한 단말의 성능 정보 및 상기 서브스트림을 저장할 수 있는 저장 장소의 성능 정보 중 적어도 어느 하나 이상을 고려하여 상기 계층화된 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성하는 것을 특징으로 하는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법.The bitstream of each layered layer is divided into a predetermined number or more of substreams in consideration of at least one of state information of a network, performance information of a terminal requesting the content, and performance information of a storage location capable of storing the substream. And a content encoding method supporting scalable encoding.
- 제1항에 있어서, The method of claim 1,상기 인덱스는 The index is상기 서브스트림을 식별하기 위한 식별 정보, 상기 서브스트림을 포함하는 프래그먼트 식별 정보 및 상기 서브스트림이 저장되는 저장 장소에 대한 식별 정보 중 적어도 어느 하나를 포함하는 것을 특징으로 하는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법.Contents supporting scalable encoding comprising at least one of identification information for identifying the substream, fragment identification information including the substream, and identification information on a storage location where the substream is stored. Transmission method.
- 제1항에 있어서, The method of claim 1,상기 메타데이터는The metadata is상기 단말의 성능 정보에 대응하여 복수 개 생성되거나, 상기 단말의 성능을 고려하여 수신할 수 있는 요소를 한정하는 정보를 포함하는 것을 특징으로 하는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법.And a plurality of information generated corresponding to the performance information of the terminal or including information for defining elements that can be received in consideration of the performance of the terminal.
- 제1항에 있어서, The method of claim 1,상기 전송하는 단계 이후에, After the transmitting step,상기 단말 인근에 분산 배치된 어느 하나의 캐시 장치에 상기 컨텐츠의 서브스트림이 캐싱되는 경우, 상기 캐시 장치로부터 상기 캐싱 정보를 수신하는 단계; 및Receiving the caching information from the cache device when the substream of the content is cached in any one cache device distributed in the vicinity of the terminal; And상기 수신된 캐싱 정보에 따라 상기 메타데이터를 수정하는 단계;Modifying the metadata according to the received caching information;를 포함하는 것을 특징으로 하는 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법.Content delivery method that supports scalable encoding comprising a.
- 제1항 내지 제6항 중 어느 하나의 항에 기재된 스케일러블 인코딩을 지원하는 컨텐츠 전송 방법을 실행하는 프로그램을 기록한 컴퓨터 판독 가능한 기록매체.A computer-readable recording medium having recorded thereon a program for executing the content transmission method supporting the scalable encoding according to any one of claims 1 to 6.
- 어느 하나의 컨텐츠를 기본 레이어(base layer) 및 향상 레이어(enhancement layer)으로 계층화하여 각 레이어에 대한 비트스트림을 생성하는 계층화부;A layering unit for layering any content into a base layer and an enhancement layer to generate a bitstream for each layer;상기 계층화된 각 레이어의 비트스트림을 일정 개수 이상의 서브스트림으로 분할하여 생성하는 서브스트림 생성부; 및A substream generator for dividing the bitstreams of the layered layers into a predetermined number or more of substreams; And상기 생성된 각각의 서브스트림에 대응하여 인덱스를 부여하는 인덱스 관리부;로 구성되는 인코딩 모듈을 포함하는 것을 특징으로 하는 스트리밍 서버.And an encoding module configured to provide an index corresponding to each of the generated substreams.
- 제7항에 있어서, The method of claim 7, wherein상기 인덱스에 대응한 메타데이터를 생성하며, 상기 컨텐츠를 요청한 단말로 전달되는 상기 서브스트림이 상기 단말 인근에 분산 배치된 어느 하나의 캐시 장치에 상기 컨텐츠의 서브스트림이 캐싱되는 경우, 상기 캐시 장치로부터 상기 캐싱 정보를 수신하고, 상기 수신된 캐싱 정보에 따라 상기 메타데이터를 수정하는 MPD 생성 모듈;When the substream of the content is cached in any one cache device generating the metadata corresponding to the index and the substream delivered to the requesting terminal is distributed in the vicinity of the terminal, An MPD generation module that receives the caching information and modifies the metadata according to the received caching information;을 더 포함하는 것을 특징으로 하는 스트리밍 서버. Streaming server, characterized in that it further comprises.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020150121785A KR20170026809A (en) | 2015-08-28 | 2015-08-28 | Method for transferring of contents with scalable encoding and streamming server therefor |
KR10-2015-0121785 | 2015-08-28 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2017039021A1 true WO2017039021A1 (en) | 2017-03-09 |
Family
ID=58188916
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/KR2015/009091 WO2017039021A1 (en) | 2015-08-28 | 2015-08-28 | Content transmission method supporting scalable encoding and streaming server therefor |
Country Status (2)
Country | Link |
---|---|
KR (1) | KR20170026809A (en) |
WO (1) | WO2017039021A1 (en) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20090028369A (en) * | 2007-09-14 | 2009-03-18 | 삼성전자주식회사 | Video encoding apparatus and method and video decoding apparatus and method |
US20130113882A1 (en) * | 2011-11-08 | 2013-05-09 | Sony Corporation | Video coding system and method of operation thereof |
WO2013108954A1 (en) * | 2012-01-20 | 2013-07-25 | 전자부품연구원 | Method for transmitting and receiving program configuration information for scalable ultra high definition video service in hybrid transmission environment, and method and apparatus for effectively transmitting scalar layer information |
KR20130105214A (en) * | 2012-03-12 | 2013-09-25 | 삼성전자주식회사 | Method and apparatus for scalable video encoding, method and apparatus for scalable video decoding |
WO2015053593A1 (en) * | 2013-10-12 | 2015-04-16 | 삼성전자 주식회사 | Method and apparatus for encoding scalable video for encoding auxiliary picture, method and apparatus for decoding scalable video for decoding auxiliary picture |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR102037644B1 (en) | 2012-09-28 | 2019-10-28 | 소니 주식회사 | Image processing device and method |
-
2015
- 2015-08-28 WO PCT/KR2015/009091 patent/WO2017039021A1/en active Application Filing
- 2015-08-28 KR KR1020150121785A patent/KR20170026809A/en unknown
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20090028369A (en) * | 2007-09-14 | 2009-03-18 | 삼성전자주식회사 | Video encoding apparatus and method and video decoding apparatus and method |
US20130113882A1 (en) * | 2011-11-08 | 2013-05-09 | Sony Corporation | Video coding system and method of operation thereof |
WO2013108954A1 (en) * | 2012-01-20 | 2013-07-25 | 전자부품연구원 | Method for transmitting and receiving program configuration information for scalable ultra high definition video service in hybrid transmission environment, and method and apparatus for effectively transmitting scalar layer information |
KR20130105214A (en) * | 2012-03-12 | 2013-09-25 | 삼성전자주식회사 | Method and apparatus for scalable video encoding, method and apparatus for scalable video decoding |
WO2015053593A1 (en) * | 2013-10-12 | 2015-04-16 | 삼성전자 주식회사 | Method and apparatus for encoding scalable video for encoding auxiliary picture, method and apparatus for decoding scalable video for decoding auxiliary picture |
Also Published As
Publication number | Publication date |
---|---|
KR20170026809A (en) | 2017-03-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2021206515A1 (en) | Offering media services through network edge | |
CN107211186B (en) | Method and apparatus for providing multi-view streaming service | |
WO2019143133A1 (en) | Method and apparatus for configuration and deployment of media processing in the network | |
WO2017138776A1 (en) | Method for supporting vr content display in communication system | |
US20220109722A1 (en) | Method and apparatus for dynamic workflow task management | |
KR20170130253A (en) | Method for providing of adaptive streaming service and apparatus therefor | |
WO2012124904A2 (en) | Method and apparatus for receiving contents in mobile communication system | |
EP2813109A1 (en) | Method and apparatus for interoperably performing services and system supporting the same | |
WO2020159319A1 (en) | Electronic device for playing high dynamic range video and method thereof | |
EP3857922A1 (en) | Method and apparatus for providing services in local area data network | |
WO2016137185A1 (en) | Electronic device and method for providing drm content by the electronic device | |
WO2013024966A1 (en) | Method and device for receiving content | |
KR102050735B1 (en) | Proxy server for cloud streaming service, cloud streaming system and method using the same | |
KR20180055342A (en) | Method and apparatus for cloud streaming service | |
WO2017039021A1 (en) | Content transmission method supporting scalable encoding and streaming server therefor | |
KR102310070B1 (en) | Method for caching of application for cloud streaming service and apparatus using the same | |
KR101743441B1 (en) | Method for providing streaming data through node linking with base station, and node using the same | |
WO2015199299A1 (en) | Method for providing cloud service, computer-readable recording medium having, recorded thereon, web application supporting same, and cloud service system and device according to same | |
WO2017200319A1 (en) | Method providing for adaptive streaming service, and device therefor | |
WO2017039022A1 (en) | Method for providing content through interworking with content centric networking and apparatus therefor | |
WO2022173113A1 (en) | Method and apparatus for providing edge computing service | |
KR102209782B1 (en) | Method for providing of streamming service and apparatus for the same | |
KR102281217B1 (en) | Method for encoding and decoding, and apparatus for the same | |
KR102209784B1 (en) | Method for caching processing of mmt packet and apparatus for the same, mthod for generating of mmt packet and apparatus for the same | |
WO2016088940A1 (en) | Cloud streaming service system, image cloud streaming service method using application code, and device therefor |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 15903082 Country of ref document: EP Kind code of ref document: A1 |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 15903082 Country of ref document: EP Kind code of ref document: A1 |