KR102234451B1 - 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용 - Google Patents

멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용 Download PDF

Info

Publication number
KR102234451B1
KR102234451B1 KR1020207014905A KR20207014905A KR102234451B1 KR 102234451 B1 KR102234451 B1 KR 102234451B1 KR 1020207014905 A KR1020207014905 A KR 1020207014905A KR 20207014905 A KR20207014905 A KR 20207014905A KR 102234451 B1 KR102234451 B1 KR 102234451B1
Authority
KR
South Korea
Prior art keywords
different
client
client devices
digital component
devices
Prior art date
Application number
KR1020207014905A
Other languages
English (en)
Other versions
KR20200060552A (ko
Inventor
티로네 나카하라
스텔라 로
Original Assignee
구글 엘엘씨
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 구글 엘엘씨 filed Critical 구글 엘엘씨
Publication of KR20200060552A publication Critical patent/KR20200060552A/ko
Application granted granted Critical
Publication of KR102234451B1 publication Critical patent/KR102234451B1/ko

Links

Images

Classifications

    • H04L65/4076
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • H04L65/611Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for multicast or broadcast
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/16Arrangements for providing special services to substations
    • H04L12/18Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
    • H04L12/185Arrangements for providing special services to substations for broadcast or conference, e.g. multicast with management of multicast group membership
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/10Active monitoring, e.g. heartbeat, ping or trace-route
    • H04L61/2069
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/50Address allocation
    • H04L61/5069Address allocation for group communication, multicast communication or broadcast communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/238Interfacing the downstream path of the transmission network, e.g. adapting the transmission rate of a video stream to network bandwidth; Processing of multiplex streams
    • H04N21/2385Channel allocation; Bandwidth allocation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/4104Peripherals receiving signals from specially adapted client devices
    • H04N21/4108Peripherals receiving signals from specially adapted client devices characterised by an identification number or address, e.g. local network address
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/438Interfacing the downstream path of the transmission network originating from a server, e.g. retrieving encoded video stream packets from an IP network
    • H04N21/4383Accessing a communication channel
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/63Control signaling related to video distribution between client, server and network components; Network processes for video distribution between server and clients or between remote clients, e.g. transmitting basic layer and enhancement layers over different transmission paths, setting up a peer-to-peer communication via Internet between remote STB's; Communication protocols; Addressing
    • H04N21/64Addressing
    • H04N21/6405Multicasting
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/60Network structure or processes for video distribution between server and client or between remote clients; Control signalling between clients, server and network components; Transmission of management data between server and client, e.g. sending from server to client commands for recording incoming content stream; Communication details between server and client 
    • H04N21/65Transmission of management data between client and server
    • H04N21/654Transmission by server directed to the client
    • H04N21/6543Transmission by server directed to the client for forcing some client operations, e.g. recording
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/80Generation or processing of content or additional data by content creator independently of the distribution process; Content per se
    • H04N21/81Monomedia components thereof
    • H04N21/812Monomedia components thereof involving advertisement data

Landscapes

  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Multimedia (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Cardiology (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Business, Economics & Management (AREA)
  • Marketing (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

컨텐츠를 전달하는 멀티캐스트 스트림과 상이한 추가 멀티캐스트 스트림에 제공될 보조 디지털 컴포넌트에 대한 디지털 컴포넌트 요청들을 수신하는 디지털 컴포넌트 요청 서버를 포함하는 시스템으로서, i) 상기 추가 멀티캐스트 스트림들을 통해 배포하기 위해 보조 디지털 컴포넌트들을 선택하고, 상기 보조 디지털 컴포넌트들은 다른 추가 멀티캐스트 스트림들 각각에 대해 선택된 보조 디지털 컴포넌트와 상이한 상기 추가 멀티캐스트 스트림들 중 하나에 대해 선택되고, 그리고 ii) 상기 다수의 클라이언트 디바이스의 복수의 그룹 중 하나의 그룹을 상기 추가 멀티캐스트 스트림들 각각에 할당하는 디지털 컴포넌트 배포 서버와; 그리고 상기 요청을 제출한 다른 클라이언트 디바이스를 포함하는 상기 다수의 클라이언트 디바이스들의 그룹에 할당된 상기 각각의 추가 멀티캐스트 스트림들에 동조(tune)하도록 상기 다수의 클라이언트 디바이스에 대한 명령들을 생성하는 명령 생성 서버를 포함한다.

Description

멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용{OPTIMIZED UTILIZATION OF STREAMING BANDWIDTH USING MULTICAST}
본 명세서는 멀티캐스트 기술을 사용하여 가용 스트리밍 대역폭을 활용하기 위한 개선된 기술을 개시한다. 더 많은 양의 컨텐츠가 네트워크 연결을 통해 스트리밍되고 서비스되는 스트리밍 디바이스의 수가 증가함에 따라 스트리밍 컨텐츠를 전달하는데 사용할 수 있는 제한된 대역폭 및/또는 채널을 보다 효율적으로 활용하기 위한 기술이 개발되고 있다.
멀티캐스트 스트림은 메인 컨텐츠 외에 스트리밍 디바이스에 렌더링될 보조 컨텐츠(supplemental content)를 배포하는데에도 사용된다. 그런데, 기존 시스템은 실시간으로 또는 특정 제한된 간격 또는 애드 혹(ad hoc) 간격으로 보조 컨텐츠의 스트리밍을 가능하게 하기 위해 여러 개의 멀티캐스트 스트림을 생성할 것을 요구한다. 이는 대역폭 가용성 및 메인 및 보조 컨텐츠의 원활한 재생과 관련된 여러 가지 문제를 나타낼 수 있으며, 이러한 스트리밍에 사용할 수 있는 네트워크 자원 및 컴퓨팅 자원을 과도하게 늘릴 수 있다. 본 출원은 보조 컨텐츠가 멀티캐스트 스트림에 할당되는 방식을 관리함으로써 메인 및 보조 컨텐츠의 최적화되고 원활한 재생을 보장하기 위해 이러한 결점을 극복하기 위한 기술을 제공하려고 시도한다.
본 명세서에서 설명된 요지의 혁신적인 양태는, 다수의 클라이언트 디바이스 각각으로부터, 스트리밍 컨텐츠를 각각의 클라이언트 디바이스에 전달하고 있는 멀티캐스트 스트림과 상이한 추가 멀티캐스트 스트림에 제공(present)될 보조 디지털 컴포넌트에 대한 디지털 컴포넌트 요청을 수신하는 디지털 컴포넌트 요청 서버와, 상기 다수의 클라이언트 디바이스에 가용 대역폭을 통해 배포될 수 있는 다수의 추가 멀티캐스트 스트림의 수는 상기 다수의 클라이언트 디바이스의 총 수보다 적고; i) 배포될 수 있는 상기 추가 멀티캐스트 스트림들 각각의 적어도 일부분을 통해 배포하기 위해 보조 디지털 컴포넌트들을 선택하고, 상기 보조 디지털 컴포넌트들은 상기 다른 추가 멀티캐스트 스트림들 각각에 대해 선택된 상기 보조 디지털 컴포넌트와 상이한 상기 추가 멀티캐스트 스트림들 각각에 대해 선택되고, 그리고 ii) 상기 다수의 클라이언트 디바이스의 복수의 그룹 중 하나의 그룹을 상기 보조 디지털 컴포넌트들을 배포하는 상기 추가 멀티캐스트 스트림들 각각에 할당하는 디지털 컴포넌트 배포 서버와, 상기 각각의 그룹에는 다수의 클라이언트 디바이스들의 다른 그룹들 각각에 할당된 상기 추가 멀티 캐스트 스트림과 상이한 추가 멀티 캐스트 스트림이 할당되고; 상기 요청을 제출한 상기 다른 클라이언트 디바이스를 포함하는 상기 다수의 클라이언트 디바이스들의 그룹에 할당된 상기 각각의 추가 멀티캐스트 스트림들에 동조(tune)하도록 상기 다수의 클라이언트 디바이스 각각에 대한 명령들을 생성하는 명령 생성 서버와; 그리고 상기 요청을 제출한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑(ping) 어드레스를 생성하는 핑 어드레스 생성 서버를 포함하는 시스템들에서 구현될 수 있다.
이들 양태들의 다른 실시예들은 컴퓨터 저장 디바이스 상에 인코딩된 방법들의 동작을 수행하도록 구성된 대응하는 방법 및 컴퓨터 프로그램을 포함한다.
이들 및 다른 실시예들은 각각 선택적으로 다음 특징들 중 하나 이상을 포함 할 수 있다. 예를 들어, 다수의 클라이언트 디바이스들의 적어도 하나의 그룹은 둘 이상의 상이한 클라이언트 디바이스를 포함한다. 상기 멀티캐스트 스트림은 다수의 클라이언트 디바이스 각각으로 동일한 메인 스트리밍 컨텐츠를 전달하고 있다. 상기 디지털 컴포넌트 요청을 수신하는 것은, 적어도 하나의 디지털 컴포넌트 요청에 대해, 상기 디지털 컴포넌트 요청 내의 다수의 디바이스 식별자를 수신하는 것을 더 포함하며, 상기 다수의 상이한 디바이스 식별자는 동일한 추가 멀티캐스트 스트림에 동일한 디지털 컴포넌트가 제공될 다수의 클라이언 디바이스를 지정한다. 상기 디지털 컴포넌트 요청의 수는 다수의 클라이언트 디바이스의 총 수보다 적다.
본 명세서에서 설명된 요지의 혁신적인 양태는, 하나 이상의 컴퓨터에 의해, 다수의 클라이언트 디바이스 각각으로부터, 스트리밍 컨텐츠를 각각의 클라이언트 디바이스로 전달하고 있는 멀티캐스트 스트림과 상이한 추가 멀티캐스트 스트림에 제시될 보조 디지털 컴포넌트에 디지털 컴포넌트 요청을 수신하는 단계와; 상기 하나 이상의 컴퓨터에 의해, 디지털 컴포넌트 요청들이 수신될 때 가용 대역폭을 통해 상기 다수의 클라이언트 디바이스에 배포될 수 있는 추가 멀티캐스트 스트림들의 수를 결정하는 단계와, 상기 추가 멀티캐스트 스트림들의 수는 상기 다수의 클라이언트 디바이스의 총 수보다 적고; 상기 하나 이상의 컴퓨터에 의해, 상기 요청들에 응답하여, 배포될 수 있는 상기 추가 멀티캐스트 스트림들 각각의 적어도 일부분을 통해 배포하기 위해 보조디지털 컴포넌트들을 선택하는 단계와, 상기 보조 디지털 컴포넌트들은 상기 다른 추가 멀티캐스트 스트림들 각각에 대해 선택된 상기 보조 디지털 컴포넌트와 상이한 상기 추가 멀티캐스트 스트림들 각각에 대해 선택되고; 상기 하나 이상의 컴퓨터에 의해, 상기 다수의 클라이언트 디바이스들의 복수의 그룹 중 하나의 그룹을 상기 보조 디지털 컴포넌트들을 배포하는 상기 추가 멀티캐스트 스트림들 각각에 할당하는 단계와, 상기 각각의 그룹에는 다수의 클라이언트 디바이스들의 다른 그룹들 각각에 할당된 상기 추가 멀티캐스트 스트림과 상이한 추가 멀티캐스트 스트림이 할당되고; 그리고 상기 하나 이상의 컴퓨터에 의해 상기 다수의 클라이언트 디바이스들로, 상기 수신된 요청들 각각에 대해 (i) 상기 요청을 제출한 클라이언트 디바이스를 포함하는 다수의 클라이언트 디바이스들의 그룹에 할당된 각각의 추가 멀티 캐스트 스트림에 동조하도록 상기 다수의 클라이언트 디바이스 각각에 지시하는 데이터 및 (ii) 상기 요청을 제출한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑(ping) 어드레스로 응답하는 단계를 포함하는 방법들에서 구현될 수 있다.
이들 양태들의 다른 실시예들은 컴퓨터 저장 디바이스들 상에 인코딩된 방법들의 동작을 수행하도록 구성된 대응하는 시스템, 장치 및 컴퓨터 프로그램을 포함한다.
이들 및 다른 실시예들은 각각 선택적으로 하나 이상의 다음 특징을 포함할 수 있다. 예를 들어, 다수의 클라이언트들의 그룹들 중 적어도 하나의 그룹은 둘 이상의 상이한 클라이언트 디바이스를 포함한다. 상기 멀티캐스트 스트림은 다수의 상이한 클라이언트 디바이스 각각으로 동일한 메인 스트리밍 컨텐츠를 전달하고 있다. 상기 디지털 컴포넌트 요청을 수신하는 단계는, 적어도 하나의 디지털 컴포넌트 요청에 대해, 상기 디지털 컴포넌트 요청 내의 다수의 디바이스 식별자를 수신하는 단계를 더 포함하고, 상기 다수의 디바이스 식별자는 동일한 추가 멀티캐스트 스트림에 동일한 디지털 컴포넌트가 제공될 다수의 클라이언 디바이스를 지정한다. 상기 디지털 컴포넌트 요청의 수는 상기 다수의 클라이언트 디바이스의 총 수보다 적다. 상기 방법은 하나 이상의 다수의 클라이언트 디바이스에 대해, 상기 클라이언트 구성 가능 핑 어드레스에 의해 지정된 목적지에서, 상기 클라이언트 디바이스가 클라이언트 구성 가능 핑 어드레스를 제출한 클라이언트 디바이스를 포함하는 각각의 그룹에 할당된 상기 추가 멀티캐스트 브로드캐스트에에 동조되었다는 통지를 수신하는 단계와; 상기 클라이언트 구성 가능 핑 어드레스를 데이터베이스에 저장하는 단계를 더 포함할 수 있다. 상기 할당하는 단계는 각각의 그룹과 관련된 하나 이상의 파라미터에 기초하여 상기 복수의 그룹의 각각의 그룹을 상기 추가 멀티캐스트 스트림들 중 상이한 하나에 할당하는 단계를 더 포함한다. 상기 파라미터들은, 각각의 그룹 내의 상기 다수의 클라이언트 디바이스와 관련된 인구 통계적 프로파일 특성을 포함할 수 있다. 상기 할당하는 단계는, 복수의 그룹의 각각의 그룹을 상기 추가 멀티캐스트 스트림들 중 상이한 것들에 할당하는 단계를 더 포함하고, 상기 방법은 특정 클라이언트 디바이스를 상기 상이한 그룹들 각각에 포함시키는 것으로부터 배제하는 단계를 더 포함한다.
본 명세서에서 설명된 요지의 혁신적인 양태는, 다수의 상이한 클라이언트 디바이스로부터, 스트리밍 컨텐츠를 상기 다수의 상이한 클라이언트 디바이스로 전달하고 있는 멀티캐스트 스트림과 상이한 추가 멀티캐스트 스트림에 제공될 보조 디지털 컴포넌트에 대한 개별 디지털 컴포넌트 요청들을 수신하는 디지털 컴포넌트 요청 서버와, 상기 다수의 상이한 클라이언트 디바이스에 가용 대역폭을 통해 배포될 수 있는 추가 멀티캐스트 스트림들의 수는 상기 다수의 상이한 클라이언트 디바이스의 총 수보다 적고; i) 배포될 수 있는 상기 추가 멀티캐스트 스트림들의 적어도 일부분을 통해 배포하기 위해, 다수의 상이한 보조 디지털 컴포넌트를 선택하고, ii) 상기 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상기 추가 멀티캐스트 스트림들 중 상이한 것들에 상기 다수의 상이한 클라이언트 디바이스들의 상이한 그룹들을 할당하는 디지털 컴포넌트 배포 서버와; 상기 요청을 제출한 상기 상이한 클라이언트 디바이스를 포함하는 상기 상이한 그룹들에 할당된 상기 추가 멀티캐스트 스트림들 중 하나에 동조하도록 상기 다수의 상이한 클라이언트 디바이스 각각에 대한 명령들을 생성하는 명령 생성 서버와; 그리고 상기 요청을 제출한 상기 상이한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑 어드레스를 생성하는 핑 어드레스 생성 서버를 포함하는 시스템들에서 구현될 수 있다.
이들 양태의 다른 실시예는 컴퓨터 저장 디바이스 상에 인코딩된, 방법들의 동작을 수행하도록 구성된 대응하는 방법 및 컴퓨터 프로그램을 포함한다. 이들 및 다른 실시예들은 각각 선택적으로 하나 이상의 다음 특징을 포함할 수 있다. 예를 들어, 상기 상이한 그룹들 중 적어도 하나의 그룹은 둘 이상의 상이한 클라이언트 디바이스를 포함한다. 상기 멀티캐스트 스트림은 다수의 상이한 클라이언트 디바이스 각각으로 동일한 스트리밍 컨텐츠를 전달하고 있다. 상기 개별 디지털 컴포넌트 요청들을 수신하는 단계는 적어도 하나의 디지털 컴포넌트 요청에 대해, 상기 디지털 컴포넌트 요청 내의 다수의 디바이스 식별자를 수신하는 단계를 더 포함하고, 상기 다수의 상이한 디바이스 식별자는 동일한 추가 멀티캐스트 스트림에 동일한 디지털 컴포넌트가 제공될 다수의 상이한 디바이스를 지정한다. 상기 디지털 컴포넌트 요청들의 수는 다수의 상이한 클라이언트 디바이스의 총 수보다 적다.
본 명세서에서 설명된 요지의 혁신적인 양태는, 하나 이상의 컴퓨터에 의해, 다수의 상이한 클라이언트 디바이스로부터, 스트리밍 컨텐츠를 상기 다수의 상이한 클라이언트 디바이스에 전달하고 있는 멀티캐스트 스트림과 상이한 멀티캐스트 스트림에 제공될 보조 디지털 컴포넌트에 대한 개별 디지털 컴포넌트 요청들을 수신하는 단계와; 상기 하나 이상의 컴퓨터에 의해, 상기 디지털 컴포넌트 요청들이 수신될 때 가용 대역폭을 통해 상기 다수의 상이한 클라이언트 디바이스에 배포될 수 있는 추가 멀티캐스트 스트림들의 수를 결정하는 단계와, 상기 추가 멀티캐스트 스트림들의 수는 상기 다수의 상이한 클라이언트 디바이스들의 총 수보다 적고; 상기 하나 이상의 컴퓨터에 의해, 상기 개별 요청들에 응답하여, 상기 배포될 수 있는 상기 추가 멀티캐스트 스트림들의 적어도 일부분을 통해 배포하기 위해다수의 상이한 보조 디지털 컴포넌트들을 선택하는 단계와; 상기 하나 이상의 컴퓨터에 의해, 상기 다수의 상이한 보조 디지털 컴포넌트들을 전송하는 상기 추가 멀티캐스트 스트림들 중 상이한 것들에 상기 다수의 상이한 클라이언트 디바이스들의 상이한 그룹들을 할당하는 단계와; 그리고 상기 하나 이상의 컴퓨터에 의해, 상기 다수의 상이한 클라이언트 디바이스들로, 상기 개별 요청들 각각에 대해 (i) 상기 요청을 제출한 상기 상이한 클라이언트 디바이스를 포함하는 상이한 그룹들에 할당된 상기 추가 멀티 캐스트 스트림들 중 하나에 동조하도록 상기 다수의 상이한 클라이언트 디바이스 각각에 지시하는 데이터 및 (ii) 상기 요청을 제출한 상기 상이한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑 어드레스로 응답하는 단계를 포함하는 방법들에서 구현될 수 있다.
이들 양태의 다른 실시예들은 컴퓨터 저장 디바이스 상에 인코딩된 방법들의 동작을 수행하도록 구성된 대응하는 시스템, 장치 및 컴퓨터 프로그램을 포함한다. 이들 및 다른 실시예들은 각각 선택적으로 하나 이상의 다음 특징을 포함할 수 있다. 예를 들어, 상기 상이한 그룹들 중 적어도 하나의 그룹은 둘 이상의 상이한 클라이언트 디바이스를 포함한다. 상기 멀티캐스트 스트림은 다수의 상이한 클라이언트 디바이스 각각으로 동일한 스트리밍 컨텐츠를 전달하고 있다. 상기 개별 디지털 컴포넌트 요청들을 수신하는 단계는, 적어도 하나의 디지털 컴포넌트 요청에 대해, 상기 디지털 컴포넌트 요청 내의 다수의 디바이스 식별자를 수신하는 단계를 더 포함하고, 상기 다수의 상이한 디바이스 식별자는 동일한 추가 멀티캐스트 스트림에 동일한 디지털 컴포넌트가 제공될 다수의 상이한 디바이스를 지정한다. 상기 디지털 컴포넌트 요청들의 수는 다수의 상이한 클라이언트 디바이스의 총 수보다 적다. 상기 방법은 하나 이상의 상기 다수의 클라이언트 디바이스에 대해, 상기 클라이언트 구성 가능 핑 어드레스에 의해 지정된 목적지에서, 상기 클라이언트 디바이스가 상기 클라이언트 구성 가능 핑 어드레스를 제출한 상기 상이한 클라이언트 디바이스를 포함하는 상기 상이한 그룹에 할당된 상기 추가 멀티캐스트 방송에 동조되었다는 통지를 수신하는 단계와; 그리고 상기 클라이언트 구성 가능 핑 어드레스를 데이터베이스에 저장하는 단계를 더 포함한다. 상기 할당하는 단계는 각 그룹과 관련된 하나 이상의 파라미터에 기초하여 상기 상이한 그룹들을 상기 추가 멀티캐스트 스트림들 중 상이한 것들에 할당하는 단계를 더 포함한다. 상기 파라미터는 상기 다수의 상이한 클라이언트 디바이스와 관련된 인구 통계적 프로파일 특성을 포함할 수 있다. 상기 다수의 상이한 클라이언트 디바이스의 상기 상이한 그룹들을 상기 추가 멀티캐스트 스트림들 중 상이한 것들에 할당하는 단계는, 특정 클라이언트 디바이스를 상기 상이한 그룹들 각각에 포함시키는 것으로부터 배제하는 단계를 더 포함한다.
본 명세서에서 설명된 주제의 특정 구현예들은 다음 이점들 중 하나 이상을 실현하도록 구현될 수 있다. 본 발명의 구현예들은 클라이언트 디바이스들과 디지털 컴포넌트들을 제공하는 서버 컴퓨팅 시스템 사이에서 제공하는 대역폭이 제한 될 때 다수의 클라이언트 디바이스들에 디지털 컴포넌트들의 할당을 제공한다. 특히, 다수의 클라이언트 디바이스 각각이 하나 이상의 클라이언트 디바이스에 개인화될 수 있는 (다수의 클라이언트 디바이스에 의해 디스플레이되는) 보조 디지털 컨텐츠를 요청할 때 다수의 클라이언트 디바이스로의 비디오 디지털 컴포넌트들의 선형 전달이 대역폭 할당에 의해 제한될 수 있다. 가용 대역폭을 효율적으로 이용하기 위해, 서버 컴퓨팅 시스템은 멀티 캐스팅 전달을 사용하여 다수의 클라이언트 디바이스로 보조 디지털 컴포넌트들을 배포하여, 보조 디지털 컴포넌트들의 다수의 구성이 클라이언트 디바이스들의 상이한 서브 세트에 제공되도록 할 수 있다.
소정(given)의 멀티캐스트 채널은 클라이언트 디바이스들의 그룹에 보조 디지털 컴포넌트들을 전달할 수 있는 반면, 상이한 멀티 캐스트 채널은 상이한 보조 디지털 컴포넌트들을 클라이언트 디바이스들의 다른 그룹에 전달할 수 있고, 따라서 클라이언트 디바이스들의 2개의 상이한 그룹이 실질적으로 동시에 상이한 보조 디지털 컴포넌트들을 제공할 수 있게 한다. 클라이언트 디바이스의 그룹 및 클라이언트 디바이스의 상이한 그룹이 모두 동일한 스트리밍 채널(예를 들어, 동일한 프로그램을 보는 경우)에 동조될 때, 상기 클라이언트 디바이스의 그룹은 보조 디지털 컴포넌트들을 제공하기 위해 일정 시간 동안 상기 소정의 멀티캐스트 채널에 동조하도록 지시될 수 있는 반면, 상기 클라이언트 디바이스의 상이한 그룹은 상이한 보조 디지털 컴포넌트들을 제공하기 위해 동일한 시간 동안 상기 상이한 멀티 캐스트 채널에 동조하도록 지시받을 수 있다. 상기 시간이 끝나면 모든 클라이언트 디바이스는 동일한 스트리밍 채널로 복귀하여 동일한 스트리밍 채널에서 제공되는 컨텐츠의 프레젠테이션을 계속할 수 있다. 이와 같이, 동일한 시간 동안, 2개의 상이한 그룹의 클라이언트 디바이스들은 상이한 컨텐츠가 클라이언트 디바이스들의 상이한 그룹들에 의해 제시될 수 있도록 하기 위해 상이한 각각의 스크리밍 채널에 동조될 수 있다. 보조 디지털 컴포넌트들을 전달하기 위해 멀티캐스트 스트림을 활용하면 클라이언트 디바이스들이 보조 디지털 컴포넌트들을 저장하지 않아도 된다. 한편, 동일한 멀티캐스트 채널에 대한 클라이언트 디바이스 그룹의 동조는, 대역폭 제한된 환경에서 (예를 들어, 유니캐스트 채널들을 사용하는 것과 관련하여) 더 많은 수의 클라이언트 디바이스를 서비스할 수 있으며, 동시에 (예를 들어, 동일한 스트리밍 채널에 모두 동조되거나 액세스하는) 상이한 클라이언트 디바이스들에 상이한 보조 디지털 컴포넌트들을 제공할 수 있다. 동일한 스트리밍 채널에 동조된 모든 클라이언트 디바이스에 동일한 보조 디지털 컴포넌트들이 제공된다는 사실에도 불구하고, 보조 디지털 컴포넌트의 프리젠테이션에 대한 클라이언트 디바이스 특정 보고는, 각각의 상이한 클라이언트 디바이스가 고유한 디바이스 식별자를 핑 (ping) 어드레스에 삽입할 수 있게 해주는 플레이스 홀더를 포함하는 구성 가능한 핑 어드레스의 사용을 통해 활성화(인에이블)된다.
본 명세서에서 개시된 주제의 하나 이상의 실시예의 세부 사항은 첨부된 도면 및 이하의 설명에서 설명된다. 상기 주제의 다른 잠재적인 특징, 양태 및 장점들은 상세한 설명, 도면 및 청구 범위로부터 명백해질 것이다.
도 1a 및 도 1b는 디지털 컴포넌트들의 환경 멀티캐스트 전달을 나타낸다.
도 2는 클라이언트 컴퓨팅 디바이스에 디지털 컴포넌트를 제공하는 예시적인 멀티캐스트 스트림을 도시한다.
도 3은 클라이언트 컴퓨팅 디바이스로 제공되는 보조 디지털 컴포넌트를 도시한다.
도 4는 디지털 컴포넌트의 멀티캐스트 전달을 위한 예시적인 프로세스를 도시한다.
도 5는 본 명세서에 개시된 기술을 구현하는데 사용될 수 있는 예시적인 컴퓨팅 시스템 및 모바일 컴퓨팅 디바이스를 도시한다.
본 명세서는 특정 스트리밍 채널(예를 들어, 디지털 컴포넌트를 전달하는데 사용되는 멀티캐스트 채널과 상이한 채널)을 통해 소정(given) 스트리밍 컨텐츠를 전송하는 동안 디지털 컴포넌트의 멀티캐스트 전달을 제공하는 방법, 시스템 및 컴퓨터 판독 가능 매체를 기술한다. 디지털 컴포넌트를 전달하기 위한 멀티캐스트 스트림의 활용은 상이한 디지털 컴포넌트가 동일한 시간 동안 다른 스트리밍 컨텐츠를 스트리밍하는 클라이언트 디바이스들 중 상이한 하나로 전달될 수 있게 한다. 특히, 시간 주기의 시작시, 일부 클라이언트 디바이스는 소정 디지털 컴포넌트를 전달하고 있는 특정 스트리밍 채널에 동조하도록 지시받을 수 있는 반면, 다른 클라이언트 디바이스는 다른 디지털 컴포넌트를 전달하는 다른 스트리밍 채널에 동조하도록 지시받을 수 있다. 이 시간 주기가 끝나면 모든 클라이언트 디바이스는 소정 스트리밍 컨텐츠의 프리젠테이션을 계속하기 위해 특정 스트리밍 채널로 되돌아가도록 동조될 수 있다. 디지털 컴포넌트를 전달하기 위한 멀티캐스트 채널의 이러한 이용은 대역폭 제한된 환경에서 가용 대역폭을 효율적으로 이용하면서 다양한 클라이언트 디바이스에 제공되는 디지털 컴포넌트의 개인화를 가능하게 한다. 아래에서 보다 상세하게 논의되는 바와 같이, 구성 가능한 핑(ping) 어드레스는 특정 디지털 컴포넌트가 멀티캐스트 스트림을 통해 전달되는 경우에도(예를 들어, 유니캐스트 스트림 또는 그렇지 않으면 해당 클라이언트 디바이스로 어드레싱되는) 각각의 클라이언트 디바이스가 그 클라이언트 디바이스에서 특정 디지털 컴포넌트의 프리젠테이션을 개별적으로 보고할 수 있게 하는데 사용될 수 있다.
일부 구현예에서, 본 명세서에 기술된 시스템은 다수의 다른 클라이언트 디바이스로부터, 스트리밍 컨텐츠를 다수의 상이한 클라이언트 디바이스로 전달하고 있는 멀티캐스트 스트림과 상이한 멀티캐스트 스트림에 제시될 보조 디지털 컴포넌트에 대한 디지털 컴포넌트 요청을 분리한다. 시스템은 또한, 디지털 컴포넌트 요청이 수신될 때 가용 대역폭을 통해 다수의 상이한 클라이언트 디바이스에 배포될 수 있는 다수의 추가 멀티캐스트 스트림을 더 결정하며, 상기 추가 멀티캐스트 스트림의 수는 다수의 상이한 클라이언트 디바이스의 총 수보다 적다. 시스템은 개별 요청에 응답하여 배포될 수 있는 추가 멀티캐스트 스트림의 적어도 일부분을 통해 배포하기 위한 다수의 상이한 보조 디지털 컴포넌트를 또한 선택한다. 시스템은 또한 다수의 상이한 보조 디지털 컴포넌트를 전송하는 추가 멀티캐스트 스트림 중 상이한 하나에 상기 다수의 상이한 클라이언트 디바이스의 상이한 그룹을 할당한다. 시스템은 또한 (i) 요청들을 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹들에 할당된 추가 멀티캐스트 스트림들 중 하나에 동조하도록 다수의 상이한 클라이언트 디바이스 각각에 지시하는 데이터 및 (ii) 상기 요청을 제출한 상이한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더(placeholder)를 포함하는 클라이언트 구성 가능 핑 어드레스를 사용하여 다수의 상이한 클라이언트 디바이스로 개별 요청 각각에 응답한다.
도 1a 및 도 1b는 디지털 컴포넌트들의 멀티캐스트 전달을 위한 환경(100)을 도시한다. 환경(100)은 서버 컴퓨팅 시스템(102), 클라이언트 컴퓨팅 디바이스(104a, 104b, 104c)(통칭하여 클라이언트 컴퓨팅 디바이스(104)라고 함) 및 디지털 컴포넌트 데이터베이스(106)를 포함한다. 서버 컴퓨팅 시스템(102)은 디지털 컴포넌트 요청 서버(110), 디지털 컴포넌트 배포 서버(112), 명령 생성 서버(114) 및 핑 어드레스 생성 서버(116)를 포함한다. 디지털 컴포넌트 요청 서버(110), 디지털 컴포넌트 배포 서버(112), 명령 생성 서버(114) 및 핑 어드레스 생성 서버(116) 각각은 개별 서버 컴퓨팅 시스템 또는 서버 컴퓨팅 시스템의 조합일 수 있다. 일부 구현예에서, 디지털 컴포넌트 요청 서버(110), 디지털 컴포넌트 배포 서버(112), 명령 생성 서버(114) 및 핑 어드레스 생성 서버(116) 각각은 동일한 물리적 하드웨어 세트로 구현될 수 있다. 서버 컴퓨팅 시스템(102)은 예를 들어 하나 이상의 네트워크를 통해 클라이언트 컴퓨팅 디바이스(104) 및 디지털 컴포넌트 데이터베이스(106)와 통신한다.
도 1a를 참조하면, 각각의 클라이언트 컴퓨팅 디바이스(104)는 (예를 들어, 제3자 컨텐츠 제공자로부터) 스트리밍 컨텐츠를 클라이언트 컴퓨팅 디바이스(104)에 전달하고 있는 멀티캐스트 스트림을 수신하고 있다. 예를 들어, 스트리밍 컨텐츠는 비디오 컨텐츠, 오디오 컨텐츠, 텍스트 컨텐츠, 이미지 컨텐츠 또는 다양한 컨텐츠 유형의 조합일 수 있다. 일부 예에서, 멀티캐스트 스트림은 각각의 클라이언트 컴퓨팅 디바이스(104)로 동일한 스트리밍 컨텐츠를 전달하고 있다. 예를 들어, 클라이언트 컴퓨팅 디바이스(104) 각각은 멀티캐스트 스트림이 클라이언트 컴퓨팅 디바이스(104) 각각에 실질적으로 동시에 전달하는 스포츠 방송에 동조된다.
각각의 클라이언트 디바이스(104)는 스트리밍 컨텐츠를 제시하거나 스트리밍 컨텐츠를 디스플레이 디바이스에 전달할 수 있는 컴퓨팅 디바이스일 수 있다. 예를 들어, 각 클라이언트 디바이스(104)는 미디어 스트리밍 디바이스, 컴퓨터, 스마트 폰, 태블릿 디바이스 또는 개인 디지털 어시스턴트일 수 있다. 일부 구현예에서, 개인 디지털 어시스턴트는 마이크로폰 및 스피커를 포함하고, 사용자가 명령을 음성으로 제출하고 상기 명령에 응답하여 오디오 및/또는 시각 정보를 제공할 수 있게 하는 디바이스이다. 예를 들어, 디지털 어시스턴트는 사용자가 음성으로 명령을 제출할 수 있는 마이크로폰을 포함할 수 있고, 오디오 정보가 사용자에게 제공되는 스피커를 포함할 수 있다. 개인 디지털 어시스턴트는 내장된 디스플레이를 포함할 수 있거나 또는 디스플레이에 무선으로 결합되어, 오디오 정보의 프리젠테이션과 함께 또는 오디오 정보와 별도로 시각 정보가 사용자에게 제시될 수 있게 한다. 간략하게, "클라이언트 컴퓨팅 디바이스"라는 용어는 본 명세서 전체에서 사용되며 위에서 논의된 클라이언트 디바이스들 중 어느 하나를 지칭하기 위한 것이다.
도 2를 참조하면 스트리밍 컨텐츠를 클라이언트 컴퓨팅 디바이스(104)로 전달하는 멀티캐스트 스트림(200)의 예가 도시된다. 즉, 멀티캐스트 스트림(200)은 실질적으로 동일한 시간에 각각의 클라이언트 컴퓨팅 디바이스(104)로 동일한 스트리밍 컨텐츠를 전달하고 있다. 즉, 각각의 클라이언트 컴퓨팅 디바이스(104)는 동일한 멀티캐스트 스트림에 동조된다. 예를 들어, 각각의 클라이언트 컴퓨팅 디바이스(104)는 라이브 스포츠 이벤트를 전달하는 멀티캐스트 스트림(예컨대, 실시간 선형 비디오)에 동조된다.
도 1a를 참조하면, 서버 컴퓨팅 시스템(102) 및 특히 디지털 컴포넌트 요청 서버(110)는 각각 클라이언트 컴퓨팅 디바이스(104a, 104b, 104c)로부터 디지털 컴포넌트 요청(120a, 120b, 120c)(통칭하여 디지털 컴포넌트 요청(120)으로 칭함)을 수신한다(동작 A). 예를 들어, 멀티캐스트 스트림(200) 동안 포인트(210)에서, 클라이언트 컴퓨팅 디바이스(104)는 디지털 컴포넌트 요청(120)을 서버 컴퓨팅 시스템(102)으로 각각 제공한다. 일부 예에서, 포인트(210)는 예를 들어 라이브 스포츠 이벤트의 타임 아웃 동안 또는 라이브 스포츠 이벤트의 컨텐츠 스트리밍의 중단(break) 동안에 멀티캐스트 스트림(200)의 스트리밍 컨텐츠 중단을 나타낼 수 있다. 일부 예에서, 클라이언트 컴퓨팅 디바이스(104)는 실질적으로 동일한 시간(예를 들어, 멀티캐스트 스트림(200)에 포함된 큐 톤(cue tone)에 의해 트리거된)에 서버 컴퓨팅 시스템(102)으로 디지털 컴포넌트 요청(120)을 각각 제공한다. 일부 예에서, 클라이언트 컴퓨팅 디바이스들(104)은 클라이언트 컴퓨팅 디바이스(104), 서버 컴퓨팅 시스템(102), 및/또는 각각의 클라이언트 컴퓨팅 디바이스(104)와 서버 컴퓨팅 시스템(102)간의 네트워크의 임의의 각각의 지연시간(latency) 문제를 고려하여 유사한 시간에 디지털 컴포넌트 요청(120)을 서버 컴퓨팅 시스템(102)에 각각 제공한다.
디지털 컴포넌트 요청들(120)은 멀티캐스트 스트림(200)과 상이한 멀티캐스트 스트림에서 제시될 보조 디지털 컴포넌트들에 대한 요청이다. 일부 예에서, 상이한 멀티캐스트 스트림은 멀티캐스트 스트림(200)을 제공하는 제3자 컨텐츠 제공자와는 다른 제3자 컨텐츠 제공자에 의해 제공된다. 보조 디지털 컴포넌트는 텍스트, 이미지, 비디오 또는 멀티미디어 디지털 컨텐츠를 포함할 수 있다. 일부 예에서, 디지털 컴포넌트는 광고를 포함할 수 있다.
일부 예에서, 디지털 컴포넌트 요청(120) 각각은 디지털 컴포넌트 요청(120)을 하는 각각의 클라이언트 컴퓨팅 디바이스(104)의 디바이스 식별자를 포함한다. 일부 예에서, 하나 이상의 디지털 컴포넌트 요청(120)은 다수의 클라이언트 컴퓨팅 디바이스(104)(예를 들어, 일괄 요청들)를 지정하는 다수의 디바이스 식별자를 포함할 수 있다. 예를 들어, 특정 디지털 컴포넌트 요청(120)은 클라이언트 컴퓨팅 디바이스(104a 및 104b)에 대한 디바이스 식별자를 포함할 수 있다. 다수의 디바이스 식별자를 포함하는 디지털 컴포넌트 요청(120)은 본 명세서에서 추가로 기술되는 동일한 추가 멀티캐스트 스트림상에 동일한 보조 디지털 컴포넌트에 대한 요청을 포함한다. 일부 예에서, 하나 이상의 디지털 컴포넌트 요청(120)은 대역폭 제한 환경(예를 들어, 환경(100))에서 가용 대역폭을 효율적으로 이용하기 위해 다수의 클라이언트 컴퓨팅 디바이스(104)를 지정하는 다수의 디바이스 식별자를 포함할 수 있다.
일부 예에서, 디지털 컴포넌트 요청(120)의 수는 클라이언트 컴퓨팅 디바이스(104)의 총 수보다 적다. 즉, 특정 디지털 컴포넌트 요청(120)이 다수의 디바이스 식별자를 포함하는 경우, 디지털 컴포넌트 요청(120)의 수는 클라이언트 컴퓨팅 디바이스(104)의 수보다 적다. 예를 들어, 특정 디지털 컴포넌트 요청(120)은 클라이언트 컴퓨팅 디바이스(104a 및 104b)에 대한 장치 식별자를 포함할 수 있으므로, 디지털 컴포넌트 요청(120)의 수(2개의 디지털 컴포넌트 요청(120))는 클라이언트 컴퓨팅 디바이스(104))의 수(3개의 클라이언트 컴퓨팅 디바이스(104))보다 적다.
서버 컴퓨팅 시스템(102)은 예를 들어 각각의 클라이언트 컴퓨팅 디바이스(104)와 서버 컴퓨팅 시스템(104) 사이에서 가용 대역폭을 통해 클라이언트 컴퓨팅 디바이스들(104)에 배포될 수 있는 추가 멀티캐스트 스트림의 수를 결정한다(동작 B). 구체적으로, (예를 들어, 스트리밍 하드웨어에 의해 출력될 수 있는 개별 스트림의 수를 제한하는 대역폭 제약 또는 스트리밍 하드웨어 제약으로 인해) 특정 수의 (상이한) 멀티캐스트 스트림 만이 클라이언트 컴퓨팅 디바이스들(104)로 배포될 수 있다. 일부 예에서, 클라이언트 컴퓨팅 디바이스(104)에 배포될 수 있는 멀티캐스트 스트림의 수는 서버 컴퓨팅 시스템(102), 클라이언트 컴퓨팅 시스템(104) 및 임의의 제3자 컨텐츠 제공자를 포함하는 네트워크 기반 구조에 기초한다. 즉, 대역폭 제한 네트워크 기반 구조는 고 대역폭 네트워크 기반 구조와 비교하여 더 적은 수의 멀티캐스트 스트림을 배포할 수 있다.
일부 예에서, 서버 컴퓨팅 시스템(102)은 클라이언트 컴퓨팅 디바이스들(104)에 배포될 수 있는 추가 멀티캐스트 스트림의 수가 클라이언트 컴퓨팅 디바이스(104)의 총 수보다 적음을 결정한다. 예를 들어, 서버 컴퓨팅 시스템(102)은 클라이언트 컴퓨팅 디바이스(104)에 배포될 수 있는 추가 멀티캐스트 스트림의 수가 2개의(상이한) 추가 멀티캐스트 스트림이라고 결정할 수 있다. 서버 컴퓨팅 시스템(104)은 클라이언트 컴퓨팅 디바이스(104)의 총 수와 클라이언트 컴퓨팅 디바이스(104)에 배포될 수 있는 추가 멀티캐스트 스트림의 수를 비교할 수 있다. 이 예에서, 멀티캐스트 스트림(200)과 상이한 멀티캐스트 스트림에 제시될 보조 디지털 컴포넌트들에 대한 디지털 컴포넌트 요청들(120)에 응답하여, 서버 컴퓨팅 시스템(102)은 보조 디지털 컴포넌트를 제공하는 상이한 멀티캐스트 스트림의 수(예컨대, 2개)는 디지털 컴포넌트 요청들(120)을 제공하는 클라이언트 컴퓨팅 디바이스들(104)의 수(예컨대, 3개)보다 적음을 결정한다. 이를 위해, 도시된 예에서, 둘 이상의 클라이언트 컴퓨팅 디바이스(104)는 본 명세서에서 더 설명되는 동일한 상이한 멀티캐스트 스트림을 (예를 들어, 제3자 컨텐츠 제공자로부터) 수신할 것이다.
디지털 컴포넌트 요청들(120)에 응답하여, 서버 컴퓨팅 시스템(102), 및 특히 디지털 컴포넌트 배포 서버(112)는 다수의 상이한 다른 보조 디지털 컴포넌트를 선택한다(동작 C). 특히, 서버 컴퓨팅 시스템(102)은 디지털 컴포넌트 데이터베이스(106)에 의해 저장되는 (다수의, 상이한) 보조 디지털 컴포넌트(150)를 선택한다. 서버 컴퓨팅 시스템(102)은 각각의 클라이언트 컴퓨팅 디바이스(104) 및/또는 멀티캐스트 스트림(200)의 하나 이상의 파라미터에 기초하여 보조 디지털 컴포넌트(150)를 선택할 수 있다. 예를 들어, 클라이언트 컴퓨팅 디바이스(104)의 파라미터들은 클라이언트 컴퓨팅 디바이스(104)의 지리적 특성과 같은 인구 통계적 특성을 포함할 수 있다. 또한, 예를 들어, 멀티캐스트 스트림(200)의 파라미터들은 컨텐츠의 카테고리(예를 들어, 라이브 스포츠 이벤트의 "스포츠")와 같은 멀티캐스트 스트림(200)의 컨텐츠 특성을 포함할 수 있다. 라이브 스포츠 이벤트의 멀티캐스트 스트림(200) 및 특정 클라이언트 컴퓨팅 디바이스(104)의 "캘리포니아 주, 샌프란시스코"의 인구 통계적 특성에 대해, 디지털 컴포넌트 배포 서버(112)는 본 명세서의 예를 계속하여, i) 스포츠 카테고리 및 ii) 캘리포니아 주, 샌프란시스코의 지리적 특성에 기초하여 보조 디지털 컴포넌트(150)를 선택할 수 있다. 디지털 컴포넌트 배포 서버(112)는 원하는 임의의 적절한 선택 방법에 기초하여 다수의 상이한 보조 디지털 컴포넌트(150)를 선택할 수 있다. 서버 컴퓨팅 시스템(102), 및 특히 디지털 컴포넌트 배포 서버(112)는 배포될 수 있는 추가 멀티캐스트 스트림들의 적어도 일부를 통해 배포하기 위해 보조 디지털 컴포넌트들(150)을 선택한다.
도 1b를 참조하면, 서버 컴퓨팅 시스템(102) 및 특히 디지털 컴포넌트 배포 서버(112)는 클라이언트 컴퓨팅 디바이스들(104)의 상이한 그룹을 다수의 상이한 보조 디지털 컨텐츠(150)를 전송하는 추가 멀티캐스트 스트림들 중 상이한 하나에 할당한다(동작 D). 예를 들어, 디지털 컴포넌트 배포 서버(112)는 클라이언트 컴퓨팅 디바이스(104a, 104b)에 제1 그룹(160)을 할당하고 클라이언트 컴퓨팅 디바이스(104c)에 제2 그룹(162)을 할당한다. 디지털 컴포넌트 배포 서버(112)는 예를 들어 클라이언트 컴퓨팅 디바이스(104)의 네트워크 기반 구조, 클라이언트 컴퓨팅 디바이스들(104)의 서로의 지리적 근접성 등에 기초하여 임의의 그룹화 방법에 따라 클라이언트 컴퓨팅 디바이스들(104)을 그룹화할 수 있다. 일부 예에서, 디지털 컴포넌트 배포 서버(112)는 클라이언트 컴퓨팅 디바이스들(104)의 파라미터의 유사성, 예컨대 인구 통계적 프로파일 특성에 기초하여 클라이언트 컴퓨팅 디바이스ㄷ들04)을 그룹화한다. 일부 예에서, 디지털 컴포넌트 배포 서버(112)는 클라이언트 컴퓨팅 디바이스들(104)을 랜덤하게 그룹화한다. 일부 예에서, 디지털 컴포넌트 배포 서버(112)가 클라이언트 컴퓨팅 디바이스(104)로 형성하는 그룹의 수는, 배포될 수 있는 추가 멀티캐스트 스트림의 수 및 클라이언트 컴퓨팅 디바이스(104)의 수(예를 들어, 클라이언트 컴퓨팅 디바이스(104)의 수에 배포될 수 있는 추가 멀티캐스트 스트림의 수의 비율)에 기초할 수 있다.
일부 예에서, 클라이언트 컴퓨팅 디바이스(104)의 상이한 그룹을 추가 멀티캐스트 스트림 중 상이한 그룹에 할당하는 것은 임의의 그룹들(예컨대, 그룹(160, 162)) 내에 포함되는 것으로부터 클라이언트 컴퓨팅 디바이스들(104) 중 하나를 배제하는 것을 포함한다. 즉, 디지털 컴포넌트 배포 서버(112)는 클라이언트 디지털 디바이스들(104) 중 하나에 대해 보조 디지털 컨텐츠(150)가 적용가능하지/적합하지 않다고 결정한다. 예를 들어, 상이한 보조 디지털 컨텐츠(150)는 특정 지리적 특성(예를 들어, 샌프란시스코에 위치된)을 갖는 클라이언트 컴퓨팅 디바이스(104)에 대한 것이며, 클라이언트 컴퓨팅 디바이스(104) 중 하나의 지리적 특성은 특정 지리적 특성과 동일하지 않다.
서버 컴퓨팅 시스템(102), 특히 명령 생성 서버(114)는 클라이언트 컴퓨팅 디바이스(104)들을 포함하는 각각의 그룹에 할당된 추가 멀티캐스트 스트림 중 하나에 동조하도록 클라이언트 컴퓨팅 디바이스(104) 각각에 지시하는 데이터를 생성한다(동작 E). 예를 들어, 명령 생성 서버(114)는 도 2에 도시된 바와 같이, 그룹(160)의 클라이언트 컴퓨팅 디바이스(104a, 104b)가 제1 추가 멀티캐스트 스트림(220a)에 각각 동조하도록 지시하는 제1 튜닝 데이터(170a)를 생성한다. 또한, 예를 들어, 명령 생성 서버(114)는 도 2에 도시된 바와 같이, 그룹(162)의 클라이언트 컴퓨팅 디바이스(104c)가 제2 추가 멀티캐스트 스트림(220b)에 동조하도록 지시하는 제2 튜닝 데이터(170b)를 생성한다. 제1 튜닝 데이터(170a) 및 제2 튜닝 데이터(170b)는 통칭하여 튜닝 데이터(170)로 지칭된다. 일부 예에서, 제1 추가 멀티캐스트 스트림(220a)은 제2 추가 멀티캐스트 스트림(220b)과 상이하다. 일부 예에서, 제1 추가 멀티캐스트 스트림(220a)은 제2 추가 멀티캐스트 스트림(220b)과 동일하다. 제1 추가 멀티캐스트 스트림(220a) 및 제2 추가 멀티캐스트 스트림(220b)은 통칭하여 추가 멀티캐스트 스트림(220)으로 지칭된다.
서버 컴퓨팅 시스템, 특히 핑 어드레스 생성 서버(116)는 (동작 F 동안) 각각의 클라이언트 컴퓨팅 디바이스(104)에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑 어드레스를 생성한다. 예를 들어, 핑 어드레스 생성 서버(116)는 클라이언트 컴퓨팅 디바이스(104a, 104b) 각각에 의해 고유한 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 제1 클라이언트 구성 가능 핑 어드레스(180a)를 생성하고; 또한 클라이언트 컴퓨팅 디바이스(104c)에 의해 고유한 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 제2 클라이언트 구성 가능 핑 어드레스(180b)를 생성한다. 제1 클라이언트 구성 가능 핑 어드레스(180a) 및 제2 구성 가능 핑 어드레스(180b)는 클라이언트 구성 가능 핑 어드레스들(180)로 지칭된다. 일부 예에서, 클라이언트 구성 가능 핑 어드레스들(180)은 클라이언트 컴퓨팅 디바이스들(104)이 추가 멀티캐스트 스트림(220)에 동조되었는지(예를 들어, 추가 멀티캐스트 스트림(220)의 보조 디지털 컨텐츠(150)의 임프레션(impression, 인상)을 등록했는지) 여부를 나타낼 수 있다. 즉, 보조 디지털 컨텐츠(150)의 임프레션을 등록한 후에, 클라이언트 컴퓨팅 디바이스(104)는 클라이언트 구성 가능 핑 어드레스(180)에 디바이스 식별자를 삽입(또는 첨부)한다.
일 예에서, 클라이언트 구성 가능 핑 어드레스들(180)은 example.com/?streamID = {streamID}, CID = {clientID}의 형태이다. 클라이언트 컴퓨팅 디바이스들(104)은 본 명세서에서 추가로 설명되는 클라이언트 구성 가능 피어 어드레스들(180)의 "clientID" 부분에서 구성 가능 핑 어드레스(180)에 각각의 고유 디바이스 식별자를 삽입한다. 또한, 클라이언트 구성 가능 핑 어드레스들(180)은 각각의 클라이언트 컴퓨팅 디바이스(104)가 동조된 추가 멀티캐스트 스트림(220)을 식별하는 데이터를 포함할 수 있다. 예를 들어, "streamID = {streamID}" 부분은 클라이언트 컴퓨팅 디바이스가 동조된 특정 멀티캐스트 스트림의 스트림 식별자로 채워질 수 있고, 따라서 추가 멀티캐스트 스트림들(220) 중 어느 것이 각각의 클라이언트 컴퓨팅 디바이스(104)가 제시했는지를 나타낸다. {streamID}는 서버 또는 클라이언트 컴퓨팅 디바이스(104)에 의해 채워질 수 있다.
서버 컴퓨팅 시스템(102)은 디지털 컴포넌트 요청들(120)에 응답한다. 특히, 요청(120a, 120b)에 응답하여, 서버 컴퓨팅 시스템(102)은 제1 튜닝 데이터(170a) 및 제1 클라이언트 구성 가능 핑 어드레스(180a)를 클라이언트 컴퓨팅 디바이스(104a, 104b)로 전송한다(동작 G). 또한, 요청(120c)에 응답하여, 서버 컴퓨팅 시스템(102)은 제2 튜닝 데이터(170b) 및 제2 클라이언트 구성 가능 핑 어드레스(180b)를 클라이언트 컴퓨팅 디바이스(104c)로 전송한다(동작 H). 일부 예에서, 서버 컴퓨팅 시스템(102)은 클라이언트 컴퓨팅 디바이스(104)의 임의의 네트워크 대기 시간이 주어진다면 실질적으로 동일한 시간에 디지털 컴포넌트 요청(120)에 응답한다. 일부 예에서, 서버 컴퓨팅 시스템(102)은 포인트(210)의 몇 초 이내에 디지털 컴포넌트 요청(120)에 응답한다.
일부 예에서, 클라이언트 컴퓨팅 디바이스(104)는 예를 들어 서버 컴퓨팅 시스템(102)으로, 각각의 클라이언트 컴퓨팅 디바이스(104)가 각각의 클라이언트 구성 가능 어드레스들에 의해 지정된 목적지에서 수신되는 추가 멀티캐스트 브로드캐스트에 동조된 각각의 통지를 제공한다. 예를 들어, 클라이언트 컴퓨팅 디바이스(104a, 104b)는 클라이언트 컴퓨팅 디바이스(104a, 104b)가 제1 멀티캐스트 스트림(220a)에 동조되고 제1 클라이언트 구성 가능 핑 어드레스(180a)에 의해 지정된 각각의 목적지에서 수신된다는 각각의 통지를 제공한다. 또한, 예를 들어, 클라이언트 컴퓨팅 디바이스(104c)는 클라이언트 컴퓨팅 디바이스(104c)가 제2 멀티캐스트 스트림 (220b)에 동조되고 제2 클라이언트 구성 가능 핑 어드레스(180b)에 의해 지정된 목적지에서 수신된다는 통지를 제공한다. 클라이언트 구성 가능 핑 어드레스(180a, 180b)는 서버 컴퓨팅 시스템(102)에 의해 데이터베이스에 저장될 수 있다. 서버 컴퓨팅 시스템(102)은 각 클라이언트 컴퓨팅 디바이스(104)가 추가 멀티캐스트 스트림(220)의 임프레션을 등록하였는지 여부를 결정하기 위해 각각의 클라이언트 구성 가능 핑 어드레스(180)를 파싱할 수 있다.
위의 예를 계속하면, 클라이언트 컴퓨팅 디바이스(104a)는 추가 멀티캐스트 스트림(220a)(예를 들어, "220a")에 대한 핑 어드레스(180a), 예를 들어, example. com/?streamID={220a},CID={104a}에 고유 ID(예를 들어, "ID104a")를 삽입하고, 클라이언트 컴퓨팅 디바이스(104b)는 추가 멀티캐스트 스트림(220a)에 대한 핑 어드레스 (180b), 예를 들어, example.com/?streamID={220a},CID ={104b}에 고유 ID(예를 들어, "ID104b")를 삽입하고, 클라이언트 컴퓨팅 디바이스(104c)는 추가 멀티캐스트 스트림(220b)(예를 들어, "220b")에 대한 핑 어드레스들(180c), 예를 들어 example.com/?streamID={220b},CID={104c}에 고유 ID(예를 들어, "ID104c")를 삽입한다.
도 2를 참조하면, 포인트(210) 이후의 포인트(230)에서, 클라이언트 컴퓨팅 디바이스들(104) 각각은, 예를 들어 적절한 추가 멀티캐스트 스트림(220a, 220b)의 수신 완료 후에 멀티캐스트 스트림(200)을 다시 수신하기 위해 멀티캐스트 스트림(200)에 다시 동조될 수 있다. 예를 들어, 최종 핑(예를 들어, 디지털 컴포넌트 완료 핑의 재생)이 클라이언트 컴퓨팅 디바이스들 중 하나에 의해 전송되면, 이 최종 핑의 전송은 클라이언트 컴퓨팅 디바이스를 트리거하여 멀티캐스트 스트림(200)에 다시 동조시킬 수 있다. 대안적으로 또는 부가적으로, 타이머 또는 다른 트리거 신호가 클라이언트 컴퓨팅 디바이스(104)를 트리거하여 멀티캐스트 스트림(200)에 다시 동조시키기 위해 사용될 수 있다. 상기 최종 핑(또는 다른 핑)에 연결되지 않은 타이머 또는 다른 트리거 신호를 사용하는 것은 디지털 컴포넌트의 재생이 완료되지 않은 경우에도 적절한 시간에 클라이언트 컴퓨팅 디바이스들(104)이 멀티캐스트 스트림(200)에 다시 동조되도록 할 수 있다. 예를 들어 타이머가 0에 도달할 때 클라이언트 컴퓨팅 디바이스(104)가 멀티캐스트 스트림(200)으로 되돌아갈 수 있도록 카운트 다운 타이머가 디지털 컴포넌트 재생의 지속 시간으로 설정될 수 있다.
도 3은 적절한 상이한 멀티캐스트 스트림들(220a, 220b)의 클라이언트 컴퓨팅 디바이스들(104) 각각에 의해 수신되는 보조 디지털 컨텐츠(150)를 도시한다. 예를 들어, 본 명세서에 언급된 바와 같이, 클라이언트 컴퓨팅 디바이스들(104a, 104b)은 제1 추가 멀티캐스트 스트림(220a)을 수신한다. 제1 추가 멀티캐스트 스트림(220a)은 제1 보조 디지털 컴포넌트(150a) 및 제2 보조 디지털 컴포넌트(150b)를 포함할 수 있다. 게다가, 예를 들어, 본 명세서에서 언급된 바와 같이, 클라이언트 컴퓨팅 디바이스(104c)는 제2 추가 멀티캐스트 스트림(220b)을 수신한다. 제2 추가 멀티캐스트 스트림(220)은 제3 보조 디지털 컴포넌트(150c) 및 제1 보조 디지털 컴포넌트(150a)를 포함할 수 있다.
이를 위해, 도 3에 도시된 바와 같이, 추가 멀티캐스트 스트림(220a, 220b)은 공통 보조 디지털 컴포넌트들을 포함할 수 있다. 예를 들어, 추가 멀티캐스트 스트림들(220a, 220b) 모두는 제1 보조 디지털 컴포넌트(150a)를 포함할 수 있다. 일부 예에서, 추가 멀티캐스트 스트림(220a, 220b)은 상이한 순서(예를 들어, 적절한 클라이언트 컴퓨팅 디바이스(104)에 의한 보조 디지털 컴포넌트들의 프리젠테이션 순서)로 배열된 동일한 보조 디지털 컴포넌트들을 포함할 수 있다.
도 4는 디지털 컨텐트의 멀티캐스트 전달을 위한 예시적인 프로세스(400)를 도시한다. 프로세스(400)는 예를 들어 서버 컴퓨팅 시스템(102) 및/또는 클라이언트 컴퓨팅 디바이스(104) 또는 다른 데이터 처리 장치에 의해 수행될 수 있다. 프로세스(400)는 또한 컴퓨터 저장 매체에 저장된 명령들로 구현될 수 있고, 하나 이상의 데이터 처리 장치에 의한 명령들의 실행은 하나 이상의 데이터 처리 장치로 하여금 프로세스(400)의 동작들의 일부 또는 전부를 수행하게 한다.
디지털 컴포넌트 요청은 클라이언트 컴퓨팅 디바이스로부터 수신된다(402). 디지털 컴포넌트 요청은 컨텐츠의 특정 스트림을 다수의 상이한 디바이스 각각에 전달하는 멀티캐스트 스트림과 상이한 멀티캐스트 스트림에 의해 전달되는 보조 디지털 컴포넌트에 대한 요청이다. 예를 들어, 디지털 컴포넌트 요청들 중 하나를 제출한 클라이언트 컴퓨팅 디바이스들 각각은 동일한 스트리밍 컨텐츠 세트(예를 들어, 특정 스포츠 이벤트)를 전달하는 동일한 스트리밍 채널에 동조될 수 있다.
요청들 각각은 요청을 제출한 클라이언트 디바이스 및/또는 클라이언트 디바이스의 사용자에 관한 다양한 정보를 포함할 수 있다. 예를 들어, 다양한 정보는 디바이스 유형(예를 들어, 태블릿, 모바일 디바이스, 데스크탑, 개인 디지털 어시스턴트), 디바이스 식별자, 사용자의 사용자 식별자, 사용자의 사용자 프로파일, 클라이언트 디바이스의 지리적 위치 또는 기타 정보를 포함할 수 있다. 요청들 각각은 또한 요청이 다수의 상이한 클라이언트 컴퓨팅 디바이스들에 전달되는 동일한 스트리밍 컨텐츠 세트 내의 중단 동안 제시될 보조 디지털 컴포넌트에 대한 것임을 지정할 수 있다.
디지털 컴포넌트 요청들이 수신될 때, 가용 대역폭을 통해 클라이언트 컴퓨팅 디바이스들로 배포될 수 있는 추가 멀티캐스트 스트림의 수가 결정된다(404). 일부 구현예에서, 배포될 수 있는 추가 멀티캐스트 스트림의 수는 스트리밍 컨텐츠를 배포하기 위해 사용되는 현재 대역폭의 양, 스트리밍 컨텐츠를 배포하는데 이용 가능한 대역폭의 총량 및/또는 디지털 컴포넌트들을 운반할 각 스트림을 전달하는데 필요한 대역폭의 양에 기초하여 결정된다.
예를 들어, 디지털 컴포넌트들을 전달할 각각의 멀티캐스트 스트림에는 6MB/s의 대역폭이 필요하고, 스트리밍 컨텐츠를 배포하는데 이용 가능한 총 대역폭은 1GB/s이고, 스트리밍 컨텐츠를 배포하는데 900MB/s의 대역폭이 현재 사용되고 있다고 가정한다. 이 예에서는, 추가 멀티캐스트 스트림들(예컨대, 1GB/s-900MB/s)을 배포하는데 100MB/s의 대역폭을 사용할 수 있으므로 16개의 추가 멀티캐스트 스트림이 클라이언트 컴퓨팅 디바이스(예컨대,(100MB/s)/(6MB/s)=16.67)로 배포될 수 있다.
일부 예에서, 배포될 수 있는 추가 멀티캐스트 스트림의 수는 디지털 컴포넌트 요청을 제출한 다수의 상이한 클라이언트 디바이스의 총 수보다 적다. 예를 들어 디지털 컴포넌트 요청들에서 수신된 디바이스 식별자의 수가 카운트되어 배포될 수 있는 추가 멀티캐스트 스트림의 수와 비교된다. 예를 들어, 32개의 상이한 디바이스 식별자가 디지털 컴포넌트 요청들에서 수신되었다고 가정한다(예를 들어, 새로운 디바이스 식별자가 발생할 때마다 증가되는 카운터에 따라). 이 예에서, 디바이스 식별자 수(예컨대, 32)는 배포될 수 있는 추가 멀티캐스트 스트림의 수(예컨대, 16)보다 크다. 이와 같이, 개별 스트림은 상이한 보조 디지털 컴포넌트를 각각의 클라이언트 디바이스로 운반하는데 사용될 수 없다. 따라서, 일부 클라이언트 디바이스는 동일한 보조 디지털 컴포넌트를 보기(view) 위해 동일한 스트리밍 채널에 동조할 것이다.
개별 요청에 응답하여, 다수의 상이한 보조 디지털 컴포넌트가 배포될 수 있는 추가 멀티캐스트 스트림의 적어도 일부를 통해 배포되도록 선택된다(406). 일부 예에서, 보조 디지털 컴포넌트들은 각각의 클라이언트 컴퓨팅 디바이스 및/또는 멀티캐스트 스트림의 파라미터들에 기초하여 선택된다. 예를 들어, 상술한 바와 같이, 파라미터들은 디바이스 유형(예를 들어, 태블릿, 모바일 디바이스, 데스크탑, 개인 디지털 어시스턴트), 디바이스 식별자, 사용자의 사용자 식별자, 사용자의 사용자 프로파일, 클라이언트 디바이스의 지리적 위치 또는 다른 정보를 포함할 수 있다. 게다가, 멀티캐스트 스트림의 파라미터들은 멀티캐스트 스트림의 컨텐츠의 카테고리를 포함할 수 있다. 예를 들어, 요청의 특정 클라이언트 컴퓨팅 디바이스에 대해, 보조 디지털 컴포넌트들은 i) 클라이언트 컴퓨팅 디바이스의 파라미터들 및 ii) 특정 클라이언트 컴퓨팅 디바이스가 동조된 멀티캐스트 스트림(동일한 스트리밍 채널)의 컨텐츠에 기초하여 선택된다.
클라이언트 컴퓨팅 디바이스는 다수의 상이한 보조 디지털 컨텐트를 전송하는 추가 멀티캐스트 스트림들 중 상이한 것들에 할당된다(408). 일부 예에서, 클라이언트 컴퓨팅 디바이스는 유사한 특성, 예를 들어, 서로에 대한 근접성 또는 사용자의 유사한 인구 통계적 프로파일에 기초하여 함께 그룹화된다. 예를 들어, 클라이언트 컴퓨팅 디바이스는 유사한 지리적 위치(예컨대, 도시 내의 동일한 구획)를 갖는 그룹으로 묶일 수 있거나 스포츠 이벤트(경기)에 동일한 관심을 함께 갖는 같은 그룹으로 묶일 수 있다. 일부 예에서, 클라이언트 컴퓨팅 디바이스는 둘 이상의 유사한 특성(예를 들어, 지리적 특성 및 인구 통계적 특성)에 기초하여 함께 그룹화된다.
디지털 컴포넌트 요청들 각각에 대한 응답이 생성되어 각각의 클라이언트 컴퓨팅 디바이스들로 전송된다(410). 일부 예에서, 응답들은 클라이언트 컴퓨팅 디바이스가 상이한 클라이언트 컴퓨팅 디바이스를 포함하는 상이한 그룹에 할당된 추가 멀티캐스트 스트림 중 하나에 동조하도록 지시하는 튜닝 데이터를 포함한다. 예를 들어, 튜닝 데이터는 각각의 클라이언트 컴퓨팅 디바이스로 하여금 각각의 클라이언트 컴퓨팅 디바이스가 속하는 그룹마다 추가 멀티캐스트 스트림들 중 하나에 동조하도록 한다. 응답들은 클라이언트 컴퓨팅 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑 어드레스를 더 포함할 수 있다. 예를 들어, 클라이언트 컴퓨팅 디바이스는 각각의 클라이언트 컴퓨팅 디바이스가 적절한 추가 멀티캐스트 스트림의 임프레션을 등록했음을 나타내는 고유한 디바이스 식별자들을 클라이언트 구성 가능 핑 어드레스들에 삽입(또는 첨부)할 수 있다.
클라이언트 컴퓨팅 디바이스들은 각각의 클라이언트 컴퓨팅 디바이스가 적절한 추가 멀티캐스트 스트림에 동조했다는 통지를 각각의 클라이언트 구성 가능 핑 어드레스에 의해 식별된 목적지로 전송할 수 있다. 즉, 클라이언트 구성 가능 핑 어드레스에 의해 지정된 목적지에서, 상기 통지가 수신된다(412). 예를 들어, 통지는 각각의 클라이언트 컴퓨팅 디바이스의 고유 클라이언트 식별자를 나타내는 핑 어드레스 및 각 클라이언트 컴퓨팅 디바이스가 임프레션을 등록한 특정 추가 멀티캐스트 스트림을 포함할 수 있다.
도 5는 본 명세서에 기술된 기술과 함께 사용될 수 있는 컴퓨팅 디바이스(500) 및 모바일 컴퓨터 디바이스(550)의 예를 도시한다. 컴퓨팅 디바이스(500)는 랩탑, 데스크탑, 워크스테이션, PDA, 서버, 블레이드 서버, 메인 프레임 및 다른 적절한 컴퓨터와 같은 다양한 형태의 디지털 컴퓨터를 나타내기 위한 것이다. 컴퓨팅 디바이스(550)는 PDA, 셀룰러 전화기, 스마트 폰 및 다른 유사한 컴퓨팅 디바이스와 같은 다양한 형태의 모바일 디바이스를 나타내기 위한 것이다. 본 명세서에 도시된 컴포넌트들, 이들의 접속 및 관계 및 그들의 기능은 단지 예시적인 것으로, 본 명세서에 기재된 및/또는 청구된 본 발명의 구현을 제한하지 않는다.
컴퓨팅 디바이스(500)는 프로세서(502), 메모리(504), 저장 디바이스(506), 메모리(504) 및 고속 확장 포트(510)에 연결되는 고속 인터페이스(508), 및 저속 버스(514) 및 저장 디바이스(506)에 연결되는 저속 인터페이스(512)를 포함한다. 컴포넌트들(502, 504, 506, 508, 510 및 512) 각각은 다양한 버스들을 사용하여 상호 연결되고, 공통 마더 보드 상에 장착되거나 또는 적절하게 다른 방식으로 장착될 수 있다. 프로세서(502)는 고속 인터페이스(508)에 연결된 디스플레이(516)와 같은 외부 입/출력 디바이스상의 GUI에 대한 그래픽 정보를 디스플레이하기 위해 메모리(504) 또는 저장 디바이스(506)에 저장된 명령들을 포함하여 컴퓨팅 디바이스(500) 내에서 실행하기 위한 명령을 처리할 수 있다. 다른 구현예에서, 다수의 메모리 및 다수 유형의 메모리와 함께, 적절하게, 다수의 프로세서 및/또는 다수의 버스가 사용될 수 있다. 또한, 다수의 컴퓨팅 디바이스(500)가 (예를 들어, 서버 뱅크, 블레이드 서버 그룹, 또는 멀티 프로세서 시스템으로서) 필요한 동작들의 일부를 제공하는 각 디바이스에 연결될 수 있다.
메모리(504)는 컴퓨팅 디바이스(500) 내의 정보를 저장한다. 일 구현예에서, 메모리(504)는 휘발성 메모리 유닛(들)이다. 다른 구현예에서, 메모리(504)는 비 휘발성 메모리 유닛(들)이다. 메모리(504)는 또한 자기 또는 광학 디스크와 같은 컴퓨터 판독 가능 매체의 다른 형태일 수 있다.
저장 디바이스(506)는 컴퓨팅 디바이스(500)를 위한 대용량 저장을 제공할 수 있다. 일 구현예에서, 저장 디바이스(506)는 저장 영역 네트워크 또는 다른 구성의 디바이스들을 포함하여, 플로피 디스크 디바이스, 하드 디스크 디바이스, 광학 디스크 디바이스 또는 테이프 디바이스, 플래시 메모리 또는 다른 유사 고체 상태 메모리 디바이스, 또는 디바이스 어레이와 같은 컴퓨터 판독 가능 매체일 수 있거나 포함할 수 있다. 컴퓨터 프로그램 제품은 정보 캐리어에 유형으로 구현될 수 있다. 컴퓨터 프로그램 제품은 또한 실행될 때 상술한 바와 같은 하나 이상의 방법을 수행하는 명령들을 포함할 수 있다. 정보 캐리어는 메모리(504), 저장 디바이스(506) 또는 프로세서(502)상의 메모리와 같은 컴퓨터 또는 기계 판독 가능 매체이다.
고속 제어기(508)는 컴퓨팅 디바이스(500)에 대한 대역-집중 동작들을 관리하는 반면, 저속 제어기(512)는 보다 낮은 대역-집중 동작을 관리한다. 이러한 기능 할당은 단지 예시적인 것이다. 일 구현에서, 고속 제어기(508)는 (예를 들어, 그래픽 프로세서 또는 가속기를 통해) 메모리(504), 디스플레이(516), 및 다양한 확장 카드(미도시)를 수용할 수 있는 고속 확장 포트(510)에 연결된다. 구현예에서, 저속 제어기(512)는 저장 디바이스(506) 및 저속 확장 포트(514)에 연결된다. 다양한 통신 포트(예를 들어, USB, 블루투스, 이더넷, 무선 이더넷)를 포함할 수 있는 저속 확장 포트는 키보드, 포인팅 디바이스, 스캐너, 또는 예를 들어 네트워크 어댑터를 통한 스위치 또는 라우터와 같은 네트워킹 디바이스와 같은 하나 이상의 입력/출력 디바이스에 연결될 수 있다.
컴퓨팅 디바이스(500)는 도면에 도시된 바와 같이 다수의 상이한 형태로 구현될 수 있다. 예를 들어, 이것은 표준 서버(520)로서 또는 이러한 서버들의 그룹으로 여러 번 구현될 수 있다. 또한, 랙 서버 시스템(524)의 일부로서 구현될 수도있다. 더욱이, 랩톱 컴퓨터(522)와 같은 퍼스널 컴퓨터에서 구현될 수 있다. 대안 적으로, 컴퓨팅 디바이스(500)의 컴포넌트들은 디바이스(550)와 같은 모바일 디바이스(미도시)의 다른 컴포넌트들과 결합될 수 있다. 이러한 디바이스 각각은 하나 이상의 컴퓨팅 디바이스(500, 550)를 포함할 수 있고, 전체 시스템은 서로 통신하는 다수의 컴퓨팅 디바이스(500, 550)로 구성될 수 있다.
컴퓨팅 디바이스(550)는 다른 컴포넌트들 중에서 프로세서(552), 메모리(564), 디스플레이(554)와 같은 입/출력 디바이스, 통신 인터페이스(566) 및 송수신기(568)를 포함한다. 디바이스(550)는 또한 추가 저장을 제공하기 위해 마이크로 드라이브 또는 다른 디바이스와 같은 저장 디바이스를 구비할 수 있다. 컴포넌트들(550, 552, 564, 554, 566 및 568) 각각은 다양한 버스를 사용하여 상호 접속되고, 몇몇 컴포넌트는 공통 마더 보드 상에 장착되거나 적절하게 다른 방식으로 장착될 수 있다.
프로세서(552)는 메모리(564)에 저장된 명령들을 포함하여, 컴퓨팅 디바이스(640) 내의 명령들을 실행할 수 있다. 프로세서는 개별 및 다중 아날로그 및 디지털 프로세서를 포함하는 칩들의 칩셋으로서 구현될 수 있다. 프로세서는 예를 들어 사용자 인터페이스의 제어, 디바이스(550)에 의해 실행되는 애플리케이션 및 디바이스(550)에 의한 무선 통신과 같이, 디바이스(550)의 다른 컴포넌트들의 조정을 제공할 수 있다.
프로세서(552)는 제어 인터페이스(648) 및 디스플레이(554)에 연결된 디스플레이 인터페이스(556)를 통해 사용자와 통신할 수 있다, 디스플레이(554)는 예를 들면, TFT의 LCD(박막 트랜지스터 액정 디스플레이) 또는 OLED(유기 발광 다이오드) 디스플레이 또는 다른 적절한 디스플레이 기술일 수 있다. 디스플레이 인터페이스(556)는 사용자에게 그래픽 및 다른 정보를 제공하기 위해 디스플레이(554)를 구동하기 위한 적절한 회로를 포함할 수 있다. 제어 인터페이스(558)는 사용자로부터 명령을 수신하여 프로세서(552)에 제출하기 위해 이들을 변환할 수 있다. 더욱이, 외부 인터페이스(562)는 다른 디바이스들과 디바이스(550)의 근거리 통신을 가능하게 하기 위해 프로세서(552)와 통신하도록 제공될 수 있다. 외부 인터페이스(562)는 예를 들어, 일부 구현예에서는 유선 통신용으로 또는 다른 구현예에서는 무선 통신용으로 제공될 수 있으며, 다중 인터페이스가 또한 사용될 수 있다.
메모리(564)는 컴퓨팅 디바이스(550) 내의 정보를 저장한다. 메모리(564)는 컴퓨터 판독 가능 매체 또는 미디어, 휘발성 메모리 유닛(들) 또는 비 휘발성 메모리 유닛(들) 중 하나 이상으로서 구현될 수 있다. 확장 메모리(554)는 또한 예를 들어 SIMM(Single In Line Memory Module) 카드 인터페이스를 포함할 수 있는 확장 인터페이스(552)를 통해 디바이스(550)에 제공 및 연결될 수 있다. 이러한 확장 메모리(554)는 디바이스(550)에 대한 여분의 저장 공간을 제공하거나 디바이스(550)에 대한 애플리케이션 또는 다른 정보를 저장할 수도 있다. 특히, 확장 메모리 (554)는 전술한 프로세스들을 수행하거나 보충하기 위한 명령들을 포함할 수 있고, 보안 정보를 포함할 수도 있다. 따라서, 예를 들어, 확장 메모리(554)는 디바이스(550)에 대한 보안 모듈로서 제공될 수 있고, 디바이스(550)의 안전한 사용을 허용하는 명령들로 프로그램될 수 있다. 게다가, 보안 애플리케이션 SIMM 카드에 식별 정보를 해킹할 수 없게 배치하는 것과 같이 추가 정보와 함께 SIMM 카드를 통해 제공될 수 있다.
메모리는 후술되는 바와 같이, 예를 들어 플래시 메모리 및/또는 NVRAM 메모리를 포함할 수 있다. 일 실시예에서, 컴퓨터 프로그램 제품은 정보 매체에 유형으로 구체화된다. 컴퓨터 프로그램 제품은 실행될 때, 상술한 바와 같은 하나 이상의 방법을 수행하는 명령들을 포함한다. 정보 캐리어는 메모리(564), 확장 메모리 (554), 프로세서(552)상의 메모리, 또는 예를 들어 송수신기(568) 또는 외부 인터페이스(562)를 통해 수신될 수 있는 전파 신호와 같은 컴퓨터 또는 기계 판독 가능 매체이다.
디바이스(550)는 통신 인터페이스(566)를 통해 무선 통신할 수 있으며, 통신 인터페이스(566)는 필요한 경우 디지털 신호 처리 회로를 포함할 수 있다. 통신 인터페이스(566)는 GSM 음성 호출, SMS, EMS 또는 MMS 메시징, CDMA, TDMA, PDC, WCDMA, CDMA2000 또는 GPRS와 같은 다양한 모드 또는 프로토콜 하에서 통신을 제공할 수 있다. 이러한 통신은, 예를 들면 무선 주파수 송수신기(568)를 통해 발생할 수 있다. 더욱이, 블루투스, WiFi 또는 다른 송수신기(미도시)를 사용하는 것과 같은 단거리 통신이 발생할 수 있다. 또한, GPS(Global Positioning System) 수신기 모듈(550)은 디바이스(550)상에서 실행되는 애플리케이션에 의해 적절하게 사용될 수 있는 추가의 네비게이션 및 위치 관련 무선 데이터를 디바이스(550)에 제공할 수 있다.
디바이스(550)는 또한 사용자로부터 발성 정보를 수신하여 그것을 이용 가능한 디지털 정보로 변환할 수 있는 오디오 코덱(560)을 사용하여 청각적으로 통신할 수 있다. 오디오 코덱(560)은 마찬가지로, 예를 들어 디바이스(550)의 핸드셋 내의 스피커를 통하는 것과 같이, 사용자를 위한 가청 사운드를 생성할 수 있다. 이러한 사운드는 음성 전화 호출의 사운드를 포함할 수 있고, 녹음된 사운드(예를 들어, 음성 메시지, 음악 파일 등)를 포함할 수 있고, 또한 디바이스(550)상에서 작동하는 애플리케이션들에 의해 생성된 사운드를 포함할 수 있다.
컴퓨팅 디바이스(550)는 도면에 도시된 바와 같이 다수의 상이한 형태로 구현될 수 있다. 예를 들어, 그것은 셀룰러 전화(580)로 구현될 수 있다. 그것은 또한 스마트 폰(582), PDA, 또는 다른 유사 모바일 디바이스의 일부로서 구현될 수 도 있다.
본 명세서에 기술된 시스템 및 기술의 다양한 구현예는 디지털 전자 회로, 집적 회로, 특별히 설계된 ASIC(주문형 집적 회로), 컴퓨터 하드웨어, 펌웨어, 소프트웨어 및/또는 이들의 조합으로 실현될 수 있다. 이러한 다양한 구현예들은, 저장 시스템, 적어도 하나의 입력 디바이스 및 적어도 하나의 출력 디바이스로부터 데이터 및 명령을 수신하고, 데이터 및 명령을 저장 시스템으로 전송하도록 결합된, 특수 또는 범용일 수 있는 적어도 하나의 프로그램 가능 프로세서를 포함하는 프로그램 가능 시스템상에서 실행 가능 및/또는 해석 가능한 하나 이상의 컴퓨터 프로그램으로의 구현을 포함할 수 있다.
이들 컴퓨터 프로그램(프로그램, 소프트웨어, 소프트웨어 애플리케이션 또는 코드로도 알려짐)은 프로그램 가능 프로세서에 대한 기계 명령들을 포함하고, 높은 수준의 절차적 및/또는 객체 지향적 프로그래밍 언어, 및/또는 어셈블리/기계 언어로 구현될 수 있다. 본 명세서에서 사용된 바와 같이, "기계 판독 가능 매체" "컴퓨터 판독 가능 매체"라는 용어는 기계 판독 가능 신호로서 기계 명령들을 수신하는 기계 판독 가능 매체를 포함하여, 기계 명령 및/또는 데이터를 프로그램 가능 프로세서에 제공하는데 사용되는 임의의 컴퓨터 프로그램 제품, 장치 및/또는 디바이스(예를 들어, 자기 디스크, 광학 디스크, 메모리, 프로그램 가능 논리 장치(PLD))를 지칭한다. "기계 판독 가능 신호"라는 용어는 기계 명령 및/또는 데이터를 프로그램 가능 프로세서에 제공하는데 사용되는 모든 신호를 지칭한다.
사용자와의 상호 작용을 제공하기 위해, 본 명세서에 기술된 시스템 및 기술은, 정보를 디스플레이하기 위한 디스플레이 디바이스(예를 들어, CRT(cathode ray tube) 또는 LCD(liquid crystal display) 모니터)와 키보드 및 사용자가 컴퓨터에 입력을 제공할 수 있는 포인팅 디바이스(예를 들어, 마우스 또는 트랙볼)를 갖는 컴퓨터 상에서 구현될 수 있다. 다른 종류의 디바이스들이 사용자와의 상호 작용을 제공하기 위해 사용될 수 있는데, 예를 들어, 사용자에게 제공된 피드백은 임의의 형태의 감각 피드백(예를 들어, 시각 피드백, 청각 피드백 또는 촉각 피드백) 일 수 있으며, 사용자로부터의 입력은 음향, 음성 또는 촉각 입력을 포함하여 임의의 형태로 수신될 수 있다.
본 명세서에 설명된 시스템 및 기술은 백 엔드 컴포넌트(예컨대, 데이터 서버)를 포함하거나 미들웨어 컴포넌트(예컨대, 애플리케이션 서버)를 포함하거나, 프론트 엔드 컴포넌트(예컨대, 사용자가 본 명세서에 설명된 시스템 및 기술의 구현과 상호 작용할 수 있는 그래픽 사용자 인터페이스 또는 웹 브라우저를 갖는 클라이언트 컴퓨터) 또는 이러한 백 엔드, 미들웨어 또는 프런트 엔드 컴포넌트의 임의의 조합을 포함하는 컴퓨팅 시스템으로 구현될 수 있다. 시스템의 컴포넌트들은 임의의 형태 또는 매체의 디지털 데이터 통신(예를 들어, 통신 네트워크)에 의해 상호 접속될 수 있다. 통신 네트워크의 예는 근거리 통신망("LAN"), 광역 통신망( "WAN") 및 인터넷을 포함한다.
컴퓨팅 시스템은 클라이언트 및 서버를 포함할 수 있다. 클라이언트와 서버는 일반적으로 서로 멀리 떨어져 있으며 일반적으로 통신 네트워크를 통해 상호 작용한다. 클라이언트와 서버의 관계는 각각의 컴퓨터에서 실행되고 서로 클라이언트-서버 관계를 갖는 컴퓨터 프로그램에 의해 발생한다.
본 명세서는 일부 세부 사항을 포함하지만, 이는 본 발명의 범위 또는 청구될 수 있는 범위에 대한 제한으로 해석되어서는 안되며, 오히려 본 발명의 예시적인 구현예의 특징의 설명으로 해석되어야 한다. 개별 구현예의 맥락에서 본 명세서에 기술된 소정 특징들은 또한 단일 구현으로 조합하여 제공될 수 있다. 반대로, 단일 구현의 맥락에서 기술된 다양한 특징은 다수의 구현예에서 개별적으로 또는 임의의 적절한 하위 조합으로 제공될 수 있다. 게다가, 특징들은 특정 조합으로 작용하고 상술한 바와 같이 초기에 청구된 것으로서 설명될 수 있지만, 청구된 조합으로부터의 하나 이상의 특징이 해당 조합으로부터 절제될 수 있고, 청구된 조합은 특징의 하위 조합 또는 변형으로 유도될 수 있다.
유사하게, 동작들은 도면에 특정 순서로 도시되어 있지만, 이는 바람직한 결과를 달성하기 위해 이러한 동작들이 도시된 특정 순서 또는 순차적인 순서로 수행되거나 도시된 모든 동작이 수행될 것을 요구하는 것으로 이해되어서는 안된다. 특정 상황에서는 멀티 태스킹 및 병렬 처리가 유리할 수 있다. 게다가, 상술한 구현예에서 다양한 시스템 컴포넌트의 분리는 모든 구현예에서 이러한 분리를 요구하는 것으로 이해되어서는 안되며, 기술된 프로그램 컴포넌트 및 시스템은 일반적으로 단일 소프트웨어 제품에 통합되거나 다수의 소프트웨어 제품으로 패키지될 수 있다.
따라서, 본 발명의 특정 구현예들이 설명되었다. 다른 구현예들은 다음의 청구항들의 범위 내에 있다. 예를 들어, 청구항들에서 열거된 동작들은 상이한 순서로 수행될 수 있으며 여전히 바람직한 결과를 달성한다. 다수의 구현예들이 개시되었다. 그럼에도 불구하고, 본 발명의 사상 및 범위를 벗어나지 않고 다양한 변형들이 이루어질 수 있음을 이해할 것이다. 예를 들어, 상술한 흐름도들의 다양한 형태가 재배열, 추가 또는 제거된 단계와 함께 사용될 수 있다. 따라서, 다른 구현예들은 다음의 청구항들의 범위 내에 있다.

Claims (20)

  1. 방법으로서,
    하나 이상의 컴퓨터에 의해 다수의 상이한 클라이언트 디바이스로부터, 보조 디지털 컴포넌트에 대한 개별 디지털 컴포넌트 요청을 수신하는 단계;
    하나 이상의 컴퓨터에 의해, 개별 디지털 컴포넌트 요청에 응답하여, 다수의 상이한 보조 디지털 컴포넌트를 다수의 상이한 클라이언트 디바이스에 분배하도록 선택하는 단계;
    하나 이상의 컴퓨터에 의해, 다수의 상이한 클라이언트 디바이스의 상이한 그룹을 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상이한 멀티캐스트 스트림에 할당하는 단계; 및
    하나 이상의 컴퓨터에 의해 다수의 상이한 클라이언트 디바이스로, (i) 상기 요청을 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹들에 할당된 상이한 멀티캐스트 스트림들 중 하나에 동조(tune)하도록 다수의 상이한 클라이언트 디바이스 각각에게 지시하는 데이터 및 (ii) 상기 요청을 제출한 상이한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑(ping) 어드레스로 상기 개별 디지털 컴포넌트 요청 각각에 응답하는 단계를 포함하는 것을 특징으로 하는 방법.
  2. 제1항에 있어서,
    상기 상이한 그룹들 중 적어도 하나의 그룹은,
    상기 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상이한 멀티캐스트 스트림들 중 하나 이외의 2개의 개별 멀티 캐스트 스트림에 현재 동조되는 둘 이상의 상이한 클라이언트 디바이스를 포함하는 것을 특징으로 하는 방법.
  3. 제1항에 있어서,
    상기 상이한 멀티캐스트 스트림들 중 하나는,
    상기 요청을 제출한 상이한 디바이스와 동일한 그룹의 다수의 상이한 클라이언트 디바이스 각각에 동일한 스트리밍 컨텐츠를 전달하는 것을 특징으로 하는 방법.
  4. 제3항에 있어서,
    상기 개별 디지털 컴포넌트 요청을 수신하는 단계는,
    적어도 하나의 디지털 컴포넌트 요청에 대해, 디지털 컴포넌트 요청 내의 다수의 상이한 디바이스 식별자를 수신하는 단계를 더 포함하고, 상기 다수의 상이한 디바이스 식별자는 동일한 멀티캐스트 스트림에 동일한 디지털 컴포넌트를 제공할 다수의 상이한 디바이스를 지정하는 것을 특징으로 하는 방법.
  5. 제4항에 있어서,
    상기 디지털 컴포넌트 요청의 수는 다수의 상이한 클라이언트 디바이스의 총 수보다 적은 것을 특징으로 하는 방법.
  6. 제1항에 있어서,
    하나 이상의 다수의 클라이언트 디바이스에 대해, 상기 클라이언트 구성 가능 핑 어드레스에 의해 지정된 목적지에서, 상기 클라이언트 디바이스가 클라이언트 구성 가능 핑 어드레스를 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹에 할당된 상이한 멀티캐스트 스트림들 중 하나에 동조되었다는 통지를 수신하는 단계; 및
    상기 클라이언트 구성 가능 핑 어드레스를 데이터베이스에 저장하는 단계를 더 포함하는 것을 특징으로 하는 방법.
  7. 제1항에 있어서,
    각 그룹과 관련된 인구 통계적 프로파일 특성에 기초하여 상기 상이한 그룹을 상이한 멀티캐스트 스트림들 중 상이한 하나에 할당하는 단계를 더 포함하는 것을 특징으로 하는 방법.
  8. 제7항에 있어서,
    상기 다수의 상이한 클라이언트 디바이스의 상이한 그룹을 상이한 멀티캐스트 스트림 중 하나에 할당하는 단계는 특정 클라이언트 디바이스를 상기 상이한 그룹 각각에 포함시키는 것으로부터 배제하는 단계를 더 포함하는 것을 특징으로 하는 방법.
  9. 실행시에 하나 이상의 컴퓨터로 하여금 동작들을 수행하게 하는 하나 이상의 컴퓨터에 의해 실행 가능한 명령들을 포함하는 소프트웨어를 저장하는 비-일시적 컴퓨터 판독 가능 매체로서, 상기 동작들은:
    다수의 상이한 클라이언트 디바이스로부터, 보조 디지털 컴포넌트에 대한 개별 디지털 컴포넌트 요청을 수신하는 단계;
    개별 디지털 컴포넌트 요청에 응답하여, 다수의 상이한 보조 디지털 컴포넌트를 다수의 상이한 클라이언트 디바이스에 분배하도록 선택하는 단계;
    다수의 상이한 클라이언트 디바이스의 상이한 그룹을 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상이한 멀티캐스트 스트림에 할당하는 단계; 및
    (i) 상기 요청을 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹에 할당된 상이한 멀티캐스트 스트림들 중 하나에 동조하도록 다수의 상이한 클라이언트 디바이스 각각에게 지시하는 데이터 및 (ii) 상기 요청을 제출한 상이한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑 어드레스로 상기 개별 디지털 컴포넌트 요청 각각에 응답하는 단계를 포함하는 것을 특징으로 하는 비-일시적 컴퓨터 판독 가능 매체.
  10. 제9항에 있어서,
    상기 상이한 그룹들 중 적어도 하나의 그룹은,
    상기 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상이한 멀티캐스트 스트림들 중 하나 이외의 2개의 개별 멀티 캐스트 스트림에 현재 동조되는 둘 이상의 상이한 클라이언트 디바이스를 포함하는 것을 특징으로 하는 비-일시적 컴퓨터 판독 가능 매체.
  11. 제9항에 있어서,
    상기 상이한 멀티캐스트 스트림들 중 하나는,
    상기 요청을 제출한 상이한 디바이스와 동일한 그룹의 다수의 상이한 클라이언트 디바이스 각각에 동일한 스트리밍 컨텐츠를 전달하는 것을 특징으로 하는 비-일시적 컴퓨터 판독 가능 매체.
  12. 제11항에 있어서,
    상기 개별 디지털 컴포넌트 요청을 수신하는 단계는,
    적어도 하나의 디지털 컴포넌트 요청에 대해, 디지털 컴포넌트 요청 내의 다수의 상이한 디바이스 식별자를 수신하는 단계를 더 포함하고, 상기 다수의 상이한 디바이스 식별자는 동일한 멀티캐스트 스트림에 동일한 디지털 컴포넌트를 제공할 다수의 상이한 디바이스를 지정하는 것을 특징으로 하는 비-일시적 컴퓨터 판독 가능 매체.
  13. 제12항에 있어서,
    상기 디지털 컴포넌트 요청의 수는 다수의 상이한 클라이언트 디바이스의 총 수보다 적은 것을 특징으로 하는 비-일시적 컴퓨터 판독 가능 매체.
  14. 제9항에 있어서,
    상기 명령들은 하나 이상의 컴퓨터로 하여금 동작들을 수행하게 하고, 상기 동작들은,
    하나 이상의 다수의 클라이언트 디바이스에 대해, 상기 클라이언트 구성 가능 핑 어드레스에 의해 지정된 목적지에서, 상기 클라이언트 디바이스가 클라이언트 구성 가능 핑 어드레스를 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹에 할당된 상이한 멀티캐스트 스트림들 중 하나에 동조되었다는 통지를 수신하는 단계; 및
    상기 클라이언트 구성 가능 핑 어드레스를 데이터베이스에 저장하는 단계를 더 포함하는 것을 특징으로 하는 비-일시적 컴퓨터 판독 가능 매체.
  15. 시스템으로서,
    하나 이상의 메모리 디바이스와; 그리고
    하나 이상의 메모리 디바이스에 저장된 명령들을 실행하도록 구성된 하나 이상의 컴퓨터를 포함하여, 상기 명령들의 실행은 하나 이상의 컴퓨터로 하여금 동작들을 수행하게 하고, 상기 동작들은:
    다수의 상이한 클라이언트 디바이스로부터, 보조 디지털 컴포넌트에 대한 개별 디지털 컴포넌트 요청을 수신하는 동작;
    개별 디지털 컴포넌트 요청에 응답하여, 다수의 상이한 보조 디지털 컴포넌트를 다수의 상이한 클라이언트 디바이스에 분배하도록 선택하는 동작;
    다수의 상이한 클라이언트 디바이스의 상이한 그룹을 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상이한 멀티캐스트 스트림에 할당하는 동작; 및
    (i) 상기 요청을 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹에 할당된 상이한 멀티캐스트 스트림들 중 하나에 동조하도록 다수의 상이한 클라이언트 디바이스 각각에게 지시하는 데이터 및 (ii) 상기 요청을 제출한 상이한 클라이언트 디바이스에 의해 디바이스 식별자를 삽입하기 위한 플레이스 홀더를 포함하는 클라이언트 구성 가능 핑 어드레스로 상기 개별 디지털 컴포넌트 요청 각각에 응답하는 동작을 포함하는 것을 특징으로 하는 시스템.
  16. 제15항에 있어서,
    상기 상이한 그룹들 중 적어도 하나의 그룹은,
    상기 다수의 상이한 보조 디지털 컴포넌트를 전송하는 상이한 멀티캐스트 스트림들 중 하나 이외의 2개의 개별 멀티 캐스트 스트림에 현재 동조되는 둘 이상의 상이한 클라이언트 디바이스를 포함하는 것을 특징으로 하는 시스템.
  17. 제15항에 있어서,
    상기 상이한 멀티캐스트 스트림들 중 하나는,
    상기 요청을 제출한 상이한 디바이스와 동일한 그룹의 다수의 상이한 클라이언트 디바이스 각각에 동일한 스트리밍 컨텐츠를 전달하는 것을 특징으로 하는 시스템.
  18. 제17항에 있어서,
    상기 개별 디지털 컴포넌트 요청을 수신하는 동작은,
    적어도 하나의 디지털 컴포넌트 요청에 대해, 디지털 컴포넌트 요청 내의 다수의 상이한 디바이스 식별자를 수신하는 동작을 더 포함하고, 상기 다수의 상이한 디바이스 식별자는 동일한 멀티캐스트 스트림에 동일한 디지털 컴포넌트를 제공할 다수의 상이한 디바이스를 지정하는 것을 특징으로 하는 시스템.
  19. 제18항에 있어서,
    상기 디지털 컴포넌트 요청의 수는 다수의 상이한 클라이언트 디바이스의 총 수보다 적은 것을 특징으로 하는 시스템.
  20. 제15항에 있어서,
    상기 명령들은 하나 이상의 컴퓨터로 하여금 동작들을 수행하게 하고, 상기 동작들은,
    하나 이상의 다수의 클라이언트 디바이스에 대해, 상기 클라이언트 구성 가능 핑 어드레스에 의해 지정된 목적지에서, 상기 클라이언트 디바이스가 클라이언트 구성 가능 핑 어드레스를 제출한 상이한 클라이언트 디바이스를 포함하는 상이한 그룹에 할당된 상이한 멀티캐스트 스트림들 중 하나에 동조되었다는 통지를 수신하는 동작; 및
    상기 클라이언트 구성 가능 핑 어드레스를 데이터베이스에 저장하는 동작을 더 포함하는 것을 특징으로 하는 시스템.
KR1020207014905A 2017-08-15 2017-12-07 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용 KR102234451B1 (ko)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US201762545830P 2017-08-15 2017-08-15
US62/545,830 2017-08-15
PCT/US2017/065128 WO2019035855A1 (en) 2017-08-15 2017-12-07 OPTIMIZED USE OF CONTINUOUS DIFFUSION BANDWIDTH USING MULTICAST

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
KR1020197004042A Division KR102117586B1 (ko) 2017-08-15 2017-12-07 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용

Publications (2)

Publication Number Publication Date
KR20200060552A KR20200060552A (ko) 2020-05-29
KR102234451B1 true KR102234451B1 (ko) 2021-03-31

Family

ID=60935963

Family Applications (2)

Application Number Title Priority Date Filing Date
KR1020207014905A KR102234451B1 (ko) 2017-08-15 2017-12-07 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용
KR1020197004042A KR102117586B1 (ko) 2017-08-15 2017-12-07 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용

Family Applications After (1)

Application Number Title Priority Date Filing Date
KR1020197004042A KR102117586B1 (ko) 2017-08-15 2017-12-07 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용

Country Status (6)

Country Link
US (2) US10735213B2 (ko)
EP (1) EP3488558B1 (ko)
JP (2) JP6633244B2 (ko)
KR (2) KR102234451B1 (ko)
CN (2) CN113395601B (ko)
WO (1) WO2019035855A1 (ko)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2021049744A1 (ko) * 2019-09-09 2021-03-18 경상대학교산학협력단 수신단 캐싱을 활용한 적응형 비디오 스트리밍 시스템

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090210899A1 (en) * 2008-02-19 2009-08-20 Marc Lawrence-Apfelbaum Methods and apparatus for enhanced advertising and promotional delivery in a network
US20170163708A1 (en) * 2012-11-20 2017-06-08 Google Technology Holdings LLC Method and apparatus for streaming media content to client devices

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001223732A (ja) 2000-02-14 2001-08-17 Casio Comput Co Ltd 情報配信方法ならびに情報配信装置および情報受信装置
JP3960211B2 (ja) 2002-11-25 2007-08-15 株式会社日立製作所 データ配信方法及び装置
US7983205B1 (en) 2003-06-20 2011-07-19 Juniper Networks, Inc. Outgoing interface mapping for multicast traffic
JP4601987B2 (ja) 2004-04-07 2010-12-22 株式会社エヌ・ティ・ティ・ドコモ データ受信装置、及び、データ受信方法
WO2008122451A1 (en) * 2007-04-06 2008-10-16 International Business Machines Corporation Method for personalizing a multimedia program broadcasted through an ip network
CN105376167A (zh) * 2009-10-28 2016-03-02 惠普公司 分布式分组流检查和处理
US9559855B2 (en) * 2010-05-20 2017-01-31 Cisco Technology, Inc. System and method for providing multicast delivery in a network environment
US9072005B2 (en) * 2011-04-20 2015-06-30 Qualcomm Incorporated Quality of service control in a multicast transmission
CN104115499B (zh) * 2012-02-15 2018-12-07 汤姆逊许可公司 定向广告
EP2868097A4 (en) * 2012-06-28 2016-03-23 Ericsson Ab METHOD AND SYSTEM FOR ADVERTISING INSERTION IN OTT (OVER THE TOP) DISTRIBUTION OF LIVE MULTIMEDIA CONTENT
US9519914B2 (en) 2013-04-30 2016-12-13 The Nielsen Company (Us), Llc Methods and apparatus to determine ratings information for online media presentations
US10445769B2 (en) 2013-12-24 2019-10-15 Google Llc Systems and methods for audience measurement
US10902474B2 (en) * 2014-03-24 2021-01-26 Qualcomm Incorporated Targeted advertisement insertion for streaming media data
CN104333481A (zh) * 2014-09-23 2015-02-04 无锡锐格思信息技术有限公司 一种通过PC组播ping包形成正确转发表的方法
CA3126649C (en) * 2014-11-20 2023-10-17 Lg Electronics Inc. Apparatus for transmitting broadcast signal, apparatus for receiving broadcast signal, method for transmitting broadcast signal and method for receiving broadcast signal
US9998434B2 (en) * 2015-01-26 2018-06-12 Listat Ltd. Secure dynamic communication network and protocol
US9819480B2 (en) * 2015-08-04 2017-11-14 Ibiquity Digital Corporation System and method for synchronous processing of analog and digital pathways in a digital radio receiver
US10693936B2 (en) 2015-08-25 2020-06-23 Qualcomm Incorporated Transporting coded audio data

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20090210899A1 (en) * 2008-02-19 2009-08-20 Marc Lawrence-Apfelbaum Methods and apparatus for enhanced advertising and promotional delivery in a network
US20170163708A1 (en) * 2012-11-20 2017-06-08 Google Technology Holdings LLC Method and apparatus for streaming media content to client devices

Also Published As

Publication number Publication date
CN113395601B (zh) 2022-09-20
CN109792394B (zh) 2021-05-11
KR20200060552A (ko) 2020-05-29
CN109792394A (zh) 2019-05-21
US20190058607A1 (en) 2019-02-21
US20200106629A1 (en) 2020-04-02
JP6951403B2 (ja) 2021-10-20
KR102117586B1 (ko) 2020-06-01
JP2020074522A (ja) 2020-05-14
CN113395601A (zh) 2021-09-14
WO2019035855A1 (en) 2019-02-21
US10735213B2 (en) 2020-08-04
EP3488558B1 (en) 2019-07-24
US11102023B2 (en) 2021-08-24
KR20190031261A (ko) 2019-03-25
JP6633244B2 (ja) 2020-01-22
JP2019534587A (ja) 2019-11-28
EP3488558A1 (en) 2019-05-29

Similar Documents

Publication Publication Date Title
WO2017202243A1 (zh) 一种多媒体播放方法及相关设备
US10904168B2 (en) System and method for providing digital media content with a conversational messaging environment
US8265672B1 (en) Text message sessions
US20180270541A1 (en) Program interaction system, method, client, and backend server
US11889133B2 (en) Burst traffic processing method, computer device and readable storage medium
CN107094280B (zh) 一种用户群创建、资源分配方法和设备
JP6580132B2 (ja) メディアコンテンツに関連付けられた情報を提供する方法および装置
WO2022111027A1 (zh) 视频获取方法、电子设备及存储介质
US20170171585A1 (en) Method and Electronic Device for Recording Live Streaming Media
EP3406071B1 (en) Integrating additional information into a telecommunications call
WO2016074326A1 (zh) 一种频道切换的方法、装置和系统
US20140094153A1 (en) System and method of interacting with a broadcaster via an application
US11848977B2 (en) Providing content to co-located devices with enhanced presentation characteristics
WO2018094480A4 (en) System for streaming
US20130148554A1 (en) Electronic device and method for sharing contents via bluetooth network
KR102234451B1 (ko) 멀티캐스트를 이용한 스트리밍 대역폭의 최적 활용
US9525987B2 (en) System and method for facilitating audio access to radio stations
US10542052B2 (en) Multi-area grouping
US9985736B2 (en) System and method for facilitation of a geographically relevant radio station and transmission of related content
US8620207B1 (en) System, method and apparatus for distributed content dissemination
KR101198943B1 (ko) 방송 시스템에서 컨텐츠 제공 장치 및 방법
CN112561553A (zh) 内容下发方法、服务器及存储介质
WO2018154354A1 (en) Systems and methods for sharing media advertisements
TW201408018A (zh) 檔案協同下載系統、裝置及方法

Legal Events

Date Code Title Description
A107 Divisional application of patent
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant