이하 상기의 목적을 구체적으로 실현할 수 있는 본 발명의 바람직한 실시예를 첨부한 도면을 참조하여 설명한다. 이때, 도면에 도시되고 또 이것에 의해서 설명되는 본 발명의 구성과 작용은 적어도 하나의 실시예로서 설명되는 것이며, 이것에 의해서 본 발명의 기술적 사상과 그 핵심 구성 및 작용이 제한되지는 않는다.
본 발명에서 사용되는 용어는 본 발명에서의 기능을 고려하면서 가능한 현재 널리 사용되는 일반적인 용어를 선택하였으나, 이는 당해 기술분야에 종사하는 기 술자의 의도 또는 관례 또는 새로운 기술의 출현 등에 따라 달라질 수 있다. 또한, 특정한 경우는 출원인이 임의로 선정한 용어도 있으며, 이 경우 해당되는 발명의 설명 부분에서 상세히 그 의미를 기재할 것이다. 따라서 본 발명에서 사용되는 용어는 단순한 용어의 명칭이 아닌 그 용어가 가지는 의미와 본 발명의 전반에 걸친 내용을 토대로 정의되어야 함을 밝혀두고자 한다.
도 1은 IPTV 서비스의 개념을 도시한 시스템 구성도이다.
도 1을 참조하면, IPTV 시스템은 서비스 프로바이더 영역(service provider domain), 네트워크 프로바이더 영역(network provider domain), 고객 영역(consumer domain)으로 구성된다.
서비스 프로바이더 영역은 컨텐츠 프로바이더(contents provider) 및 서비스 프로바이더(service provider)를 포함할 수 있다. 상기 컨텐츠 프로바이더는 서비스 프로바이더에게 컨텐츠를 제공해주는 역할을 한다. 상기 서비스 프로바이더는 가입자에게 서비스를 제공하며, 다양한 컨텐츠를 수집하여 IP 환경에 맞게 신호를 변형하여 사용자에게 전달한다. 또한, 서비스 프로바이더(Service Provider)는 멀티미디어 데이터를 전송하고, 사용자(Customer)에게 컨텐츠가 안정적으로 수신되도록 전송망을 유지 보수 관리하고, 컨텐츠 프로바이더에게는 네트워크 전송을 할 수 있는 기반 시설과 기능을 제공한다. 여기서, 서비스 프로바이더는 가상의 존재일 수 있고, 컨텐츠 프로바이더가 곧 서비스 프로바이더가 될 수도 있다.
네트워크 프로바이더 영역은 사용자와 서비스 프로바이더를 IP 네트워크를 통해서 연결한다. 전송 시스템은 접속망(access network), 기간망(backbone network) 또는 무선 WAN(wireless Wide Area Network) 등의 다양한 네트워크 망을 이용할 수 있다.
고객 영역은 IPTV 서비스를 소비하는 영역이다. 상기 고객 영역은 xDSL(digital subscriber loop)이나 케이블과 같은 기반시설을 이용하여 수신되는 데이터를 재생하고 사용자의 요구에 즉시 반응하는 등의 역할을 한다. 대부분이 IPTV를 생산하는 업체들로 구성되고, 그 종류들은 IPTV, IP STB, IP Phone 등이 있다. 상기 고객 영역에는 컨텐츠를 제공받아, 방송을 수신하기 위해 고객 영역 장치가 사용될 수 있다. 여기서, 고객 영역 장치로 셋탑 박스(set top box), PC, 이동 단말기, ITF(IPTV Terminal Function) 장치 또는 DNG(Delivery Network Gateway) 장치 등이 있다.
각각의 영역에 대하여 자세하게 알아보도록 한다.
먼저 컨텐츠 프로바이더(contents provider)는 방송 프로그램을 만드는 TV Station 및 Radio Station이 있을 수 있다. TV Station은 기존의 지상파나 케이블 방송국을 의미하며, 이러한 방송국은 사용자들이 시청할 수 있는 프로그램을 만들어 저장하고 이를 디지털로 바꾸어서 전송할 수 있다. 일반적으로 여러 가지 방송형태로 전송할 수 있도록 하기 위함이다.
Radio Station은 일반 라디오 방송국을 의미하며, 비디오 채널이 때에 따라서 있을 수도 있지만, 대부분의 경우 비디오 채널이 없이 운영된다고 볼 수 있다. VoD(Video on Demand), AoD(Audio on Demand) 서비스는 TV Station이나 Radio Station과는 다른 특성을 가진다. 컨텐츠 프로바이더(contents provider)에서도 방송할 프로그램을 저장해서 보관하겠지만, 이는 연속성이 있는 라이브 방송으로, 레코딩을 하지 않는 이상은 되감아서 보거나 정지시켜서 볼 수 없는 특징이 있다. 그러나 VoD나 AoD의 경우에는 내가 원하는 방송 프로그램 혹은 영화, 음악 등을 저장해 놓고 나서 재생하여 볼 수 있도록 서비스해준다. 예를 들어, 현재 시간이 없어서 제대로 보지 못했던 방송 프로그램이 있는 경우, 이러한 방송 서비스를 제공하는 사이트에 접속해서 해당 파일을 다운로드 받거나 바로 재생을 해서 볼 수 있다. AoD도 마찬가지로 오디오 프로그램을 녹화하기 어렵거나 실시간으로 들을 수 있는 기능을 제공한다. MoD(Music on Demand) 서비스는 내가 원하는 음악을 다운로드 받아서 들을 수 있다. MoD의 서비스의 대상은 음반사 또는 음반 배포사가 기존의 웹 서비스를 확대하여 실시할 수 있다.
이하에서는 컨텐츠 프로바이더가 제공하는 서비스의 실시예에 대하여 살펴본다.
PF 서버는 컨텐츠 프로바이더(contents provider)가 제공하는 모든 방송 정보와 Location 정보 등을 대신 관리해주는 업체가 서비스를 할 수 있다. 이 서비스는 주로 해당 방송국의 방송 시간이나 방송에 필요한 위치 정보 및 사용자(Customer)가 접속을 할 수 있는 정보를 담고 있다. 사용자(Customer)는 이 정보를 얻어 화면에 표시할 수 있다. PF 서버는 각 방송국마다 갖추어야 하는 서비스 중에 하나로 IPTV 환경에서는 이 서비스를 제공하여, 사용자가 해당 방송국에 접속하도록 할 수 있다.
EPG 서비스는 방송 프로그램을 사용자가 시간대 별로 조회하고, 채널 별로 파악할 수 있도록 제공하는 편리한 서비스 중에 하나이다. EPG 서비스는 이미 프로그램이 자동으로 Customer 측에 설치가 되어 실행할 수 있도록 되어 있다. 사용자(Customer)는 PF 서버로부터 해당 방송국에 대한 정보만을 얻을 수 있지만, EPG 서비스는 모든 방송국의 실시간 방송 채널에 대한 정보들을 한꺼번에 얻을 수 있어서 매우 편리하게 사용할 수 있다. 가령, CNN 뉴스를 예약 녹화를 한다든지, Disney 방송을 시청 예약한다든지 하는 강력한 기능을 내장하고 있기 때문이다. 따라서, EPG 서비스는 해당 지역의 방송 프로그램의 정보를 시간대별로 자세하게 제공해야 한다. 특히, 어떤 드라마의 경우 드라마의 내용을 검색하거나, 카테고리로 나누어 SF, Drama, Animation 등의 구분도 할 수 있으며, 간단한 방영 프로그램의 영화나 드라마의 줄거리나 등장 인물들에 대한 세부적인 정보도 포함할 수 있다. EPG 서비스의 큰 문제점은 IPTV를 시청하는 사용자(Customer)의 라이센스(license)의 종류가 많아 사용자에게 맞는 EPG 데이터를 어떻게 전송할 것이냐 하는 것이 문제가 될 수 있다. EPG 서비스를 접속하려면, 사용자(Customer)는 간단하게 입력 키를 리모컨에서 찾아서 누르기만 하면 된다.
ECG 서비스는 컨텐츠 프로바이더(contents provider)가 가진 컨텐트(Content)의 정보와 접속 서버의 위치 및 접근 권한 등을 사용자가 편리하게 사용할 수 있는 모든 기능이 있다. 간단히 말하면 컨텐트를 가지고 있는 서버들을 쉽게 접속하도록 하는 기능과 컨텐트의 정보를 상세하게 알려 주는 전자 프로그램 가이드(Electronic Content Guide: EPG) 이다. 즉, 실시간 방송이 아니라 AoD, MoD 그리고 VoD와 같은 서비스들을 EPG와 같이 하나로 묶어서 사용자가 어떤 컨텐트 서비스(Content Service)에 컨텐트를 보거나 다운로드 하기 위해 개별 접속하는 부담을 덜어 준다. EPG 서비스와 비슷하지만, 이 서비스는 실시간 방송 채널 정보를 알려 주는 것이 아니라 이미 서버에 저장이 되어 있어서 언제든지 시청할 수 있고 다운로드를 해서 저장할 수 있도록 한다. 사용자가 각 컨텐트가 있는 서버에 접속하려면 매우 어려운 주소나 PF 서버들을 접속해서 얻어야 할 것이다. 이것은 매우 복잡한 과정이며, 많은 시간이 소요된다. ECG를 제공하는 업체는 ECG 프로그램을 사용자에 자동 설치되도록 하고, 모든 컨텐츠에 대한 정보를 수집하여 데이터를 제공한다. ECG 서비스에 접속하려면 사용자는 역시 리모컨에 있는 입력 키 버튼을 클릭하면 된다.
포털 서버(Portal Server)는 각 방송국에서 제공하는 웹서비스로 방송국이나 컨텐트를 서비스하는 업체의 웹서버로 연결이 된다. 포털 서버의 역할은 각 방송국이나 컨텐트 서비스를 제공하는 컨텐츠 프로바이더(contents provider)들이 제공하는 프로그램 리스트를 검색하거나 리스트를 볼 수 있다. 이것은 마치 ECG나 EPG와 같은 기능이라고 생각할 수도 있다. 그러나 포털 서비스에서는 사용자의 인증이나 라이센스 계약 등과 같은 기능도 갖추고 있어서 내가 원하는 프로그램을 시청하기 위해서 접속할 필요가 있다. 또한, ECG나 EPG는 통합된 방송이나 컨텐트 리스트를 제공하지만, 포털 서비스는 해당 프로그램 제공 업체에 대한 방송이나 컨텐트 리스트 정보를 제공하여 세부적인 검색이 가능할 수 있다. 포털 서비스에 접속하려면, 사용자는 리모컨에서 포털 입력 버튼을 클릭하면 된다.
이렇게 해서 컨텐츠 프로바이더(contents provider)쪽은 이러한 서비스들을 제공하는 기능 등이 포함되어야 하고, 이러한 기능들이 정상적으로 동작하려면, 실시간으로 해당 프로그램을 전송하거나 방송 정보를 전송할 수 있도록 각 서비스 업체들의 서버(130)는 IP 네트워크에 접속되어 있어야 한다. 또한 각 방송국이나 서비스 업체들은 서비스 프로바이더(Service Provider)의 네트워크에 연결이 되어 지연과 에러 없이 전송이 되어야 하므로 RTP(real-time transport protocol), RTSP(real-time streaming protocol), RSVP(Resource Reservation Protocol) 그리고 MPLS(multi protocol label switching) 등의 인터넷 실시간 프로토콜을 이용하여 멀티미디어 데이터를 전송할 수 있도록 시스템이 갖추어져야 한다. 예를 들어, 현재 뉴스를 제공하는 TV Studio에서 실시간으로 멀티미디어를 전송하려고 할 때, MPEG-2와 AC-3 오디오 스펙으로 꾸며져 있는 경우 이를 IPTV의 포맷에 맞게 바꾸는 트랜스코드(Transcode) 작업을 해야 한다. 이러한 작업을 하는 서버를 통과하면, 캡션(Caption)이나 립싱크(Lipsync)를 맞출 수 있도록 시간 정보가 포함된 RTP/UDP 프로토콜을 붙여 서비스 프로바이더가 제공한 IP 네트워크를 통과하도록 시스템을 구성한다.
서비스 프로바이더(Service Provider)는 컨텐츠 프로바이더(contents provider)에서 전송되는 멀티미디어 데이터와 방송 데이터들을 잘 전송할 수 있도록 네트워크의 안정성과 대역폭을 제공한다. 서비스 프로바이더들은 기존의 케이블 망을 이용하여 IPTV 서비스를 제공할 수도 있는데, 이런 경우에는 전송 네트워크(Delivery Network)의 장비들의 변경이 필요하다. 즉, 실시간 데이터 전송을 할 수 있는 네트워크 장비들로 구성을 해야 하고, 사용자에도 대역폭을 감안하여 네트워크를 구성해야 한다. 이러한 장비들은 IPTV의 기본적인 네트워크 서비스인 멀티캐스트(Multicast) 서비스를 사용하여 대용량의 멀티미디어 데이터들을 처리하여 대역폭을 줄여야 한다. 대역폭이 확보되지 못할 경우에는 서비스 프로바이더에서 대역폭을 확보하려는 노력으로 광케이블 망 구성이나 컨텐츠 프로바이더로부터 오는 멀티미디어 방송 데이터들을 다시 트랜스코드하여 MPEG-4 나 MPEG-7과 같은 형태로 변형해서 전송할 수도 있다. 서비스 프로바이더는 이를 위해서 크게 몇 가지 서비스를 제공해야 하는데 크게 NMS(Network Management System), DHCP(Dynamic Host Control Protocol) 그리고 CDN 서비스를 제공하도록 되어 있다.
NMS 서비스는 서비스 프로바이더가 각 사용자에게까지 전송할 수 있는 딜리버리 네트워크를 관리하고 RCMS(Remote Configuration and Management Server) 기능을 수행한다. 즉, 전송망에 문제가 발생하여 사용자가 방송을 수신하지 못하는 경우 이를 응급 처리할 수 있는 수단이 있어야 한다. NMS는 원격의 전송 계층의 기계들을 원활하게 제어하고 관리할 수 있는 표준화된 수단으로 널리 사용되고 있다. 이 서비스를 이용하여 어떤 방송에 대하여 얼마만큼의 트래픽이 발생하고 있고, 어떤 지역에서 대역폭이 모자라는지를 확인할 수 있다. 또한, 컨텐츠 프로바이더에게 멀티캐스트 시에 그룹을 생성하고 관리할 수 있도록 컨텐츠 프로바이더들에게 제공해야 한다. 때에 따라서는 멀티캐스트 그룹을 더 생성할 수도 있어야 하기 때문이다.
DHCP 서비스는 사용자의 IPTV 수신기에게 자동적으로 IP를 할당할 수 있도록 하고, CDN 서버의 주소를 알려 주는데 사용한다. DHCP 서비스는 일반 네트워크에서도 PC에 IP를 할당하는 좋은 수단이 되고 있다. 사용이 허락된 IPTV 수신기에게 접속할 수 있는 주소를 전송해 주어 사용자가 최초 접속할 때 등록 절차를 할 수 있도록 해야 한다. 일반적으로 IPv4를 IPTV 수신기에서는 제공할 것이지만, IPv6도 사용할 수 있도록 되어 있다. 따라서 IPv4를 제공하는 IPTV 수신기라고 해서 사용하지 못하는 것은 아니다.
CDN 서비스는 서비스 프로바이더가 제공하는 데이터로 IPTV 수신기가 최초로 전원이 인가되어 동작할 때, DHCP 서비스에 의하여 IP를 받으면서 CDN 정보를 서비스 프로바이더에게 수신받게 된다. 이 정보는 IPTV 사업자의 사용자의 등록이나 인증 그리고 앞서 언급했던 PF 정보들을 담고 있다. IPTV 수신기가 서비스 프로바이더에게서 CDN 정보를 얻음으로써, IP 방송 신호 수신이 가능할 수 있다.
사용자(Customer)는 여러 가지 형태의 IPTV 수신기를 가질 수 있다. 일반 TV를 가지고 있는 사용자의 경우에는 IPTV STB를 임대하여 저렴하게 IPTV를 즐길 수 있으며, 서비스 프로바이더가 저렴한 가격으로 추가적인 서비스 비용을 지불하고 IP Phone도 함께 신청하여 사용할 수도 있다. IPTV 수신기는 기본적으로 네트워크에 접속할 수 있는 네트워크 인터페이스(Network Interface)가 있고, 인터넷 프로토콜을 가지고 있어서 네트워크로부터 들어오는 데이터 패킷을 받아 처리하여 멀티미디어 데이터인 경우에는 화면에 재생할 수 있고, 리모컨으로 조작할 경우, 데이터 패킷을 네트워크로 신속하게 전송해서 해당 정보를 서버에서 얻어 반응을 해야 한다. 즉, IPTV 수신기는 멀티미디어 데이터를 처리하면서 양방향으로 사용자의 요구사항을 전송할 수 있도록 동작할 수 있다. 또한, 서비스를 잘 이용할 수 있도록 리모컨에 IPTV 용 버튼들을 제공할 수 있다. 이렇게 제공된 IPTV 수신기에서 사용자는 드라마에 나오는 멋진 장면을 저장하여 볼 수 있고, 위치정보라든지 호텔 예약이라든지 하는 부가 서비스를 누릴 수 있다.
한편, 앞서 언급했던 NMS는 서비스 프로바이더(Service Provider)가 망을 관리하는 기능뿐만 아니라 RCMS 기능을 수행한다. RCMS는 사용자가 가지고 있는 IPTV 수신기를 제어하고 관리할 수 있도록 도와 주는데, IPTV 수신기가 급증하고 부가적인 서비스가 늘어나면, RCMS의 역할은 더욱 중요하게 된다. 이 때문에 IPTV 방송 수신기에 SNMP 프로토콜을 의무화하고 있다. 이는 서비스 프로바이더가 IPTV 방송 수신기를 관리하고 제어할 수 있도록 하겠다는 의도이다. 이렇게 되면, IPTV 방송 수신기는 현재 통신하고 있는 프로토콜의 통계자료 그리고 사용하는 프로세서의 정보, 어떤 TV 생산업체인지 등에 대하여 자세하게 파악할 수 있다.
고객 영역에서 IPTV 서비스를 수신하기 위해, ITF(120)는 DNS 서버(110)에 서버 주소 응답 요청(Server Address resolution request)을 전송할 수 있다. DNS 서버(110)는 ITF(120)에게 서버 주소를 전송한다. ITF(120)는 전송받은 서버 주소에 근거하여 서버(130)에 연결하고 IPTV 서비스를 수신받을 수 있게 된다. 여기서, ITF(120)는 서버(130)와 멀티캐스트 방식 및 유니캐스트 방식 중 적어도 하나의 방식으로 연결될 수 있다.
도 2는 멀티캐스트 방식에 대해 개략적으로 도시한 도면이다.
도 2를 참조하면, 멀티캐스트 방식은 특정한 그룹의 다수의 수신자에게 데이터를 전송하는 방식이다. 예를 들어, 서비스 프로바이더는 데이터를 미리 등록된 다수의 ITF에 한꺼번에 전송할 수 있다. 상기 멀티캐스트 등록을 위해 IGMP(Internet Group Management Protocol) 프로토콜 등이 사용될 수 있다.
도 3은 유니캐스트 방식에 대해 개략적으로 도시한 도면이다.
도 3을 참조하면, 상기 유니캐스트 방식은 하나의 송신자와 하나의 수신자 사이에 데이터를 1:1로 전송하는 방식이다. 예를 들어, 유니캐스트 방식의 경우 ITF에서 서비스 프로바이더에 서비스를 요청하면, 상기 서비스 프로바이더는 요청에 따라 해당 서비스를 상기 ITF에 전송한다.
도 4는 본 발명에 따른 IPTV 서비스의 탐색 방법에 대한 바람직한 일실시예의 수행과정을 도시한 도면이다.
도 4를 참조하면, IPTV 서비스를 수신하기 위해, ITF는 서비스 프로바이더 디스커버리(Service Provider Discovery)를 수행하여 SD 서버(Service Discovery Server)의 주소 목록을 찾는다. 여기서, 서비스 프로바이더 디스커버리(Service Provider Discovery)는 ITF가 IPTV 서비스 프로바이더에 대한 정보 및 보안 관리되는 네트워크로 서비스 프로바이더에 접속하기 위한 정보를 찾는 과정을 의미한다. ITF는 다음과 같은 방식으로 SD 서버(Service Discovery Server)의 주소 목록을 찾을 수 있다.
SD 서버(Service Discovery Server)의 주소 목록 서치 방식
1. 사전에 설정되거나 수동 설정 : ITF에 사전에 설정된 주소를 따르거나 사용자 수동 설정
2. DHCP 기반 SP Discovery : DHCP option을 사용하여 SD 서버의 주소 목록을 얻어옴
3. DNS SRV-based SP Discovery : DNS SRV 메커니즘을 이용하여 쿼리를 SD 서버 주속 목록을 얻어옴
ITF(420)는 전술한 1 내지 3의 방법으로 얻은 SD 서버 주소 목록을 통해 특정 SD 서버를 찾을 수 있게 되고 특정 SD 서버로부터 서비스 프로바이더 디스커버리 레코드를 수신할 수 있게 된다.
서비스 프로바이더(410)는 ITF(420)에 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery record)를 전송한다(S400). 여기서, 서비스 프로바이더 디스커버리 레코드는 유용한 IPTV 서비스 프로바이더에 대한 정보 및 보안 관리되는 네트워크로 서비스 프로바이더에 접속하기 위한 정보를 포함한다. 서비스 프로바이더 디스커버리 레코드는 푸시 모드(Push mode) 또는 풀 모드(Pull mode)로 전송될 수 있다. 풀 모드로 전송되는 경우에는, ITF(420)가 서비스 프로바이더 디스커버리 레코드에 대한 전송 요청이 있는 경우에 서비스 프로바이더(410)가 서비스 프로바이더 디스커버리 레코드를 전송한다. 그러나 푸시 모드로 전송되는 경우는, ITF(420)가 서비스 프로바이더 디스커버리 레코드에 대한 전송 요청과 관계없이 서비스 프로바이더(410)가 서비스 프로바이더 디스커버리 레코드를 전송한다.
ITF(420)는 서비스 프로바이더 디스커버리 레코드에 포함된 Registration Server의 주소 정보가 지정하는 Registration Server에 접속하여 ITF 등록 절차를 수행한다(S405). 이때, ITF(420)에서 서비스 프로바이더(410)로 전달하는 정보는 ITFRegistrationInputType 레코드의 형태로 전달될 수 있고 가입자 식별자 정보 및 가입자 위치 정보를 포함할 수 있다. 그리고 ITF 등록은 SP 접속(Service Provider Attachment)으로 명명될 수 있고, 이는 당해 기술분야에 종사하는 기술자의 의도 또는 관례 또는 새로운 기술의 출현 등에 따라 달라질 수 있다.
인증 성공 후 서비스 프로바이더(410)는 ITF(420)에 프로비젼 인포메이션 레코드(provision information record)를 전송한다(S410). 여기서, 프로비젼 인포메이션 레코드(provision information record)는 서비스 프로바이더(SP) 접속 절차 동안 ITF에 의해 획득되는 프로비젼닝 인포메이션(provisioning information)과 인증 정보(authentication information)를 제공하는 레코드이다. 프로비젼 인포메이션 레코드(provision information record)는 ITFRegistrationOutputType 레코드의 형태를 가지며, ITFRegistrationInputType 레코드에 포함된 정보를 기초로 가입한 서비스에 커스트마이징된 데이터일 수 있다. 여기서, ITFRegistrationInputType 레코드는 가입자 식별자 정보 및 가입자 위치 정보 중 적어도 하나를 포함할 수 있다. 여기서, 가입자 위치 정보는 가입자의 ITF가 위치하는 주소일 수 있다. 또한, ITFRegistrationInputType 레코드가 가입자 식별자 정보만을 포함하는 경우에는, Registration 서버는 가입자 식별자 정보를 기초로 사전에 저장된 가입자 위치 정보 및 가입 상태 정보를 획득할 수 있다.
일예로 프로비젼 인포메이션 레코드(provision information record)는 가입자의 가입 상태 및 ITF 위치로 커스트마이징될 수 있다. ITF(420)는 ITFRegistrationInputType 레코드를 통해 자신의 ID와 위치정보를 제공하고 Registration 서버는 이를 바탕으로 ITF가 가입한 서비스를 특정 지을 수 있다. 그리고 Registration 서버는 특정된 서비스를 바탕으로 ITF(420)가 받아야 할 서비스 인포메이션(Service Information)을 획득할 수 있는 주소를 ITFRegistrationOutputType 레코드 형태로 제공한다.
서비스 인포메이션(Service Information)은 채널 맵(Channel Map)과 채널 디테일스(Channel Details)에 대한 버전을 관리하는 마스터 SI 테이블 레코드(Master SI Table Record)와 패키지 형태의 채널 목록을 제공하는 채널 맵 레코드(Channel Map Record), 그리고 각 채널의 상세 정보를 담고 있는 채널 디테일스 레코드(Channel Details Record)로 구분된다. 여기서, 서비스 인포메이션(Service Information)은 푸쉬(Push) 모드 또는 풀(Pull) 모드로 전송될 수 있다.
서비스 프로바이더(410)는 ITF(420)에 마스터 SI 테이블 레코드(Master SI Table Record)를 전송한다(S415). 여기서, ITF(420)는 프로비젼 인포메이션 레코드(provision information record)에 포함된 Master SI Table의 위치 정보를 기초로 해당 마스터 SI 테이블 레코드를 수신하거나 서비스 프로바이더(410)에 요청할 수 있다.
또한, 서비스 프로바이더(410)는 ITF(420)에 채널 맵 레코드를 전송한다(S420). 여기서, ITF(420)는 마스터 SI 테이블 레코드에 포함된 채널 정보를 기초로 해당 채널 맵 레코드를 수신하거나 서비스 프로바이더(410)에 요청할 수 있다.
그리고 서비스 프로바이더(410)는 ITF(420)에 채널 디테일스 레코드를 전송한다(S425). 여기서, ITF(420)는 마스터 SI 테이블 레코드에 포함된 가상 채널 정보 또는 채널 맵 레코드에 포함된 채널 디테일스 위치 정보를 기초로 채널 디테일스 레코드를 수신하거나 서비스 프로바이더(410)에 요청할 수 있다.
도 5는 본 발명에 따른 서비스 프로바이더 디스커버리 타입(Service Provider Discovery Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 5를 참조하면, 서비스 프로바이더 디스커버리 레코드는 ServiceProviderID 속성, Version 속성, LogoURI 속성, Name 엘리먼트, Description 엘리먼트 및 SProviderRegistrationServer 엘리먼트를 포함한다.
ServiceProviderID 속성은 서비스 프로바이더를 식별하는 유일한 식별자 정보를 포함하며, 식별자로 등록된 domain name을 사용함으로서 식별자의 유일성을 보장할 수 있다.
Version 속성은 이 레코드의 버전 정보를 포함한다.
LogoURI 속성은 서비스 프로바이더의 로고 이미지의 URI를 지정하는 로고 이미지 정보를 포함하며, 선택적으로 사용될 수 있다.
Name 엘리먼트는 서비스 프로바이더의 이름에 대한 정보를 포함하며, 서비스 프로바이더는 각 언어별로 하나씩의 이름을 가질 수 있다. 이를 위해, Name 엘리먼트는 Language 속성을 포함하며, Language 속성은 각 언어별로 정의된 이름에 대한 정보를 포함한다. 여기서, Name 엘리먼트는 적어도 하나의 Language 속성을 포함해야 한다.
Description 엘리먼트는 서비스 프로바이더에 대한 상세한 텍스트 설명 정보를 포함하며 텍스트 설명 정보는 서비스 프로바이더의 이름에 대항 정보와 유사하게 각 언어별로 하나씩 있을 수 있다. 이를 위해, Description 엘리먼트는 Language 속성을 포함하며, 상기 Language 속성을 복수개 포함할 수 있다. Language 속성은 텍스트 설명 정보를 포함한다. 여기서, 텍스트 설명 정보는 선택적으로 제공 가능하며 제공되지 않을 수도 있다.
SProviderRegistrationServer 엘리먼트는 서비스 프로바이더의 Registration Server의 주소 정보를 포함한다. 이를 위해, SProviderRegistrationServer 엘리먼트는 Location URL 속성을 포함할 수 있으며, Location URL 속성은 Registration Server의 주소 정보를 포함한다. 여기서, Registration Server의 주소 정보는 일예로 URL 형태가 될 수 있다.
도 6은 본 발명에 따른 ITF 레지스트레이션 입풋 타입(ITF Registration Input Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 6을 참조하면, ITF 레지스트레이션 입풋 레코드(ITF Registration Input record)는 ConsumerID 속성 및 ConsumerLocation 속성을 포함하며, Registration을 위해 ITF에서 Registration Sever로 전송하는 정보는 ITF 레지스트레이션 입풋 타입의 구조로 전송될 수 있다.
ConsumerID 속성은 가입자를 유일하게 식별할 수 있는 가입자 식별자 정보를 포함하며, 가입자 식별자로 ITF의 mac address 등이 사용될 수 있다.
ConsumerLocation 속성은 가입자의 위치를 나타내는 가입자 위치 정보를 포함한다. ConsumerLocation에 포함된 정보를 통해 Registration server는 가입자의 위치를 인식하여 해당되는 지역을 판정할 수 있고, 판정된 지역에 따라 ITF에 적합한 flow들을 선별하여 보내줄 수 있다. 여기서, 가입자 위치 정보는 네트워크 접속(Network Attachment)단계에서 DHCP 옵션을 통하여 얻어질 수 있다.
도 7은 본 발명에 따른 ITF 레지스트레이션 아웃풋 타입(ITF Regitstration Output Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 7을 참조하면, ITF 레지스트레이션 아웃풋 레코드는 MasterSITableLocation 엘리먼트, SubscribedChannelMap 엘리먼트, UnsubscribedChannelMap 엘리먼트, EPGDiscoveryLocation 엘리먼트 및 SPRemoteConfigurationServerLocation 엘리먼트를 포함하며, Registration을 성공하였을 경우에 Registartion Server에서 ITF로 전송하는 정보는 ITF 레지스트레이션 아웃풋 타입(ITF Regitstration Output Type) 구조로 전송될 수 있다.
MasterSITableLocation 엘리먼트는 Master SI Table의 위치 정보를 포함한다.
SubscribedChannelMap 엘리먼트는 사용자가 가입한 채널 맵에 대한 정보를 포함한다. 서비스 프로바이더는 자신들이 서비스하는 채널들을 여러 개의 채널 맵 형태로 제공하여 사용자가 이중 하나 이상을 선택하여 가입할 수 있도록 할 수 있다. 또한, 채널 맵이 직접 사용자에게 보이지 않고 내부적으로 채널 맵 형태로 구성하여 채널 맵의 조합으로 사용자가 가입한 채널 목록을 제공하는 것도 가능할 것이다.
UnsubscribedChannelMap 엘리먼트는 사용자가 가입하지 않은 채널 맵에 대한 정보를 포함한다. 서비스 사업자는 사용자가 비록 현재는 가입하지 않아 시청할 수 없지만 프로모션을 위하여 이러한 채널 목록을 제공하는 것이 필요할 수 있다. 서비스 사업자는 선택적으로 이러한 채널 맵들을 제공할 수 있다.
EPGDiscoveryLocation 엘리먼트는 EPG 데이터를 디스커버리(discovery) 하기 위한 EPG 데이터 제공자 정보를 포함한다. 상기 EPG 데이터 제공자 정보는 EPG 데이터를 받을 수 있는 주소 정보를 포함한다. EPG는 선택적으로 제공할 수 있으며 하나 이상의 EPG를 제공할 수도 있다. 여기서, EPGDiscoveryLocation 엘리먼트는 일예로 EPG 디스커버리 레코드 타입(EPG Discovery Record Type)으로 정의될 수 있다.
SPRemoteConfigurationServerLocation 엘리먼트는 SP가 제공하는 Remote Configuration Server의 주소 정보를 포함한다. Remote Configuration Server의 주소 정보가 존재할 경우에는 ITF는 반드시 Remote Configuration Server에 접속하여 Remote Configuration 절차를 수행하여야 한다. 여기서, Remote Configuration Server는 전술한 RCMS 기능을 수행한다.
도 8은 서비스 인포메이션(SI: Service Information)을 구성하는 각 테이블간의 관계를 도시한 도면이다.
도 8을 참조하면, 마스터 SI 테이블 레코드(Master SI Table Record)는 가상 채널 맵(Virtual Channel Map)들에 대한 포인터들을 제공한다. 여기서, 포인터들은 가상 채널 디스커버리 과정(Virtual Channel discovery process)를 시작하기 위해 필요한 정보이다. 또한, 마스터 SI 테이블 레코드(Master SI Table Record)는 ITF가 SI의 일부 버전의 변경을 감지할 수 있도록 한다. 마스터 SI 테이블 레코드(Master SI Table Record)는 각 채널 맵들의 버전 정보를 담고 있는 채널 맵 마스터(Channel Map Master)와 채널의 상세 정보를 담고 있는 채널 디테일스(Channel Detail)에 대한 버전 정보를 담고 있는 가상 채널 마스터(Virtual Channel Master)들로 구성될 수 있다. 여기서, 마스터 SI 테이블 레코드(Master SI Table Record)는 가상 채널 마스터(Virtual Channel Master)를 선택적으로 포함할 수 있다.
각 Channel Map은 VCListID로 유일하게 식별되며 VCListVerion과 ChannelDetailsVersion의 두 가지 버전 정보를 가진다. VCListVersion은 Channel Map의 채널 목록에 대한 버전으로, 채널이 추가되거나 삭제될 경우에만 버전이 변경된다. ChannelDetailsVersion은 Channel Map에 포함된 채널의 상세 정보가 변경 여부를 관리하는 버전 정보로 채널의 상세 정보가 변경된 경우에만 버전이 변경된다.
마스터 SI 테이블 레코드는 서비스 프로바이더에 유일하게 하나만 존재할 수도 있다. 하지만 서비스의 구성이 지역별로 다를 경우, 각 지역별로 하나의 마스터 SI 테이블 레코드를 구성하는 것이 보다 효율적일 것이다. 이 경우 Registration 단계를 통해 ITF가 속한 지역에 맞는 마스터 SI 테이블 레코드를 제공하는 것이 가능하다.
도 8에서 마스터 SI 테이블 레코드에 2개의 채널 맵의 예시되어져 있고, 이들은 VCListID로 유일하게 식별될 수 있다. 각 채널 맵은 하나 이상의 채널을 가질 수 있으며 채널의 상세 정보를 채널 맵 상에 포함하는 것이 아니라, 이 정보를 얻을 수 있는 위치를 지정한다. 즉, 채널 디테일스 로케이션(Channel Details Location)이 채널 상세 정보의 위치를 지정하는 역할을 한다.
채널 디테일스 레코드는 채널의 상세 정보를 담고 있으며 채널 맵 상의 채널 디테일스 로케이션(Channel Details Location)에 의하여 찾아갈 수 있다. 이와 같은 방법 외에도 채널 디테일스 레코드를 전달하는 방법은 다음과 같이 여러 가지 방식을 가질 수 있다.
채널 디테일스 레코드(Channel Details Record) 전달 방식
1. 글로벌(Global)로 하나의 멀티캐스트 스트림(Multicast stream)으로 제공하는 방법
하나의 글로벌(Global)한 멀티캐스트 스트림으로 서비스 프로바이더가 제공하는 모든 채널의 채널 디테일스 레코드(Channel Details Record)를 뿌리는 방식이다. 이 경우에는 전술한 것과 같이 채널 맵 상에서 각 채널별 상세 정보의 주소를 알려줄 필요 없이 ITFRegistrationOutputType에 이 글로벌한 멀티캐스트 스트림(Multicast stream)의 주소를 담아 줌으로써 제공해 줄 수 있다.
2. 지역별로 하나의 멀티캐스트 스트림(Multicast stream)으로 제공하는 방법
상기 1번의 방식은 전역적으로 하나의 스트림으로 채널 상세 정보를 제공하는데 비해서, 이 경우 각 지역별로 별개의 멀티캐스트 스트림을 통하여 채널 상세 정보를 제공할 수 있다. 이 경우에도 Registration 과정을 통해 ITF에 속한 지역을 특정 지을 수 있기 때문에 ITFRegistrationOutputType을 통해 지역별 유일한 멀티캐스트 스트림(Multicast stream)의 주소를 지정해 줄 수 있다.
3. 채널 맵에 기본 채널 디테일스 로케이션(Default Channel details location) 지정 방법
한 채널 맵에 속한 채널의 상세 정보가 일부 혹은 전부가 동일 주소에서 받아올 수 있다면, 이를 각 채널 디테일스 로케이션(Channel Details Location)별로 지정하는 것보다 채널 맵에 한 번 지정하는 것으로 충분하다. 이 경우 만일 다른 주소에서 상세 정보를 획득해야 할 채널이 존재할 경우에는, 채널 디테일스 로케이션에 다시 또는 추가로 지정함으로써, 채널 맵에서 지정한 주소를 오버라이드(Override)할 수 있게 된다.
4. 도 5에서 도시한 바와 같이 채널 디테일스 로케이션을 통해 각 채널별 상세 정보의 위치를 지정하는 방법
각 채널 맵에 속한 채널의 상세 정보를 각 채널 디테일스 로케이션별로 지정하는 방식이다. 예를 들면, ServiceID가 각각 "WNBC.COM/ch9" 및 "WNBC.COM/ch11"인 채널에 대해서, "WNBC.COM/ch9"인 경우에는, 상기 채널의 채널 디테일스 로케이션의 LocationURL을 "ipm://sd.verizon.com"로, "WNBC.COM/ch11"인 채널의 경우에는, 상기 채널의 상세 정보에 대한 채널 디테일스 로케이션의 LocationURL을 "ipm://sd.verizon.com"로 각각 지정한다.
전송되는 채널 디테일스 레코드들에서 각 채널의 상세 정보를 찾기 위해, 채널 디테일스 로케이션(Channel Details Location)의 ServiceID가 각 채널의 상세 정보를 구분 짓는 유일한 식별자로 역할을 할 수 있으며, 채널 디테일스 로케이션의 ServiceID를 통해 해당 채널의 채널 디테일스 레코드를 찾을 수 있다.
만일 멀티캐스트 방식으로 채널 디테일스 레코드를 전달받는 경우에는, 해당 스트림에 조인(join)하여 레코드들을 계속 수신하면서 ServiceID에 해당하는 채널 디테일스 레코드를 찾을 수 있다.
만일 유니캐스트 방식으로 채널 디테일스 레코드를 수신하는 경우에는, ServiceID를 파라미터로 서버에 전달하여 원하는 채널 디테일스 레코드만을 전송하도록 하여 해당 채널 디테일스 레코드만을 수신할 수 있다.
마스터 SI 테이블 레코드(Master SI Table Record), 채널 맵 레코드, 채널 디테일스 레코드는 논리적으로 세 개의 분리된 플로우(flow)를 통해 전달되며 푸쉬 모드 및 풀 모드 중 어느 하나의 방식이라도 무방하게 전달될 수 있다.
마스터 SI 테이블 레코드(Master SI Table Record)를 통행 ITF는 채널 맵과 채널 디테일스(Channel Details)의 업데이트를 관리할 수 있다. ITF는 마스터 SI 테이블을 모니터링하여 채널 맵과 채널 디테일스(Channel Details)의 버전 변경 여부를 판단하고, 버전이 변경된 경우에는, 채널 맵과 채널 디테일스(Channel Details)가 업데이트되었다고 인식하여 채널 맵과 채널 디테일스(Channel Details)에 대한 업데이트를 수행할 수 있다.
여기서, 채널 디테일스(Channel Details)의 업데이트 유무는 두 가지 방법으로 확인할 수 있다. 첫 번째는 마스터 SI 테이블 레코드(Master SI Table Record)의 Channel Map Master의 Channel Details Version을 통해 확인할 수 있다. Channel Map Master의 Channel Details Version이 변경된 경우에는, 채널 디테일스(Channel Details)는 업데이트되었다고 인식할 수 있다. 두 번째는 채널 맵 레코드의 채널 디테일스 버전(Channel Details Version)을 통해 확인할 수 있다. 즉, 채널 맵 마스터(Channel Map Master)가 지시하는 채널 맵 레코드를 찾고 해당 채널 맵 레코드의 채널 디테일스 버전의 변경 여부를 판단하여 업데이트 유무를 확인할 수 있다. 두 번째 방법에서 마스터 SI 테이블 레코드는 가상 채널 마스터(Virtual Channel Master)를 포함할 필요가 없고 채널 맵 마스터가 채널 디테일스 버전을 포함할 필요가 없다.
도 9는 마스터 SI 테이블 레코드 타입(Master SI Table Record Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 9를 참조하면, 마스터 SI 테이블 레코드(Master SI Table Record)는 채널 맵 관리 정보를 포함한다. 이를 위해, 마스터 SI 테이블 레코드는 ServiceProviderID 속성, Version 속성, ChannelMapMaster 엘리먼트, VirtualChannelMaster 엘리먼트를 포함할 수 있다. 여기서, VirtualChannelMaster 엘리먼트는 선택적으로 포함할 수 있다.
ServiceProviderID 속성은 서비스 프로바이더를 유일하게 식별할 수 있는 서비스 프로바이더 식별자 정보를 포함하고 서비스 프로바이더 식별자로 등록된 도메인 이름을 이용할 수 있다.
Version 속성은 마스터 SI 테이블 레코드의 버전 정보를 포함한다. Version 속성에 포함된 버전 정보로 마스터 SI 테이블 레코드의 업데이트 여부를 판단할 수 있다.
ChannelMapMaster 엘리먼트는 채널 맵을 수신하기 위한 정보를 포함한다. 즉, ChannelMapMaster 엘리먼트는 채널 맵 인스턴스(Channel Map Instance)에 대한 포인터를 포함한다. 또한, 마스터 SI 테이블 레코드(Master SI Table Record)는 하나 이상의 채널 맵 레코드들을 각각 지시하기 위한 하나 이상의 포인터들을 포함할 수 있다. ChannelMapMaster 엘리먼트에 포함된 정보를 기초로 채널 맵 레코드(Channel Map Record)를 수신할 수 있고 채널 맵의 업데이트 여부를 판단할 수 있다. 이를 위해 ChannelMapMaster 엘리먼트는 VCListID 속성, VCListVersion 속성 및 ChannelDetailsVersion 속성을 포함할 수 있다. VCListID 속성은 채널 맵 인스턴스를 유일하게 식별하는 식별자 정보를 포함한다. VCListVersion 속성은 채널 맵을 구성하는 채널 목록들의 변화 여부를 알려주는 버전 정보를 포함한다. 여기서, VCListVersion 속성에 포함된 버전 정보는 채널이 추가되거나 삭제될 경우 변경된다. ChannelDetailsVersion 속성은 채널 맵을 구성하는 채널의 상세 정보가 변경 여부를 알려주는 버전 정보를 포함한다. 여기서, ChannelDetailsVersion 속성에 포한된 버전 정보는 채널의 상세 정보가 변경될 때 바뀐다.
VirtualChannelMaster 엘리먼트는 ServiceID 속성 및 VCVersion 속성을 포함한다. ServiceID 속성은 서비스를 유일하게 식별하기 위한 식별자 정보를 포함한다. ServiceID 속성에 포함된 정보를 기초로 원하는 채널 디테일스 레코드를 찾을 수 있다. VCVersion 속성은 채널 디테일스(Channel Details)의 버전 정보를 포함한다.
도 10은 채널 맵 타입(Channel Map Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 10을 참조하면, 채널 맵은 채널 맵 정보를 담고 있는 구조로 채널의 상세 정보를 포함하고 있지 않으며, 채널들의 묶음 형태의 패키지의 역할을 수행한다. 여기서, 도 10의 채널 맵은 도 8에서 전술한 채널 디테일스(Channel Details) 전달방법 중 4번째 방법인 각 채널 디테일스(Channel Details) 별로 별도 주소를 지정하는 방식을 나타내고 있다. 여기서, 채널 맵 정보는 일예로 채널 맵 인스턴스(Channel Map Instance)가 될 수 있다.
채널 맵 레코드(Channel Map Record)는 채널 맵 인스턴스를 포함한다. 이를 위해, 채널 맵 레코드(Channel Map Record)는 ServiceProviderID 속성, VCListID 속성, VCListVersion 속성, ChannelDetailsVersion 속성 및 ChannelDetailsLocation 엘리먼트를 포함한다.
ServiceProviderID 속성은 서비스 프로바이더를 유일하게 식별할 수 있는 서비스 프로바이더 식별자 정보를 포함하고 서비스 프로바이더 식별자로 등록된 도메인 이름을 이용할 수 있다.
VCListID는 채널 맵을 유일하게 식별하는 식별자 정보를 포함한다.
VCListVersion 속성은 채널 맵을 구성하는 채널 목록들의 변화 여부를 알려주는 버전 정보를 포함한다. 여기서, VCListVersion 속성에 포함된 버전 정보는 채널이 추가되거나 삭제될 경우 변경된다.
ChannelDetailsVersion 속성은 채널 맵을 구성하는 채널의 상세 정보의 변경 여부를 알려주는 버전 정보를 포함한다. 여기서, ChannelDetailsVersion 속성에 포한된 버전 정보는 채널의 상세 정보가 변경 될 때 바뀐다.
ChannelDetailsLocation 엘리먼트는 각 채널의 상세 정보의 위치 정보를 포함한다. 이를 위해 ChannelDetailsLocation 엘리먼트는 ServiceID 속성, LocationURL 속성 및 VCVersion 속성을 포함한다. ServiceID 속성은 서비스를 유일하게 식별하기 위한 식별자 정보를 포함한다. ServiceID 속성에 포함된 정보를 기초로 원하는 채널 디테일스 레코드를 찾을 수 있다. LocationURL 속성은 이 서비스의 상세 정보를 얻을 수 있는 주소 정보를 포함한다. VCVersion 속성은 채널 디테일스(Channel Details)의 버전 정보를 포함한다.
도 11은 채널 맵 타입(Channel Map Type)에 대한 바람직한 다른 실시예의 스키마를 도시한 도면이다.
도 11을 참조하면, 채널 맵은 채널 맵 정보를 담고 있는 구조로 채널들의 묶음 형태의 패키지의 역할을 수행하며 채널의 상세 정보를 포함하고 있지 않고 대신에 채널의 상세 정보의 디볼트 위치에 대한 정보를 포함한다. 여기서, 도 11의 채널 맵은 도 8에서 전술한 채널 디테일스(Channel Details) 전달방법 중 3번째 방법인 채널 맵에 기본 채널 디테일스 로케이션(default channel details location) 지정 방법을 나타내고 있다. 여기서, 채널 맵 정보는 일예로 채널 맵 인스턴스(Channel Map Instance)가 될 수 있다.
채널 맵 레코드(Channel Map Record)는 채널 맵 인스턴스를 포함한다. 이를 위해, 채널 맵 레코드는 ServiceProviderID 속성, VCListID 속성, VCListVersion 속성, ChannelDetailsVersion 속성, ChannelDetailsDefaultLocation 엘리먼트 및 ChannelDetailsLocation 엘리먼트를 포함한다.
ServiceProviderID 속성은 서비스 프로바이더를 유일하게 식별할 수 있는 서비스 프로바이더 식별자 정보를 포함하고 서비스 프로바이더 식별자로 등록된 도메인 이름을 이용할 수 있다.
VCListID는 채널 맵을 유일하게 식별하는 식별자 정보를 포함한다.
VCListVersion 속성은 채널 맵을 구성하는 채널 목록들의 변화 여부를 알려주는 버전 정보를 포함한다. 여기서, VCListVersion 속성에 포함된 버전 정보는 채널이 추가되거나 삭제될 경우 변경된다.
ChannelDetailsVersion 속성은 채널 맵을 구성하는 채널의 상세 정보의 변경 여부를 알려주는 버전 정보를 포함한다. 여기서, ChannelDetailsVersion 속성에 포한된 버전 정보는 채널의 상세 정보가 변경 될 때 바뀐다.
ChannelDetailsDefaultLocation 엘리먼트는 채널 맵에 속한 채널의 상세 정보의 디볼트 위치 정보를 포한한다. 이를 위해 ChannelDetailsDefaultLocation 엘리먼트는 LocationURL 속성을 포함한다. LocationURL 속성은 디볼트 위치 정보를 포함한다. 여기서, 디볼트 위치 정보는 한 채널 맵에 속한 채널의 상세 정보를 전부 또는 일부 받아올 수 있는 주소이다. 만일 다른 주소에서 상세 정보를 획득해야 할 채널이 존재하는 경우에는, ChannelDetailsLocation 엘리먼트에 해당 채널의 상세 정보의 위치 정보를 오버라이드할 수 있다.
ChannelDetailsLocation 엘리먼트는 각 Channel의 상세 정보의 위치 정보를 포함한다. 즉 ChannelDetailsDefaultLocation 엘리먼트에 포함된 디볼트 위치 정보로부터 얻어 올 수 없는 채널의 상세 정보가 있는 경우에는, ChannelDetailsLocation 엘리먼트가 상기 채널의 상세 정보의 위치 정보를 포함한다. 이를 위해 ChannelDetailsLocation 엘리먼트는 ServiceID 속성, LocationURL 속성 및 VCVersion 속성을 포함한다. ServiceID 속성은 서비스를 유일하게 식별하기 위한 식별자 정보를 포함한다. ServiceID 속성에 포함된 정보를 기초로 원하는 채널 디테일스 레코드를 찾을 수 있다. LocationURL 속성은 이 서비스의 상세 정보를 얻을 수 있는 주소 정보를 포함한다. VCVersion 속성은 채널 디테일스(Channel Details)의 버전 정보를 포함한다.
도 12a 및 도 12b는 채널 디테일스 타입(Channel Details Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 12a 및 도 12b를 참조하면, 채널 디테일스 레코드는 채널 맵에 포함된 채널의 상세 정보를 포함한다. 이를 위한 채널 디테일스 레코드는 ServiceProviderID 속성, VirtualChannelDetails 엘리먼트를 포함한다.
ServiceProviderID 속성은 서비스 프로바이더를 유일하게 식별할 수 있는 서비스 프로바이더 식별자 정보를 포함한다.
VirtualChannelDetails 엘리먼트는 각 채널의 상세 정보를 포함한다. 이를 위해, VirtualChannelDetails 엘리먼트는 ChannelType 속성, ServiceID 속성, VCVersion 속성, ShortChannelName 엘리먼트, ChannelNumber 엘리먼트 및 ChannelSource 엘리먼트를 포함한다. 여기서, ChannelSource 엘리먼트는 선택적으로 포함될 수 있다. VirtualChannelDetails 엘리먼트가 ChannelSource 엘리먼트가 포함하지 않는 경우에는, ChannelSource 엘리먼트는 별도의 ChannelSource 레코드로 독립적으로 전송될 수 있고, VirtualChannelDetails 엘리먼트는 ChannelSource 레코드를 수신할 수 있는 위치 정보 및 식별 정보를 포함할 수 있다.
ChannelType 속성은 채널의 서비스 종류를 나타내는 서비스 타입 정보를 포함하고, 서비스 타입 정보는 해당 채널이 비디오 채널, 오디오채널, 데이터방송 채 널 인지를 알려준다.
ServiceID 속성은 서비스를 유일하게 식별하기 위한 식별자 정보를 포함한다. ServiceID 속성에 포함된 정보를 기초로 원하는 채널 디테일스 레코드를 찾을 수 있다.
VCVersion 속성은 채널 디테일스(Channel Details)의 버전 정보를 포함한다.
ShortChannelName 엘리먼트는 7자 이내의 짧은 텍스트 값으로 채널의 이름을 포함한다. 일예로 "WABC"와 같은 값이 될 수 있을 것이다.
ChannelNumber 엘리먼트는 해당 채널 번호를 포함한다. 본 발명에서는 1파트 채널 넘버 및 2파트 채널 넘버를 모두를 지원할 수 있어, 해당 채널 번호는 1파트 채널 넘버 및 2파트 채널 넘버 중 어느 하나가 될 수 있다. 이를 위해 ChannelNumber 엘리먼트는 물리적 채널 정보를 포함하는 MajorChannelNumber 엘리먼트 및 논리적 채널 정보를 포함하는 MinorChannelNumber를 포함할 수 있다.
ChannelSource 엘리먼트는 해당 채널의 실제 소스를 지정하는 정보를 포함한다. 이를 위해 ChannelSource 엘리먼트는 VirtualChannelLocation 엘리먼트, ChannelSourcePurpose 엘리먼트, VideoAttribute 엘리먼트, AudioAttributes 엘리먼트 및 ECMLocation 엘리먼트를 포함한다.
VirtualChannelLocation 엘리먼트는 채널의 소스를 받을 수 있는 IP 주소 및 전송 프로토콜 정보를 포함한다. 이를 위해 VirtualChannelLocation 엘리먼트는 ProgramNumber 속성 및 IPLocation 엘리먼트를 포함한다. ProgramNumber 속성을 선택적으로 지원함으로써 MPTS로의 확장성을 보장함과 동시에 SPTS의 경우에도 수신 한 스트림이 내가 원하는 스트림인지를 확인할 수 있는 기회를 제공한다. IPLocation 엘리먼트는 채널의 소스를 받을 수 있는 URL 정보를 포함하는 Location URL 속성을 포함한다.
ChannelSourcePurpose 엘리먼트는 채널의 성격을 나타내는 값인 소스 타입 정보를 포함하며, 복수 개의 소스 타입 정보를 포함할 수 있다. 여기서, 소스 타입 정보는 HD, SD, PIP 및 Barker 중 어느 하나의 값이 될 수 있다. Barker 채널은 광고 혹은 홍보용의 채널로써 해당 채널의 권한이 없어서 시청할 수 없을 때 이 채널로 자동 선택되며 해당채널의 홍보와 가입 안내의 역할을 수행하며, Barker는 HD Barker, SD Barker 및 PIP Barker 중 적어도 하나의 값을 포함한다.
한 채널은 ChannelSourcePurpose가 지정하는 값 별로 하나씩의 소스를 가질 수 있다. 즉, ChannelSourcePurpose 엘리먼트가 하나의 HD 및 하나의 SD를 동시에 포함하는 경우에는, 한 채널은 하나의 HD 소스 및 하나의 SD 소스를 가질 수 있다. 그러나 한 채널은 2개의 HD 소스를 동시 가질 필요는 없으므로, ChannelSourcePurpose 엘리먼트는 2개의 HD를 동시에 포함하지 않는다.
VideoAttributes 엘리먼트는 해당 소스의 비디오 속성 정보를 포함한다. 이를 위해 VideoAttributes 엘리먼트는 비디오 코덱 정보를 포함하는 Codec 속성, 비디오 프로파일 정보를 포함하는 Profile 속성 및 비디오 레벨 정보를 포함하는 Level 속성을 포함한다.
AudioAttributes 엘리먼트는 해당 소스의 오디오 속성 정보를 포함한다. 이를 위해 AudioAttributes 엘리먼트는 오디오 코덱 정보를 포함하는 Codec, 비디오 프로파일 정보를 포함하는 Profile 속성, 오디오 레벨 정보를 포함하는 Level 속성, 오디오 bitrate 정보를 포함하는 Bitrate 속성 및 오디오 샘플링 주파수 정보를 포함하는 SamplingFrequency 정보를 포함한다.
VideoAttribute 엘리먼트에 포함된 비디오 속성 정보 및 AudioAttributes 엘리먼트에 포함된 오디오 속성 정보를 통해 ITF의 기능에 맞추어서 최적의 소스를 선택하여 시청할 수 있다.
ECMLocation 엘리먼트는 ECMLocation은 ECM 정보를 수신할 수 있는 주소 정보를 포함한다.
도 13은 본 발명에 따른 서비스 프로바이더 디스커버리(Service Provider Discovery)에 대한 바람직한 일실시예의 수행과정을 도시한 흐름도이다.
도 13을 참조하면, ITF는 SD 서버를 찾는다(S1300). 여기서, ITF는 도 4에서 전술된 SD 서버(Service Discovery Server)의 주소 목록 서치 방식에 따라 SD 서버를 찾을 수 있다.
ITF는 SD 서버의 주속 목록을 기초로 SD 서버에 접속하여 SD 서버로부터 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)를 구한다(S1310). 여기서, 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)는 도 5에서 전술한 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)일 수 있다. 또한 ITF는 SD 서버로부터 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)를 PUSH 모드 또는 PULL 모드로 수신받을 수 있다.
ITF는 수신한 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)의 ServiceProviderID 속성을 파싱하여, ServiceProviderID 속성에 포함된 서비스 프로바이더 식별자 정보를 산출한다(S1320).
ITF는 산출한 서비스 프로바이더 식별자 정보가 서비스를 제공받기를 원하는 서비스 프로바이더인지를 확인한다(S1330). 서비스를 제공받기를 원하는 서비스 프로바이더가 아닌 경우에는, ITF는 단계 S1300을 수행하여 SD 서버의 주속 목록에서 다른 SD 서버를 찾는다.
서비스를 제공받기를 원하는 서비스 프로바이더인 경우에는, ITF는 프로바이더 디스커버리 레코드(Service Provider Discovery Record)의 Name 속성 및 Description 속성을 파싱하여, Name 속성에 포함된 서비스 프로바이더의 이름에 대한 정보 및 Description 속성에 포함된 서비스 프로바이더에 대한 상세한 텍스트 설명 정보를 산출한다(S1340).
그리고 ITF는 프로바이더 디스커버리 레코드(Service Provider Discovery Record)의 SProviderRegistrationServer 엘리먼트를 파싱하여, SProviderRegistrationServer 엘리먼트에 포함된 서비스 프로바이더의 Registration Server의 주소 정보를 산출한다(S1350). ITF는 산출한 Registration Server의 주소 정보를 기초로 Registration Server에 접속하여 ITF 등록 절차를 수행할 수 있다.
도 14는 본 발명에 따른 서비스 프로바이더 등록(Service Provider Registration) 및 서비스 디스커버리(Service Discovery)에 대한 바람직한 일실시 예의 수행과정을 도시한 흐름도이다.
도 14를 참조하면, ITF는 서비스 프로바이더 디스커버리 레코드에 포함된 Registration Server의 주소 정보가 지정하는 Registration Server로 등록 요청을 전송한다(S1400). 여기서, ITF는 등록 요청으로 도 6에서 전술된 ITFRegistrationInputType 레코드를 전송할 수 있다.
Registration Server는 등록 요청을 수신하여 ITF의 등록 여부를 판단한다(S1410). 여기서, Registration Server는 등록 요청으로 ITFRegistrationInputType 레코드를 수신할 수 있고, ITFRegistrationInputType 레코드에 포함된 가입자 식별자 정보 및 가입자 위치 정보를 기초로 등록 여부를 판단할 수 있다.
등록이 승인된 경우에는, ITF는 ITFRegistrationOutputType 레코드를 수신한다(S1420). 여기서, ITFRegistrationOutputType 레코드는 도 7에서 전술된 ITFRegistrationOutputType 레코드일 수 있고, 또한 TFRegistrationOutputType 레코드에 포함된 정보는 ITFRegistrationInputType 레코드에 포함된 정보에 의해 커스트마이징된 정보일 수 있다.
ITF는 수신한 ITFRegistrationOutputType 레코드의 MasterSITableLocation 엘리먼트 파싱하여, MasterSITableLocation 엘리먼트에 포함된 Master SI Table의 위치 정보를 산출한다(S1430).
ITF는 산출한 Master SI Table의 위치 정보를 기초로 마스터 SI 테이블 레코드(Master SI Table Record)를 수신한다(S1440). 여기서, 수신된 마스터 SI 테이블 레코드(Master SI Table Record)는 도 9에서 전술된 마스터 SI 테이블 레코드(Master SI Table Record)일 수 있다.
ITF는 수신한 ITFRegistrationOutputType 레코드의 SubscribedChannelMap 엘리먼트를 파싱하여, SubscribedChannelMap 엘리먼트에 포함된 사용자가 가입한 채널 맵에 대한 정보를 산출한다(S1450). 여기서, ITF는 사용자가 가입한 채널 맵을 수신하기 위한 채널 맵 위치 정보를 마스터 SI 테이블 레코드(Master SI Table Record)의 ChannelMapMaster로 부터 산출할 수 있다.
ITF는 상기 산출한 채널 맵 위치 정보를 기초로 채널 맵 레코드(Channel Map Record)를 수신한다(S1460). 여기서, 수신된 채널 맵 레코드(Channel Map Record)는 도 10에서 전술된 채널 맵 레코드(Channel Map Record) 및 도 11에서 전술된 채널 맵 레코드(Channel Map Record) 중 적어도 하나일 수 있다.
ITF는 수신한 채널 맵 레코드(Channel Map Record)의 ChannelDetailsLocation 엘리먼트를 파싱하여, ChannelDetailsLocation 엘리먼트에 포함된 채널의 상세 정보의 위치 정보를 산출한다(S1470).
ITF는 산출한 채널의 상세 정보의 위치 정보를 기초로 채널 디테일스 레코드를 수신한다(S1480). 여기서, 수신한 채널 디테일스 레코드는 도 12a 및 도 12b에서 도시된 채널 디테일스 레코드일 수 있다.
그리고 ITF는 수신한 서비스 서비스를 시작한다(S1490).
도 15는 마스터 SI 테이블(Master SI Table)의 업데이트를 처리하는 방법에 대한 바람직한 일실시예의 수행과정을 도시한 흐름도이다.
도 15를 참조하면, ITF는 마스터 SI 테이블(Master SI Table)을 업데이트한다(S1500). ITF는 마스터 SI 테이블(Master SI Table)을 실시간으로 모니터닝하며 수신한 마스터 SI 테이블 레코드(Master SI Table Record)의 버전 변경 여부를 확인할 수 있다. 그리고 수신한 마스터 SI 테이블 레코드(Master SI Table Record)의 버전이 변경된 경우에는, ITF는 수신한 마스터 SI 테이블 레코드(Master SI Table Record)에 포함된 정보로 마스터 SI 테이블(Master SI Table)을 업데이트한다.
ITF는 마스터 SI 테이블(Master SI Table)에 포함된 ChannelMapMaster 엘리먼트 중 업데이트를 위한 ChannelMapMaster 엘리먼트를 선택한다(S1510).
ITF는 선택한 ChannelMapMaster 엘리먼트가 사용자가 가입한 채널 맵을 수신하기 위한 정보를 포함하는지 확인한다(S1520). 이를 위해 ITF는 ITFRegistrationOutputType 레코드의 SubscribedChannelMap에 포함된 사용자가 가입한 채널 맵에 대한 정보를 사용할 수 있다.
사용자가 가입한 채널 맵을 수신하기 위한 정보를 포함하는 경우에는, ITF는 선택한 ChannelMapMaster 엘리먼트의 VCListVersion 속성에 포함된 버전 정보가 변경되었는지 확인한다(S1530). VCListVersion 속성에 포함된 버전 정보가 변경된 경우에는, ITF는 업데이트된 채널 맵 레코드(Channel Map Record)를 수신하고, 수신한 채널 맵 레코드(Channel Map Record)에 포함된 정보로 채널 맵을 업데이트한다(S1540).
마스터 SI 테이블(Master SI Table)에 선택되진 않은 ChannelMapMaster 엘리 먼트가 있는지 확인한다(S1550). 선택되진 않은 ChannelMapMaster 엘리먼트가 있는 경우에는, ITF는 단계 S1510을 수행한다.
도 16은 마스터 SI 테이블(Master SI Table)의 업데이트를 처리하는 방법에 대한 바람직한 다른 실시예의 수행과정을 도시한 흐름도이다.
도 16을 참조하면, ITF는 마스터 SI 테이블을 업데이트한다(S1600). ITF는 마스터 SI 테이블을 실시간으로 모니터닝하며 수신한 마스터 SI 테이블 레코드(Master SI Table Record)의 버전 변경 여부를 확인할 수 있다. 그리고 수신한 마스터 SI 테이블 레코드의 버전이 변경된 경우에는, ITF는 수신한 마스터 SI 테이블 레코드에 포함된 정보로 마스터 SI 테이블을 업데이트한다.
ITF는 마스터 SI 테이블에 포함된 ChannelMapMaster 엘리먼트 중 업데이트를 위한 ChannelMapMaster 엘리먼트를 선택한다(S1610).
ITF는 선택한 ChannelMapMaster 엘리먼트가 사용자가 가입한 채널 맵을 수신하기 위한 정보를 포함하는지 확인한다(S1620). 이를 위해 ITF는 ITFRegistrationOutputType 레코드의 SubscribedChannelMap에 포함된 사용자가 가입한 채널 맵에 대한 정보를 사용할 수 있다.
사용자가 가입한 채널 맵을 수신하기 위한 정보를 포함하는 경우에는, ITF는 선택한 ChannelMapMaster 엘리먼트의 VCListVersion 속성에 포함된 버전 정보가 변경되었는지 확인한다(S1630). VCListVersion 속성에 포함된 버전 정보가 변경된 경우에는, ITF는 업데이트된 채널 맵 레코드(Channel Map Record)를 수신하고, 수신한 채널 맵 레코드에 포함된 정보로 채널 맵을 업데이트한다(S1640).
ITF는 선택한 ChannelMapMaster 엘리먼트의 ChannelDetailsVersion 속성에 포함된 버전 정보가 변경되었는지 확인한다(S1650). ChannelDetailsVersion 속성에 포함된 버전 정보가 변경된 경우에는, 채널 상세 정보(Channel Details) 업데이트를 수행한다(S1650).
마스터 SI 테이블에 선택되진 않은 ChannelMapMaster 엘리먼트가 있는지 확인한다(S1670). 선택되진 않은 ChannelMapMaster 엘리먼트가 있는 경우에는, ITF는 단계 S1610을 수행한다.
도 17은 채널 디테일스 버전(Channel Details Version)의 업데이트를 처리하는 방법에 대한 바람직한 일실시예의 수행과정을 도시한 흐름도이다.
도 17을 참조하면, ITF는 채널 맵을 업데이트한다(S1700).
ITF는 채널 맵에서 채널을 선택한다(S1710). 여기서, ITF는 채널 맵에서 선택한 채널의 상세 정보의 위치 정보를 포함하는 ChannelDetailsLocation 엘리먼트도 함께 선택할 수 있다.
ITF는 선택한 ChannelDetailsLocation 엘리먼트의 VCVersion 속성에 포함된 버전 정보가 변경되었는지를 확인한다(S1720). 버전 정보가 변경된 경우에는, ITF는 업데이트된 채널 디테일스 레코드를 수신하고, 수신한 채널 디테일스 레코드에 포함된 정보를 기초로 선택한 채널의 채널 디테일스(Channel Details)를 업데이트한다(S1730).
ITF는 채널 맵에서 선택되지 않은 채널이 있는 지를 확인한다(S1740). 선택되지 않은 채널이 있는 경우에는, ITF는 단계 S1710을 수행한다.
도 18은 채널 디테일스 버전(Channel Details Version)의 업데이트를 처리하는 방법에 대한 바람직한 다른 실시예의 수행과정을 도시한 흐름도이다.
도 18을 참조하면, ITF는 채널 맵에서 채널을 선택한다(S1800). 여기서, ITF는 채널 맵에서 선택한 채널의 상세 정보의 위치 정보를 포함하는 ChannelDetailsLocation 엘리먼트도 함께 선택할 수 있다.
ITF는 마스터 SI 테이블(MasterSITable)에서 선택한 ChannelDetailsLocation 엘리먼트의 ServiceID 속성에 포함된 식별자 정보와 같은 식별자 정보를 포함하는 ServiceID 속성이 포함된 Virtual Channel Master 엘리먼트를 검색한다(S1810).
ITF는 검색한 Virtual Channel Master 엘리먼트의 VCVersion 속성에 포함된 버전 정보와 선택한 ChannelDetailsLocation 엘리먼트의 VCVersion 속성에 포함된 버전 정보와 같은 지를 판단한다(S1820). 버전 정보과 다른 경우에는, ITF는 업데이트된 채널 디테일스 레코드를 수신하고, 수신한 채널 디테일스 레코드에 포함된 정보를 기초로 선택한 채널의 채널 디테일스(Channel Details)를 업데이트한다(S1830).
ITF는 채널 맵에서 선택되지 않은 채널이 있는 지를 확인한다(S1840). 선택되지 않은 채널이 있는 경우에는, ITF는 단계 S1800을 수행한다.
도 19는 본 발명에 따른 EPG 디스커버리 레코드 타입(EPG Discovery Record Type)에 대한 바람직한 일실시예의 스키마를 도시한 도면이다.
도 19를 참조하면, EPG 디스커버리 레코드(EPG Discovery Record)는 EPG 데이터를 디스커버리(discovery) 위한 EPG 디스커버리 정보를 포함한다. 이를 위해, EPG 디스커버리 레코드(EPG Discovery Record)는 EPGProviderID 속성, Version 속성, Name 엘리먼트, Description 엘리먼트, EPG ServerLocation 엘리먼트, TargetServiceProviderID 엘리먼트 및 Logo 엘리먼트를 포함한다.
EPGProviderID는 EPG 데이터를 제공하는 제공자를 유일하게 식별할 수 있는 식별자 정보를 포함한다. 여기서, 식별자 정보로 등록된 도메인 이름이 사용될 수 있다.
Version 속성은 EPG 디스커버리 레코드(EPG Discovery Record)의 버전 정보를 포함한다.
Name 엘리먼트는 EPG 데이터 제공자의 텍스트 이름에 대한 정보를 포함하며, EPG 데이터 제공자는 각 언어별로 하나씩의 이름을 가질 수 있다. 이를 위해, Name 엘리먼트는 Language 속성을 포함한다. 또한 Name 엘리먼트는 Language 속성을 복수개 포함할 수 있으며 복수의 Language 속성 각각은 각 언어별로 정의된 EPG 데이터 제공자의 텍스트 이름에 대한 정보를 포함한다.
Description 엘리먼트는 EPG 데이터 제공자에 대한 상세한 텍스트 설명 정보를 포함하며 텍스트 설명 정보는 EPG 데이터 제공자의 이름에 대항 정보와 유사하게 각 언어별로 하나씩 있을 수 있다. 이를 위해, Description 엘리먼트는 Language 속성을 포함한다. 또한 Description 엘리먼트는 Language 속성을 복수개 포함할 수 있으며 복수의 Language 속성 각각은 각 언어별로 정의된 텍스트 설명 정보를 포함한다.
EPG ServerLocation 엘리먼트는 EPG 데이터를 받을 수 있는 IP 주소 정보 및 EPG 데이터를 수신하는데 사용되는 프로토콜 정보 포함한다.
TargetServiceProviderID 엘리먼트는 EPG 데이터 제공자가 지원하는 서비스 프로바이더들의 ID 정보를 포함한다.
Logo는 이 EPG 데이터 제공자의 logo의 위치 정보를 포함한다. 여기서, logo의 위치 정보는 URI 형태일 수 있다.
도 20은 본 발명에 따른 ITF(IPTV Terminal Function)에 대한 바람직한 일실시예의 구성을 도시한 블록도이다.
도 20을 참조하면, ITF는 네트워크 인터페이스부, IP 네트워크 스택(IP Network Stack)(2015), 파일 핸들러(File Handler)(2020), SI 핸들러(SI Handler)(2025), EPG 핸들러(EPG Handler)(2030), 저장부(Storage)(2035), SI 디코더(SI Decoder)(2040), EPG 디코더(EPG Decoder)(2045), ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050), 채널 서비스 매니저(Channel Service Manager)(2055), 애플리케이션 매니저(Application Manager)(2060), 디멀티플렉서(2065), PSI/PSIP 파서(PSI/PSIP Parser)(2070), A/V 디코더(A/V Decoder)(2075) 및 디스플레이 모듈(Display Modul)(2080)을 포함한다. 여기서, 네트워크 인터페이스부는 모뎀(Modem)(2005) 및 이더넷 네트워크 인터페이서(Ethernet NIC)(2010)를 포함할 수 있다.
모뎀(Modem)(2005)은 Physical level에서 ITF가 IP 네트워크와 연결되는 인 터페이스 역할을 수행한다. 모뎀(Modem)(2005)은 물리적인 매체(Physical medium)를 통해서 전송된 신호를 디모듈레이트(Demodulate)하여, 디지털 신호로 복원하고 ITF가 서비스 프로바이더로 전송하는 디지털 신호를 모듈레이트(modulate)하여, IP 네트워크로 출력한다. 모뎀(Modem)(2005)은 Cable 모뎀, DSL 모뎀 등으로 구현될 수 있다.
이더넷 네트워크 인터페이서(Ethernet NIC)(2010)는 모뎀(Modem)(2005)을 통하여 전송 받은 디지털 신호를 IP 패킷을 복원하여 이를 IP 네트워크 스택(IP Network Stack)(2015)으로 출력한다. 또한 이더넷 네트워크 인터페이서(Ethernet NIC)(2010)는 IP 네트워크 스택(IP Network Stack)(2015)로부터 출력되는 IP 패킷을 이더넷 데이터그램으로 캡슐화하여 모뎀(Modem)(2005)으로 출력한다.
IP 네트워크 스택(IP Network Stack)(2015)은 IP Protocol stack에 따른 각 layer의 처리 모듈을 처리한다. IP 네트워크 스택(IP Network Stack)(2015)은 ITF에 수신되는 패킷과 ITF에서 전송하는 패킷에 대하여 소스로부터 목적지까지의 패킷 전달에 관여한다. 그리고 IP 네트워크 스택(IP Network Stack)(2015)은 수신된 패킷을 적절한 프로토콜에 대응되도록 분류하고, 파일 핸들러(File Handler)(2020) 및 디멀티플렉서(2065)로 분류된 패킷을 출력한다. 일예로 네트워크 스택(IP Network Stack)(2015)은 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record), ITF 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record), 마스터 SI 테이블 레코드(Master SI Table Record), 채널 맵 레코드(Channel Map Record), 채널 디테일스 레코드 및 EPG 디스커버리 레코드(EPG Discovery Record) 중 어느 하나를 포함하는 패킷을 수신한 경우에는, 해당 패킷에 포함된 데이터를 파일 핸들러(File Handler)(2020)로 출력한다. 또한 네트워크 스택(IP Network Stack)(2015)은 ITF 레지스트레이션 입풋 레코드(ITF Registration Input Record)를 IP 패킷화하여 서비스 프로바이더로 전달되도록 이더넷 네트워크 인터페이서(Ethernet NIC)(2010)로 출력한다.
파일 핸들러(File Handler)(2020)는 IP 네트워크 스택(IP Network Stack)(2015)이 출력한 데이터를 취합하여 파일 형태로 복원한다. 여기서, 파일 핸들러(File Handler)(2020)는 FLUTE를 이용하여 IP 네트워크 스택(IP Network Stack)(2015)이 출력한 데이터를 파일 형태로 복원할 수 있다. 즉 서비스 프로바이더는 FLUTE를 이용하여 파일을 전송할 수 있고, 파일 핸들러(File Handler)(2020)는 FLUTE를 이용하여 서비스 프로바이더가 전송한 파일을 수신받을 수 있다. 파일 핸들러(File Handler)(2020)는 변환한 파일을 분류하여 SI 핸들러(SI Handler)(2025) 및 EPG 핸들러(EPG Handler)(2030) 중 어느 하나로 출력한다.
SI 핸들러(SI Handler)(2025)는 파일 핸들러(File Handler)(2020)로부터 전송 받은 File 형태의 데이터 중에서, IPTV SI 데이터에 해당하는 부분을 처리하여 저장부(Storage)(2035)에 저장한다. 여기서, IPTV SI 데이터는 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record), ITF 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record), 마스터 SI 테이블 레코드(Master SI Table Record), 채널 맵 레코드(Channel Map Record), 채널 디테일스 레코드 및 EPG 디스커버리 레코드(EPG Discovery Record) 중 적어도 하나일 수 있다.
EPG 핸들러(EPG Handler)(2030)는 파일 핸들러(File Handler)(2020)로부터 전송 받은 File 형태의 데이터 중, IPTV EPG 데이터에 해당하는 부분을 처리하여 저장부(Storage)(2035)에 저장할 수 있다. 여기서, IPTV EPG 데이터는 EPG 디스커버리 레코드에 포함된 정보를 이용하여 서비스 프로바이더로부터 수신받을 수 있다.
저장부(Storage)(2035)는 SI 핸들러(SI Handler)(2025)가 제공하는 SI, EPG 핸들러(EPG Handler)(2030)가 제공하는 EPG 및 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)가 제공하는 데이터 등을 저장한다.
SI 디코더(SI Decoder)(2040)는 저장부(Storage)(2035)에 저장된 SI 데이터를 디코딩하여 필요한 정보를 복원하고, 이를 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)에 제공한다. SI 디코더(SI Decoder)(2040)는 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)로부터 유용한 IPTV 서비스 프로바이더에 대한 정보 및 보안 관리되는 네트워크로 서비스 프로바이더에 접속하기 위한 정보를 산출한다. 일예로 SI 디코더(SI Decoder)(2040)는 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)를 파싱하여 서비스 프로바이더 디스커버리 레코드에 포함된 등록 서버(Registration Server) 주소 정보를 산출할 수 있다.
또한 SI 디코더(SI Decoder)(2040)는 ITF 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record)를 파싱하여, ITF 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record)에 포함된 정보를 산출할 수 있다. 일예로 SI 디코 더(SI Decoder)(2040)는 ITF 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record)에 포함된 EPG 데이터를 디스커버리(discovery) 하기 위한 EPG 디스커버리 정보 및 마스터 SI 테이블 레코드 수신하기 위한 주소 정보를 산출할 수 있다.
또한 SI 디코더(SI Decoder)(2040)는 마스터 SI 테이블 레코드(Master SI Table Record)를 파싱하여, 마스터 SI 테이블 레코드(Master SI Table Record)에 포함된 채널 맵 레코드 및 채널 디테일스 레코드를 수신하기 위한 정보, 채널 맵 레코드의 버전 정보, 및 채널 디테일스 레코드의 버전 정보를 산출할 수 있다.
그리고 SI 디코더(SI Decoder)(2040)는 채널 맵 레코드(Channel Map Record)로부터 채널 맵 정보를 산출할 수 있고, 채널 디테일스 레코드로부터 해당 채널의 채널 상세 정보를 산출할 수 있다.
EPG 디코더(EPG Decoder)(2045)는 EPG 정보가 필요할 경우에는 저장부(Storage)(2035)에 저장된 EPG 데이터를 가져와 분석하여, EPG 데이터를 복원하다. 그리고 EPG 디코더(EPG Decoder)(2045)는 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)에 복원된 EPG 데이터를 제공한다.
ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 ITF의 동작을 제어한다. ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 SI 디코더(SI Decoder)(2040), EPG 디코더(EPG Decoder)(2045) 및 디스플레이 모듈(Display Modul)(2080)을 제어하고, ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 채널 서비스 매니저(Channel Service Manager)(2055) 및 애플 리케이션 매니저(Application Manager)(2060)로부터 입력되는 요청을 처리한다.
ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 SI 디코더(SI Decoder)(2040)를 제어하여 채널 맵을 만들고 채널 서비스 매니저(Channel Service Manager)(2055)로부터 수신한 키 입력에 따라 상기 채널 맵을 이용하여 채널을 선택하다. 그리고 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 선택된 채널이 수신되도록 SI 디코더(SI Decoder)(2015)를 제어한다. 또한 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 선택된 채널이 수신되도록 IP 네트워크 스택(IP Network Stack)(2015)을 제어할 수 있다. 또한 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)는 선택된 채널이 수신되도록 PSI/PSIP 파서(PSI/PSIP Parser)(2070)를 제어할 수 있다.
채널 서비스 매니저(Channel Service Manager)(2055)는 사용자로부터 채널 요청 신호를 입력받고, 입력된 채널 요청 신호를 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)에 제공하여 요청된 채널로 채널이 변경되도록 관장한다.
애플리케이션 매니저(Application Manager)(2060)는 전반적인 상태를 관리하고 유저 인터페이스를 제공한다. 애플리케이션 매니저(Application Manager)(2060)는 유저 인터페이스를 통해 사용자로부터 EPG 디스플레이 요청을 받은 경우에는, EPG 디스플레이 요청을 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)에 제공하여 디스플레이 모듈(Display Modul)(2080)이 EPG를 디스플레이하도록 관장한다.
디멀티플렉서(2060)는 수신된 패킷을 오디오 데이터, 비디오 데이터 및 PSI(Program Specific Information) 데이터 등으로 역다중화하여 각각 A/V 디코더(A/V Decoder)(2075) 및 PSI/PSIP 파서(PSI/PSIP Parser)(2070)에 전송한다. 즉 디멀티플렉서(2065)는 IP 네트워크 스택(IP Network Stack)(2015)으로부터 전송 받은 IP 패킷에서 MPEG-2 Transport Stream 데이터를 추출하여 각 PID에 따라 PSI/PSIP 파서(PSI/PSIP Parser)(2070) 또는 A/V 디코더(A/V Decoder)(2075)로 전달한다.
PSI/PSIP 파서(PSI/PSIP Parser)(2070)는 디멀티플렉서(2060)로부터 전송 받은 IP Datagram 내의 MPEG-2 Transport Stream의 각 데이터(A/V, etc.)의 PID 정보 등의 프로그램 엘리먼트(Program element)를 접속할 수 있는 정보를 담은 PSI/PSIP 데이터를 추출 및 파싱한다. 또한 PSI/PSIP 파서(PSI/PSIP Parser)(2070)는 추출한 PSI/PSIP 데이터를 기초로 디멀티플렉서(2060)의 역다중화 과정을 제어할 수 있다.
A/V 디코더(A/V Decoder)(2075)는 디멀티플렉서(2010)에서 수신된 비디오 데이터와 오디오 데이터를 디코딩한다. 이를 위해 디코더(2014)는 오디오 디코더 및 비디오 디코더를 포함할 수 있다. 상기 오디오 디코더에서 디코딩된 오디오 데이터는 디스플레이 모듈(Display Modul)(2080)을 통하여 사용자에게 제공되며, 상기 비디오 디코더에서 디코딩된 비디오 데이터는 디스플레이 모듈(Display Modul)(2080)을 통하여 디스플레이된다.
디스플레이 모듈(Display Modul)(2080)은 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)의 제어에 따라 A/V 디코더(A/V Decoder)(2075)가 디 코딩한 비디오 데이터 및 오디오 데이터를 디스플레이한다. 또한 디스플레이 모듈(Display Modul)(2080)은 ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)로부터 EPG 데이터를 수신하여, ITF 오퍼레이션 컨트롤러(ITF Operation Controller)(2050)에 따라 수신한 EPG 데이터를 디스플레이한다.
도 21은 본 발명에 따른 가상 채널 설정 방법에 대한 바람직한 일실시예의 수행과정을 도시한 흐름도이다.
도 21을 참조하면, ITF는 네트워크 접속(Network Attachment)을 수행한다(S2100). 여기서, 네트워크 접속(Network Attachment)은 ITF가 IP 네트워크와 layer 3 계층의 연결을 설정하고, 네트워크 배치 데이터(network configuration data)를 획득하는 절차이다.
ITF는 서비스 프로바이더 디스커버리(Service Provider Discovery)를 수행하여 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)를 획득한다(S2105). 여기서, ITF는 도 13에서 전술된 서비스 프로바이더 디스커버리(Service Provider Discovery)를 실시할 수 있다.
ITF는 획득한 서비스 프로바이더 디스커버리 레코드(Service Provider Discovery Record)에 포함된 정보를 이용하여 SI 및 EPG 데이터를 획득한다(S2110). 여기서, ITF는 SI 메타데이터를 획득하기 위해 도 14에서 전술된 서비스 프로바이더 등록(Service Provider Registration) 및 서비스 디스커버리(Service Discovery)를 수행할 수 있다. ITF는 서비스 프로바이더 등록(Service Provider Registration)을 수행하여 ITF는 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record)를 획득할 수 있고, 획득한 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record)에 포함된 정보를 기초로 서비스 디스커버리(Service Discovery)를 수행할 수 있다. 그리고 ITF는 서비스 디스커버리(Service Discovery)를 수행하여 마스터 SI 테이블 레코드(Master SI Table Record), 채널 맵 레코드(Channel Map Record) 및 채널 디테일스 레코드를 획득할 수 있다. SI 메타데이터는 채널 맵 레코드(Channel Map Record) 및 채널 디테일스 레코드에 포함된 정보로부터 산출될 수 있다.
또한 ITF는 레지스트레이션 아웃풋 레코드(ITF Regitstration Output Record)에 포함된 EPGDiscoveryLocation에 포함된 정보를 기초로 EPG 데이터를 획득할 수 있다.
ITF는 구한 SI 메타데이터를 이용하여 채널 맵을 생성하고 생성한 채널 맵을 저장한다(S1215). 그리고 ITF는 사용자의 가상 채널 요청 신호를 입력받는다(S1220). 여기서, 사용자는 채널을 업/다운하여 시청할 가상 채널을 선택할 수 있다.
또한 ITF는 획득한 EPG 데이터를 이용하여 EPG를 생성하고 생성한 EPG를 저장한다(S1225). ITF는 저장한 EPG를 디스플레이한다(S1230). 그리고 ITF는 디스플레이된 EPG로부터 선택된 가상 채널 요청 신호를 입력받는다(S1235). 여기서, 사용자는 스트린상에 디스플레이된 EPG에서 시청하기 원하는 특정 가상 채널을 선택할 수 있다.
ITF는 가상 채널 요청 신호에 따라 요청된 가상 채널에 대한 정보를 상기 저장된 채널 맵에서 검색한다(S1240). 여기서, ITF는 요청된 가상 채널의 SeviceID와 일치하는 SeviceID를 포함하는 Channel Details Location을 채널 맵에서 검색하여 Channel Details Location의 LocationURL에 포함된 가상 채널을 수신할 수 있는 위치 정보를 검출할 수 있다. 또한 ITF는 요청된 가상 채널의 SeviceID와 일치하는 SeviceID를 포함하는 채널 디테일스를 검색하여 요청된 가상 채널의 상세 정보를 검출할 수 있다.
ITF는 검색된 가상 채널에 대한 정보를 기초로 상기 요청된 가상 채널로 튜닝한다(S1245). 여기서, ITF는 상기 검출된 가상 채널을 수신할 수 있는 위치 정보가 지시하는 주소를 접속하여 상기 요청된 가상 채널에 대한 IPTV 서비스를 수신할 수 있다. ITF는 수신한 IPTV 서비스를 사용자게에 제공한다(S1250).
이하에서는 본 발명에 따라 ITF(IPTV Terminal Function)에서 채널 맵을 빌딩(building)하기 위하여 채널을 제어하는 방법 및 장치에 관하여 첨부된 도면을 참조하여 상세하게 설명한다. 따라서, 본 발명에 따르면, ITF에서 IPTV 서비스를 제공함에 있어서 사용자의 편리를 추구할 수 있다.
특히, 본 명세서에서는 IPTV 서비스 이용에 필수적인 SI(System Information)와 EPG(Electronic Programming Guide) 데이터를 이용하여 ITF에서 보다 효율적으로 채널 맵을 빌딩하기 위하여 채널을 제어하는 방법 및 장치를 설명한다.
관련하여, 본 명세서에서 "채널(Channel)"이라 함은, 기존 방송 환경에서 사 용되는 채널의 개념과, IPTV 서비스 및 컨텐츠의 이용과 관련된 채널 모두를 통칭하는 의미로 사용한다.
그리고 본 명세서에서 "액티브 채널(Active Channel)"이라 함은, 관련 규격에서 정의된 내용을 포함하고, IPTV 서비스 및 컨텐츠 이용에 필수적인 SI 정보와 EPG 정보를 참조할 때, 현재 방송이 중단되지 않고 서비스되고 있는 채널의 의미로 사용한다.
또한, 본 명세서에서 "인액티브 채널(Inactive Channel)"이라 함은, 상기 액티브 채널과 달리 현재 방송이 중단되어 서비스되고 있지 않는 채널의 의미로 사용한다.
IPTV 환경에서 각 가상 채널의 서비스는 24시간 연속적이지 않을 수 있다. 예를 들어, 어느 하나의 가상 채널이 오전 6:00에서 저녁 12시까지는 액티브 채널이나 상기 시간을 제외하고는 인액티브 채널일 수 있다. 따라서, ITF에서는 채널을 운용함에 있어서, 각 가상 채널에 대한 채널 상태에 대해 보다 정확하게 알고 있어야 할 필요가 있다. 그러나, 현재 관련 규격에서는 그에 대한 내용 즉, 채널 운용과 관련하여 채널 상태의 변경 등에 관한 정보가 구체적으로 정의되어 있지 않다. 따라서, ITF는 그러한 채널 상태 등을 반영하지 못함으로써 채널 운용이 비효율적이 되고, 그로 인해 사용자의 불편을 초래할 수도 있다.
이에 따라, 본 발명에서는 송수신단 간에 미리 약속에 의해 SI 데이터나 EPG 데이터에 본 발명의 일실시예에 따라 각 채널의 상태 및 그 상태 등의 변경 등 채널 운용과 관련된 정보를 정의하여 상기와 같은 문제점을 해결하고자 한다. 따라 서, 본 발명에 따르면, ITF는 보다 효율적으로 채널을 운용할 수 있게 되고, 그에 따라 사용자의 불편을 해소할 수 있게 된다.
도 22는 본 발명과 관련하여, IPTV의 서비스 어퀴지션(Service Acquisition)을 위해 필요한 SI 데이터의 주요 컴포넌트(Component)와 그 관계 및 EPG와의 관계를 도시한 것이다.
도 22를 참조하면, SI 데이터는, 컨텐트를 액세스하고 파싱하기 위해 ITF에 필수적인 정보로서(The information that is necessary for the ITF to access and parse the content.), 크게 마스터 SI 테이블(Master SI table), 가상 채널 맵(Virtual Channel Map), 및 가상 채널 디스크립션 테이블(Virtual Channel Description table)을 포함하여 구성된다. 이때, 상기 마스터 SI 테이블 이외의 나머지 테이블은 예를 들어, 다른 SI 테이블들(other SI tables)이라 명명하여 구분할 수 있다.
마스터 SI 테이블은 SI 데이터의 버전 등의 이슈를 제어하기 위한 것으로, 개별 가상 채널 맵 인스턴스의 위치(Location of the Virtual Channel Map instance) 정보 엘리먼트와 상기 가상 채널 맵 인스턴스 자체 내 버전 넘버와 일치되는 각 가상 채널 맵 인스턴스의 해당 인스턴스의 버전 넘버(Version number of this instance of the Virtual Channel Map instance, which shall match the version number in the Virtual Channel Map instance itself) 정보 엘리먼트를 포함한다. 여기서, 상기 위치 정보는 예를 들어, VirtualChannelUrl 엘리먼트 표현되어 있다. 따라서, ITF는 상기 마스터 SI 테이블 내 VirtualChannelUrl 엘리먼트를 이용하여 개별 가상 채널 맵 인스턴스를 수신할 수 있다.
가상 채널 맵은 해당 SI 데이터 및 IPTV 서비스를 제공하는 서비스 프로바이더(SP)의 가상 채널들에 대한 정보를 제공하며, 해당 가상 채널 맵에서 가상 채널들의 가상 채널 디스크립션을 포함하는 파일의 디폴트 위치 정보 엘리먼트(Default location of the file containing the Virtual Channel Descriptions of the virtual channels in this VirtualChannelMap)와 각 가상 채널 서비스 엘리먼트를 포함한다. 여기서, 상기 디폴트 위치 정보 엘리먼트는 예를 들어, VirutalChannelDescription 엘리먼트로 표현하고, 상기 각 가상 채널 서비스 엘리먼트는 VirtualChannelService 엘리먼트로 표현될 수 있다. 상기 VirtualChannelService 엘리먼트는 엔트리(entry)를 포함할 수 있고(Each Virtual Channel Service has an entry), 상기 엔트리로 예를 들면, VirtualChannelDescriptionOverride 엘리먼트가 포함될 수 있다. 따라서, ITF는 상기 가상 채널 맵 내 VirutalChannelDescription 엘리먼트를 이용하여 가상 채널 디스크립션 테이블을 수신할 수 있다.
가상 채널 디스크립션 테이블은 각각의 가상 채널을 접속하기 위한 리소스(resource) 정보를 제공하며, 상기 가상 채널 서비스의 식별자를 정의하는 VirtualChannelServiceId 엘리먼트(Identifier of the Virtual Channel Service)와 관련 Source Table를 수신하기 위해 특정 값에 의해 정의된 다수의 ProgrammingSource 엘리먼트를 포함한다. 따라서, ITF는 상기 ProgrammingSource 엘리먼트를 이용하여 관련 Source table를 수신할 수 있다.
결국, ITF는 수신되는 마스터 SI 테이블을 이용하여 가상 채널 맵 을 수신하고, 수신된 가상 채널 맵을 이용하여 가상 채널 디스크립션 테이블을 수신하고, 수신된 가상 채널 맵 디스크립션 테이블을 이용하여 관련 소스 테이블을 수신한다.
도 22를 참조하면, EPG 데이터는, 가상 채널 서비스에 대한 정보를 제공하고, VirtualChannelService 엘리먼트를 포함한다. 여기서, 상기 EPG 데이터 내 VirtualChannelService 엘리먼트는 상기 SI 데이터 내 가상 채널 맵에 포함된 VirtualChannelService 엘리먼트와, 가상 채널 디스크립션 테이블에 포함된 VirtualChannelServiceId 엘리먼트와 연계된다.
도 23은 본 발명과 관련하여, ITF가 EPG 데이터를 받아 EPG 정보를 출력한 화면(Screen)을 도시한 것이다.
도 23을 참조하면, 12:00에서 15:00 사이에 존재하는 30-1(ABC), 31-1(NBC), 32-1(FOX-1), 및 32-2(FOX-2)의 4 개의 채널이 도시되었다. 그리고 상기 각 채널에 대한 가이드 정보가 제공되고 있다.
여기에서, 32-2(FOX-2) 채널은, 12:00부터 14:00까지는 서비스가 제공되지 않는 인밸리드(invalid) 상태이고, 14:00부터 서비스가 제공되는 밸리드(valid) 상태가 된다. 이때, ITF는, 사용자가 12:00와 14:00 사이에 32-2(FOX-2) 채널을 채널 업/다운(Channel Up/down) 또는 EPG 화면에서의 선택 등으로 사용자가 접속을 요청하는 경우, 해당 채널이 인밸리드 상태이므로 접속을 허용하여서는 안된다.
이를 위해서는 ITF는 해당 시각에 해당 채널이 인밸리드 상태인지 즉, ITF는 채널의 상태를 파악하고 있어야 상기와 같은 채널 접속 요청에 적절히 대응할 수 있다. 그러나, 현재 관련 규격에 정의된 SI 데이터나 EPG 데이터에 채널의 상태 등과 관련된 정보가 정의되지 않아 ITF는 알지 못하여 그런 상황에 적절히 대응하지 못하고 비효율적으로 동작할 수밖에 없다.
이하에서는 상기와 같은 본 발명에 따라 ITF(IPTV Terminal Function)에서 채널 맵(Channel Map)을 빌딩(building)하기 위하여 채널을 제어하는 방법을 설명함에 있어서, 두 방식으로 나누어 설명한다. 첫째가, 각 가상 채널 속성 즉, 해당 가상 채널이 액티브 채널에서 인액티브 채널로 또는 그 반대로 변경되는 시간에 대한 정보를 정의하여 이용하는 방법과, 둘째, 해당 가상 채널이 현재 액티브 채널인지 인액티브 채널인지 알려주고, 현재 속성에서 다른 속성으로 변경되는 시간에 대한 정보를 정의하는 방법이 있다. 이하에서는 상기 방식을 각 실시 예로 하여 설명한다.
우선 첫 번째 방식에 따른 실시 예를 기술하면, 다음과 같다.
도 24는 본 발명의 일실시 예에 따라 구성한 가상 채널 속성(Virtual Channel Availability) 엘리먼트의 스키마(schema)를 도시한 것이고, 도 25는 상기 도 24의 스키마를 XML 형태로 표시한 것이다.
첨부된 도 24와 25를 참조하면, 가상 채널 속성 엘리먼트는 해당 가상 채널의 상태가 변경되는 시간 정보를 포함한다. 여기에서, 상기 해당 가상 채널 상태가 변경되는 시간 정보라 함은 예를 들어, 해당 가상 채널이 인액티브 채널에서 액티브 채널로 변경되는 시각에 대한 정보와, 반대로 액티브 채널에서 인액티브 채널로 변경되는 시각에 대한 정보 중 적어도 하나를 포함한다.
도 24와 25를 참조하면, 본 발명에 따라 가상 채널 속성 엘리먼트는 VCValidateTime 엘리먼트와 VCInvalidateTime 엘리먼트 중 적어도 하나의 엘리멘트를 포함할 수 있다. 이때, 상기 가상 채널 속성 엘리먼트는 해당 가상 채널이 인액티브 채널인지 액티브 채널인지에 따라 대응되는 하나의 엘리먼트만이 포함될 수 있다. 따라서, ITF는 상기 가상 채널 속성 엘리먼트가 존재하고, 그 하위에 존재하는 엘리먼트로부터 해당 가상 채널이 액티브 채널인지 아니면 인액티브 채널인지 판단할 수 있다.
VCValidateTime 엘리먼트는 데이트타임 타입(dateTime type)의 엘리먼트로 현재(예를 들어, SI 데이터가 제작된 시점) 해당 가상 채널이 인액티브 채널(Inactive Channel)일 경우 유효하다. 해당 엘리먼트의 값은 앞으로 해당 가상 채널이 액티브 채널(Active Channel)로 전환될 시점을 나타내며, 해당 가상 채널이 액티브 채널로 전환될 계획이 현재 없을 시, 특정 값으로 해당 엘리먼트를 설정해 이를 나타낼 수 있다. 해당 가상 채널 서비스가 액티브가 되는 시간을 지시한다. 만약 해당 엘리먼트가 생략되면, 해당 가상 채널 서비스는 항상 액티브임을 의미할 수 있다.(Designation of the times when this Virtual Channel Service is active (i.e, “on the air”). If this element is omitted, it SHALL mean that this Virtual Channel Service is always active.)
VCInvalidateTime element는 데이트타임 타입의 엘리먼트로 현재(예를 들어, SI 데이터가 제작된 시점) 해당 가상 채널이 액티브 채널일 경우 유효하다. 해당 엘리먼트의 값은 앞으로 해당 가상 채널이 인액티브 채널로 전환될 시점을 나타내 며, 해당 가상 채널이 인액티브 채널로 전환될 계획이 현재 없을 시, 특정 값으로 해당 엘리먼트를 설정해 이를 나타낸다. 해당 가상 채널 서비스가 인액티브가 되는 시간을 지시한다.
도 26은 본 발명의 일실시 예에 따라 상기 도 24의 가상 채널 속성 엘리먼트 스키마를 포함하는 가상 채널 서비스 타입(Virtual Channel Service Type)의 스키마 구조를 도시한 것이다. 도 27은 상기 도 26의 스키마를 XML 형태로 표현한 것이다.
도 26과 27을 참조할 때, 본 발명의 일실시 예에 따른 가상 채널 속성 엘리먼트의 위치는 제한적이지 않다. 즉, 상기 가상 채널 속성 엘리먼트는 가상 채널 맵에 포함되는 것으로 설명하나 예를 들어, 상기 가상 채널 속성 엘리먼트는 가상 채널 디스크립션 테이블에 포함될 수도 있다. 다만, 본 명세서에서는 설명의 편의를 위해 상기 가상 채널 서비스(Virtual Channel Service) 엘리먼트의 하위 엘리먼트로 예시한다. 여기에서, 상기 가상 채널 서비스 엘리먼트는 가상 채널 맵 엘리먼트의 하위 엘리먼트인 가상 채널 맵 엘리먼트의 다수의 엘리먼트의 하나이다. 또한, 상기 가상 채널 서비스 엘리먼트는 그 하위에 가상 채널 서비스 엘리먼트를 포함하고, 상기 가상 채널 서비스 엘리먼트는 그 하위에 다수의 엘리먼트를 포함하는바, 본 발명의 일실시 예인 가상 채널 속성 엘리먼트도 상기 가상 채널 서비스 엘리먼트에 포함되는 것을 예로 한다.
따라서, 상술한 가상 채널 속성 엘리먼트의 내용이 업데이트될 경우, 가상 채널 서비스 엘리먼트의 가상 채널 서비스 버전(Virtual Channel Service Version) 엘리먼트 또한 업데이트 되어 ITF로 하여금, 해당 가상 채널 정보의 변화가 있음을 알 수 있도록 할 수 있다.
다음으로, 두 번째 방식에 따른 다른 실시 예를 기술하면, 다음과 같다.
도 28은 본 발명의 일실시 예에 따라 구성한 가상 채널 속성 엘리먼트의 스키마를 도시한 것이고, 도 29는 상기 도 28의 스키마를 XML 형태로 표시한 것이다.
이하에서는 상술한 도 24내지 25와 공통된 부분에 대한 설명은 원용하고, 상이한 부분을 위주로 하여 설명한다. 본 실시 예는, 상술한 실시 예와 달리, 하기의 두 엘리먼트가 모두 존재할 수도 있다.
VCAvailabilityFlag 엘리먼트는 대수 타입(boolean type)의 플래그(flag)이다. 상기 플래그는, 현재(예를 들어, SI 데이터가 제작된 시점) 해당 가상 채널이 액티브 채널인지 또는 인액티브 채널인지를 나타낸다. 이 엘리먼트가 해당 가상 채널이 인액티브 채널이라고 나타낼 때에만 다음 가상 채널 유효 타임 엘리먼트(Virtual Channel Validate Time element)가 유효하게 된다.
VCValidateTime 엘리먼트는 상술한 도 24의 정의와 동일하나, 상기 VCAvailabilityFlag 엘리먼트가 해당 가상 채널이 인액티브 채널임을 나타낼 때만 유효하다.
다만, 본 발명의 기술적 사상은 상기 각 엘리먼트의 명칭이나 설명에 한정되는 것은 아니다. 예를 들어, 상기 플래그 엘리먼트는 해당 가상 채널의 상태 즉, 인밸리드한지 아니면 밸리드한지를 알려주고, 그에 따라 시간 엘리먼트에서 현재 상태에서 다른 상태 즉, 인액티브 채널에서 액티브 채널로 또는 액티브 채널에서 인액티브 채널로 변경되는 시간에 대한 정보를 주는 것으로 정의할 수도 있다. 이는 당연히 본 발명의 기술사상에 포함됨을 알 수 있다.
따라서, ITF는 VCAvailabilityFlag 엘리먼트로부터 해당 가상 채널이 액티브 채널 또는 인액티브 채널인지 판단하고, 판단 결과 인액티브 채널이면, VCValidateTime 엘리먼트로부터 해당 가상 채널이 언제 액티브 채널로 변경되는지를 알게 되어 이를 반영할 수 있을 것이다. 이때, 만약, ITF는 상기에서 VCAvailabilityFlag 엘리먼트가 존재하지 않고 VCValidateTime 엘리먼트만 존재한다면 해당 가상 채널은 인액티브 채널로 판단하여 처리할 수도 있을 것이다.
도 30은 본 발명의 일실시 예에 따라 상기 도 28의 가상 채널 속성 엘리먼트 스키마를 포함하는 가상 채널 서비스 타입의 스키마 구조를 도시한 것이다. 도 31은 상기 도 30의 스키마를 XML 형태로 표현한 것이다.
도 30과 31은 상술한 도 26과 27에서 설명한 내용과 동일한바, 그를 원용한다. 다만, 도 28과 29를 참조할 때, 가상 채널 속성 부분이 상이하다.
도 32는 본 발명의 일실시 예에 따라 가상 채널 속성 엘리먼트를 이용하여 ITF(IPTV Terminal Function)에서 채널 맵(Channel Map)을 빌딩(building)하기 위하여 채널을 제어하는 방법을 설명하기 위해 도시한 순서도이다.
도 32는 사용자가 예를 들어, 리모콘(remote controller)을 이용하여 채널 업/다운(Channel Up/down)을 하거나 화면상에 출력된 EPG에서의 선택을 통하여 채널 변경을 요청하면, ITF는 상기 요청에 따라 변경할 가상 채널이 인액티브 채널인 경우 SI 데이터에 해당 가상 채널의 속성(Availability) 정보를 이용하여 해당 가 상 채널로 튜닝을 방지하는 구조를 설명한다. 여기에서, 도 32의 S3201 내지 S3209 단계는 상술한 도 21의 내용과 동일한바 이를 원용하고, 이하에서는 S3210 단계에서부터 설명한다.
ITF는 S3209 단계에서 검색한 결과를 이용하여 채널 맵 정보 내 가상 채널 속성 엘리먼트가 존재하는지 판단한다(S3210).
상기 S3210 단계 판단 결과, 만약 상기 채널 맵 정보 내 가상 채널 속성 엘리먼트가 존재하지 않는다면, 상기 S3205 단계 또는 S3208 단계를 통해 사용자로부터 요청된 해당 가상 채널을 튜닝(S3214)한다. 그리고 튜닝된 가상 채널을 통해 수신되는 IPTV 서비스를 사용자에게 제공한다(S3215).
그러나, 상기 S3210 단계 판단 결과, 만약 상기 채널 맵 정보 내 가상 채널 속성 엘리먼트가 존재한다면, 상기 가상 채널 속성 엘리먼트를 파싱(S3211)한다. 그리고 상기 파싱된 가상 채널 속성 엘리먼트에 근거하여 상기 S3205 단계 또는 S3208 단계를 통해 사용자로부터 요청된 해당 가상 채널이 인액티브 채널인지 판단한다(S3212). 상기 S3212 단계에서, 해당 가상 채널이 인액티브 채널인지 판단은 예를 들어, 도 24 또는 26에서 상술한 본 발명에 따라 두 가지 방법으로 판단할 수 있다.
즉, 하나는, 도 24에서 상술한 바와 같이, 상기 파싱된 가상 채널 속성 엘리먼트의 하위 엘리먼트가 VCValidateTime 엘리먼트이면, 해당 가상 채널은 인액티브 채널로 판단할 수 있다. 다만, 상기 하위 엘리먼트가 VCInvalidateTime 엘리먼트이면, 해당 가상 채널은 액티브 채널로 판단할 수 있다.
다른 하나는, 도 28에서 상술한 바와 같이, 상기 파싱된 가상 채널 속성 엘리먼트의 하위 엘리먼트 중 VCAvailabilityFlag 엘리먼트를 이용하는 것이다. 즉, 상기 VCAvailabilityFlag 엘리먼트는 각 가상 채널이 현재 액티브 채널인지 인액티브 채널인지를 알려주므로, 이로부터 사용자로부터 요청된 해당 가상 채널인 인액티브 채널인지 알 수 있다.
이에 따라, ITF는 상기 S3212 단계에서 판단 결과 해당 가상 채널이 인액티브 채널이 아니면, 상술한 S3210 단계에서 판단 결과 채널 맵 정보 내 가상 채널 속성 엘리먼트가 존재하지 않는 경우의 플로우와 같이 S3214 단계와 S3215 단계를 거쳐 사용자에게 IPTV 서비스를 제공한다.
그러나, 상기 S3212 단계에서 판단 결과 만약 해당 가상 채널이 인액티브 채널이면, ITF는 상기 사용자의 요청에도 불구하고 해당 가상 채널이 튜닝되지 않도록 한다(S3213). 다만, ITF는 상기 S3205 단계 또는 S3208 단계에서 사용자로부터 채널 변경에 대한 요청이 수신되었으므로, 그에 대해 응답이 필요한 경우도 있다. 이 경우, ITF는 예를 들어, "No Service" 메시지 또는 "When this Channel will be available"이라는 메시지를 UI(User Interface)(예를 들어, 도 23의 EPG 화면)를 제공할 수도 있다. 그리고 다시 S3204 단계로 돌아가 사용자의 채널 선택 요청을 대기한다.
상술한 본 발명의 바람직한 실시 예에 따르면, ITF는 각 가상 채널의 서비스 제공과 관련된 속성을 미리 파악할 수 있고, 각 채널 맵 및 서비스 어퀴지션(Service Acquisition)을 위한 SI 데이터의 운용을 보다 효율적으로 할 수 있다.
한편, 본 발명에서 사용되는 용어(terminology)들은 본 발명에서의 기능을 고려하여 정의 내려진 용어들로써, 이는 당 분야에 종사하는 기술자의 의도 또는 관례 등에 따라 달라질 수 있으므로, 그 정의는 본 발명의 전반에 걸친 내용을 토대로 내려져야 할 것이다.
본 발명은 상술한 실시 예에 한정되지 않으며, 첨부된 청구범위에서 알 수 있는 바와 같이 본 발명이 속한 분야의 통상의 지식을 가진 자에 의해 변형이 가능하고 이러한 변형은 본 발명의 범위에 속한다.
그리고, 상기에서 언급한 수치들은 바람직한 실시 예이거나, 단순한 예시인 바, 상기 수치들에 본 발명의 권리범위가 제한되지는 않으며, 첨부된 청구범위에서 알 수 있는 바와 같이 본 발명이 속한 분야의 통상의 지식을 가진 자에 의해 변형이 가능하고 이러한 변형은 본 발명의 범위에 속한다.