Method And Apparatus For Facilitating Remote Search Of A Community

Information

  • Patent Application
  • 20140229503
  • Publication Number
    20140229503
  • Date Filed
    February 11, 2013
    11 years ago
  • Date Published
    August 14, 2014
    10 years ago
Abstract
A method and apparatus are provided for facilitating remote search via an ad hoc community. In the context of a method, a search request is received from a remote terminal for information from an ad hoc community. The ad hoc community is formed by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other. The remote terminal is located at a second location that is outside of a range of the proximity-based wireless communication technology from the first location. The method includes causing a first terminal of the plurality of terminals to broadcast the search request to the plurality of terminals using the proximity-based wireless communication technology. The method also receives information responsive to the search request from the plurality of terminals and causes the first terminal of the plurality of terminals to transmit the received information to the remote terminal.
Description
TECHNOLOGICAL FIELD

Example embodiments of the present invention relate generally to communications technology and, more particularly, relate to a method and apparatus for facilitating remote search of a community.


BACKGROUND

The modern communications era has brought about a tremendous expansion of wireline and wireless networks. Computer networks, television networks, and telephony networks are experiencing an unprecedented technological expansion, fueled by consumer demand. Wireless and mobile networking technologies have addressed related consumer demands, while providing more flexibility and immediacy of information transfer and providing convenience to users.


Concurrent with the expansion of networking technologies, an expansion in computing power has resulted in development of affordable computing devices capable of taking advantage of services made possible by modern networking technologies. This expansion in computing power has led to a reduction in the size of computing devices and given rise to a new generation of mobile devices that are capable of performing functionality that only a few years ago required processing power that could be provided only by the most advanced desktop computers. Consequently, mobile computing devices having a small form factor have become ubiquitous and are used to access network applications and services by consumers of all socioeconomic backgrounds. Consumers may accordingly use their mobile computing devices to access services and communicate with other devices over mobile networks at a variety of locations.


BRIEF SUMMARY

A method, apparatus, and computer program product are herein provided for facilitating remote search via a community. For example, some example embodiments provide an apparatus that may be embodied by a terminal configured to serve as a gateway between one or more terminals participating in a community at a first location and a remote terminal via a structured network. The apparatus of some embodiments may be configured to receive a search request regarding the community, so as to enable the remote terminal to search the knowledge base of the community.


In one example embodiment, a method is provided, which may include receiving, from a remote terminal, a search request for information from an ad hoc community, the ad hoc community formed by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other at the first location, wherein the remote terminal is located at a second location that is outside of a range of the proximity-based wireless communication technology from the first location. The method of this example embodiment may further include causing a first terminal of the plurality of terminals to broadcast the search request to the plurality of terminals using the proximity-based wireless communication technology. Additionally, the method of this embodiment may include causing the first terminal of the plurality of terminals to transmit to the remote terminal any received information responsive to the search request.


The method of an additional embodiment may include causing the first terminal to initiate a local search for information responsive to the search request, and causing the first terminal to collect information responsive to the local search, wherein the received information responsive to the search request includes the collected information responsive to the local search. In this embodiment, initiating a local search for information responsive to the search request may comprise activating a search agent based on the search request, and collecting information responsive to the local search may comprise broadcasting, using the search agent, a signal using the proximity-based wireless communication technology and collecting, using the search agent, information received in response to the broadcast signal. In some embodiments of the method, the search request is received from the remote terminal via a social networking application and includes parameters indicating a number of times the search request may be broadcast, and a number of times the search request may be retransmitted via the social networking application. In one such embodiment, causing the first terminal to broadcast the search request to the plurality of terminals includes, in an instance in which the parameter indicating a number of times the search request may be broadcast is greater than zero, causing the first terminal to modify the search request by decrementing the parameter indicating a number of times the search request may be broadcast by one, and causing the first terminal to broadcast the modified search request to the plurality of terminals using the proximity-based wireless communication technology. In another such embodiment, the method further includes, in an instance in which the parameter indicating a number of times the search request may be transmitted is greater than zero, causing the first terminal to modify the search request by decrementing the parameter indicating a number of times the search request may be transmitted by one, and causing the first terminal to transmit the modified search request to a set of contacts retrieved using a social networking application. In one additional embodiment of the method, the search request includes one or more parameters indicating least one of a geographical limitation and a time period after which the search request expires.


In another example embodiment, an apparatus includes at least one processor and at least one memory including computer program code. In this embodiment, the at least one memory and the computer program code are configured to, with the processor, cause the apparatus to receive, from a remote terminal, a search request for information from an ad hoc community, the ad hoc community formed by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other at the first location, wherein the remote terminal is located at a second location that is outside of a range of the proximity-based wireless communication technology from the first location. The at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to broadcast the search request to the plurality of terminals using the proximity-based wireless communication technology. Additionally, the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to transmit any received information responsive to the search request to the remote terminal.


In an additional embodiment of the apparatus, the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to initiate a local search for information responsive to the search request, and collect information responsive to the local search, wherein the received information responsive to the search request includes the collected information responsive to the local search. In this embodiment, initiating a local search for information responsive to the search request may comprise activating a search agent based on the search request, and collecting information responsive to the local search may comprise broadcasting, using the search agent, a signal using the proximity-based wireless communication technology and collecting, using the search agent, information received in response to the broadcast signal. In another embodiment of the apparatus, the search request is received from the remote terminal via a social networking application and includes parameters indicating a number of times the search request may be broadcast, and a number of times the search request may be retransmitted via the social networking application. In some embodiments of the apparatus, broadcasting the search request to the plurality of terminals comprises, in an instance in which the parameter indicating a number of times the search request may be broadcast is greater than zero, modifying the search request by decrementing the parameter indicating a number of times the search request may be broadcast by one, and causing the modified search to be broadcast to the plurality of terminals using the proximity-based wireless communication technology. In another such embodiment, the at least one memory and the computer program code are configured to, with the processor, cause the apparatus to, in an instance in which the parameter indicating a number of times the search request may be transmitted is greater than zero, modify the search request by decrementing the parameter indicating a number of times the search request may be transmitted by one, and transmit the modified search request to a set of contacts retrieved using a social networking application. In another embodiment of the apparatus, the search request includes one or more parameters indicating least one of a geographical limitation and a time period after which the search request expires.


In another example embodiment, an apparatus is provided including means for receiving, from a remote terminal, a search request for information from an ad hoc community, the ad hoc community formed by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other, wherein the remote terminal is located at a second location that is outside of a range of the proximity-based wireless communication technology from the first location. The apparatus of this example embodiment may further include means for causing a first terminal of the plurality of terminals to broadcast the search request to the plurality of terminals using the proximity-based wireless communication technology. Additionally, the apparatus of this embodiment may include means for causing the first terminal of the plurality of terminals to transmit any received information responsive to the search request to the remote terminal.


In another example embodiment, a method is provided, which may include receiving a search request from a remote terminal that participates in a search service, wherein the search request is for information relating to a first location. The method of this example embodiment may further include identifying, with a processor, whether a terminal that participates in the search service is at the first location. Additionally, the method of this embodiment may include causing transmission of the search request to the identified terminal. In addition, the method of this embodiment may include receiving information responsive to the search request from the identified terminal and causing transmission of the received information to the remote terminal.


In the method of an additional embodiment, the remote terminal and the identified terminal are anonymous to each other. In another embodiment, identifying whether a terminal that participates in the search service is at the first location may include causing the server to determine a location of participating terminals using a global positioning system, a wireless local area network, identities of cell sites nearest the participating terminals, a social networking application, or user input, and causing the server to compare the location of the participating terminals to the first location.


In another example embodiment, an apparatus includes at least one processor and at least one memory including computer program code. In this embodiment, the at least one memory and the computer program code are configured to, with the processor, cause the apparatus to receive a search request from a remote terminal that participates in a search service, wherein the search request is for information relating to a first location. In this embodiment, the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to identify whether a terminal that participates in the search service is at the first location. Additionally, the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to transmit the search request to the identified terminal. In addition, the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to receive information responsive to the search request from the identified terminal and transmit the received information to the remote terminal.


In the apparatus of an additional embodiment, the remote terminal and the identified terminal are anonymous to each other. In another embodiment of the apparatus, identifying whether a terminal that participates in the search service is at the first location may include determining a location of participating terminals using a global positioning system, a wireless local area network, identities of cell sites nearest the participating terminals, a social networking application, or user input, and comparing the location of the participating terminals to the first location.


In another example embodiment of the invention, a computer program product comprising at least one non-transitory computer-readable storage medium having computer-executable program code portions stored therein, the computer-executable program code portions comprising program code instructions that, when executed, cause an apparatus to perform the above-described methods.


In another example embodiment, an apparatus is provided, including means for receiving a search request from a remote terminal that participates in a search service, wherein the search request is for information relating to a first location. The apparatus of this example embodiment may further include means for identifying, with a processor, whether a terminal that participates in the search service is at the first location. Additionally, the apparatus of this embodiment may include means for causing broadcast of the search request to the identified terminal. In addition, the apparatus of this embodiment may include means for receiving information responsive to the search request from the identified terminal and means for causing transmission of the received information to the remote terminal.


The above summary is provided merely for purposes of summarizing some example embodiments of the invention so as to provide a basic understanding of some aspects of the invention. Accordingly, it will be appreciated that the above described example embodiments are merely examples and should not be construed to narrow the scope or spirit of the invention in any way. It will be appreciated that the scope of the invention encompasses many potential embodiments, some of which will be further described below, in addition to those here summarized.





BRIEF DESCRIPTION OF THE DRAWINGS

Having thus described example embodiments of the invention in general terms, reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:



FIG. 1 illustrates a system for facilitating remote participance in a community according to some example embodiments;



FIG. 2 is a schematic block diagram of a mobile terminal according to some example embodiments;



FIG. 3 illustrates a block diagram of a terminal apparatus according to some example embodiments;



FIG. 4 illustrates an example of maintaining a community according to some example embodiments;



FIG. 5 illustrates a flowchart according to an example method for facilitating remote participation in a community according to some example embodiments;



FIG. 6 illustrates a system for facilitating a remote search of a community according to some example embodiments;



FIG. 7 illustrates a flowchart according to an example method for facilitating a remote search of a community according to some example embodiments;



FIG. 8 illustrates a chart visually depicting the information flow in an example embodiment according to some example embodiments;



FIG. 9 illustrates a flowchart of operations for facilitating a remote search of a community according to additional example embodiments;



FIG. 10 illustrates a flowchart of operations for facilitating a social search according to some example embodiments; and



FIG. 11 illustrates a flowchart of operations for performing a local search according to some example embodiments.





DETAILED DESCRIPTION

Some example embodiments of the present invention will now be described more fully hereinafter with reference to the accompanying drawings, in which some, but not all embodiments of the invention are shown. Indeed, the invention may be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will satisfy applicable legal requirements. Like reference numerals refer to like elements throughout.


As used herein, the terms “data,” “content,” “information” and similar terms may be used interchangeably to refer to data capable of being transmitted, received, displayed and/or stored in accordance with various example embodiments. Thus, use of any such terms should not be taken to limit the spirit and scope of the disclosure. Further, where a computing device is described herein to receive data from or send data to another computing device, it will be appreciated that the data may be received or sent directly from the another computing device or may be received or sent indirectly via one or more intermediary computing devices, such as, for example, one or more servers, relays, routers, network access points, base stations, and/or the like.


The term “computer-readable medium” as used herein refers to any medium configured to participate in providing information to a processor, including instructions for execution. Such a medium may take many forms, including, but not limited to a non-transitory computer-readable storage medium (for example, non-volatile media, volatile media), and transmission media. Transmission media include, for example, coaxial cables, copper wire, fiber optic cables, and carrier waves that travel through space without wires or cables, such as acoustic waves and electromagnetic waves, including radio, optical and infrared waves. Examples of non-transitory computer-readable media include a floppy disk, hard disk, magnetic tape, any other non-transitory magnetic medium, a compact disc read only memory (CD-ROM), compact disc compact disc-rewritable (CD-RW), digital versatile disc (DVD), Blu-Ray, any other non-transitory optical medium, a random access memory (RAM), a programmable read only memory (PROM), an erasable programmable read only memory (EPROM), a FLASH-EPROM, any other memory chip or cartridge, or any other non-transitory medium from which a computer can read. The term computer-readable storage medium is used herein to refer to any computer-readable medium except transmission media. However, it will be appreciated that where embodiments are described to use a computer-readable storage medium, other types of computer-readable mediums may be substituted for or used in addition to the computer-readable storage medium in alternative embodiments.


Additionally, as used herein, the term ‘circuitry’ refers to (a) hardware-only circuit implementations (for example, implementations in analog circuitry and/or digital circuitry); (b) combinations of circuits and computer program product(s) comprising software and/or firmware instructions stored on one or more computer readable memories that work together to cause an apparatus to perform one or more functions described herein; and (c) circuits, such as, for example, a microprocessor(s) or a portion of a microprocessor(s), that require software or firmware for operation even if the software or firmware is not physically present. This definition of ‘circuitry’ applies to all uses of this term herein, including in any claims. As a further example, as used herein, the term ‘circuitry’ also includes an implementation comprising one or more processors and/or portion(s) thereof and accompanying software and/or firmware. As another example, the term ‘circuitry’ as used herein also includes, for example, a baseband integrated circuit or applications processor integrated circuit for a mobile phone or a similar integrated circuit in a server, a cellular network device, other network device, and/or other computing device.


Users having mobile computing devices within sufficient proximity of each other may establish ad hoc communities by which they may wirelessly exchange data and engage in various social activities. In this regard, the mobile computing devices may be configured to use a proximity-based communication technology, such as various radio frequency signaling technologies having a proximity-limited effective range (for example, Bluetooth, Wi-Fi signaling, various Institute of Electrical and Electronics Engineers 802.11 and/or 802.15 techniques, and/or the like), to establish an ad hoc local community when the devices are within sufficient proximity of each other to communicate via the proximity-based communication technology. However, the nature of these local communities may be temporary, as membership in the community may be dissolved when the user moves out of the requisite proximity to the other member(s) of the community. In this regard, a user having a computing device located at a location outside of range of the proximity-based communication technology used for communication between members of the local community may not be able to participate in the community. As such, some example embodiments facilitate remote participance in a community, such as a local ad hoc community formed at least in part by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other.



FIG. 1 illustrates a diagram of a system 100 for facilitating remote participance in a community according to some example embodiments. It will be appreciated that the system 100 as well as the illustrations in other figures are each provided as an example of some embodiments and should not be construed to narrow the scope or spirit of the disclosure in any way. In this regard, the scope of the disclosure encompasses many potential embodiments in addition to those illustrated and described herein. As such, while FIG. 1 illustrates one example of a configuration of a system for facilitating remote participance in a community, numerous other configurations may also be used to implement embodiments of the present invention.


In some example embodiments, the system 100 may include a local ad hoc community 110. The community 110 may be formed at least in part by a plurality of computing devices at a location that are within sufficient proximity of each other to communicate using a proximity-based communication technology. For example, a community 110 may be formed by users having compatible computing devices at a sporting event or other gathering where there may be users within sufficient proximity of each other. Three computing devices, the anchor terminal 102, terminal A 104, and terminal B 106, are illustrated as being members of the community 110 in the system 100 by way of example. However, it will be appreciated that the community 100 and/or other such local communities that may be formed in accordance with various example embodiments may include any number of computing devices.


As illustrated in FIG. 1, the computing devices forming the community 110 (for example, the anchor terminal 102, terminal A 104, and terminal B 106) may communicate via ad hoc proximity-based communication 108. This proximity-based communication may comprise the computing devices forming an ad hoc mesh network and/or communicating via one or more wireless communication links using a proximity-based communication technology. Such proximity-based communications technology may comprise any wireless communications technology by which two or more computing devices may communicate when they are within a proximate range of each other (for example, within a communications or signaling range of the proximity-based communications technology). By way of non-limiting example, such proximity-based communications technology may comprise Bluetooth, a communications technique implementing any version of the Institute of Electrical and Electronics Engineers (IEEE) 802.15 standard, ZigBee, Ultra-Wideband, a near field communications technology, infrared, a wireless local area network (WLAN) communications technology, signaling using any version of the IEEE 802.11 standard, any wireless personal area networking (PAN) technology, or the like. In some example embodiments, the community 110 may be formed using ad hoc proximity-based communication in accordance with Nokia® Instant Community (NIC) technology. In some example embodiments, the community 110 may comprise an Awarenet-based community.


One of the terminals forming the community 110 may be designated to serve as the anchor terminal. In the example of FIG. 1, the anchor terminal 102 is illustrated as serving as the anchor terminal. The anchor terminal 102 may be configured to maintain a connection to a structured network 112 so as to enable remote participance in the community. In this regard, as will be further described herein below, the anchor terminal 102 may be configured to enable a remote terminal(s), such as the remote terminal 114, that may be located at a location that is outside of range of the proximity-based wireless communication technology of the terminals locally participating in the community (for example, the anchor terminal 102, terminal A 104, and terminal B 106) to participate in the community. Accordingly, for example, a community may be formed by a group of friends attending a baseball game that possess the anchor terminal 102, the terminal A 104, and the terminal B 106. However, another friend that may use the remote terminal 114 may not be able to attend the game. Some example embodiments may accordingly facilitate remote participance in the community by the friend that is unable to attend the game. While only a single remote terminal 114 is illustrated in FIG. 1, it will be appreciated that this illustration is by way of example, and not by way of limitation. In this regard, some example embodiments may facilitate remote participance in a community by multiple remote terminals 114.


The structured network 112 may comprise any structured network. By way of non-limiting example, the structured network 112 may comprise one or more wireless networks (for example, a cellular network, a structured wireless local area network, wireless metropolitan area network, and/or the like), one or more wireline networks, or some combination thereof, and in some embodiments may comprise at least a portion of the Internet. In this regard, the anchor terminal 102 may, in some example embodiments, be connected to the a cellular network, the internet, and/or other structured network while communicating with one or more other members of the community 110 via ad hoc proximity-based communication 108.


A computing device participating in the community 110, such as the anchor terminal 102, terminal A 104, terminal B 106, remote terminal 114, and/or the like may comprise any computing device configured to communicate with another computing device, such as through use of a proximity-based communication technology and/or via the structured network 112. By way of non-limiting example, such a computing device may be embodied as a computer, laptop computer, mobile terminal, mobile computer, mobile phone, mobile communication device, tablet computing device, game device, digital camera/camcorder, audio/video player, television device, radio receiver, digital video recorder, positioning device, wrist watch, portable digital assistant (PDA), a chipset, an apparatus comprising a chipset, any combination thereof, and/or the like.


According to some example embodiments, a computing device configured to participate in the community 110 (for example, the terminal A 102, terminal A 104, terminal B 106, remote terminal 114, and/or the like) may be embodied as a mobile terminal, such as that illustrated in FIG. 2. In this regard, FIG. 2 illustrates a block diagram of a mobile terminal 10 representative of some embodiments of a computing device configured to participate in the community 110 (for example, the terminal A 102, terminal A 104, terminal B 106, remote terminal 114, and/or the like). It should be understood, however, that the mobile terminal 10 illustrated and hereinafter described is merely illustrative of one type of computing device that may implement and/or benefit from various embodiments and, therefore, should not be taken to limit the scope of the disclosure. While several embodiments of the electronic device are illustrated and will be hereinafter described for purposes of example, other types of electronic devices, such as mobile telephones, mobile computers, portable digital assistants (PDAs), pagers, laptop computers, desktop computers, gaming devices, televisions, and other types of electronic systems, may employ various embodiments of the invention.


As shown, the mobile terminal 10 may include an antenna 12 (or multiple antennas 12) in communication with a transmitter 14 and a receiver 16. The mobile terminal 10 may also include a processor 20 configured to provide signals to and receive signals from the transmitter and receiver, respectively. The processor 20 may, for example, be embodied as various means including circuitry, one or more microprocessors with accompanying digital signal processor(s), one or more processor(s) without an accompanying digital signal processor, one or more coprocessors, one or more multi-core processors, one or more controllers, processing circuitry, one or more computers, various other processing elements including integrated circuits such as, for example, an ASIC (application specific integrated circuit) or FPGA (field programmable gate array), or some combination thereof. Accordingly, although illustrated in FIG. 2 as a single processor, in some example embodiments the processor 20 may comprise a plurality of processors. These signals sent and received by the processor 20 may include signaling information in accordance with an air interface standard of an applicable cellular system, and/or any number of different wireline or wireless networking techniques, comprising but not limited to Wi-Fi, wireless local access network (WLAN) techniques such as Institute of Electrical and Electronics Engineers (IEEE) 802.11, 802.16, and/or the like. In addition, these signals may include speech data, user generated data, user requested data, and/or the like. In this regard, the mobile terminal may be capable of operating with one or more air interface standards, communication protocols, modulation types, access types, and/or the like. More particularly, the mobile terminal may be capable of operating in accordance with various first generation (1G), second generation (2G), 2.5G, third-generation (3G) communication protocols, fourth-generation (4G) communication protocols, Internet Protocol Multimedia Subsystem (IMS) communication protocols (for example, session initiation protocol (SIP)), and/or the like. For example, the mobile terminal may be capable of operating in accordance with 2G wireless communication protocols IS-136 (Time Division Multiple Access (TDMA)), Global System for Mobile communications (GSM), IS-95 (Code Division Multiple Access (CDMA)), and/or the like. Also, for example, the mobile terminal may be capable of operating in accordance with 2.5G wireless communication protocols General Packet Radio Service (GPRS), Enhanced Data GSM Environment (EDGE), and/or the like. Further, for example, the mobile terminal may be capable of operating in accordance with 3G wireless communication protocols such as Universal Mobile Telecommunications System (UMTS), Code Division Multiple Access 2000 (CDMA2000), Wideband Code Division Multiple Access (WCDMA), Time Division-Synchronous Code Division Multiple Access (TD-SCDMA), and/or the like. The mobile terminal may be additionally capable of operating in accordance with 3.9G wireless communication protocols such as Long Term Evolution (LTE) or Evolved Universal Terrestrial Radio Access Network (E-UTRAN) and/or the like. Additionally, for example, the mobile terminal may be capable of operating in accordance with fourth-generation (4G) wireless communication protocols and/or the like as well as similar wireless communication protocols that may be developed in the future.


Some Narrow-band Advanced Mobile Phone System (NAMPS), as well as Total Access Communication System (TACS), mobile terminals may also benefit from embodiments of this invention, as should dual or higher mode phones (for example, digital/analog or TDMA/CDMA/analog phones). Additionally, the mobile terminal 10 may be capable of operating according to Wi-Fi or Worldwide Interoperability for Microwave Access (WiMAX) protocols.


It is understood that the processor 20 may comprise circuitry for implementing audio/video and logic functions of the mobile terminal 10. For example, the processor 20 may comprise a digital signal processor device, a microprocessor device, an analog-to-digital converter, a digital-to-analog converter, and/or the like. Control and signal processing functions of the mobile terminal may be allocated between these devices according to their respective capabilities. The processor may additionally comprise an internal voice coder (VC) 20a, an internal data modem (DM) 20b, and/or the like. Further, the processor may comprise functionality to operate one or more software programs, which may be stored in memory. For example, the processor 20 may be capable of operating a connectivity program, such as a web browser. The connectivity program may allow the mobile terminal 10 to transmit and receive web content, such as location-based content, according to a protocol, such as Wireless Application Protocol (WAP), hypertext transfer protocol (HTTP), and/or the like. The mobile terminal 10 may be capable of using a Transmission Control Protocol/Internet Protocol (TCP/IP) to transmit and receive web content across the internet or other networks.


The mobile terminal 10 may also comprise a user interface including, for example, an earphone or speaker 24, a ringer 22, a microphone 26, a display 28, a user input interface, and/or the like, which may be operationally coupled to the processor 20. In this regard, the processor 20 may comprise user interface circuitry configured to control at least some functions of one or more elements of the user interface, such as, for example, the speaker 24, the ringer 22, the microphone 26, the display 28, and/or the like. The processor 20 and/or user interface circuitry comprising the processor 20 may be configured to control one or more functions of one or more elements of the user interface through computer program instructions (for example, software and/or firmware) stored on a memory accessible to the processor 20 (for example, volatile memory 40, non-volatile memory 42, and/or the like). The mobile terminal may comprise a battery for powering various circuits related to the mobile terminal, for example, a circuit to provide mechanical vibration as a detectable output. The user input interface may comprise devices allowing the mobile terminal to receive data, such as a keypad 30, a touch display, a joystick, and/or other input device. In embodiments including a keypad, the keypad may comprise numeric (0-9) and related keys (#, *), and/or other keys for operating the mobile terminal.


As shown in FIG. 2, the mobile terminal 10 may also include one or more means for sharing and/or obtaining data. For example, the mobile terminal may comprise a short-range radio frequency (RF) transceiver and/or interrogator 64 so data may be shared with and/or obtained from electronic devices in accordance with RF techniques. The mobile terminal may comprise other short-range transceivers, such as, for example, an infrared (IR) transceiver 66, a Bluetooth™ (BT) transceiver 68 operating using Bluetooth™ brand wireless technology developed by the Bluetooth™ Special Interest Group, a wireless universal serial bus (USB) transceiver 70 and/or the like. The Bluetooth™ transceiver 68 may be capable of operating according to ultra-low power Bluetooth™ technology (for example, Wibree™) radio standards. In this regard, the mobile terminal 10 and, in particular, the short-range transceiver may be capable of transmitting data to and/or receiving data from electronic devices within a proximity of the mobile terminal, such as within 10 meters, for example. The mobile terminal may be capable of transmitting and/or receiving data from electronic devices according to various wireless networking techniques, including Wi-Fi, WLAN techniques such as IEEE 802.11 techniques, IEEE 802.15 techniques, IEEE 802.16 techniques, and/or the like.


The mobile terminal 10 may comprise memory, such as a removable or non-removable subscriber identity module (SIM) 38, a soft SIM 38, a fixed SIM 38, a removable or non-removable universal subscriber identity module (USIM) 38, a soft USIM 38, a fixed USIM 38, a removable user identity module (R-UIM), and/or the like, which may store information elements related to a mobile subscriber. In addition to the SIM, the mobile terminal may comprise other removable and/or fixed memory. The mobile terminal 10 may include volatile memory 40 and/or non-volatile memory 42. For example, volatile memory 40 may include Random Access Memory (RAM) including dynamic and/or static RAM, on-chip or off-chip cache memory, and/or the like. Non-volatile memory 42, which may be embedded and/or removable, may include, for example, read-only memory, flash memory, magnetic storage devices (for example, hard disks, floppy disk drives, magnetic tape, etc.), optical disc drives and/or media, non-volatile random access memory (NVRAM), and/or the like. Like volatile memory 40, non-volatile memory 42 may also include a cache area for temporary storage of data. The memories may store one or more software programs, instructions, pieces of information, data, and/or the like which may be used by the mobile terminal for performing functions of the mobile terminal. For example, the memories may comprise an identifier, such as an international mobile equipment identification (IMEI) code, capable of uniquely identifying the mobile terminal 10.


Referring now to FIG. 3, FIG. 3 illustrates a block diagram of a terminal apparatus 302 according to some example embodiments. The terminal apparatus 302 may comprise an apparatus, which may be implemented on a computing device which may be configured to participate in a community, such as the community 110 in accordance with some example embodiments. Accordingly, the terminal apparatus 302 may be implemented on an anchor terminal 102, terminal A 104, terminal B 106, remote terminal 114, and/or the like in accordance with some example embodiments.


In some example embodiments, the terminal apparatus 302 may include various means for performing the various functions herein described. These means may comprise one or more of a processor 310, memory 312, communication interface 314, user interface 316, or community participance module 318. The means of the terminal apparatus 302 as described herein may be embodied as, for example, circuitry, hardware elements (for example, a suitably programmed processor, combinational logic circuit, and/or the like), a computer program product comprising a computer-readable medium (for example memory 312) storing computer-readable program instructions (for example, software or firmware) that are executable by a suitably configured processing device (for example, the processor 310), or some combination thereof.


In some example embodiments, one or more of the means illustrated in FIG. 3 may be embodied as a chip or chip set. In other words, the terminal apparatus 302 may comprise one or more physical packages (for example, chips) including materials, components and/or wires on a structural assembly (for example, a baseboard). The structural assembly may provide physical strength, conservation of size, and/or limitation of electrical interaction for component circuitry included thereon. In this regard, the processor 310, memory 312, communication interface 314, user interface 316, and/or community participance module 318 may be embodied as a chip or chip set. The terminal apparatus 302 may therefore, in some example embodiments, be configured to implement example embodiments of the present invention on a single chip or as a single “system on a chip.” As another example, in some example embodiments, the terminal apparatus 302 may comprise component(s) configured to implement embodiments of the present invention on a single chip or as a single “system on a chip.” As such, in some cases, a chip or chipset may constitute means for performing one or more operations for providing the functionalities described herein and/or for enabling user interface navigation with respect to the functionalities and/or services described herein.


The processor 310 may, for example, be embodied as various means including one or more microprocessors with accompanying digital signal processor(s), one or more processor(s) without an accompanying digital signal processor, one or more coprocessors, one or more multi-core processors, one or more controllers, processing circuitry, one or more computers, various other processing elements including integrated circuits such as, for example, an ASIC (application specific integrated circuit) or FPGA (field programmable gate array), one or more other hardware processors, or some combination thereof. Accordingly, although illustrated in FIG. 3 as a single processor, in some example embodiments the processor 310 may comprise a plurality of processors. The plurality of processors may be in operative communication with each other and may be collectively configured to perform one or more functionalities of the terminal apparatus 302 as described herein. The plurality of processors may be embodied on a single computing device or distributed across a plurality of computing devices collectively configured to function as the terminal apparatus 302. In embodiments wherein the terminal apparatus 302 is embodied as a mobile terminal 10, the processor 310 may be embodied as or may comprise the processor 20. In some example embodiments, the processor 310 is configured to execute instructions stored in the memory 312 or otherwise accessible to the processor 310. These instructions, when executed by the processor 310, may cause the terminal apparatus 302 to perform one or more of the functionalities of the terminal apparatus 302 as described herein. As such, whether configured by hardware or software methods, or by a combination thereof, the processor 310 may comprise an entity capable of performing operations according to embodiments of the present invention while configured accordingly. Thus, for example, when the processor 310 is embodied as an ASIC, FPGA or the like, the processor 310 may comprise specifically configured hardware for conducting one or more operations described herein. Alternatively, as another example, when the processor 310 is embodied as an executor of instructions, such as may be stored in the memory 312, the instructions may specifically configure the processor 310 to perform one or more algorithms and operations described herein.


The memory 312 may comprise, for example, volatile memory, non-volatile memory, or some combination thereof. In this regard, the memory 312 may comprise a non-transitory computer-readable storage medium. Although illustrated in FIG. 3 as a single memory, the memory 312 may comprise a plurality of memories. The plurality of memories may be embodied on a single computing device or may be distributed across a plurality of computing devices collectively configured to function as the terminal apparatus 302. In various example embodiments, the memory 312 may comprise a hard disk, random access memory, cache memory, flash memory, a compact disc read only memory (CD-ROM), digital versatile disc read only memory (DVD-ROM), an optical disc, circuitry configured to store information, or some combination thereof. In embodiments wherein the terminal apparatus 302 is embodied as a mobile terminal 10, the memory 312 may comprise the volatile memory 40 and/or the non-volatile memory 42. The memory 312 may be configured to store information, data, applications, instructions, or the like for enabling the terminal apparatus 302 to carry out various functions in accordance with various example embodiments. For example, in some example embodiments, the memory 312 may be configured to buffer input data for processing by the processor 310. Additionally or alternatively, the memory 312 may be configured to store program instructions for execution by the processor 310. The memory 312 may store information in the form of static and/or dynamic information. This stored information may be stored and/or used by the community participance module 318 during the course of performing its functionalities.


The communication interface 314 may be embodied as any device or means embodied in circuitry, hardware, a computer program product comprising a computer-readable medium (for example memory 312) storing computer-readable program instructions (for example, software or firmware) that are executable by a suitably configured processing device (for example, the processor 310), or a combination thereof that is configured to receive and/or transmit data from/to another computing device. According to some example embodiments, the communication interface 314 may be at least partially embodied as or otherwise controlled by the processor 310. In this regard, the communication interface 314 may be in communication with the processor 310, such as via a bus. The communication interface 314 may include, for example, an antenna, a transmitter, a receiver, a transceiver and/or supporting hardware or software for enabling communications with one or more computing devices. The communication interface 314 may be configured to receive and/or transmit data using any protocol that may be used for communications between computing devices. In this regard, the communication interface 314 may be configured to receive and/or transmit data using any protocol that may be used for transmission of data over a wireless network, wireline network, some combination thereof, or the like by which the terminal apparatus 302 and one or more computing devices or computing resources may be in communication. As an example, the communication interface 314 may be configured to support communication with another terminal apparatus 302 using a proximity-based communication technology. Accordingly, the communication interface 314 may be configured to facilitate establishment and participation in a local community, such as the community 110. As a further example, the communication interface 314 may be configured to enable communication between the terminal apparatus 302 and another computing device via the structured network 112. The communication interface 314 may additionally be in communication with the memory 312, user interface 316, and/or community participance module 318, such as via a bus(es).


The user interface 316 may be in communication with the processor 310 to receive an indication of a user input and/or to provide an audible, visual, mechanical, or other output to a user. As such, the user interface 316 may include, for example, a keyboard, a mouse, a joystick, a display, a touch screen display, a microphone, a speaker, and/or other input/output mechanisms. In embodiments wherein the user interface 316 comprises a touch screen display, the user interface 316 may additionally be configured to detect and/or receive an indication of a touch gesture or other input to the touch screen display. The user interface 316 may be in communication with the memory 312, communication interface 314, and/or community participance module 318, such as via a bus(es).


The community participance module 318 may be embodied as various means, such as circuitry, hardware, a computer program product comprising a computer-readable medium (for example memory 312) storing computer-readable program instructions (for example, software or firmware) that are executable by a suitably configured processing device (for example, the processor 310), or some combination thereof and, in some example embodiments, may be embodied as or otherwise controlled by the processor 310. In embodiments wherein the community participance module 318 is embodied separately from the processor 310, the community participance module 318 may be in communication with the processor 310. The community participance module 318 may further be in communication with one or more of the memory 312, communication interface 314, or user interface 316, such as via a bus(es).


The community participance module 318 associated with a terminal apparatus 302 may be configured to determine a presence of another computing device and/or an established community (for example, a community 110) within sufficient proximity of a proximity-based communication technology. For example, the community participance module 318 may be configured to determine a presence of another computing device and/or an established community by detecting and/or interpreting wireless signals and/or data that may be received via the communication interface 314 from a proximate device in accordance with a proximity-based communication technology. The community participance module 318 may be further configured to cause the terminal apparatus 302 to establish a community and/or join an existing community by communicating with one or more proximate computing devices using a proximity-based communication technology.


In this regard, using the example of FIG. 1 in some example embodiments wherein a terminal apparatus 302 is implemented on the anchor terminal 102, the community participance module 318 associated with the anchor terminal 102 may be configured to determine a presence of the terminal A 104, terminal B 106, and/or an existing established community including the terminal A 104 and terminal B 106 while within the location of the local community 110. The community participance module 318 associated with anchor terminal 102 may be further configured to cause the anchor terminal 102 to join and/or establish the community 110 at least in part by causing the anchor terminal 102 to communicate with the terminal A 104 and/or terminal B 106 using a proximity-based communication technology.


In some example embodiments, a terminal participating in the community may serve as the anchor terminal. In some example embodiments, the terminal forming the community may serve as the anchor terminal. As another example, in the event that an anchor terminal for the community has not yet been designated, a terminal may volunteer to serve as the anchor terminal. Additionally or alternatively, in some example embodiments, terminals locally participating in the community may collectively negotiate which terminal serves as the anchor terminal based on specified criteria. For example, selection of an anchor terminal may be based at least in part on a quality of a connection with the structured network 112 (for example, a terminal having an available and/or higher quality connection to the structured network 112 may be preferred as the anchor terminal over a terminal that does not have a connection to the structured network 112 or that has a low connection quality). As another example, in an instance in which one or more of the terminals participating in the local community 110 are battery powered, selection of an anchor terminal may be based at least in part on available battery resources. In this regard, for example, a terminal having the greatest available power reserves may be preferred to serve as the anchor terminal in some example embodiments. As another example, in some example embodiments, a terminal having at least a threshold amount of power reserves may be selected to serve as the anchor terminal.


The community participance module 318 that may be associated with a terminal serving as the anchor terminal for a community (for example, the anchor terminal 102) may be configured to cause the anchor terminal to maintain a connection to the structured network 112 so as to enable one or more remote terminals, such as the remote terminal 114, to participate in the community. In this regard, a remote terminal may use an address that may be associated with the anchor terminal 102 that may be used to send data to the anchor terminal over the structured network 112 to participate in the community. By way of example, the address that may be associated with the anchor terminal 102 may comprise a phone number, International Mobile Subscriber Identity (IMSI), an email address, an Internet Protocol (IP) address, a Domain Service Name (DSN), a SIP Universal Resource Identifier (URI), and/or any other address that may be used to communicate with the anchor terminal 102 over the structured network 112.


As such, in an instance in which a remote terminal, such as the remote terminal 114, participates in the community, the community participance module 318 may be configured to cause the anchor terminal 102 to serve as a gateway between the terminals participating in the community at the first location (for example, the terminal A 104 and terminal B 106) and the remote terminal. Accordingly, the remote terminal 114 may send data to the community via the structured network 112 using an address associated with the anchor terminal 102. The community participance module 318 that may be associated with the anchor terminal 102 may be configured to receive the data sent by the remote terminal 114, and may be configured to cause the received data to be forwarded to one or more terminals participating in the community at the location of the anchor terminal 102 (for example, the terminal A 104 and/or terminal B 106) via proximity-based communication. The community participance module 318 that may be associated with the anchor terminal 102 may be further configured to cause data exchanged between terminals participating in the community at the location of the anchor terminal (for example, data exchanged between the anchor terminal 102, terminal A 104, and/or terminal B 106) to be forwarded toward the remote terminal 114 via the structured network 112.


In some example embodiments, a community may be identified by a community identifier for the community. The community identifier may, for example, comprise an alphabetic identifier, numeric identifier, alphanumeric identifier, an address, and/or other identifier by which a particular community may be identified and distinguished from other communities. The community identifier may be usable to enable terminals, such as the remote terminal 114 to participate in the community by sending data to other members of the community. In this regard, data sent to the community by a participant in the community may be flagged or otherwise sent in association with the community identifier to indicate that the data is to be sent to the community. Thus, for example, data sent to the community by the remote terminal 114 may be flagged with the community identifier such that the community participance module 318 that may be associated with the anchor terminal 102 may recognize that the data received from the remote terminal 114 is intended for the community and may forward it to the terminal A 104, terminal B 106, and/or other participant(s) in the community.


In some example embodiments, the community identifier may be automatically selected by the anchor terminal 102, and may be provided to other terminals participating in the community. Additionally or alternatively, in some example embodiments, one or more participants participating in the community may select an identifier for the community and communicate the selected identifier to the other terminals participating in the community. As still a further example, the community identifier may be randomly generated by a community participance module 318 that may be associated with a terminal participating in the community.


In some example embodiments, the community participance module 318 that may be associated with a terminal participating in the community may be configured to maintain membership information for the community. The maintained membership information may, for example, be stored in memory 312. The maintained membership information may, for example, comprise membership information that may include contact information associated with one or more members of the community. In this regard, the contact information may comprise information enabling the participating members to be contacted such that data may be communicated to members of the community. As such, the contact information may comprise any address, identifier, and/or the like associated with a terminal participating in the community that enables information to be sent to a terminal participating in the community and/or to a user associated with a participating terminal. By way of example, the contact information may comprise a phone number, International Mobile Subscriber Identity (IMSI) associated with a participating terminal, an email address associated with a participating user, an Internet Protocol (IP) address associated with a participating terminal, a Domain Service Name (DSN) associated with a participating terminal, a SIP Universal Resource Identifier (URI), and/or the like.


Membership information maintained by a terminal may be stored in association with the community identifier. In this regard, the community identifier may distinguish membership information for the community from membership information that may be stored for one or more other communities of which the terminal may be a member.


In some example embodiments, a user may specify a preferred or prohibited contact method for data exchanged within a community in which the user is participating. Accordingly, in some example embodiments, the type of contact information stored and/or used by a community participance module 318 to facilitate exchanging data with other members of the community may be selected in accordance with user preferences.


In some example embodiments, membership information may be maintained by the anchor terminal. In such example embodiments, the community participance module 318 that may be associated with the anchor terminal may collect membership information from other members of the community. The community participance module 318 that may be associated with the anchor terminal may be configured to use the stored membership information to facilitate serving as a gateway between the terminals participating in the community at the location of the anchor terminal and the remote terminal 114. In this regard, for example, contact information for the remote terminal 114 may be used to send data exchanged between members of the community to the remoter terminal 114 over the structured network 112.


In some example embodiments, contact information (for example, an address) for contacting the anchor terminal over the structured network 112 may be distributed to participants in the community. This contact information may be used by remote terminals, such as the remote terminal 114 to participate in the community. Additionally, as will be described further herein below, the contact information for the anchor terminal may be used by a terminal to continue to participate in the community after the terminal has left the location at which the community was formed. In some example embodiments, the contact information of anchor terminal may be secured such that a user that is a member of the community may not be able to view the contact information. In this regard, the contact information may be secured such that the community participance module 118 associated with a terminal may have access to the contact information for the anchor terminal, but a user of the terminal may not be able to directly view the contact information.


In some example embodiments, communities may be established as private communities or public communities. For example, a private community may be established between members of a group of people who know each other. In some such example embodiments, new (non-anonymous) participants in a private community may be approved by the community establisher/anchor terminal. The identity of the new joining participants may be automatically sent to all other participants.


A public community may be open to participation without a new participant having to be approved prior to joining the community, and thus may include members who do not know each other. A public community may be anonymous such that a user may not see the identity of other participants in the community. In embodiments wherein a public community is anonymous, the community participance module 318 associated with a terminal participating in the community may be configured to prevent a user of the terminal from seeing the identities of individuals that have joined the group. However, the number of participants and/or other non-sensitive information may be visible for the user. Alternatively, a public community may be non-anonymous such that users participating in the community may see identity information for other members of the community. As still a further alternative, in some example embodiments, identity information for members of a public community may only be visible to a user of the anchor terminal. In some example embodiments contact information and/or other identity information for members of the community may be provided in an open format only to trusted individuals, such as a member's friends on a social network, a member's email contacts, and/or the like.


In some example embodiments, data having larger file sizes may not be directly exchanged between members of the community. Instead, a larger file may be saved to a network-accessible hosting site, and a link to the file may be distributed to other members of the community. In this regard, for example, rather than communicating an image or video file to members of the community (for example, via ad hoc proximity-based communication 108 and/or over the structured network 112), the image or video file may be saved to a hosting site and a link enabling the image or video file to be accessed from the hosting site may be distributed to members of the community. Accordingly, in such example embodiments, data associated with a file size satisfying a threshold size (for example, a file exceeding a certain file limit) and/or a file having a certain type may not be directly exchanged between members of the community, but rather a link to a network-accessible file containing the data may be exchanged between members of the community.


In some example embodiments, data exchanged between participants in the community may be archived or otherwise saved on one or more participating terminals. In some such example embodiments, the anchor terminal may be responsible for saving all data exchanged between participants in the community. Alternatively, in some such example embodiments, the responsibility for storing data distributed in the community may be shared by multiple terminals participating in the community so as to relax the memory consumption burden on the anchor terminal. As still a further example, each terminal participating in the community may optionally save data that is exchanged between participants in the community.


In some example embodiments, wherein data exchanged between participants in the community is archived, the archived data may serve as a log of communication in a community. In some such example embodiments, users may access the log from the terminal(s) on which the log is saved, such as via the structured network 112 and/or via proximity-based communication. Additionally or alternatively, in some example embodiments, rather than remotely accessing the log, a user may request a terminal(s) on which the log is saved to send the log to his or her computing device, such as by email, a file transfer protocol transfer, and/or other method for transferring a file between computing devices. In some example embodiments, access to a log of community communications may be available to members of the community. Additionally or alternatively, in some example embodiments, access to a log of community communications may be controlled through access permissions such that a subset of members of the community may be granted access to the log, one or more individuals who are not members of the community may be granted access to the log, and/or the like.


In some instances, the anchor terminal 102 may leave the location at which the community was formed while one or more terminals (for example, the terminal A 104 and terminal B 106) may remain at the location. In such a situation, the role of anchor terminal may be transferred to another terminal that remains at the location. Thus, for example, the terminal A 104 or terminal B 106 may assume the role of anchor terminal. The terminal assuming the role of anchor terminal may maintain a connection to the structured network 112 so as to enable the remote terminal 114 to continue to participate in the community. Additionally, the anchor terminal 102 may continue to participate in the community remotely via the structured network 112 by communicating with the terminal that assumes the role of anchor terminal.


In an instance in which the role of anchor terminal is transferred, a terminal may volunteer to serve as the anchor terminal. Additionally or alternatively, in some example embodiments, terminals participating in the community that remain on location may collectively negotiate which terminal will assume the role of the anchor terminal based on specified criteria. For example, selection of the terminal to assume the role of anchor terminal may be based at least in part on a quality of a connection with the structured network 112 (for example, a terminal having an available and/or higher quality connection to the structured network 112 may be preferred as the anchor terminal over a terminal that does not have a connection to the structured network 112 or that has a low connection quality). As another example, in an instance in which one or more of the terminals participating in the local community 110 are battery powered, selection of a terminal to assume the role of anchor terminal may be based at least in part on available battery resources. In this regard, for example, a terminal having the greatest available power reserves may be preferred to serve as the anchor terminal in some example embodiments. As another example, in some example embodiments, a terminal having at least a threshold amount of power reserves may be selected to assume the role of anchor terminal.


In some example embodiments, the community participance module 318 that may be associated with the anchor terminal 102 may be configured to facilitate remote participance in the community and/or maintenance of the community after one or more members of the community (for example, terminal A 104, terminal B 106, the anchor terminal 102 itself, and/or the like) have left the location of the community (for example, the location at which the community 110 was formed). For example, using the previous example of a community formed by a group of friends attending a baseball game, the members of the community may disperse subsequent to the conclusion of the baseball game. While the members of the community may no longer be able to communicate using proximity-based communication, the community participation module 318 of some example embodiments may be configured to use a stored community identifier and/or associated community membership information (for example, contact information for members of the community) to enable communications among members of the community even after the baseball game, such as via the structured network 112.


It is possible that in some instances, a member of the community that has left the community may not have traveled a significant distance from the location of the community. In this regard, for example, during the course of mobility, the member may intermittently come within range of the location of the community (for example, within range of the ad hoc proximity-based communication 108). As another example, a member of the community that has left the community may later return to the location of the community while at least one further member of the community is still at the location. As still a further example, the remote terminal 114 may come within the location of the community during the course of mobility. In some example embodiments, the community participance module 318 that may be associated with the anchor terminal 102, may be configured to send information via the structured network 112 to a terminal participating in the community remotely (for example, the remote terminal 114 and/or a terminal(s) that has become remote from the community, such as the terminal A 104, terminal B 106, and/or the like) for enabling the terminal to determine whether it is within range of the location of the community and/or to communicate with one or more members of the community via ad hoc proximity-based communication 108. The information that may be sent to a terminal that is participating in the community remotely may, for example, include an indication of the location of the anchor terminal 102 (for example, coordinates of the anchor terminal 102), radio communication information for communicating with community members via ad hoc proximity-based communication 108 (for example, a channel identifier, a proximity-based communication technology used by the members of the community, and/or the like), and/or other information for facilitating communication with one or more community members via proximity-based communication 108. The community participance module 318 that may be associated with a terminal participating in the community remotely may accordingly use the information to determine whether and when the terminal may locally participate in the community via the ad hoc proximity-based communication 108, such as by detecting whether the terminal is within sufficient range of the location of the community. Additionally or alternatively, a community participance module 318 that may be associated with a terminal participating in the community remotely may use the information to aid a user of the terminal to find the local community, such as by providing an indication of the location of the local community on a display of the terminal, providing navigational directions to the location of the local community, and/or the like.



FIG. 4 illustrates an example of maintaining a community according to some example embodiments within the context of the system 100 illustrated in FIG. 1. Referring to FIG. 4, the anchor terminal 102, terminal A 104, terminal B 106, and remote terminal 114 are illustrated as being connected to the structured network 112. In this regard, the anchor terminal 102, terminal A 104, and terminal B 106 may have left the location at which the community 110 illustrated in FIG. 1 was formed, such that they are unable to communicate with each other using proximity-based communication. However, the anchor terminal 102, terminal A 104, and terminal B 106 may have access to the structured network 112. One or more of the anchor terminal 102, terminal A 104, terminal B 106, and remote terminal 114 may use the community identifier for the community and/or membership information for the community to send data to other members of the community. For example, a terminal other than the anchor terminal 102 (for example, the terminal A 104, terminal B 106, or remote terminal 114) may send data over the structured network 112 to the anchor terminal 102 using an address for the anchor terminal 102. The data may be flagged with the community identifier. The community participance module 318 that may be associated with the anchor terminal 102 may be configured to use stored membership information associated with the community identifier to determine contact information for the members of the community (for example, the terminal A 104, terminal B 106, and/or remote terminal 114) and may use the determined contact information to cause the received data to be forwarded from the anchor terminal 102 to one or more further members of the community (for example, the terminal A 104, terminal B 106, and/or remote terminal 114) over the structured network 112.



FIG. 5 illustrates a flowchart according to another example method for facilitating remote participance in a community according to some example embodiments. In this regard, FIG. 5 illustrates operations that may be performed at a terminal apparatus 302 serving as an anchor terminal for a community. The operations illustrated in and described with respect to FIG. 5 may, for example, be performed by, with the assistance of, and/or under the control of one or more of the processor 310, memory 312, communication interface 314, user interface 316, or community participance module 318. Operation 500 may comprise causing an anchor terminal located at a first location to use a proximity-based wireless communication technology to participate in an ad hoc community formed at least in part by the anchor terminal and one or more further terminals at the first location using the proximity-based wireless communication technology to communicate with each other. The processor 310, memory 312, communication interface 314, user interface 316, and/or community participance module 318 may, for example, provide means for performing operation 500. Operation 510 may comprise causing the anchor terminal to maintain a connection to a structured network, thereby enabling a remote terminal located at a second location to participate in the ad hoc community by using an address associated with the anchor terminal to communicate with the anchor terminal over the structured network. The second location may be outside of range of the proximity-based wireless communication technology used by the terminals at the first location to participate in the ad hoc community. The processor 310, memory 312, communication interface 314, user interface 316, and/or community participance module 318 may, for example, provide means for performing operation 510. Operation 520 may comprise, in an instance in which the remote terminal participates in the community, causing the anchor terminal to serve as a gateway between the terminals participating in the community at the first location and the remote terminal. The processor 310, memory 312, communication interface 314, user interface 316, and/or community participance module 318 may, for example, provide means for performing operation 520.



FIG. 6 illustrates an example embodiment using which a remote terminal 114 may leverage the collective knowledge of the ad hoc community, even without itself participating in the community. As shown in FIG. 6, remote terminal 114 may communicate with members of the community in a variety of ways. For example, an anchor terminal 102 may be configured to maintain a connection to structured network 112 so as to enable communication between remote terminal 114 and the community (for example, the anchor terminal 102, terminal A 104, and terminal B 106), as illustrated in FIG. 1. Alternatively, as described above with respect to FIG. 4, terminal A 104 and/or terminal B 106 may additionally be connected to structural network 112, even in the case where anchor terminal 102 and/or terminal A 104 and/or terminal B remain able to communicate with each other using proximity-based communication, such as community participance module 318 or the like. Accordingly, remote terminal 114 may communicate with any terminal in the community that is connected to structural network 112. A remote terminal 114 that does not participate in the community may transmit a search request to a terminal of the community using a known identifier, such as a telephone number, associated with the terminal.


However, in another embodiment according to FIG. 6, remote terminal 114 may interact with a server or other network entity (hereinafter generically referenced as a “server”), and may transmit a search request to the server without needing to know the identifier of a specific terminal of the community. The server may comprise circuitry, such as, for example, an apparatus as illustrated in FIG. 3, or the like. In this embodiment, the remote terminal 114 may transmit a search request to the server and may receive information responsive to the search request from the server via structural network 112 using, for example, short message system (SMS) messages, U-Plane data or the like. The server may then identify a terminal to which the server may transmit the search request, as will be described in further detail with respect to FIG. 9.



FIG. 7 illustrates a flowchart according to an embodiment in which remote terminal 114 may remotely retrieve contextual information about a location from terminals in one or more ad hoc communities using structural network 112, regardless of whether remote terminal 114 participates in the communities. As one example, a parent may launch a search request to a child's terminal to collect information about what is near the child. In one embodiment, remote terminal 114 may transmit search requests regarding the one or more communities. In operation 700, an apparatus embodied by a first terminal participating in at least one ad hoc community formed by a plurality of terminals at a first location may include means, such as processor 310, communication interface 314, or the like, for receiving, from remote terminal 114, the search request for information. In some embodiments, upon receipt of the search request, the first terminal may conduct a local search to collect information responsive to the search request, as described below in conjunction with FIG. 11. Nevertheless, the apparatus embodied by the first terminal may further include means, such as processor 310 or the like, for causing the search request to be broadcast to one or more neighboring terminals in a community using proximity-based communication, such as community participance module 318 or the like. See operation 710. Additionally, the neighboring terminals may also broadcast the search request using proximity-based communication, such as community participance module 318 or the like. In this manner, the search request may be propagated to an entire community, even if the first terminal is not directly within range of every terminal participating in the community using proximity-based communication such as community participance module 318 or the like. Of course, because the first terminal may participate in more than one community, in some embodiments the search request may be broadcast to the neighboring terminals of one or more additional communities in which the first terminal participates. Each terminal receiving the search request may collect local information responsive to the search request and communicate the responsive information to the apparatus. In operation 720, the apparatus embodied by the first terminal includes means, such as processor 310, communications interface 314, or the like, for receiving information responsive to the search request from the neighboring terminals. After receiving all information responsive to the search request from the neighboring terminals (and collecting any local responsive information, if a local search is conducted), the apparatus embodied by the first terminal includes means, such as processor 310, communication interface 314, or the like, for causing any received or self-collected responsive information to be transmitted to remote terminal 114 using structural network 112, such as, for example, using an SMS message, U-Plane data, a social networking application, or the like.



FIG. 8 illustrates an example embodiment in which remote terminal 114 may remotely retrieve contextual information in accordance with the operations described with respect to FIG. 7 above. In one embodiment, a request to search within an ad hoc community is facilitated using a proprietary engine and application programming interface (API) to standardize and streamline the process with which search requests may be handled, such as, for instance, the PubSub Engine and PubSub API. The PubSub Engine and PubSub API are described in more detail in U.S. patent application Ser. No. 12/956,901, filed Nov. 30, 2010, the entire contents of which are incorporated herein by reference. In an example embodiment, a remote terminal 114 may transmit to the first terminal, for example, a service SMS containing a request to make a subscription for information using the PubSub API. The first terminal may employ the PubSub Engine to broadcast the search query to the neighboring devices of the community and receive responsive information. Thereafter, the first terminal may use the PubSub API to generate a Discovery Report based on the responsive information, which the first terminal transmits back to the remote terminal 114 using, for example, a service SMS.



FIG. 9 illustrates a flowchart according to an embodiment of the invention in which remote terminal 114 interacts with a server to process search requests. In operation 900, an apparatus embodied by the server may include a means, such as processor 310, communication interface 314, any other suitably configured circuitry, processor, and/or interface, or the like, for receiving a search request from remote terminal 114. The search request may, for instance, comprise a request for information regarding a specific location, but unlike the search described with respect to FIG. 8 above, need not include reference to a specific terminal at the location. In operation 910, the apparatus embodied by the server may include a means, such as processor 310, any other suitably configured circuitry or processors, or the like, for identifying whether a terminal that has authorized performance of a search is at the specific location. For example, the server may store a database describing all terminals that have authorized the search function and having information regarding the location of each such terminal. Additionally or alternatively, such a database may be stored remotely from the server, while being made available to the server using structural network 112 and, for example, communication interface 314, any other suitably configured interface, or the like. The information may be collected using a global positioning system, a wireless local area network, identities of cell sites nearest the participating terminals (Cell ID), one or more social networking applications (such as by using a location identification feature associated with the social networking application, e.g., Facebook Places, Foursquare, or the like), or user input. In any event, if the apparatus embodied by the server, such as processor 310, any other suitably configured circuitry, processor, or the like, identifies in operation 910 that a destination terminal that has authorized the search function is at the location indicated in the search request, then the apparatus embodied by the server may include means, such as the processor, the communication interface or the like, for causing the search request to be sent to the destination terminal. See operation 920. Upon receipt of the search request, the destination terminal may perform a search for information responsive to the search request. In one embodiment, responsive information may be collected by the destination terminal, for example, from a plurality of terminals in an ad hoc community of which the destination terminal is a member, in the manner described in conjunction with FIGS. 7 and 8 above. In other embodiments, the destination terminal may additionally or alternatively retrieve information by, for example, collecting local information responsive to the search request, or by searching any number of other networks to which the destination terminal is connected. Regardless of the manner with which responsive information is collected, however, the destination terminal may transmit the collected responsive information responsive to the server. Pursuant to operation 930, the apparatus embodied by the server may include means, such as processor 310, communication interface 314 any other suitably configured circuitry, processor, and/or interface, or the like, for receiving information responsive to the search request from the destination terminal. In one embodiment, the server may store the received search results, such as in memory, for future reference by other remote terminals 114. In operation 940, the apparatus embodied by the server may include means, such as processor 310, communication interface 314 any other suitably configured circuitry, processor, and/or interface, or the like, for causing the received information to be transmitted to the remote terminal.


Accordingly, although the server may communicate with both remote terminal 114 and at least one terminal of an ad hoc community, and can further cause a search request to propagate throughout one or more communities, in one example embodiment the server may maintain anonymity between end users, such as remote terminal 114 and the destination terminal. In this fashion, ad hoc communities can be leveraged to benefit every terminal that has authorized the above-described search functionality. In one embodiment, the server may additionally store the received search results, and subsequently use stored search results for immediate retrieval and obviate the need for processing repetitive search requests. In this regard, a search request may include a parameter indicating a time period after which the search request will expire, as another mechanism that may reduce the burden of unnecessary search operations. For instance, in one embodiment, if all participating terminals have responded within the indicated time period, then all received information may be transmitted to the remote terminal. However, if, at the end of the indicated time period, not all participating terminals have responded to the search request, then only the information received from terminals that have responded within the time period may be transmitted to the remote terminal. However, if no information is received within the time period, then in one embodiment no transmission is sent to the remote terminal. Alternatively, even if no information is received within the time period, a message may still be transmitted to the remote terminal indicating that no search results were identified. In any event, in one example embodiment, if a search request includes a parameter indicating a time period after which the search request will expire, then any responsive information received from a participating terminal after the time period may be discarded.



FIG. 10 illustrates a flowchart according to an embodiment in which remote terminal 114 may perform a “social search,” and retrieve contextual information from terminals participating in one or more social networks, such as Facebook, LinkedIn, or the like. In this regard, FIG. 10 illustrates the operations performed to enable a search request based on a user's existence within a social graph, rather than purely based on a user's physical location. Using the operations illustrated in FIG. 10, remote terminal 114 may search for information regarding the vicinity of every user within a social graph, and as a result, remote terminal 114 may search for information proximate to a number of users simultaneously.


For instance, in one embodiment, remote terminal 114 may transmit a search request using one or more social networking applications. The search is sent to one or more contacts in the social networking application. Identification of the contacts to which the search will be transmitted may require the social networking application's login credentials. In this regard, in one embodiment, the remote terminal may already have been granted access to the social networking application. In another embodiment, the username and password for the relevant social networking application may be entered to facilitate the search request. In any event, upon gaining access to the relevant contacts from the social networking application, remote terminal 114 may transmit a search request to the set of contacts using structural network 112, such as, for example, using an SMS message, U-Plane data, the social networking application itself, or the like.


In one embodiment, the search request includes a parameter indicating the number of transmissions allowed in social searches (M) and a parameter indicating the number of broadcasts allowed in proximity-based searches (N). These parameters indicate the number of times the search may be recursively performed by a terminal receiving the search request and may be included and may reduce the global resources required to complete the search request. In one embodiment, the search request may also include a parameter indicating a time period after which the search request will expire, as previously described. In another embodiment, the search request may also include a parameter indicating geographic limitations for the search, as will be explained below. Moreover, the search request may include parameters indicating particular topics for the search (such as sporting events, concerts, community activities, or the like). In one such embodiment, these parameters may be set by remote terminal 114 in the social networking application. In another embodiment, the parameters may be set in a profile associated with search requests created by the remote terminal. In either case, these topical search parameters may focus the search results that will be returned to remote terminal 114 using the social search.


An apparatus embodied by a first terminal may include means, such as processor 310, communication interface 314, or the like, for receiving, from remote terminal 114, the search request for information. See operation 1000. In some embodiments, upon receipt of the search request, the first terminal may conduct a local search to collect information responsive to the search request, as described below in conjunction with FIG. 11. Nevertheless, the apparatus embodied by the first terminal may include means, such as processor 310 or the like, for determining whether the parameter indicating the number of broadcasts is greater than zero. See operation 1010. An instance in which the number of broadcasts is not greater than zero indicates that the apparatus embodied by the first terminal is not authorized to rebroadcast the received search request, and the procedure continues to operation 1070, described below. However, in an instance in which the parameter indicates a number of broadcasts greater than zero, the apparatus embodied by the first terminal may include means, such as processor 310 or the like, for decrementing the parameter. See operation 1020.


The apparatus embodied by the first terminal may include means, such as processor 310, Communication Interface 314, Community Participance Module 318, or the like, for subsequently broadcasting the search request to one or more ad hoc communities using the proximity-based wireless communication technology, wherein each terminal receiving the search request may propagate the search request if counters M and N are greater than zero. Furthermore, in embodiments in which the search request includes a parameter indicating geographic limitations of the search request, then the physical proximity-based search request may not be propagated to the entirety of each ad hoc community, but instead will propagate only to a portion thereof, in accordance with the geographic limitations. In this regard, the search request may limit the search to a certain area if there is no need to check larger area. For instance, if the search request is directed to looking for a lost dog, the geographic limitation may in one example be 20 km. In some embodiments, this may be accomplished by including, within the search request, the originating location of the search request, wherein each terminal receiving the search request may propagate the search request if the current distance from the originating location does not extend beyond the geographic limitations indicated in the search request. See operation 1030.


Each terminal receiving this search request broadcast may transmit responsive information back to the apparatus. Subsequently, the apparatus embodied by the first terminal includes means, such as processor 310, communication interface 314, or the like, for receiving this information responsive to the search request transmitted using proximity-based wireless communication technology. After receipt of all such information responsive to the search request from the terminals receiving the search request broadcast (and collection of any local information responsive to the search request) or alternatively at expiry of the time period for the search, the apparatus embodied by the first terminal includes means, such as processor 310, communication interface 314, or the like, for causing any received or self-collected information to be transmitted to remote terminal 114 terminal using structural network 112, such as, for example, using a short message system (SMS) message, U-Plane data, a social networking application, or the like. See operation 1070.


Additionally, however, the apparatus embodied by the first terminal may include means, such as processor 310 or the like, for determining whether the parameter indicating the number of transmissions is greater than zero. See operation 1040. An instance in which the number of transmissions is not greater than zero indicates that the apparatus embodied by the first terminal is not authorized to rebroadcast the received search request, and the procedure continues to operation 1070, described above. However, in an instance in which the parameter indicates a number of transmissions greater than zero, the apparatus embodied by the first terminal may include means, such as processor 310 or the like, for decrementing the parameter. See operation 1050.


The apparatus embodied by the first terminal may include means, such as processor 310, Communication Interface 314, Community Participance Module 318, or the like, for subsequently transmitting the search request to a set of contacts retrieved using a social networking application (which may or may not be the same social networking application used by remote terminal 114 to create the social search). Transmitting the search request to the set of contacts may be performed using structural network 112, such as, for example, using an SMS message, U-Plane data, the social networking application itself, or the like. See operation 1060. Each terminal receiving this search request transmission may transmit responsive information back to the apparatus. Each such terminal may also propagate the search request if the parameters M and N are greater than zero. Subsequently, the apparatus embodied by the first terminal may cause any received or self-collected information to be transmitted back to remote terminal 114 as described above. See operation 1070.


In accordance with the operations illustrated in FIG. 10, the social search function enables a search of a broader network of terminals than just those within a certain physical proximity of a first terminal. In addition, any terminal receiving a social search request may perform both a physical proximity-based search as well as a search of its social graph. Moreover, in one embodiment, any terminal receiving a search request using proximity-based wireless communication technology may recursively propagate the proximity-based search, but may also propagate a social graph search request as well.



FIG. 11 illustrates a flowchart further describing the manner in which a terminal may collect local information. In particular, FIG. 11 illustrates operations performed to enable terminals receiving a propagated search request to collect local information responsive to the search request. Accordingly, an apparatus embodied by one such terminal may include means, such as processor 310, communication interface 314, or the like, for receiving, from remote terminal 114, the search request for information. See operation 1100.


Upon receiving the search request, the apparatus embodied by the terminal may include means, such as processor 310 or the like, for initiating a local search for information responsive to the search request. See operation 1110. In this regard, the local search may be performed by an application stored on the terminal, subsequently referred to as a search agent. In one embodiment, the search agent may be contained in a search request, and therefore may be installed on each terminal when the terminal receives the search request. In this fashion, the search agent may spread in a viral fashion. In another embodiment, the search agent may already be installed on the terminal upon receipt of the search request. In this embodiment, to enable participation in the search service, users may download the search agent or have the search agent pre-installed. Accordingly, in this embodiment, the search agent is activated upon receipt of the search request.


In some embodiments, the user may be involved in the initiation of a local search. For example, receipt of the search request may cause a message to be displayed on the terminal (such as, for example, using user interface 316): “a dog has been lost in the neighborhood and asks if you accept to participate into the search”. If the user selects “yes,” the local search is initiated and the search agent is activated. Of course, users may choose to preset specific information regarding their willingness to participate in searches. In one such embodiment, the user may choose a personal time limit parameter dictating how long a terminal will participate in the search (such as one hour), to limit the energy consumption of the terminal. In another embodiment, the user may employ a setting defining which kinds of searches the terminal will participate in. For example, a user may design a profile that allows automatic searches for lost children or dogs, but not for cats. Of course the items searched for can also be non-living material, like a car or a bicycle equipped with a tag.


To initiate the external search, in some embodiments when the device receives the tag type contained in the search request, the search agent automatically switches on the related radio transceiver (if it is not already active). In one such embodiment, when the receiving device accepts the search request (which may, in some instances, occur without the user's knowledge), the search agent may automatically check whether the related radio transceiver is on or not. If not, the search agent may switch on the radio transceiver to begin searching for the tag. In any event, upon initiation of the external search, the terminal may use the transceiver to collect information responsive to the search request. In this regard, the search agent may only remain active for a pre-defined time (from minutes to hours to days). After the pre-defined time, the search agent may cease to exist if it was transmitted within the search request. Alternatively, if the search agent was installed on the terminal by the user or pre-installed on the terminal, the search agent may not be removed, but instead may only be deactivated (i.e., the application may stop running). In other embodiments, the search agent may remain active until responsive information is located.


After initiating the search, the apparatus embodied by the terminal may include means, such as processor 310 or the like, for enabling the search agent to collect information responsive to the local search. See operation 1120. In one embodiment, the search agent may conduct an internal search for responsive information, by querying a memory associated with the terminal, such as memory 312, and therefore collecting any stored information responsive to the search request. Alternatively, the search agent may conduct an external search by collecting information using a communication interface, such as communication interface 314 or the like. One example external local search embodiment may be referred to as a tag-based search. To request a tag-based search, the search request may indicate a radio technology tag type (such as BlueTooth, BlueTooth Low Energy, ZigBee, or the like) used by a tag associated with an object that the remote terminal 114 is searching for. If the tag has a special code or ID, that may also be contained in the search request. To conduct the search, the apparatus embodied by the terminal may use a communication interface that communicates a signal using the indicated tag type and collects any responsive signals.


For example, consider a situation in which a remote user is looking for a lost dog that has an implanted Radio Frequency Identification (RFID) tag. The remote user may use remote terminal 114 to transmit a search request to find the dog, and may include the dog's tag type in the search request. If the dog's tag has a known special code or ID, that may also be included in the search request. In this example, each terminal receiving the search request may conduct a local external search to determine whether the dog is nearby.


As noted above, time parameters may constrain the duration of the search. However, a local search may be stopped and started as long as the time period for the search has not expired. For instance, after receipt of the search request, the search agent may at times be deactivated, such as if the device has been powered off or if the communication interface has been disabled by using an “Airplane Mode” setting, or the like. After arriving to a new location, if the time period for the search has not expired, the search agent may be reactivated and may continue the search.


Alternatively, the local search may be terminated for other reasons, as well, such as if the search request includes a geographic limitation. For instance, when the user moves to another area (e.g., the terminal moves outside the geographic limitation), the local search may be automatically stopped if location information is available, or it may be stopped at the user's direction.


Referring back to FIG. 11, after collecting information responsive to the search request, the apparatus embodied by the terminal may include means, such as communication interface 314, community participance module 318, or the like, for causing any collected information to be transmitted to remote terminal 114 terminal using structural network 112, such as, for example, using a short message system (SMS) message, U-Plane data, a social networking application, or the like. See operation 1130. This information may be transmitted in conjunction with responsive information that the terminal has received from neighboring terminals to which the terminal propagated the search request. This transmission, of course, may require that the address (e.g. a phone number, an email address etc.) of remote terminal 114 is known. Alternatively, if a server is used for relaying the search, a device ID that the server recognizes may be sufficient.


Accordingly, using the search request concepts disclosed above, in some embodiments, extensive local searches or searches through social graphs may be performed even without the terminals being connected to Internet. In one embodiment, each terminal of a community may perform its respective search operations as background processes, such that the operations do not interfere with user manipulation of the terminals. Because responding to search requests may increase the depletion rate of terminal battery resources, in one example embodiment each terminal may allow search requests only for pre-authorized terminals, or alternatively may only authorize search requests when battery resources are above a threshold value. Additionally or alternatively, a terminal or server receiving a search request from a remote terminal may confirm that the remote terminal is authorized to transmit a search request prior to processing the search request. Additionally or alternatively, terminals wishing to transmit search requests may also be required to consent to participation in search requests transmitted from other terminals.



FIGS. 5, 7, 9, 10, and 11 illustrate flowcharts of a system, method, and computer program product according to some example embodiments. It will be understood that each block of the flowcharts, and combinations of blocks in the flowcharts, may be implemented by various means, such as hardware and/or a computer program product comprising one or more computer-readable mediums having computer readable program instructions stored thereon. For example, one or more of the procedures described herein may be embodied by computer program instructions of a computer program product. In this regard, the computer program product(s) which embody the procedures described herein may be stored by one or more memory devices of a mobile terminal, server, or other computing device (for example, in the memory 312) and executed by a processor in the computing device (for example, by the processor 310). In some example embodiments, the computer program instructions comprising the computer program product(s) which embody the procedures described above may be stored by memory devices of a plurality of computing devices. As will be appreciated, any such computer program product may be loaded onto a computer or other programmable apparatus (for example, a terminal apparatus 302 and/or other apparatus) to produce a machine, such that the computer program product including the instructions which execute on the computer or other programmable apparatus creates means for implementing the functions specified in the flowchart block(s). Further, the computer program product may comprise one or more computer-readable memories on which the computer program instructions may be stored such that the one or more computer-readable memories can direct a computer or other programmable apparatus to function in a particular manner, such that the computer program product may comprise an article of manufacture which implements the function specified in the flowchart block(s). The computer program instructions of one or more computer program products may also be loaded onto a computer or other programmable apparatus (for example, a terminal apparatus 302 and/or other apparatus) to cause a series of operations to be performed on the computer or other programmable apparatus to produce a computer-implemented process such that the instructions which execute on the computer or other programmable apparatus implement the functions specified in the flowchart block(s).


Accordingly, blocks of the flowcharts support combinations of means for performing the specified functions. It will also be understood that one or more blocks of the flowcharts, and combinations of blocks in the flowcharts, may be implemented by special purpose hardware-based computer systems which perform the specified functions, or combinations of special purpose hardware and computer program product(s).


The above described functions may be carried out in many ways. For example, any suitable means for carrying out each of the functions described above may be employed to carry out embodiments of the invention. According to some example embodiments, a suitably configured processor (for example, the processor 310) may provide all or a portion of the elements. In other example embodiments, all or a portion of the elements may be configured by and operate under control of a computer program product. The computer program product for performing the methods of some example embodiments may include a computer-readable storage medium (for example, the memory 312), such as the non-volatile storage medium, and computer-readable program code portions, such as a series of computer instructions, embodied in the computer-readable storage medium.


Many modifications and other embodiments of the inventions set forth herein will come to mind to one skilled in the art to which these inventions pertain having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Therefore, it is to be understood that the embodiments of the invention are not to be limited to the specific embodiments disclosed and that modifications and other embodiments are intended to be included within the scope of the invention. Moreover, although the foregoing descriptions and the associated drawings describe example embodiments in the context of certain example combinations of elements and/or functions, it should be appreciated that different combinations of elements and/or functions may be provided by alternative embodiments without departing from the scope of the invention. In this regard, for example, different combinations of elements and/or functions than those explicitly described above are also contemplated within the scope of the invention. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.

Claims
  • 1. A method comprising: receiving, from a remote terminal, a search request for information from an ad hoc community, the ad hoc community formed by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other at the first location, wherein the remote terminal is located at a second location that is outside of a range of the proximity-based wireless communication technology from the first location;causing a first terminal of the plurality of terminals to broadcast the search request to the plurality of terminals using the proximity-based wireless communication technology; andcausing the first terminal of the plurality of terminals to transmit to the remote terminal any received information responsive to the search request.
  • 2. The method of claim 1, further comprising: causing the first terminal to initiate a local search for information responsive to the search request; andcausing the first terminal to collect information responsive to the local search,wherein the received information responsive to the search request includes the collected information responsive to the local search.
  • 3. The method of claim 2, wherein initiating a local search for information responsive to the search request comprises activating a search agent based on the search request, andcollecting information responsive to the local search comprises broadcasting, using the search agent, a signal using the proximity-based wireless communication technology and collecting, using the search agent, information received in response to the broadcast signal.
  • 4. The method of claim 1, wherein the search request is received from the remote terminal via a social networking application and includes parameters indicating a number of times the search request may be broadcast, and a number of times the search request may be retransmitted via the social networking application.
  • 5. The method of claim 4, wherein, causing the first terminal to broadcast the search request to the plurality of terminals comprises: in an instance in which the parameter indicating a number of times the search request may be broadcast is greater than zero, causing the first terminal to modify the search request by decrementing the parameter indicating a number of times the search request may be broadcast by one; andcausing the first terminal to broadcast the modified search request to the plurality of terminals using the proximity-based wireless communication technology.
  • 6. The method of claim 4, further comprising: in an instance in which the parameter indicating a number of times the search request may be transmitted is greater than zero, causing the first terminal to modify the search request by decrementing the parameter indicating a number of times the search request may be transmitted by one, andcausing the first terminal to transmit the modified search request to a set of contacts retrieved using a social networking application.
  • 7. The method of claim 4, wherein the search request includes one or more parameters indicating least one of a geographical limitation and a time period after which the search request expires.
  • 8. A computer program product comprising at least one non-transitory computer-readable storage medium having computer-executable program code portions stored therein, the computer-executable program code portions comprising program code instructions that, when executed, cause an apparatus to perform the method of claim 1.
  • 9. An apparatus comprising at least one processor and at least one memory including computer program code, the at least one memory and the computer program code configured to, with the processor, cause the apparatus to at least: receive, from a remote terminal, a search request for information from an ad hoc community, the ad hoc community formed by a plurality of terminals at a first location using a proximity-based wireless communication technology to communicate with each other at the first location, wherein the remote terminal is located at a second location that is outside of a range of the proximity-based wireless communication technology from the first location;cause the search request to be broadcast to the plurality of terminals using the proximity-based wireless communication technology; andcause any received information responsive to the search request to be transmitted to the remote terminal.
  • 10. The apparatus of claim 9, wherein the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to: initiate a local search for information responsive to the search request; andcollect information responsive to the local search,wherein the received information responsive to the search request includes the collected information responsive to the local search.
  • 11. The apparatus of claim 10, wherein initiating a local search for information responsive to the search request comprises activating a search agent based on the search request, andcollecting information responsive to the local search comprises broadcasting, using the search agent, a signal using the proximity-based wireless communication technology and collecting, using the search agent, information received in response to the broadcast signal.
  • 12. The apparatus of claim 9, wherein the search request is received from the remote terminal via a social networking application and includes parameters indicating a number of times the search request may be broadcast, and a number of times the search request may be retransmitted via the social networking application.
  • 13. The apparatus of claim 12, wherein, causing the search request to be broadcast to the ad hoc community comprises: in an instance in which the parameter indicating a number of times the search request may be broadcast is greater than zero, modifying the search request by decrementing the parameter indicating a number of times the search request may be broadcast by one; andcausing the modified search request to be broadcast to the plurality of terminals using the proximity-based wireless communication technology.
  • 14. The apparatus of claim 12, wherein the at least one memory and the computer program code are further configured to, with the processor, cause the apparatus to: in an instance in which the parameter indicating a number of times the search request may be transmitted is greater than zero, modify the search request by decrementing the parameter indicating a number of times the search request may be transmitted by one, andtransmit the modified search request to a set of contacts retrieved using a social networking application.
  • 15. The apparatus of claim 12, wherein the search request includes one or more parameters indicating least one of a geographical limitation and a time period after which the search request expires.
  • 16. A method comprising: receiving a search request from a remote terminal that participates in a search service, wherein the search request is for information relating to a first location;identifying, with a processor, whether a terminal that participates in the search service is at the first location;causing transmission of the search request to the identified terminal;receiving information responsive to the search request from the identified terminal; andcausing transmission of the received information to the remote terminal.
  • 17. The method of claim 16, wherein the remote terminal and the identified terminal are anonymous to each other.
  • 18. The method of claim 16, wherein identifying whether a terminal that participates in the search service is at the first location includes: determining a location of participating terminals using a global positioning system, a wireless local area network, identities of cell sites nearest the participating terminals, a social networking application, or user input; andcomparing the location of the participating terminals to the first location.
  • 19. A computer program product comprising at least one non-transitory computer-readable storage medium having computer-executable program code portions stored therein, the computer-executable program code portions comprising program code instructions that, when executed, cause an apparatus to perform the method of claim 16.
  • 20. An apparatus comprising at least one processor and at least one memory including computer program code, the at least one memory and the computer program code configured to, with the processor, cause the apparatus to at least: receive a search request from a remote terminal that participates in a search service, wherein the search request is for information relating to a first location;identify whether a terminal that participates in the search service is at the first location;transmit the search request to the identified terminal;receive information responsive to the search request from the identified terminal; andtransmit the received information to the remote terminal
  • 21. The apparatus of claim 20, wherein the remote terminal and the identified terminal are anonymous to each other.
  • 22. The apparatus of claim 20, wherein identifying whether a terminal that participates in the search service is at the first location includes: determining a location of participating terminals using a global positioning system, a wireless local area network, identities of cell sites nearest the participating terminals, a social networking application, or user input; andcomparing the location of participating terminals to the first location.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation-in-part of International Application No. PCT/IB2012/050518, filed Feb. 3, 2012, the entire contents of which are incorporated herein by reference.