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.
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.
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.
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:
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.
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
One of the terminals forming the community 110 may be designated to serve as the anchor terminal. In the example of
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
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
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
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
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
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
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
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
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.
However, in another embodiment according to
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.
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
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
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
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.
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.
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.