KR101592043B1 - 무선 통신 환경 오버레이 - Google Patents

무선 통신 환경 오버레이 Download PDF

Info

Publication number
KR101592043B1
KR101592043B1 KR1020107015952A KR20107015952A KR101592043B1 KR 101592043 B1 KR101592043 B1 KR 101592043B1 KR 1020107015952 A KR1020107015952 A KR 1020107015952A KR 20107015952 A KR20107015952 A KR 20107015952A KR 101592043 B1 KR101592043 B1 KR 101592043B1
Authority
KR
South Korea
Prior art keywords
client computing
computing environments
group
wireless communication
access points
Prior art date
Application number
KR1020107015952A
Other languages
English (en)
Other versions
KR20100102166A (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 KR20100102166A publication Critical patent/KR20100102166A/ko
Application granted granted Critical
Publication of KR101592043B1 publication Critical patent/KR101592043B1/ko

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W84/00Network topologies
    • H04W84/02Hierarchically pre-organised networks, e.g. paging networks, cellular networks, WLAN [Wireless Local Area Network] or WLL [Wireless Local Loop]
    • H04W84/10Small scale networks; Flat hierarchical networks
    • H04W84/12WLAN [Wireless Local Area Networks]
    • 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/189Arrangements for providing special services to substations for broadcast or conference, e.g. multicast in combination with wireless systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/06Selective distribution of broadcast services, e.g. multimedia broadcast multicast service [MBMS]; Services to user groups; One-way selective calling services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W8/00Network data management
    • H04W8/18Processing of user or subscriber data, e.g. subscribed services, user preferences or user profiles; Transfer of user or subscriber data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W8/00Network data management
    • H04W8/18Processing of user or subscriber data, e.g. subscribed services, user preferences or user profiles; Transfer of user or subscriber data
    • H04W8/186Processing of subscriber group data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W88/00Devices specially adapted for wireless communication networks, e.g. terminals, base stations or access point devices
    • H04W88/08Access point devices
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W48/00Access restriction; Network selection; Access point selection
    • H04W48/16Discovering, processing access restriction or access information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W72/00Local resource management
    • H04W72/30Resource management for broadcast services

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Databases & Information Systems (AREA)
  • Multimedia (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

방법이 제공되며, 이 방법은 식별된 인접한 협업하는 액세스 포인트들로부터의 네이버캐스트 그룹에 가입함으로써 데이터를 전달 및 수신하기 위해 클라이언트 컴퓨팅 환경과 협업할 수 있는 인접한 무선 통신 액세스 포인트들(AP)을 식별하는 단계를 포함하며, 그에 따라 네이버캐스트 그룹이 식별된 인접한 무선 통신 액세스 포인트들을 이용하는 협업하는 클라이언트 컴퓨팅 환경들 사이의 통신 오버레이를 포함한다. 예시적인 구현에서, 무선 통신 환경은 예시적인 통신 오버레이를 통해 하나 이상의 무선 통신 동작(협업하는 클라이언트 컴퓨팅 환경들 및/또는 무선 액세스 포인트들 및/또는 RSS 서버들이 있는지 스캔하는 것, 통신 오버레이 그룹에 가입하는 것, 및 무선 통신 오버레이의 협업하는 컴포넌트들에 의해 소비되는 데이터를 게시하는 것을 포함함)을 수행하기 위해 예시적인 명령어 세트로부터의 적어도 하나의 명령어를 처리하는 동작을 하는 통신 오버레이 엔진을 포함하는 적어도 2개의 클라이언트 통신 환경들을 포함한다.

Description

무선 통신 환경 오버레이{WIRELESS COMMUNICATIONS ENVIRONMENT OVERLAY}
도심 지역들과 기업 및 캠퍼스 네트워크들에서 Wi-Fi 액세스 포인트(Access Point)(AP)의 밀도가 급속히 증가되었다. 대부분의 시나리오들에서, Wi-Fi 클라이언트는 2개 이상의 이용가능한 AP와 연관될 선택권을 갖는다. 따라서, 물리적으로 근처의 Wi-Fi 클라이언트들이 서로 다른 AP들과 연관되어 있는 일이 점점 더 흔하다.
다수의 애플리케이션들이 근처의 클라이언트들로/로부터 정보를 전송 및 수신할 수 있는 능력으로부터 이득을 볼 수 있다. 예를 들어, 클라이언트들은 이웃하는 AP들과 연관된 클라이언트들의 성능에 관하여 알고 있는 경우 더 나은 AP 선택을 수행할 수 있다. "내 근방에 있는 친구들(buddies near me)"과 같은 애플리케이션들은 근처에 있지만 다른 AP와 연관되어 있는 클라이언트들을 발견할 수 있다. 이와 유사하게, 지오캐스팅(geocasting) 기반 애플리케이션들은 단지 하나의 무선 네트워크로 제한되는 것보다 동일한 지역 내의 더 많은 클라이언트들에까지 이를 수 있다.
그렇지만, 이 애플리케이션들을 가능하게 해주는 기존의 방식들은 상당한 인프라 변경 또는 광범위한 수동 프로파일링(manual profiling)을 필요로 한다. 예를 들어, 802.11k는 더 나은 AP 선택을 위해 AP들 및 클라이언트 드라이버들을 수정한다. 비이컨스터핑(BeaconStuffing)은 그의 네트워크에 대한 부하에 관한 정보를 전송하도록 AP들을 수정한다. 게다가, AOL의 친구 목록(buddy list) 등의 "내 근방에 있는 친구들"의 기존의 구현들은 광범위한 워드라이빙(wardriving)을 필요로 한다.
게다가, 현재의 실무들은 네이버캐스트(neighborcast)를 지원하지 않는데, 근처의 클라이언트들은, 서로 다른 AP와 연관되어 있고 이 기능을 달성하기 위해 멀티캐스트를 이용하지 않을 때에도, 이 네이버캐스트를 사용하여 서로 통신할 수 있다. 고안된 방식에서, 각각의 AP는 전역 고유 멀티캐스트 그룹 ID(globally unique multicast group ID)를 할당받을 수 있고, IP 주소를 갖는 Wi-Fi 클라이언트는 그 주변의 모든 AP들에 대응하는 멀티캐스트 그룹(multicast group)에 참여한다. IP 멀티캐스트, 애플리케이션 레벨 멀티캐스트(Application Level Multicast) 또는 RSS 피드(RSS feed)를 사용하는 웹-서버 기반 방식 중 어느 하나를 사용하는 멀티캐스트 기능도 역시 구현될 수 있다.
기존의 실무들과는 달리, 네이버캐스트는 클라이언트들에서 AP들에 대한 어떤 수정들 또는 커널-레벨 소프트웨어 변경들도 필요로 하지 않는다. 게다가, IP 멀티캐스트 또는 애플리케이션 레벨 멀티캐스트를 사용함으로써, Wi-Fi 클라이언트에 의해 발생되는 네이버캐스트 트래픽이 로컬이며, 즉 근처의 AP들에만 전파된다. 네이버캐스트는, 이용(deploy)될 때, 완전한 중앙집중형 게시/가입 기반 방식보다 더 확장성이 있을 수 있다.
이상으로부터, 네이버캐스트를 가능하게 해주는 무선 통신 네트워크에 관한 한, 기존의 실무들의 단점들을 극복할 필요가 있다는 것을 잘 알 것이다.
이하는 본 명세서의 몇몇 측면들에 대한 기본적인 이해를 제공하기 위해 본 발명의 간략화된 요약을 제공한다. 이 요약은 본 명세서의 전반적인 개요가 아니다. 이 요약은 본 명세서의 중요한 또는 필수적인 구성요소를 확인하기 위한 것이 아니며 본 명세서의 범위를 정하기 위한 것도 아니다. 이 요약의 유일한 목적은 나중에 제공되는 보다 상세한 설명에 대한 서문으로서 본 명세서의 몇몇 개념들을 간략화된 형태로 제공하는 데 있다.
한 측면에서, 방법이 제공되며, 이 방법은 데이터를 전달 및 수신하기 위해 클라이언트 컴퓨팅 환경과 협업할 수 있는 근처의 무선 통신 액세스 포인트들(APs)을 식별하는 단계를 포함한다. 예시적인 구현에서, 이 방법은, 예시로서 네이버캐스트 그룹(neighborcast group)이 식별된 근처의 무선 통신 액세스 포인트들을 이용하여 협업하는 클라이언트 컴퓨팅 환경들 간의 통신 오버레이(communications overlay)를 포함하도록, 식별된 근처의 협업하는 액세스 포인트들로부터 네이버캐스트 그룹(neighborcast group)을 생성하는 단계를 더 포함한다.
예시적인 구현에서, 무선 통신 환경은 협업하는 클라이언트 컴퓨팅 환경들 사이에서 데이터를 통신하기 위한 무선 통신 세션을 선택 및/또는 유지하는 데 사용하기 위해 하나 이상의 협업하는 클라이언트 컴퓨팅 환경들 및/또는 무선 액세스 포인트들 및/또는 RSS 컴퓨팅 환경 서버들과, 예시적인 통신 오버레이를 통해, 하나 이상의 무선 통신 동작들(하나 이상의 액세스 포인트들이 있는지 스캔하는 것, 무선 통신 오버레이 그룹에 가입하는 것, 및 하나 이상의 무선 통신 채널들의 성능 및 부하에 관한 데이터를 게시하는 것을 포함함)을 수행하기 위해, 예시적인 명령어 세트로부터의 적어도 하나의 명령어를 처리하는 동작을 하는 통신 오버레이 엔진(communications overlay engine)을 포함하는 적어도 2개의 클라이언트 컴퓨팅 환경들을 포함한다.
이하의 설명 및 첨부 도면들은 발명 대상의 어떤 예시적인 측면들을 상세히 기술하고 있다. 그렇지만, 이 측면들은 발명 대상이 이용될 수 있는 다양한 방식들 중 단지 몇개만을 나타낸 것이며, 청구된 발명 대상이 모든 이러한 측면들 및 그의 등가물들을 포함하는 것으로 보아야 한다.
도 1은 네이버캐스팅(neighborcasting)을 지원하는 예시적인 Wi-Fi 환경의 예시적인 구현의 블록도.
도 2는 RSS 피드를 사용하여 네이버캐스팅을 지원하는 다른 예시적인 Wi-Fi 환경의 예시적인 구현의 블록도.
도 3은 WAN(wide area network) 통신 환경에서 개선된 사용자 연관관계(user association)를 가능하게 해주는, 네이버캐스팅을 지원하는 다른 예시적인 Wi-Fi 환경의 예시적인 구현의 블록도.
도 4는 Wi-Fi 네이버캐스트-지원 환경(Wi-Fi neighborcast enabled environment)에서 멀티캐스트 그룹(multicast group)을 구축하기 위해 수행되는 예시적인 처리를 나타낸 블록도.
도 5는 Wi-Fi 네이버캐스트-지원 환경에서 RSS 피드를 사용하여 네이버캐스팅을 실현하기 위해 수행되는 예시적인 처리를 나타낸 블록도.
도 6은 예시적인 네이버캐스트 처리를 사용하여 WLAN에서 사용자 연관관계를 개선하기 위해 수행되는 예시적인 처리를 나타낸 블록도.
도 7은 본 명세서에 기술된 다양한 측면들에 따른 예시적인 네트워크화된 컴퓨팅 환경의 블록도.
도 8은 본 명세서에 기술된 다양한 측면들에 따른 예시적인 컴퓨팅 환경의 블록도.
이제부터 첨부 도면들을 참조하여 청구된 발명 대상에 대해 기술하며, 도면 전체에 걸쳐 유사한 참조 번호들이 유사한 구성요소들을 가리키는 데 사용되고 있다. 이하의 설명에서, 설명의 목적상, 청구된 발명 대상에 대한 완전한 이해를 제공하기 위해 수많은 구체적인 상세가 기술되어 있다. 그렇지만, 청구된 발명 대상이 이 구체적인 상세들을 사용하지 않고도 실시될 수 있다는 것이 명백할 수 있다. 다른 경우들에, 청구된 발명 대상의 설명을 용이하게 해주기 위해 공지의 구조들 및 장치들이 블록도 형태로 도시되어 있다.
본 출원에서 사용되는 바와 같이, 용어 "컴포넌트", "모듈", "시스템", "인터페이스", 기타는 일반적으로 컴퓨터-관련 개체(computer-related entity), 예를 들어, 하드웨어, 하드웨어와 소프트웨어의 조합, 소프트웨어, 또는 실행 중인 소프트웨어를 말하기 위한 것이다. 예를 들어, 컴포넌트는 프로세서 상에서 실행 중인 프로세스, 프로세서, 객체, 실행 파일, 실행 쓰레드, 프로그램 및/또는 컴퓨터일 수 있지만, 이들로 제한되지 않는다. 예시로서, 제어기 상에서 실행 중인 애플리케이션 및 그 제어기 둘다가 컴포넌트일 수 있다. 하나 이상의 컴포넌트들이 프로세스 및/또는 실행 쓰레드 내에 존재할 수 있고, 컴포넌트가 하나의 컴퓨터 상에 로컬화되어 있을 수 있고 및/또는 2개 이상의 컴퓨터들 간에 분산되어 있을 수 있다. 다른 일례로서, 인터페이스는 I/O 컴포넌트들은 물론 연관된 프로세서, 애플리케이션 및/또는 API 컴포넌트들도 포함할 수 있다.
게다가, 청구된 발명 대상이 소프트웨어, 펌웨어, 하드웨어, 또는 이들의 임의의 조합을 생성하는 표준의 프로그래밍 및/또는 엔지니어링 기법들을 사용하여 컴퓨터를 제어해 개시된 발명 대상을 구현하는 방법, 장치, 또는 제조 물품으로서 구현될 수 있다. "제조 물품(article of manufacture)"이라는 용어는, 본 명세서에서 사용되는 바와 같이, 임의의 컴퓨터-판독가능 장치, 캐리어(carrier), 또는 매체로부터 액세스될 수 있는 컴퓨터 프로그램을 포괄하기 위한 것이다. 예를 들어, 컴퓨터-판독가능 매체로는 자기 저장 장치(예를 들어, 하드 디스크, 플로피 디스크, 자기 스트립 ...), 광 디스크[예를 들어, 컴팩트 디스크(CD), DVD(digital versatile disk) ...], 스마트 카드, 그리고 플래쉬 메모리 장치들(예를 들어, 카드, 스틱, 키 드라이브 ...)이 있을 수 있지만, 이들로 제한되지 않는다. 그에 부가하여, 반송파가, 전자 메일(electronic mail)을 전송 및 수신하는 데 또는 인터넷이나 LAN(local area network) 등의 네트워크에 액세스하는 데 사용되는 것과 같이, 컴퓨터-판독가능 전자 데이터를 전달하는 데 이용될 수 있다는 것을 잘 알 것이다. 물론, 당업자라면 청구된 발명 대상의 범위 또는 사상을 벗어나지 않고 이 구성에 많은 수정들이 이루어질 수 있다는 것을 잘 알 것이다.
게다가, "예시적인"이라는 단어는 본 명세서에서 일례, 실례 또는 예시로서 역할한다는 것을 의미하기 위해 사용된다. 본 명세서에서 "예시적인" 것으로 기술된 임의의 측면 또는 설계가 꼭 다른 측면들 또는 설계들보다 양호하다거나 이점이 있는 것으로 해석되어야 하는 것은 아니다. 오히려, "예시적인"이라는 단어의 사용은 개념들을 구체적인 방식으로 제시하기 위한 것이다. 본 출원에서 사용되는 바와 같이, "또는"이라는 용어는 배타적인 "논리합"(exclusive "or")이라기 보다는 포함적인 "논리합"(inclusive "or")를 의미하기 위한 것이다. 즉, 달리 언급하지 않는 한 또는 문맥으로부터 명확하지 않는 한, "X가 A 또는 B를 이용한다"는 포함적인 자연 순열들(natural inclusive permutations) 중 어느 하나를 의미하기 위한 것이다. 즉, X가 A를 이용하는 경우, X가 B를 이용하는 경우, 또는 X가 A 및 B 둘다를 이용하는 경우, 이상의 경우들 중 어느 하나의 경우 하에서 "X가 A 또는 B를 이용한다"는 만족된다. 그에 부가하여, 본 출원 및 첨부된 청구항들에서 사용되는 단수 표현은, 달리 언급하지 않는 한 또는 단수 형태에 관한 것이라고 문맥으로부터 명확하지 않는 한, 일반적으로 "하나 이상"을 의미하는 것으로 해석되어야 한다.
개요: 네이버캐스트
도 1은 예시적인 무선 통신 환경(100)의 예시적인 컴포넌트들의 협업(cooperation)을 나타낸 것이다. 도 1에 도시된 바와 같이, 예시적인 무선 통신 환경은 통신 네트워크(102)[예를 들어, LAN(local area network), 인터넷, WAN(wide area network)], 액세스 포인트-1(106), 액세스 포인트-2(104), 액세스 포인트-3(108), 클라이언트 컴퓨팅 환경들(각각 110, 112 및 114), 및 다른 클라이언트 컴퓨팅 환경들(116)(점선 박스 내에 표시되어 있음)을 포함하고 있다. 예시적인 구현에서, 다른 클라이언트 컴퓨팅 환경들은 PDA(personal digital assistant), 이동 전화, 및 무선 통신을 할 수 있는 기타 휴대용 전자 장치들을 포함할 수 있다. 게다가, 도 1에 도시된 바와 같이, 무선 통신 환경(100)은, 예시적인 동작에서, 무선 통신 환경(100)의 하나 이상의 컴포넌트들의 협업을 통해 생성될 수 있는 무선 통신 환경 오버레이(wireless communications environment overlay)(118)를 포함한다. 도 1에 도시된 바와 같이, 클라이언트 컴퓨팅 환경들(110, 112, 114 및 116)은 무선 통신 환경 오버레이 애플리케이션(wireless communications environment overlay application)(120)을 실행하는 동작을 한다. 예시로서, 무선 통신 환경 오버레이 애플리케이션(120)은 오버레이 엔진(overlay engine)(124) 및 오버레이 엔진 명령어 세트(overlay engine instruction set)(122)를 더 포함한다.
예시적인 구현에서, 무선 통신 환경 오버레이(118)(예를 들어, 네이버캐스트)에 의해 클라이언트 컴퓨팅 환경들(110, 112 및 114)[또는 다른 클라이언트 컴퓨팅 환경들(116)]은, 자신들이 연관되어 있는 AP[예를 들어, 액세스 포인트-1(106), 액세스 포인트-2(104), 액세스 포인트-3(108)]와 상관없이, 다른 근처의 클라이언트 컴퓨팅 환경들(110, 112 및 114)[또는 다른 클라이언트 컴퓨팅 환경들(116)]을 발견하고 그들과 통신할 수 있게 된다. 예시로서, 네이버캐스트는 하나 이상의 네이버캐스트 동작들을 수행하기 위해 오버레이 엔진 명령어 세트로부터의 적어도 하나의 명령어를 처리하는 오버레이 엔진(124)을 실행하는 무선 통신 환경 오버레이 애플리케이션(120)으로서 동작할 수 있다.
예시적인 구현에서, 무선 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116)이 공통의 액세스 포인트(예를 들어, 104, 106 또는 108)로부터 무선 전송들을 수신할 수 있는 경우, 2개의 무선 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116)이 서로의 "근방"에 있는 것으로 생각될 수 있다. 예시적인 구현에서, 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116)이 서로 다른 주파수 채널들을 통해 서로 다른 액세스 포인트들(예를 들어, 104, 106 또는 108)과 연관되어 있는 경우에도, 2개의 클라이언트 컴퓨팅 환경들(110, 112, 114 또는 116)이 "근방"에 있는 것으로 생각될 수 있다. 게다가, 예시적인 구현에서, 2개의 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116)이 공통의 액세스 포인트(104, 106 또는 108)와 통신을 할 수 있다면 서로의 통신 범위(communication range) 내에 있지 않을 때에 서로 통신을 할 수 있는 경우, 네이버캐스트[예를 들어, 무선 통신 환경 오버레이(118)]는 각각의 개별 액세스 포인트(예를 들어, 104, 106 또는 108)에 의해 제공되는 것보다 더 많은 도달 거리(range)를 실현할 수 있다. 액세스 포인트가 또한 다른 협업하는 클라이언트 컴퓨팅 환경들 및/또는 액세스 포인트들에 대한 액세스 포인트로서 역할하는 클라이언트 컴퓨팅 환경도 포함할 수 있다는 것을 잘 알 것이다.
예시적인 구현에서, 네이버캐스트[예를 들어, 무선 통신 환경 오버레이(118)]가 멀티캐스트 그룹들의 확장으로서 이용(deploying)될 수 있다. 예시적인 동작에서, 전역 고유 그룹 식별자(ID)가 협업하는 액세스 포인트들(104, 106 또는 108)에 할당될 수 있는데, 이 전역 고유 그룹 식별자는, 예시로서, 협업하는 액세스 포인트의 고유 BSSID(basic service set identifier)로부터 도출될 수 있다. 예시적인 동작에서, 협업하는 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116)은, 협업하는 클라이언트 컴퓨티 환경들(예를 들어, 110, 112, 114 또는 116)이 협업하는 액세스 포인트들(예를 들어, 104, 106 또는 108)을 발견하는 프로세스의 일부로서 발견할 수 있는 협업하는 액세스 포인트들(예를 들어, 104, 106 또는 108)에 대한 예시적인 멀티캐스트 그룹에 가입(참여)할 수 있다. 예시적인 동작에서, 협업하는 클라이언트 컴퓨팅 환경들 중 하나 이상이 그와 연관되어 있는 액세스 포인트의 멀티캐스트 그룹에 관한 업데이트들(예를 들어, 클라이언트 컴퓨팅 환경의 존재 및/또는 성능을 나타내는 데이터)을 게시하는 동작을 할 수 있다.
도 1에 도시된 바와 같이, 클라이언트 컴퓨팅 환경들(110, 112, 114 또는 116)은 [예를 들어, 클라이언트 컴퓨팅 환경들(110, 112, 114 또는 116)이 서로 다른 액세스 포인트들과 연관되어 있더라도, 즉 도시된 바와 같이, 클라이언트 컴퓨팅 환경(110)이 액세스 포인트-2(104)와 연관되어 있는 것으로 도시되어 있고, 클라이언트 컴퓨팅 환경(112)이 액세스 포인트-1(106)과 연관되어 있는 것으로 도시되어 있으며, 클라이언트 컴퓨팅 환경(114)이 액세스 포인트-3(108)와 연관되어 있는 것으로 도시되어 있고, 다른 클라이언트 컴퓨팅 환경들(116)이 액세스 포인트-1(106)과 연관되어 있는 것으로 도시되어 있음] 액세스 포인트-1(106)의 도달 거리 내에서 동작할 수 있고 네이버캐스트 그룹(118)에 가입할 수 있다. 예시적인 동작에서, 네이버캐스트[예를 들어, 무선 통신 환경 오버레이(118)]에 의해 클라이언트 컴퓨팅 환경들(110, 112, 114 또는 116)은, 예시적인 동작에서, 공통의 네이버캐스트 그룹(118)[예를 들어, 액세스 포인트-1(106)에 대응함]을 사용하여 서로 통신을 할 수 있다.
무선 통신 동작들이 무선 통신 환경 오버레이를 생성하도록 이용되는 예시적인 구현들에서, 네이버캐스트는 예시로서 물리적으로 근방에 있는 무선 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116) 간에 IP(Internet protocol) 오버레이를 구축하는 동작을 할 수 있다. 예시적인 구현에서, IP 오버레이는 서로 다른 무선 통신 환경들 및 주파수 채널들에 걸쳐 있을 수 있다. 예시적인 동작에서, 협업하는 클라이언트 컴퓨팅 환경(예를 들어, 110, 112, 114 또는 116)에 의해 그의 액세스 포인트(예를 들어, 104, 106 또는 108)의 멀티캐스트 그룹(예를 들어, 118)를 통해 게시된 업데이트는, 협업하는 클라이언트 컴퓨팅 환경들(110, 112, 114 또는 116)이 브로드캐스팅 클라이언트 컴퓨팅 환경과 연관된 액세스 포인트와 다른 액세스 포인트와 연관되어 있는지에 상관없이, 액세스 포인트(예를 들어, 104, 106 또는 108)의 도달 거리 내의 협업하는 클라이언트 컴퓨팅 환경들(예를 들어, 110, 112, 114 또는 116)에 의해 수신될 수 있다. 예시적인 구현에서, 근처의 협업하는 클라이언트 컴퓨팅 환경들의 상대 거리들을 추정하기 위해 네이버캐스트가 확장될 수 있다.
예시적인 구현에서, 액세스 포인트의 멀티캐스트 그룹 식별자는 액세스 포인트의 전역 고유 BSSID로부터 도출될 수 있는 IP 멀티캐스트 주소(예를 들어, 228.xxx.xxx.xxx)에 대응할 수 있다. 예시적인 동작에서, 6-바이트 BSSID로부터 멀티캐스트 IP 주소 내의 3 바이트로의 이러한 매핑은 액세스 포인트의 BSSID의 마지막 3 바이트를 재사용함으로써 처리될 수 있다. 예를 들어, 00:17:95:81:CA:30의 BSSID는 228.129.202.48(0x81 = 129, 0xCA = 202, 0x30 = 48임)의 멀티캐스트 IP 주소에 대응할 수 있다.
예시적인 동작에서, 클라이언트 컴퓨팅 환경은 협업하는 액세스 포인트들(예를 들어, 클라이언트 컴퓨팅 환경이 연결할 수 있는 액세스 포인트들)의 BSSID를, 예시적인 스캐닝 프로세스의 일부로서, 대응하는 멀티캐스트 IP 주소에 매핑하는 동작을 한다. 예시적인 동작에서, 클라이언트 컴퓨팅 환경은 이어서 식별된 멀티캐스트 그룹들에 가입할 수 있고, 그와 연관되어 있는 액세스 포인트의 IP 멀티캐스트 그룹에 관한 정보를 게시할 수 있다.
예시적인 구현에서, 네이버캐스트(무선 통신 환경 오버레이를 사용한 데이터의 통신)는, 주어진 서브-네트워크(예를 들어, 주거 지역 및 쇼핑 지역)의 일부가 아닌 협업하는 액세스 포인트들을 수용하기 위해, ALM(application level multicast)을 사용하여 배포될 수 있다. 예시적인 구현에서, 멀티캐스트 그룹들에 걸쳐 그룹 멤버쉽의 발견 및 관리를 위해 랑데부 서버(rendezvous server)가 제공될 수 있다.
예시적인 구현에서, ALM 방식이 멀티캐스트로 구현될 수 있다. 예시적인 동작에서, 멀티캐스트 그룹에 참여하기 위해, 협업하는 클라이언트 컴퓨팅 환경은 그 그룹의 멤버들인 협업하는 클라이언트 컴퓨팅 환경들의 IP 주소들의 리스트로 응답하는 동작을 할 수 있는 랑데부 서버(중앙 제어기)(도시 생략)와 접촉할 수 있다. 업데이트도 또한 예시로서 새로운 클라이언트 컴퓨팅 환경의 IP 주소와 함께 그 그룹 내의 협업하는 클라이언트 컴퓨팅 환경들로 전달될 수 있다. 협업하는 클라이언트 컴퓨팅 환경들은, 멀티캐스트 그룹 내의 협업하는 클라이언트 컴퓨팅 환경들로 개별적으로 유니캐스트함으로써, 데이터를 멀티캐스트할 수 있다. 이와 유사하게, 협업하는 클라이언트 컴퓨팅 환경은, 그룹을 빠져 나갈 때, 랑데부 서버에 통보하는 동작을 할 수 있고, 랑데부 서버는 이어서 이 업데이트를 그 그룹 내의 다른 협업하는 클라이언트 컴퓨팅 환경들로 전송할 수 있다. 멀티캐스트 그룹의 일부인 협업하는 클라이언트 컴퓨팅 환경들은 또한, 자신들의 존재를 알려주기 위해, 주기적인 "하트비트" 메시지들("heartbeat" messages)을 예시적인 랑데부 서버(도시 생략)로 전송할 수 있다.
도 2는 데이터 통신을 용이하게 해주는 동작을 하는 예시적인 무선 통신 환경(200)의 다른 예시적인 구현을 나타낸 것이다. 도 2에 도시된 바와 같이, 예시적인 무선 통신 환경(200)은 RSS 피드 서버(202), 액세스 포인트-1(206), 액세스 포인트-2(204), 액세스 포인트-3(208), 및 클라이언트 컴퓨팅 환경들(210, 212, 214 및 216)을 포함한다. 예시적인 구현에서, 웹 서버가 인터넷 상에서 이용될 수 있고, 이 인터넷 상에서 협업하는 액세스 포인트들(예를 들어, 204, 206 및 208)은 대응하는 웹 피드(web feed)를 갖는다. 예시로서, 웹 피드는 XML 파일에 의해 식별될 수 있다. 예시적인 동작에서, XML 파일에 대한 링크가 협업하는 액세스 포인트들(예를 들어, 204, 206, 또는 208) 중 하나의 BSSID를 사용하여 획득될 수 있다. 예를 들어, BSSID 00:17:95:81:CA:30를 갖는 협업하는 액세스 포인트의 예시적인 웹 피드가 http://webserver/N00 17 95 81 CA 30.xml이다. 협업하는 액세스 포인트(예를 들어, 204, 206 또는 208)와 연관된 협업하는 클라이언트 컴퓨팅 환경들(예를 들어, 210, 212, 214, 또는 216)은 항목들을 웹 서버 상에 게시할 수 있다. 예시적인 동작에서, 협업하는 액세스 포인트(예를 들어, 204, 206 또는 208)의 도달 거리 내의 협업하는 클라이언트 컴퓨팅 환경들(예를 들어, 210, 212, 214 또는 216)은 그의 BSSID를 이용하여, 협업하는 액세스 포인트(예를 들어, 204, 206 또는 208)로부터의 RSS 피드들에 가입할 수 있다. 예시적인 동작에서, RSS 피드 서버(202)와 통신할 수 있는 하나 이상의 협업하는 액세스 포인트들(예를 들어, 204, 206 또는 208) 사이의 통신은 HTTP(hyper text transfer protocol)를 통해 행해질 수 있다.
도 3은 데이터 통신을 용이하게 해주는 동작을 하는 예시적인 무선 통신 환경(300)의 다른 예시적인 구현을 나타낸 것이다. 도 3에 도시된 바와 같이, 예시적인 무선 통신 환경(300)은 액세스 포인트-1(302), 액세스 포인트-2(304), 클라이언트 컴퓨팅 환경들(310, 312, 320, 322, 324, 및 314)을 갖는 네이버캐스트 그룹(306), 및 클라이언트 컴퓨팅 환경들(314, 324, 326, 316, 328, 332, 318, 및 330)을 갖는 네이버캐스트 그룹(308)을 포함한다. 도 3에 도시된 바와 같이, 클라이언트 컴퓨팅 환경들(314 및 324) 중 몇몇은 네이버캐스트 그룹들(306 및 308) 둘다에 가입할 수 있다.
예시적인 구현에서, 클라이언트 컴퓨팅 환경들(310 및 312)은 액세스 포인트-1(302)와 연관되어 있을 수 있고, 클라이언트 컴퓨팅 환경들(316, 322, 및 318)은 액세스 포인트-2(304)와 연관되어 있을 수 있다. 에시적인 구현에서, 클라이언트 컴퓨팅 환경(314)은 액세스 포인트-1(302)의 도달 거리 내에 있을 수 있고 그의 네이버캐스트 그룹(306)에 가입할 수 있다. 네이버캐스트 그룹들(306 및 308) 둘다에 게시된 정보를 사용하여, 클라이언트 컴퓨팅 환경(314)은 액세스 포인트들(302 및 304) 둘다에 대한 부하 및 액세스 포인트들(302 및 304)의 채널 특성들의 데이터를 수신할 수 있다. 수신된 데이터를 사용하여, 클라이언트 컴퓨팅 환경(314)은 클라이언트 컴퓨팅 환경(314)이 어느 액세스 포인트(302 또는 304)와 가장 잘 연관될 수 있는지를 판정할 수 있다.
도 4는 무선 통신 환경의 협업하는 컴포넌트들 간의 통신을 용이하게 해주는 예시적인 방법(400)을 나타낸 것이다. 도시된 바와 같이, 처리는 근처의 액세스 포인트들이 식별되는 블록(402)에서 시작된다. 이어서, 처리는 식별된 근처의 액세스 포인트들과 연관된 고유 그룹 ID(unique group identification)가 식별되는 블록(404)으로 진행한다. 그곳으로부터, 처리는 협업하는 클라이언트 컴퓨팅 환경이 식별된 고유 그룹 ID들을 사용하는 식별된 근처의 액세스 포인트들의 네이버캐스트(예를 들어, 무선 통신 환경 오버레이) 그룹에 참여하는 블록(406)으로 진행한다. 이어서, 처리는 협업하는 컴퓨팅 환경 및/또는 액세스 포인트의 연결/통신/성능 상태를 나타내는 업데이트가 네이버캐스트 그룹에 게시되는 블록(408)으로 진행된다. 이어서, 블록(410)에서, 추가적인 근처의 액세스 포인트들이 있는지 알아보기 위해 스캔된다.
도 5는 RSS 서버 컴퓨팅 환경을 이용하여 무선 통신 환경의 협업하는 컴포넌트들 간의 통신을 용이하게 해주는 예시적인 방법(500)을 나타낸 것이다. 도시된 바와 같이, 처리는 근처의 액세스 포인트들이 식별되는 블록(502)에서 시작된다. 이어서, 처리는 근처의 액세스 포인트들과 연관된 RSS(really simple syndication) 서버가 식별되는 블록(504)으로 진행한다. 이어서, 블록(506)에서 (예를 들어, 하나 이상의 협업하는 클라이언트 컴퓨팅 환경들에 의한) 식별된 RSS 서버에 대한 가입이 수행된다. 이어서, 블록(508)에서, 식별된 RSS 서버를 사용하여 협업하는 당사자들과 데이터를 통신한다. 이어서, 블록(510)에서, 연결/통신/성능 상태를 나타내는 업데이트가 RSS 서버에 게시된다. 블록(512)에서, 추가적인 근처의 액세스 포인트들이 있는지 알아보기 위해 리스닝되고 스캔된다.
도 6은 무선 통신 환경의 협업하는 컴포넌트들 간의 통신을 용이하게 해주는 예시적인 방법(600)을 나타낸 것이다. 도시된 바와 같이, 처리는 근처의 액세스 포인트들이 식별되는 블록(602)에서 시작된다. 그곳으로부터, 처리는 네이버캐스트 그룹을 통해 협업하는 클라이언트 컴퓨팅 환경들이 식별되는 블록(604)으로 진행한다. 블록(606)에서, 네이버캐스트 그룹에 기여하는 근처의 액세스 포인트들의 채널 상태들 및 부하 상태들을 나타내는 주기적으로 게시되는 데이터가 있는지 스캔된다. 블록(608)에서, 원하는 채널 상태들 및 부하 상태들을 갖는 액세스 포인트들이 식별된다. 그곳으로부터, 처리는 협업하는 클라이언트 컴퓨팅 환경이 원하는 액세스 포인트(또는 액세스 포인트들)에 연결되는 블록(610)으로 진행한다.
예시적인 동작에서, 협업하는 클라이언트 컴퓨팅 환경들은 통신을 위해 IP 멀티캐스트를 이용할 수 있다. 다른 예시적인 동작들에서, ALM 또는 RSS 피드도 역시 이용될 수 있다. 예시적인 동작에서, 클라이언트 컴퓨팅 환경은, 액세스 포인트와 연관되어 있을 때, 예시적인 동작에서, 그 액세스 포인트에 대한 그룹의 멀티캐스트 IP 주소를 도출할 수 있고 그 멀티캐스트 그룹에 참여할 수 있다. 예시로서, 협업하는 클라이언트 컴퓨팅 환경은 멀티캐스트 그룹에 대한 채널 상태들 및 부하에 관한 정보를 주기적으로 게시할 수 있다. 이 정보는 예시로서 협업하는 클라이언트 컴퓨팅 환경들에 의해 처리되는 액세스 포인트들의 비이컨들(beacons)의 신호 강도, 선택된 기간에 협업하는 클라이언트 컴퓨팅 환경에 의해 발생된 트래픽의 요약, 및 발생되어 협업하는 클라이언트 컴퓨팅 환경들 사이에서 전달될 수 있는 서브넷 상의 첫번째 홉 게이트웨이(hop gateway)까지의 RTT의 추정치를 포함할 수 있다.
예시적인 동작에서, 협업하는 클라이언트 컴퓨팅 환경은 또한 협업하는 클라이언트 컴퓨팅 환경 주변에 액세스 포인트들이 있는지 스캔할 수 있고 그들의 멀티캐스트 그룹들에도 가입할 수 있다. 예시적인 동작에서, 협업하는 클라이언트 컴퓨팅 환경은 (i) 자신과 연관되어 있는 협업하는 액세스 포인트 상의 다른 클라이언트들에 의해 발생되는 부하, 및 (ii) 다른 근처의 액세스 포인트들에 대한 채널 상태들 및 부하 정보에 관한 정보를 수신할 수 있다. 이 정보에 기초하여, 협업하는 클라이언트 컴퓨팅 환경은 다른 액세스 포인트로 스위칭할지를 판정할 수 있다.
예시적인 구현에서, 액세스 포인트 선택이 협업적 문제 진단(cooperative problem diagnosis)으로 일반화될 수 있다. 협업하는 클라이언트 컴퓨팅 환경들은, 예시적인 무선 통신 환경에서의 문제점들을 자동화된 방식으로 진단하고 로컬화하기 위해, 근처의 다른 협업하는 클라이언트 컴퓨팅 환경들과 협업하는 데 네이버캐스트를 사용할 수 있다. 예시적인 구현에서, 정보를 전파시키는 데 네이버캐스트가 사용될 수 있다. 예를 들어, 협업하는 클라이언트 컴퓨팅 환경은, 좋지 않은 연결성(poor connectivity)을 경험할 때, 문제점을 진단하고 로컬화하기 위해 자신의 액세스 포인트와 연관된 다른 클라이언트 컴퓨팅 환경들 및 근처의 액세스 포인트들과 연관된 협업하는 클라이언트 컴퓨팅 환경들과 협업할 수 있다. 이 문제점이 게이트웨이로, 액세스 포인트로, 협업하는 클라이언트 컴퓨팅 환경의 무선 소프트웨어/하드웨어 컴포넌트로, 또는 협업하는 클라이언트 컴퓨팅 환경의 물리적 장소로 로컬화될 수 있다.
본 방법들은 하나 이상의 컴퓨터-판독가능 매체 상에 저장되거나 임의의 적당한 유형의 신호에 의해 전달되는 컴퓨터-실행가능 명령어들에 의해 구현될 수 있다. 본 방법들은 적어도 부분적으로 수동으로(manually) 구현될 수 있다. 본 방법들의 단계들이 소프트웨어로 또는 소프트웨어와 하드웨어의 조합으로 또한 이상에서 기술한 방식들 중 임의의 방식으로 구현될 수 있다. 컴퓨터-실행가능 명령어들은 하나의 마이크로프로세서 또는 복수의 마이크로프로세서들 상에서 실행되는 동일한 프로세스이거나 하나의 마이크로프로세서 또는 복수의 마이크로프로세서들 상에서 실행되는 다수의 프로세스들일 수 있다. 본 방법들은 필요에 따라 임의의 횟수 반복될 수 있고, 본 방법들의 단계들은 임의의 적당한 순서로 수행될 수 있다.
본 명세서에 기술된 발명 대상이 일반적으로 하나 이상의 컴포넌트들에 의해 실행되는, 프로그램 모듈들 등의, 컴퓨터-실행가능 명령어들과 관련하여 동작할 수 있다. 일반적으로, 프로그램 모듈들은 특정의 태스크들을 수행하거나 특정의 추상 데이터 유형들을 구현하는 루틴, 프로그램, 객체, 데이터 구조, 및 기타 등등을 포함한다. 통상적으로, 프로그램 모듈들의 기능이 원하는 바에 따라 결합되거나 분산될 수 있다. 이상의 설명이 일반적으로 컴퓨터 및/또는 컴퓨터들 상에서 실행되는 컴퓨터 프로그램의 컴퓨터-실행가능 명령어들에 관련되어 있지만, 사용자 인터페이스, 방법 및 시스템이 또한 다른 프로그램 모듈들과 결합하여 구현될 수 있다. 일반적으로, 프로그램 모듈들은 특정의 태스크들을 수행하고 및/또는 특정의 추상 데이터 유형들을 구현하는 루틴, 프로그램, 컴포넌트, 데이터 구조, 및 기타 등등을 포함한다.
게다가, 본 명세서에 기술된 발명 대상이, 단일-프로세서 또는 멀티프로세서 컴퓨터 시스템, 미니-컴퓨팅 장치, 메인프레임 컴퓨터, 퍼스널 컴퓨터, 독립형 컴퓨터, 핸드헬드 컴퓨팅 장치, 웨어러블 컴퓨팅 장치, 마이크로프로세서-기반 또는 프로그램가능 가전 제품, 기타는 물론 태스크들이 통신 네트워크를 통해 연결되어 있는 원격 처리 장치들에 의해 수행되는 분산 컴퓨팅 환경을 비롯한 대부분의 임의의 적당한 컴퓨터 시스템 구성들에서 실시될 수 있다. 분산 컴퓨팅 환경에서는, 프로그램 모듈들이 로컬 메모리 저장 장치들 및 원격 메모리 저장 장치들 둘다에 위치할 수 있다. 본 명세서에 기술된 방법들 및 시스템들은 컴퓨터-실행가능 명령어들을 갖는 컴퓨터-판독가능 매체는 물론, 예를 들어, 네트워크를 통해 이러한 정보를 전송하도록 구성된 신호들(예를 들어, 전자 신호들) 상에 구현될 수 있다.
발명 대상이 구조적 특징들 및/또는 방법적 동작들과 관련하여 기술되어 있지만, 첨부된 청구항들에 정의된 발명 대상이 이상에서 기술한 특정의 특징들 또는 동작들로 반드시 제한되는 것은 아니라는 것을 잘 알 것이다. 오히려, 이상에서 기술한 구체적인 특징들 및 동작들은 청구항들 중 일부를 구현하는 예시적인 형태들로서 개시되어 있다.
물론, 청구된 발명 대상 내에 속하는 컴포넌트들 및/또는 방법들의 모든 생각가능한 조합을 다 기술할 수는 없지만, 발명 대상의 많은 추가의 조합들 및 치환들이 가능하다. 특정의 특징이 몇개의 구현들 중 단지 하나와 관련하여 개시되어 있을 수 있지만, 임의의 주어진 또는 특정의 응용에 바람직하고 유익할 수 있는 바와 같이, 이러한 특징이 발명 대상의 다른 구현들의 하나 이상의 다른 특징들과 결합될 수 있다.
게다가, 본 명세서에 기술된 다양한 측면들이 휴대용 컴퓨팅 장치들(예를 들어, 현장 의료 장치) 상에서 구현될 수 있고 또 다른 측면들이 분산 컴퓨팅 플랫폼들(예를 들어, 원격 의료 또는 연구 애플리케이션들)에 걸쳐 구현될 수 있다는 것을 잘 알 것이다. 마찬가지로, 본 명세서에 기술된 다양한 측면들이 일련의 서비스들(예를 들어, 모델링, 예측, 분석, 기타)로서 구현될 수 있다.
도 7은 개시된 아키텍처를 실행하는 동작을 하는 컴퓨터의 블록도를 나타낸 것이다. 본 명세서의 다양한 측면들에 대한 부가적인 상황을 제공하기 위해, 도 7 및 이하의 설명은 본 명세서의 다양한 측면들이 구현될 수 있는 적당한 컴퓨팅 환경(700)에 대한 간략하고 개괄적인 설명을 제공하기 위한 것이다. 본 명세서가 일반적으로 하나 이상의 컴퓨터들 상에서 실행될 수 있는 컴퓨터-실행가능 명령어들과 관련하여 이상에서 기술되었지만, 당업자라면 본 명세서도 역시 다른 프로그램 모듈들과 결합하여 및/또는 하드웨어와 소프트웨어의 조합으로서 구현될 수 있다는 것을 잘 알 것이다.
일반적으로, 프로그램 모듈들은 특정의 태스크들을 수행하거나 특정의 추상 데이터 유형들을 구현하는 루틴, 프로그램, 컴포넌트, 데이터 구조, 및 기타 등등을 포함한다. 게다가, 당업자라면 본 발명의 방법들이 단일-프로세서 또는 멀티프로세서 컴퓨터 시스템, 미니컴퓨터, 메인프레임 컴퓨터는 물론, 퍼스널 컴퓨터, 핸드헬드 컴퓨팅 장치, 마이크로프로세서-기반 또는 프로그램가능 가전 제품, 기타 등등(이들 각각은 하나 이상의 연관된 장치들과 결합되어 동작할 수 있음)을 비롯한 다른 컴퓨터 시스템 구성들에서도 실시될 수 있다는 것을 잘 알 것이다.
본 명세서의 예시된 측면들은 또한 어떤 태스크들이 통신 네트워크를 통해 연결되어 있는 원격 처리 장치들에 의해 수행되는 분산 컴퓨팅 환경에서도 실시될 수 있다. 분산 컴퓨팅 환경에서는, 프로그램 모듈들이 로컬 메모리 저장 장치들 및 원격 메모리 저장 장치들 둘다에 위치할 수 있다.
컴퓨터는 통상적으로 각종의 컴퓨터-판독가능 매체를 포함하고 있다. 컴퓨터-판독가능 매체는 컴퓨터에 의해 액세스될 수 있는 이용가능한 매체라면 어느 것이라도 될 수 있고, 휘발성 및 비휘발성 매체, 이동식 및 비이동식 매체 둘다를 포함한다. 제한이 아닌 예로서, 컴퓨터-판독가능 매체는 컴퓨터 저장 매체 및 통신 매체를 포함할 수 있다. 컴퓨터 저장 매체는 컴퓨터 판독가능 명령어, 데이터 구조, 프로그램 모듈 또는 기타 데이터 등의 정보를 저장하는 임의의 방법 또는 기술로 구현되는 휘발성 및 비휘발성, 이동식 및 비이동식 매체를 포함한다. 컴퓨터 저장 매체로는 RAM, ROM, EEPROM, 플래쉬 메모리 또는 기타 메모리 기술, CD-ROM, DVD(digital versatile disk) 또는 기타 광 디스크 저장 장치, 자기 카세트, 자기 테이프, 자기 디스크 저장 장치 또는 기타 자기 저장 장치, 또는 원하는 정보를 저장하는 데 사용될 수 있고 또 컴퓨터에 의해 액세스될 수 있는 임의의 다른 매체가 있지만, 이들로 제한되지 않는다.
통신 매체는 통상적으로 컴퓨터-판독가능 명령어, 데이터 구조, 프로그램 모듈 또는 기타 데이터를 반송파 또는 기타 전송 메카니즘 등의 피변조 데이터 신호(modulated data signal)에 구현하고 모든 정보 전달 매체를 포함한다. "피변조 데이터 신호"라는 용어는 신호의 특성들 중 하나 이상이 정보를 그 신호에 인코딩하는 방식으로 설정 또는 변경된 신호를 의미한다. 제한이 아닌 예로서, 통신 매체는 유선 네트워크 또는 직접 배선 연결(direct-wired connection) 등의 유선 매체와, 음향, RF, 적외선 및 기타 무선 매체 등의 무선 매체를 포함한다. 상기한 것들 중 임의의 것의 조합도 역시 컴퓨터-판독가능 매체의 범위 내에 포함되어야 한다.
보다 상세하게는, 도 7을 참조하면, 본 명세서에 기술된 다양한 측면들을 구현하는 예시적인 환경(700)은 컴퓨터(702)를 포함하고 있고, 이 컴퓨터(702)는 처리 장치(704), 시스템 메모리(706) 및 시스템 버스(708)를 포함하고 있다. 시스템 버스(708)는 시스템 메모리(706)(이것으로 제한되지 않음)를 비롯한 시스템 컴포넌트들을 처리 장치(704)에 연결시킨다. 처리 장치(704)는 다양한 상용 프로세서들 중 어느 것이라도 될 수 있다. 듀얼 마이크로프로세서 및 기타 멀티-프로세서 아키텍처도 처리 장치(704)로서 이용될 수 있다.
시스템 버스(708)는 메모리 버스(메모리 컨트롤러를 갖거나 갖지 않음), 주변 장치 버스, 및 각종의 상용 버스 아키텍처들 중 어느 것이라도 사용하는 로컬 버스와 추가적으로 상호연결될 수 있는 몇가지 유형의 버스 구조들 중 어느 것이라도 될 수 있다. 시스템 메모리(706)는 판독 전용 메모리(ROM)(710) 및 랜덤 액세스 메모리(RAM)(712)를 포함한다. 기본 입/출력 시스템(BIOS)은 ROM, EPROM, EEPROM 등의 비휘발성 메모리(710)에 저장되며, 이 BIOS는 시동 중과 같은 때에 컴퓨터(702) 내의 구성요소들 간의 정보 전송을 돕는 기본 루틴들을 포함하고 있다. RAM(712)은 또한 데이터를 캐싱하기 위한 정적 RAM 등의 고속 RAM도 포함할 수 있다.
컴퓨터(702)는 내장형 하드 디스크 드라이브(HDD)(714)(예를 들어, EIDE, SATA) - 이 내장형 하드 디스크 드라이브(714)는 또한 적당한 새시(도시 생략)에 넣어 외장용으로도 구성될 수 있음 -, 자기 플로피 디스크 드라이브(FDD)(716)[예를 들어, 이동식 디스켓(718)으로부터 판독을 하거나 그에 기록을 함] 및 광 디스크 드라이브(720)[예를 들어, CD-ROM 디스크(722)를 판독하거나, 또는 DVD 등의 기타 대용량 광 매체로부터 판독을 하거나 그에 기록을 함]를 더 포함하고 있다. 하드 디스크 드라이브(714), 자기 디스크 드라이브(716) 및 광 디스크 드라이브(720)는 제각기 하드 디스크 드라이브 인터페이스(724), 자기 디스크 드라이브 인터페이스(726) 및 광 드라이브 인터페이스(728)에 의해 시스템 버스(708)에 연결될 수 있다. 외장형 드라이브 구현들을 위한 인터페이스(724)는 USB(Universal Serial Bus) 및 IEEE 1394 인터페이스 기술들 중 적어도 하나 또는 둘다를 포함한다. 기타 외장형 드라이브 연결 기술들이 본 명세서의 적용 범위(contemplation) 내에 속한다.
이들 드라이브 및 그와 연관된 컴퓨터-판독가능 매체는 데이터, 데이터 구조, 컴퓨터-실행가능 명령어, 기타 등등의 비휘발성 저장을 제공한다. 컴퓨터(702)의 경우, 이들 드라이브 및 매체는 임의의 데이터를 적당한 디지털 포맷으로 저장하기 위한 것이다. 컴퓨터 판독가능 매체에 대한 이상의 설명에서 HDD, 이동식 자기 디스켓, 및 CD나 DVD 등의 이동식 광 매체에 대해 언급하고 있지만, 당업자라면 컴퓨터에 의해 판독가능한 기타 유형의 매체들(zip 드라이브, 자기 카세트, 플래쉬 메모리 카드, 카트리지, 기타 등등)도 이 예시적인 운영 환경에서 사용될 수 있다는 것과 또한 임의의 이러한 매체가 본 명세서의 방법들을 수행하는 컴퓨터 실행가능 명령어들을 포함하고 있을 수 있다는 것도 잘 알 것이다.
운영 체제(730), 하나 이상의 애플리케이션 프로그램들(732), 기타 프로그램 모듈들(734) 및 프로그램 데이터(736)를 비롯한 다수의 프로그램 모듈들이 이들 드라이브 및 RAM(712)에 저장될 수 있다. 운영 체제, 애플리케이션들, 모듈들 및/또는 데이터의 전부 또는 일부도 역시 RAM(712)에 캐싱될 수 있다. 본 명세서가 다양한 상용 운영 체제들 또는 운영 체제들의 조합들에서 구현될 수 있다는 것을 잘 알 것이다.
사용자는 하나 이상의 유선/무선 입력 장치들, 예를 들어, 키보드(738) 및 마우스(740) 등의 포인팅 장치를 통해 컴퓨터(702)에 명령들 및 정보를 입력할 수 있다. 다른 입력 장치들(도시 생략)로는 마이크, IR 리모콘, 조이스틱, 게임 패드, 스타일러스 펜, 터치 스크린, 기타 등등이 있을 수 있다. 이들 및 기타 입력 장치들은 종종 시스템 버스(708)에 결합되어 있는 입력 장치 인터페이스(742)를 통해 처리 장치(704)에 연결되지만, 병렬 포트, IEEE 1394 직렬 포트, 게임 포트, USB 포트, IR 인터페이스, 기타 등등의 다른 인터페이스들에 의해 연결될 수 있다.
모니터(744) 또는 기타 유형의 디스플레이 장치도 비디오 어댑터(746) 등의 인터페이스를 통해 시스템 버스(708)에 연결된다. 모니터(744) 이외에, 컴퓨터는 통상적으로 스피커들, 프린터들, 기타 등등의 기타 주변 출력 장치들(도시 생략)도 포함하고 있다.
컴퓨터(702)는 원격 컴퓨터(들)(748) 등의 하나 이상의 원격 컴퓨터들과의 유선 및/또는 무선 통신을 통한 논리적 연결들을 사용하여 네트워크화된 환경에서 동작할 수 있다. 원격 컴퓨터(들)(748)는 워크스테이션, 서버 컴퓨터, 라우터, 퍼스널 컴퓨터, 휴대용 컴퓨터, 마이크로프로세서-기반 오락 기기, 피어 장치 또는 기타 통상의 네트워크 노드일 수 있으며, 통상적으로 컴퓨터(702)와 관련하여 기술된 구성요소들 중 다수 또는 그 전부를 포함하지만, 간략함을 위해 메모리/저장 장치(750)만이 도시되어 있다. 도시된 논리적 연결들은 근거리 통신망(LAN)(752) 및/또는 보다 대규모의 네트워크, 예를 들어, 원거리 통신망(WAN)(754)에의 유선/무선 연결을 포함한다. 이러한 LAN 및 WAN 네트워킹 환경들은 사무실들 및 회사들에서 흔하게 볼 수 있고 인트라넷 등의 전사적 컴퓨터 네트워크들을 용이하게 해주며, 이들 네트워크 전부는 전세계 통신 네트워크, 예를 들어, 인터넷에 연결할 수 있다.
LAN 네트워킹 환경에서 사용될 때, 컴퓨터(702)는 유선 및/또는 무선 통신 네트워크 인터페이스 또는 어댑터(756)를 통해 로컬 네트워크(752)에 연결된다. 어댑터(756)는 LAN(752)과의 유선 또는 무선 통신을 용이하게 해줄 수 있으며, 이 LAN(752)은 무선 어댑터(756)와 통신하기 위해 LAN에 배치되어 있는 무선 액세스 포인트도 포함하고 있을 수 있다.
WAN 네트워킹 환경에서 사용될 때, 컴퓨터(702)는 모뎀(758)을 포함할 수 있거나, WAN(754) 상의 통신 서버에 연결되어 있거나, WAN(754)을 통해, 예를 들어, 인터넷을 통해 통신을 설정하는 기타 수단을 갖는다. 내장형이거나 외장형이고 유선 또는 무선 장치일 수 있는 모뎀(758)은 직렬 포트 인터페이스(742)를 통해 시스템 버스(708)에 연결된다. 네트워크화된 환경에서, 컴퓨터(702) 또는 그의 일부와 관련하여 도시된 프로그램 모듈들은 원격 메모리/저장 장치(750)에 저장될 수 있다. 도시된 네트워크 연결들이 예시적인 것이고 컴퓨터들 간에 통신 링크를 설정하는 기타 수단이 사용될 수 있다는 것을 잘 알 것이다.
컴퓨터(702)는 무선 통신에 배치되어 동작하는 임의의 무선 장치들 또는 개체들, 예를 들어, 프린터, 스캐너, 데스크톱 및/또는 휴대용 컴퓨터, PDA(portable data assistant), 통신 위성, 무선 검출가능 태그와 연관된 임의의 장비 또는 장소(예를 들어, 키오스크, 신문 가판대, 휴게실), 그리고 전화와 통신하는 동작을 한다. 이것은 적어도 Wi-Fi 및 블루투스™ 무선 기술들을 포함한다. 따라서, 이 통신은 종래의 네트워크 또는 단지 적어도 2개의 장치들 간의 애드혹 통신(ad hoc communication)에서와 같이 미리 정의된 구조일 수 있다.
Wi-Fi(Wireless Fidelity)에 의해, 집에 있는 소파, 호텔방에 있는 침대, 또는 회사에 있는 회의실로부터 유선 없이 인터넷에 연결할 수 있다. Wi-Fi는 이러한 장치들(예를 들어, 컴퓨터들)이 실내에서 및 실외에서(기지국의 도달 범위 내의 어느 곳에서라도) 데이터를 전송 및 수신할 수 있게 해주는 셀 전화에서 사용되는 것과 유사한 무선 기술이다. Wi-Fi 네트워크들은 안전하고 신뢰성있는 고속의 무선 연결을 제공하기 위해 IEEE 802.11(a, b, g, 기타)라고 불리우는 무선 기술들을 사용한다. Wi-Fi 네트워크는 컴퓨터들을 서로 연결시키고, 인터넷에 연결시키며, 또 유선 네트워크들(IEEE 802.3, 즉 이더넷을 사용함)에 연결시키는 데 사용될 수 있다. Wi-Fi 네트워크들은 비면허 2.4 및 5 GHz 무선 대역에서, 예를 들어, 11 Mbps(802.11b) 또는 54 Mbps(802.11a) 데이터 레이트로 또는 양쪽 대역(듀얼 대역)을 포함하는 제품들에서 동작하며, 따라서 이 네트워크들은 다수의 사무실들에서 사용되는 기본적인 10BaseT 유선 이더넷 네트워크들과 유사한 실세계 성능을 제공할 수 있다.
이제 도 8을 참조하면, 본 발명에 따른 예시적인 컴퓨팅 환경(800)의 개략 블록도가 도시되어 있다. 시스템(800)은 하나 이상의 클라이언트(들)(810)를 포함하고 있다. 클라이언트(들)(810)는 하드웨어 및/또는 소프트웨어(예를 들어, 쓰레드들, 프로세스들, 컴퓨팅 장치들)일 수 있다. 클라이언트(들)(810)는, 예를 들어, 본 발명을 이용함으로써 쿠키(들) 및/또는 연관된 컨텍스트 정보(contextual information)를 가지고 있을 수 있다. 시스템(800)은 또한 하나 이상의 서버(들)(820)도 포함하고 있다. 서버(들)(820)도 역시 하드웨어 및/또는 소프트웨어(예를 들어, 쓰레드들, 프로세스들, 컴퓨팅 장치들)일 수 있다. 서버(들)(820)는, 예를 들어, 본 방법들 및/또는 시스템들을 이용하여 변환을 수행하는 쓰레드들을 가지고 있을 수 있다. 클라이언트(810)와 서버(820) 간의 한가지 가능한 통신은 2개 이상의 컴퓨터 프로세스들 간에 전송되도록 구성되어 있는 데이터 패킷의 형태로 되어 있을 수 있다. 이 데이터 패킷은, 예를 들어, 쿠키 및/또는 연관된 컨텍스트 정보를 포함할 수 있다. 시스템(800)은 클라이언트(들)(810)와 서버(들)(820) 간의 통신을 용이하게 해주는 데 이용될 수 있는 통신 프레임워크(830)(예를 들어, 인터넷 등의 전세계 통신 네트워크)를 포함하고 있다.
유선(광 섬유를 포함함) 및/또는 무선 기술을 통해 통신이 용이하게 될 수 있다. 클라이언트(들)(810)는 클라이언트(들)(810)에 로컬인 정보(예를 들어, 쿠키(들) 및/또는 연관된 컨텍스트 정보)를 저장하는 데 이용될 수 있는 하나 이상의 클라이언트 데이터 저장소(들)(840)에 연결되어 동작한다. 이와 유사하게, 서버(들)(820)는 서버(들)(820)에 로컬인 정보를 저장하는 데 이용될 수 있는 하나 이상의 서버 데이터 저장소(들)(850)에 연결되어 동작한다.
청구된 발명 대상의 일례들에 대해 이상에서 설명하였다. 물론, 청구된 발명 대상을 설명하기 위해 컴포넌트들 및/또는 방법들의 모든 생각가능한 조합을 다 기술할 수는 없지만, 당업자라면 청구된 발명 대상의 많은 추가의 조합들 및 치환들이 가능하다는 것을 잘 알 것이다. 그에 따라, 청구된 발명 대상이 첨부된 청구항들의 사상 및 범위 내에 속하는 모든 이러한 변경들, 수정들 및 변형들을 포괄하는 것으로 보아야 한다. 게다가, "포함한다"라는 용어가 상세한 설명 또는 청구항들에서 사용되는 한, 이러한 용어는 "포함하는"이라는 용어가 청구항에서 전이구(transitional word)로 이용될 때 해석되는 것과 유사한 방식으로 포함적(inclusive)인 것으로 보아야 한다.

Claims (20)

  1. 무선 통신 환경에서 데이터를 통신하는 방법으로서,
    클라이언트 컴퓨팅 환경이, 하나 이상의 인접한 협업 액세스 포인트(cooperating access point)의 고유 식별자를 사용하여 상기 하나 이상의 인접한 협업 액세스 포인트를 식별하는 단계와,
    클라이언트 컴퓨팅 환경이, 네이버캐스트 그룹(neighborcast group)을 생성하기 위해 상기 하나 이상의 인접한 협업 액세스 포인트에 가입하는(subscribing) 단계와,
    클라이언트 컴퓨팅 환경이, 상기 네이버캐스트 그룹의 하나 이상의 컴포넌트에 의해 수신 및 처리 중 하나 이상이 될 수 있는 데이터를 게시하는(publishing) 단계
    를 포함하는 방법.
  2. 제1항에 있어서,
    상기 생성된 네이버캐스트 그룹을 사용하여 둘 이상의 클라이언트 컴퓨팅 환경들 사이에 데이터를 통신하는 단계
    를 더 포함하는 방법.
  3. 제1항에 있어서,
    하나 이상의 IP(internet protocol) 멀티캐스팅 동작을 사용하여 상기 네이버캐스트 그룹을 생성하거나 상기 네이버캐스트 그룹을 통해 데이터를 게시하는 단계
    를 더 포함하는 방법.
  4. 제1항에 있어서,
    RSS 피드 서버(RSS feed server)를 이용(deploying)하여 상기 네이버캐스트 그룹을 생성하는 단계
    를 더 포함하는 방법.
  5. 제4항에 있어서,
    데이터 통신을 위해 하나 이상의 액세스 포인트를 상기 RSS 피드 서버에 가입시키는 단계
    를 더 포함하는 방법.
  6. 제5항에 있어서,
    상기 하나 이상의 액세스 포인트 및 상기 RSS 피드 서버를 통해 하나 이상의 클라이언트 컴퓨팅 환경 사이에 데이터를 통신하는 단계
    를 더 포함하는 방법.
  7. 제1항에 있어서,
    상기 하나 이상의 인접한 협업 액세스 포인트 중 어느 것과 연관시켜야 할지를 결정하기 위해, 하나 이상의 인접한 협업 액세스 포인트의 성능을 나타내는 데이터를 하나 이상의 클라이언트 컴퓨팅 환경으로부터 수신하는 단계
    를 더 포함하는 방법.
  8. 제7항에 있어서,
    상기 하나 이상의 클라이언트 컴퓨팅 환경에 의해, 상기 하나 이상의 클라이언트 컴퓨팅 환경이 연관관계를 갖는 액세스 포인트의 성능에 대한 데이터를 상기 네이버캐스트 그룹을 통해 게시하는 단계
    를 더 포함하는 방법.
  9. 제1항에 있어서,
    무선 통신 환경 내의 하나 이상의 클라이언트 컴퓨팅 환경의 존재에 관해 나타내는 데이터를 게시하는 단계
    를 더 포함하는 방법.
  10. 컴퓨터에게 방법을 수행하라고 지시하는 컴퓨터-판독가능 명령어들을 포함하는 휘발성 또는 비휘발성 컴퓨터-판독가능 매체로서,
    상기 방법은,
    하나 이상의 인접한 액세스 포인트의 고유 식별자를 사용하여 상기 하나 이상의 인접한 액세스 포인트를 식별하는 단계와,
    네이버캐스트 그룹(neighborcast group)을 생성하기 위해 상기 하나 이상의 인접한 액세스 포인트에 가입하는 단계와,
    상기 네이버캐스트 그룹의 하나 이상의 컴포넌트에 의해 수신 및 처리 중 하나 이상이 될 수 있는 데이터를 게시하는 단계
    를 포함하는 컴퓨터-판독가능 매체.
  11. 무선 통신 환경에서의 통신을 용이하게 하는 시스템으로서,
    무선 통신 환경 오버레이를 사용하여 둘 이상의 인접한 클라이언트 컴퓨팅 환경들 사이의 데이터의 통신을 조정하도록 동작가능한 무선 통신 환경 오버레이 엔진 - 상기 무선 통신 환경 오버레이는 둘 이상의 인접한 클라이언트 컴퓨팅 환경 사이에서 인터넷 프로토콜(IP)을 사용하여 데이터를 통신하도록 동작가능한 오버레이를 포함함 - 과,
    상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들에 대한 네이버캐스트 그룹을 구축하기 위해, 상기 무선 통신 환경 오버레이 엔진에게 상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들의 동작 특징들(operational features)을 나타내는 데이터를 처리하라고 지시하는 적어도 하나의 명령어를 포함하는 명령어 세트를 포함하되,
    상기 네이버캐스트 그룹은 무선 통신 네트워크상에서 동작가능하고,
    상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들 중 하나가 상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들 중 다른 하나와 상이한 무선 통신 환경 연관관계(wireless communications environment associations)를 유지하는
    시스템.
  12. 제11항에 있어서,
    상기 네이버캐스트 그룹을 통해 상기 클라이언트 컴퓨팅 환경들 간에 또한 상기 클라이언트 컴퓨팅 환경들과 데이터를 통신하도록 상기 무선 통신 환경에서 동작가능한 둘 이상의 액세스 포인트들을 더 포함하는
    시스템.
  13. 제12항에 있어서,
    상기 네이버캐스트 그룹은 하나 이상의 IP(Internet Protocol) 멀티캐스팅 동작을 이용하여 구축되는
    시스템.
  14. 제12항에 있어서,
    상기 네이버캐스트 그룹은 하나 이상의 ALM(application level multicasting) 동작을 이용하여 구축되는
    시스템.
  15. 제12항에 있어서,
    상기 둘 이상의 액세스 포인트들은 서로 다른 무선 통신 환경 통신 채널들 상에서 동작하는
    시스템.
  16. 제15항에 있어서,
    상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들은 상기 무선 통신 채널에서 사용되는 둘 이상의 네이버캐스트 그룹들에 참여하도록 동작가능하고, 상기 둘 이상의 액세스 포인트들 상에서 동작가능한
    시스템.
  17. 제11항에 있어서,
    상기 네이버캐스트 그룹을 통해 데이터를 통신하기 위해 상기 둘 이상의 인접합 클라이언트 컴퓨팅 환경들과 협업하도록 동작가능한 RSS(really simple syndication) 피드 컴퓨팅 서버 환경을 더 포함하는
    시스템.
  18. 제11항에 있어서,
    상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들은 상기 네이버캐스트 그룹을 통해 상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들의 동작 특징들을 나타내는 데이터를 게시하도록 동작하는
    시스템.
  19. 제11항에 있어서,
    상기 무선 통신 환경 오버레이 엔진은 컴퓨팅 애플리케이션을 포함하는
    시스템.
  20. 제19항에 있어서,
    상기 컴퓨팅 애플리케이션은 상기 둘 이상의 인접한 클라이언트 컴퓨팅 환경들에서 동작가능한
    시스템.
KR1020107015952A 2008-01-23 2009-01-05 무선 통신 환경 오버레이 KR101592043B1 (ko)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/018,723 US7978652B2 (en) 2008-01-23 2008-01-23 Wireless communications environment overlay
US12/018,723 2008-01-23

Publications (2)

Publication Number Publication Date
KR20100102166A KR20100102166A (ko) 2010-09-20
KR101592043B1 true KR101592043B1 (ko) 2016-02-04

Family

ID=40876440

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020107015952A KR101592043B1 (ko) 2008-01-23 2009-01-05 무선 통신 환경 오버레이

Country Status (5)

Country Link
US (1) US7978652B2 (ko)
EP (1) EP2241060A4 (ko)
KR (1) KR101592043B1 (ko)
CN (1) CN101926128B (ko)
WO (1) WO2009094234A1 (ko)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8661080B2 (en) * 2010-07-15 2014-02-25 International Business Machines Corporation Propagating changes in topic subscription status of processes in an overlay network
US9351297B2 (en) * 2012-08-27 2016-05-24 Huawei Technologies Co., Ltd. System and method for a collaborative service set
US9392067B2 (en) * 2013-05-07 2016-07-12 Microsoft Technology Licensing, Llc Efficient automatic sharing of network access among devices
EP3123796A4 (en) * 2014-09-26 2017-12-06 Hewlett-Packard Enterprise Development LP Computing nodes
US10454977B2 (en) * 2017-02-14 2019-10-22 At&T Intellectual Property I, L.P. Systems and methods for allocating and managing resources in an internet of things environment using location based focus of attention
EP3556146B1 (en) 2017-06-15 2021-03-03 ZTE Corporation System and method for exchanging configuration information between two nodes in a wireless network

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060046709A1 (en) 2004-06-29 2006-03-02 Microsoft Corporation Proximity detection using wireless signal strengths
US20060165035A1 (en) 2005-01-25 2006-07-27 Interdigital Technology Corporation Peer-to-peer wireless communication system

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7738407B2 (en) 2001-08-03 2010-06-15 At&T Intellectual Property Ii, L.P. Method and apparatus for delivering IPP2T (IP-push-to-talk) wireless LAN mobile radio service
US7936872B2 (en) * 2003-05-19 2011-05-03 Microsoft Corporation Client proximity detection method and system
US20060008256A1 (en) * 2003-10-01 2006-01-12 Khedouri Robert K Audio visual player apparatus and system and method of content distribution using the same
US7129891B2 (en) * 2003-11-21 2006-10-31 Xerox Corporation Method for determining proximity of devices in a wireless network
US20050223086A1 (en) * 2004-03-31 2005-10-06 Raverdy Pierre G Discovering nearby hosts and applications for impromptu interactions using well-known ad-hoc network configuration
US20050220106A1 (en) * 2004-03-31 2005-10-06 Pierre Guillaume Raverdy Inter-wireless interactions using user discovery for ad-hoc environments
CN101496430A (zh) * 2005-01-25 2009-07-29 美商内数位科技公司 点对点无线通信系统
US7385960B2 (en) * 2005-02-28 2008-06-10 Microsoft Corporation Measurement based mechanism to enable two wireless devices to directly communicate with each other to support traffic prioritization
KR100644695B1 (ko) * 2005-05-07 2006-11-10 삼성전자주식회사 확장된 무선 랜에서 이동 노드를 그룹화하기 위한 방법 및장치
US20060291412A1 (en) * 2005-06-24 2006-12-28 Naqvi Shamim A Associated device discovery in IMS networks
US7577125B2 (en) * 2005-07-08 2009-08-18 Microsoft Corporation Direct wireless client to client communication
WO2007062004A2 (en) * 2005-11-22 2007-05-31 The Trustees Of Columbia University In The City Of New York Methods, media, and devices for moving a connection from one point of access to another point of access
US8374122B2 (en) * 2005-12-21 2013-02-12 Cisco Technology, Inc. System and method for integrated WiFi/WiMax neighbor AP discovery and AP advertisement

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060046709A1 (en) 2004-06-29 2006-03-02 Microsoft Corporation Proximity detection using wireless signal strengths
US20060165035A1 (en) 2005-01-25 2006-07-27 Interdigital Technology Corporation Peer-to-peer wireless communication system

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
MAXEMCHUK, N F , TIENTRAKOOL, P , WILLKE, T L , 'Reliable Neighborcasf, Vehicular Technology, IEEE Transactions on, Vol. 56
Ranveer Chandra et al., 'Wi-Fi neighborcast enabling communication among nearby clients'

Also Published As

Publication number Publication date
EP2241060A4 (en) 2016-07-06
US20090185514A1 (en) 2009-07-23
KR20100102166A (ko) 2010-09-20
CN101926128B (zh) 2015-07-22
EP2241060A1 (en) 2010-10-20
US7978652B2 (en) 2011-07-12
WO2009094234A1 (en) 2009-07-30
CN101926128A (zh) 2010-12-22

Similar Documents

Publication Publication Date Title
US10623312B2 (en) Wireless home network routing protocol
Maccari et al. A week in the life of three large Wireless Community Networks
KR101571376B1 (ko) 구성원 자원에 액세스하는 방법, 그룹 서버 및 구성원 장치
US7978631B1 (en) Method and apparatus for encoding and mapping of virtual addresses for clusters
KR101592043B1 (ko) 무선 통신 환경 오버레이
DE112013002674B4 (de) Bewerben, Ermitteln und Verwenden von Diensten durch virtuelle Zugriffspunkt-Schnittstellen
US9191219B2 (en) Network multicast peer discovery methods
Wang et al. Device-to-Device based mobile social networking in proximity (MSNP) on smartphones: Framework, challenges and prototype
EP2583423B1 (en) Apparatus and method for configuring personal network using pn routing table
CN104468327B (zh) 一种群组加入方法、装置及系统
US11979315B2 (en) Information centric network interworking techniques
US10880162B1 (en) Linking logical broadcast domains
US8051157B2 (en) Discovery apparatus and method
Bernaschi et al. A CAPWAP-based solution for frequency planning in large scale networks of WiFi Hot-Spots
US20090157878A1 (en) Method and system for connecting lower nodes to one another to increase scalability in zigbee network
Omer Farooq RIoT: a routing protocol for the internet of things
DE102022202570A1 (de) Verteilte pfadauswahl in informationszentrischen netzwerken
CN102316006B (zh) 一种发送数据报文的方法和装置
Raghavendran et al. Internet of Things–A big challenge in getting the right protocol
Saxena et al. An Optimal Link cum State Routing method for channelized data MANET
Li A Coordination Model and Framework for Developing Distributed Mobile Applications
Giudici CAESAR: an urban location service for VANETs
CN117692295A (zh) 网关组网方法、装置、设备及介质
Canonico et al. Content Networks for Communities: An Architectural Framework
Dow et al. An efficient anycast scheme for discovering k services in cluster‐based mobile ad hoc networks

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
N231 Notification of change of applicant
E701 Decision to grant or registration of patent right
FPAY Annual fee payment

Payment date: 20190103

Year of fee payment: 4

FPAY Annual fee payment

Payment date: 20200103

Year of fee payment: 5