Service providers (e.g., wireless, cellular, etc.) and device manufacturers are continually challenged to deliver value and convenience to consumers by, for example, providing compelling network services. A series of very popular network services are social networks that alert groups of members identified as friends about the current or recent activities of other members of the group. Such activities range from profiles of personal information, photos, music playing and other content rendering, and geographic location, among others.
These social services provide techniques for adding members to a group of friends of an individual member (called herein a “personal network”); but such techniques typically involve several steps. For example, many services require a first member (called herein an “inviter”) to search through registered members of the service to identify another member, to notify the other member (called herein an “invitee”) of an opportunity to join the personal network of the inviter for a particular social service (using a messaging channel, e.g., email, outside the service), requiring action by the invitee to launch the service, and then require further action by the invitee to accept or reject the invitation. Even more steps are involved if the invitee is not already a member of the social service. For example, the inviter is further asked to provide the invitee's identifier on a particular messaging channel (e.g., email), and send a message to the invitee with a link over a communications network to a registration page of the social service. The invitee must then establish a communications network connection with the service, register with the service, logon to the service, and then initiate an invitation with the inviter. These multiple-step techniques are a burden on both inviter and invitee, diminish the user experience for both, and hinder the establishment of social connections between users.
Therefore, there is a need for a robust approach to join a personal network, with many fewer steps to extend and accept invitations to the personal network.
According to one embodiment, a method comprises receiving, at a communication device, data that indicates a selected contact for a user of the communication device. In response to receiving the contact data that indicates the selected contact, a request message is sent automatically to the selected contact. The request message comprises first data and second data. The first data indicates a social networking service. The second data indicates a unique identifier for an invitation to join a personal network of the user within the social networking service.
According to another embodiment, 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 at least one processor, cause the apparatus to receive data that indicates a selected contact for a user of the apparatus. In response to receiving the contact data that indicates the selected contact, a request message is sent to the selected contact. The request message comprises first data and second data. The first data indicates a social networking service. The second data indicates a unique identifier for an invitation to join a personal network of the user within the social networking service.
According to another embodiment, a computer-readable storage medium carrying one or more sequences of one or more instructions which, when executed by one or more processors, cause an apparatus to receive data that indicates a selected contact for a user of the apparatus. In response to receiving the contact data that indicates the selected contact, a request message is sent automatically to the selected contact. The request message comprises first data and second data. The first data indicates a social networking service. The second data indicates a unique identifier for an invitation to join a personal network of the user within the social networking service
According to yet another embodiment, an apparatus comprises means for receiving data that indicates a selected contact for a user of the apparatus. The apparatus further comprises means for automatically sending a request message to the selected contact in response to receiving the contact data that indicates the selected contact. The request message comprises first data and second data. The first data indicates a social networking service. The second data indicates a unique identifier for an invitation to join a personal network of the user within the social networking service.
Still other aspects, features, and advantages of the invention are readily apparent from the following detailed description, simply by illustrating a number of particular embodiments and implementations, including the best mode contemplated for carrying out the invention. The invention is also capable of other and different embodiments, and its several details can be modified in various obvious respects, all without departing from the spirit and scope of the invention. Accordingly, the drawings and description are to be regarded as illustrative in nature, and not as restrictive.
The embodiments of the invention are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings:
A method and apparatus for robust approach to join a personal network are disclosed. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the embodiments of the invention. It is apparent, however, to one skilled in the art that the embodiments of the invention may be practiced without these specific details or with an equivalent arrangement. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the embodiments of the invention.
As used herein, the term “application” refers to any process running on user or service provider equipment, including stand alone processes, client processes communicating with a server process hosted somewhere on a network, and the server processes. As also used herein, the term “independent message” refers to a message sent by an independent message service that is different from an application. However, the message may originate in an instance of the application. Furthermore, although various embodiments are described with respect to a social network service, such as maps-with-friends, it is contemplated that the approach described herein may be used with any application that involves sending messages among instances of the application using an independent message service.
To address this problem, a system 100 of
As shown in
The UE 101 is any type of mobile terminal, fixed terminal, or portable terminal including a mobile handset, station, unit, device, multimedia tablet, Internet node, communicator, desktop computer, laptop computer, Personal Digital Assistants (PDAs), or any combination thereof. It is also contemplated that the UE 101 can support any type of interface to the user (such as “wearable” circuitry, etc.). In the illustrated embodiment UE 101a is a fixed terminal in communication with network 105 via network link 103, and UE 101b and UE 101c are wireless mobile terminals, as described in more detail below with reference to
By way of example, the UE 101, and hosts 131 and 140 communicate with each other and other components of the communication network 105 using well known, new or still developing protocols. In this context, a protocol includes a set of rules defining how the network nodes within the communication network 105 interact with each other based on information sent over the communication links. The protocols are effective at different layers of operation within each node, from generating and receiving physical signals of various types, to selecting a link for transferring those signals, to the format of information indicated by those signals, to identifying which software application executing on a computer system sends or receives the information. The conceptually different layers of protocols for exchanging information over a network are described in the Open Systems Interconnection (OSI) Reference Model.
The client-server model of computer process interaction is widely known and used. According to the client-server model, a client process sends a message including a request to a server process, and the server process responds by providing a service. The server process may also return a message with a response to the client process. Often the client process and server process execute on different computer devices, called hosts, and communicate via a network using one or more protocols for network communications. The term “server” is conventionally used to refer to the process that provides the service, or the host computer on which the process operates. Similarly, the term “client” is conventionally used to refer to the process that makes the request, or the host computer on which the process operates. As used herein, the terms “client” and “server” refer to the processes, rather than the host computers, unless otherwise clear from the context. In addition, the process performed by a server can be broken up to run as multiple processes on multiple hosts (sometimes called tiers) for reasons that include reliability, scalability, and redundancy, among others. A well known client process available on most nodes connected to a communications network is a World Wide Web client (called a “web browser,” or simply “browser”) that interacts through messages formatted according to the hypertext transfer protocol (HTTP) with any of a large number of servers called World Wide Web servers that provide web pages
As shown in
UE 101a, UE 101b, and UE 101c include social network clients 109a, 109b, 109c, respectively, collectively called social network clients 109 hereinafter. According to the illustrated embodiment, one or more of the social network clients 109 includes an in-service message presentation module 151 that intercepts and presents independent messages sent from a social network server 155 or social network client on different UE. According to the illustrated embodiment, one or more of the social network clients 109 includes an invite contact module 153a, 153b (collectively referenced hereinafter as invite contact module 153) that allows a user of the UE, who is also a subscribes to the social network service, to invite a contact of the user to join the personal network of the user.
The message service client 203, uses one or more message service data structures 210, including a contacts list 211, a send queue 215 and a receive queue 217. The contacts list 211 holds data that identifies other users of the message service on other UE. In embodiments with an SMS message service, the contacts lists 211 includes a cell phone list 213. These are contacts for the message service known to message service client 203; and zero or more of the contacts so indicated might not be subscribers of the social network known to social network client 207. The message service client 203 also constructs and maintains the send queue 215 to hold messages to be sent when the UE 200 is in communication with network 105, and the receive queue to hold messages received when the UE 200 was most recently in communication with network 105. This interaction is indicated by an arrow connecting message service client 203 to the message service data structures 210.
In the illustrated embodiment, the UE 200 also includes an executing social network client, either as a pre-installed social network client 207a, or a subsequently installed social network client 207b, collectively referenced hereinafter as social network client 207. As depicted in
According to the illustrated embodiment, the in-service message presentation module 151 monitors the receive queue or send queue 215 of an independent message service, or both, for a message associated with an application, such as social network message 219 received from a different UE 101. Once detected, the message, e.g. social network message 219, is removed from control of the message service, e.g., removed from the receive queue 217, and used as the basis of an interface of the application (e.g., an interface of social network client 207) presented to a user of UE 200. This interaction is indicated by an arrow connecting in-service message presentation module 151 to the message service data structures 210.
The source field 251 holds data that indicates a message service source of the message 250, e.g., an email address or cell phone number of a message service client on a different device. For purposes of illustration, it is assumed that the source of message 250 is an SMS message service client on UE 101b; and that source field 251 holds data that indicates the cell phone number for UE 101b. In this embodiment, source field 251 is part of the SMS header.
The subscriber ID field 253 holds data that indicates a user of the application that uses the independent message service, e.g., a subscriber of the social network service. For example, in an SMS message a free text field is used to indicate a subscriber ID by which the sending user is known to the recipient user. For example, userA is a subscriber ID for a first user, e.g., an inviter, of the social network service who is using an SMS messaging service on a cell phone with a telephone number 444-555-6666. The source field 251 holds data indicating the source of the SMS message, cell phone number 444-555-6666, and the subscriber ID field 253 holds data that indicates “userA.”
The service link field 255 holds data that indicates a network address of a download page for the application, e.g., a universal resource identifier (URI) for the social network service 155. The data in service link field 255 can be used by a browser on the UE 200 to open a web page interface for the social network service 155.
The message type field 257 holds data that indicates how the message 250 is to be used by the application on receiving UE 200. For example, the data in the message type field 257 indicates whether the message 250 is an invitation to join a personal network of the inviter indicated in subscriber ID field 253, or some other type of message, e.g., an alert to a change in status of the subscriber. In some embodiments, all messages for a particular application are of the same type; and field 257 is omitted.
The token field 259 holds data that indicates a unique number so that a response to the message 250 can be associated with the message 250. For example, the sending node, e.g., UE101b can distinguish between multiple responses to multiple earlier invitations because the response will have the same value in the token field 259 as the invitation being responded to.
Although a particular set of nodes, processes, fields, messages and data structures, such as databases, are shown in
In step 303, data is received that indicates a user who is a subscriber to the social network service and who wishes to add a contact (who might not be a subscriber) to the subscriber's personal network (e.g., add the contact as a location sharing friend to a maps-with-friends service). Any method may be used to receive this data, for example the data is received as user input resulting from depressing a physical key with a hard or soft label or by activating a virtual key using a pointing device on the UE 101b.
In step 305 of
In step 307, data is received that indicates a particular contact. Any method may be used to receive this data, as described above. For example, the second screen 331 is a second user interface for the social network service client and includes a list of contacts in a phonebook, and the soft key label bar described above. The user indicates the particular contact by highlighting the phonebook item 333 labeled with the name of the contact, and depressing the key below the “Select” label. It is assumed for purposes of illustration that several network addresses of the contact are available and that a third screen 335 is also presented during step 307. The third screen 335 is a third user interface for the social network service client and includes a list of addresses for the particular contact in the phone book, and the soft key label bar described above. The user indicates the particular address for the contact by highlighting the address item 337 labeled with the address of the contact, and depressing the key below the “Select” label. As a result, a cell phone serving as UE, e.g. UE 101b, receives data indicating the network address for a contact to invite to the personal network of the subscriber, as occurs during step 307.
In step 309 of
During step 309 in some embodiments, the cell phone presents screen 341 of
In step 311, it is determined whether the invitation is accepted. For example, it is determined whether an independent message like 250 is received with data in message type field 257 indicating “accept” and value in token field 239 equal to the value in the token field 259 of the corresponding invitation message. If the message type field holds data that indicate “reject” then the process ends. If, instead the message type indicates “accept,” then in step 313 the selected contact is added to the user's personal network and the social network data is shared. For example, the contact name in panel 349 changes to the contact's subscriber name, if different than the contact name, and the status is changed to indicate the location of the subscriber, as in panel 347. The invitation process then ends.
In some embodiments, the subscriber is adding a friend through a social networking service executing on a remote device, such as social network service 155 running as a world wide web server on host 131.
The page 351 lists the status of the members of the subscriber's personal network and includes HTML button 354, and panel 353, panel 355a, panel 355b, panel 357a, panel 357b, panel 357c, panel 357d, panel 357e and panel 358. Panel 353 presents data indicating the friends list and one or two active elements for changing the contents or order of the listed friends. For purposes of illustration it is assumed that the application is a maps-with-friends server, and the current subscriber is the user of device UE 101b. Panel 355a and panel 355b (collectively referenced hereinafter as panels 355) present data that indicates the subscriber IDs of other subscribers who have invited the current subscriber to share location information, along with their location sharing status. Panels 357a, 357b, 357c, 357d and panel 357d (collectively referenced hereinafter as panels 357) presents data that indicates the subscriber IDs of other subscribers who are currently sharing their location information with the current subscriber and their location status. Panel 358 presents data that indicates the contact name of another subscriber who is a friend for some communications but is currently not sharing location data.
The user indicates a wish to add a contact to the user's personal network by activating the HTML button 354 labeled “Add friends.” As a result, web page 361 is sent by the server to the device of the current subscriber. Page 361 includes a web forms field 363 to indicate the contact information for a contact of the current subscriber, and an HTML “Send” button. The forms field 363 is configured to accept input from the current subscriber to indicate a contact. In the illustrated embodiment, the email address of the contact is manually keyed in by the current subscriber and received by the server, when the current subscriber activates the Send button. In other embodiments, the field 363 includes a pull down menu listing one or more contacts from the contact book 139 in the user profile data structure for the current subscriber. In these embodiments, the current subscriber simply indicates one of the contact book entries as the selected contact. The email address or cell phone number or other network address associated with the selected contact in the contact book 139 is used as a destination address of a request message, for inviting the recipient to join the personal network of the sender, the current subscriber. The recipient might be a subscriber already or might not be a subscriber.
As a result of activating the HTML Send button, the page 371 is presented by the server 155. The page 371 lists the status of the members of the subscriber's personal network and includes HTML button 354, and panel 353, panels 357 and panel 358, described above for page 351, and panel 359. Panel 359 presents data that indicates the contact name of the selected user (who might not be a subscriber) whom the local subscriber has invited to share location information and that status.
In step 403, the messages in the independent message service are monitored. This is an example of the general step of monitoring a messaging service for arrival of a message at an apparatus. For example, SMS message 219 in an SMS receive queue 217 is read.
In step, 405 it is determined whether a message for the service client is detected. This is an example of determining whether the message indicates an installed application that is installed on the apparatus and is different from the messaging service. For example, it is determined whether the data in the service link field 255 indicates the web page where the application doing the monitoring (e.g., the social network service client) can be downloaded. If not, then in step 407, it is determined whether the process is done. If done, then the process ends. Otherwise, step 403 and following are repeated to continue monitoring the messages in the independent message service.
If, in step 405, it is determined that a message for the service client is detected, then the message is presented within the application and removed from the message service, as described in the following steps. Thus, if the message indicates the installed application, then removal of the message from a queue of received messages for the external messaging service is initiated, and a user interface for the application is presented based on the message.
In step 409 the message is extracted, e.g., the useful fields of the message are extracted and stored in memory allocated to the application, e.g., memory allocated to the social network service client on UE 101c. In step 411, the message is removed from the message service receive queue. For example, the message 219 is removed from receive queue 217 by the in-service message presentation module 151. This can often be accomplished fast enough that a user of the UE 200 does not even see an indication of the message 219 within the message service. In some embodiments, an audible alert is sounded when the message 219 is placed in the receive queue 217, but the message does not appear in the message service. Instead a user interface of the application appears, as described below, and the user learns to associate the audible alert with the application interface.
In step 413, it is determined whether the user of the UE is a registered user of the application, e.g., a subscriber to the service, such as the social network service. In some embodiments involving stand alone applications, all users of an apparatus are considered registered users if the stand alone application is installed; and none are considered registered users if the stand alone application is not installed. For a client process of a service that requires registration, such as a social network service client, a user is a registered user if the user has registered with the service—such a user is a subscriber to the service. The client can tell if a user is a subscriber by contacting the service with the locally stored credentials for the user of the client.
If it is determined in step 413 that a user of the UE, e.g., a user of UE101c, is a registered user, then in step 415 a user interface is presented to the user based on the message. For example, in response to receiving a SMS message indicating an invitation to share location data with a maps and friends service, the user is presented with a panel like panel 345a or panel 345b of
In step 417, the application responds to user input. For example, the social network client responds to subscriber input to accept the invitation. For the map and friends client, the response includes displaying positions of the invited subscriber and the inviter subscriber. Control then passes back to step 403 to continue monitoring the independent messages.
If it is determined in step 413 that a user of the UE, e.g., a user of UE101c, is not a registered user, then in step 419 a user interface is presented to the user that allows the user to subscribe to the service. Any method may be use to present this interface. In some embodiments, the user is presented with a logon screen and invited to create an account with the service.
In step 421, it is determined whether the user has subscribed to the service. For example, it is determined whether the user responded with input to create an account in response to the prompt on the logon screen. If not, then the response to the independent message is complete, the user will not subscribe; and there is no need for the in-service message presentation to continue to monitor the messages in step 403. If the user has subscribed to the service, then in step 415 and following, the user interface based on the message is presented to the user, as described above.
In step 511, the message service client stores received messages in a receive queue, e.g., message service client 203 places received message 219 in receive queue 217. In step 513, it is determined whether a user of the UE has selected the received message. For example, it is determined if the user selected message 219 by pointing to it on a list of messages on a touch screen display. If not, it is determined in step 515 whether the user is done with the message service. If so, the message client 510 ends; otherwise, the message client 510 continues to queue received messages.
If, in step 513, it is determined that a user of the UE has selected the received message, then, in step 517, the received message is displayed e.g., on a display screen of the UE. For example, the data indicated in message 250 is presented on a screen of the mobile device, including the service link where the application can be downloaded or an icon representing the link.
In step 519, it is determined whether the user has selected the service link, e.g., by touching its location on a touch screen or clicking a soft key or button on a pointing device when a cursor is placed over the link. If not, then control passes back to step 511 to queue received messages and following steps, described above.
If the user has selected the service link, then the browser 520 (e.g., browser 205 on UE 200) opens on the apparatus and requests the web page indicated by the link. In step 521, the browser 520 displays the page where the application can be downloaded, e.g., a social service client download page from the social network service 155.
In step 523, it is determined whether the UE is compatible with the application, e.g., with the social network service client. If not, control passes to step 525. For example, to share position on the maps-with-friends service, the UE should include a Global Positioning System (GPS) receiver. If the UE does not include a GPS receiver, it is determined that the apparatus is not compatible and control passes to step 525.
In step 525, the browser 520 is directed to another page from the service, where the user can logon to the service and run it remotely. For example, the browser 520 on the UE 101c is directed to a logon page provided by service 155 on the host 131. The remote service 155 then responds to user input through browser 520 in step 527. In step 529, it is determined whether the user is done with the application. If so, the process ends; otherwise control passes back to step 527 to respond to further user input.
If it is determined, in step 523, that the UE is compatible with the application, e.g., with the social network service client, then control passes to step 531. In step 531, the application is downloaded, installed and launched to display a user interface based on the received independent message, either fully automatically, or with one or more interventions by a user of the apparatus. For example, the social network service client is automatically downloaded and installed on the UE 101c, and is launched automatically, and automatically presents the logon/register page to the user. After the user provides registration information, the user is automatically presented with the user interface based on the message, e.g., the invitation to join the personal network of userA on UE 101b.
In step 527, the local application responds to the user input, instead of the remote service described above with reference to step 527. When the user is done with input, the process ends, as determined in step 529, described above.
In step 553, an HTTP request is received to download the social network service client. For example, an HTTP message sent by browser 205 on UE 101c is received. In step 555, it is determined whether the apparatus from which the request is sent is compatible with the service client. For example, a script or applet is downloaded to the requesting apparatus UE 101c to determine whether a GPS receiver is aboard and report back. If compatible, then in step 557 the application is downloaded for automatic installation and execution. The application is designed to automatically prompt the user for registration information, and in response to cull the independent message service receive queue for messages associated with the downloaded application. If found, the application presents the user interface based on the message, e.g., the invitation to share location with inviter subscriber, userA. The service process 155 is then done with the UE 101c.
If not compatible, then in step 559 the user's browser is redirected to a page of the service 155 used for remote logon and operation, e.g., an instance of the server is launched to interact with this one browser. In step 561, the instance of service 155 responds to user input at browser 520 and the HTTP messages sent by the browser to the instance of service 155. If user input is done, then the instance ends; otherwise, control passes back to step 561 to respond to more user input.
In this embodiment, the application is not installed on the UE when the message 250 is received with the service link for the maps-with-friends service. In the illustrated embodiment, the message displayed in step 517 appears as screen 571. When the user selects the “accept” soft key, the browser requests the download page from the remote service. If a network connection is not available, then the browser presents the internet connection settings in process 573. If a connection is available, then the user is presented with a service logon/registration page 575a. The screen 575a is presented either through the browser from the remote service in step 525 described above, or after automated download, installation and launch in step 531 described above. In either case, the user registers with the service by typing in a user name (e.g., Armin1954) and password using keypad depicted as 575b to produce filled in logon/registration screen 575c. After pressing the soft key labelled “Send,” the user is presented with screen 577, indicating the maps-with-friends application is processing. Screen 579 presents the current location (Schloβstraβe 123) of the user Armin1954. When the user presses the soft key labelled “Select,” screen 581a is presented with a graphical switch that can be set to “OFF” 581b or “ON” 581c, to turn location sharing on or off. The screen 583 shows the current location along with a sharing status of “ON.” When the user presses the soft key labelled “Options” the menu screen 321 is presented that allows the user to accept an invitation or invite a contact from the user's phone book, as shown above with reference to
When the invitee accepts the friendship request, then the invitee will appear as a friend on the inviter's friends list and the inviter will appear as friend on the invitee's friends list. Accordingly, the inviter and invitee have decided to share their location with each other. Advantageously, location sharing only occurs upon mutual agreement.
The processes and arrangements, according to certain embodiments, advantageously permits a user to join a personal network without executing many procedures that consume system and network resources (e.g., power and bandwidth).
The processes described herein for providing a robust approach to join a personal network may be advantageously implemented via software, hardware (e.g., general processor, Digital Signal Processing (DSP) chip, an Application Specific Integrated Circuit (ASIC), Field Programmable Gate Arrays (FPGAs), etc.), firmware or a combination thereof. Such exemplary hardware for performing the described functions is detailed below.
A bus 610 includes one or more parallel conductors of information so that information is transferred quickly among devices coupled to the bus 610. One or more processors 602 for processing information are coupled with the bus 610.
A processor 602 performs a set of operations on information as specified by computer program code related for a robust approach to join a personal network. The computer program code is a set of instructions or statements providing instructions for the operation of the processor and/or the computer system to perform specified functions. The code, for example, may be written in a computer programming language that is compiled into a native instruction set of the processor. The code may also be written directly using the native instruction set (e.g., machine language). The set of operations include bringing information in from the bus 610 and placing information on the bus 610. The set of operations also typically include comparing two or more units of information, shifting positions of units of information, and combining two or more units of information, such as by addition or multiplication or logical operations like OR, exclusive OR (XOR), and AND. Each operation of the set of operations that can be performed by the processor is represented to the processor by information called instructions, such as an operation code of one or more digits. A sequence of operations to be executed by the processor 602, such as a sequence of operation codes, constitute processor instructions, also called computer system instructions or, simply, computer instructions. Processors may be implemented as mechanical, electrical, magnetic, optical, chemical or quantum components, among others, alone or in combination.
Computer system 600 also includes a memory 604 coupled to bus 610. The memory 604, such as a random access memory (RAM) or other dynamic storage device, stores information including processor instructions for a robust approach to join a personal network. Dynamic memory allows information stored therein to be changed by the computer system 600. RAM allows a unit of information stored at a location called a memory address to be stored and retrieved independently of information at neighboring addresses. The memory 604 is also used by the processor 602 to store temporary values during execution of processor instructions. The computer system 600 also includes a read only memory (ROM) 606 or other static storage device coupled to the bus 610 for storing static information, including instructions, that is not changed by the computer system 600. Some memory is composed of volatile storage that loses the information stored thereon when power is lost. Also coupled to bus 610 is a non-volatile (persistent) storage device 608, such as a magnetic disk, optical disk or flash card, for storing information, including instructions, that persists even when the computer system 600 is turned off or otherwise loses power.
Information, including instructions for a robust approach to join a personal network, is provided to the bus 610 for use by the processor from an external input device 612, such as a keyboard containing alphanumeric keys operated by a human user, or a sensor. A sensor detects conditions in its vicinity and transforms those detections into physical expression compatible with the measurable phenomenon used to represent information in computer system 600. Other external devices coupled to bus 610, used primarily for interacting with humans, include a display device 614, such as a cathode ray tube (CRT) or a liquid crystal display (LCD), or plasma screen or printer for presenting text or images, and a pointing device 616, such as a mouse or a trackball or cursor direction keys, or motion sensor, for controlling a position of a small cursor image presented on the display 614 and issuing commands associated with graphical elements presented on the display 614. In some embodiments, for example, in embodiments in which the computer system 600 performs all functions automatically without human input, one or more of external input device 612, display device 614 and pointing device 616 is omitted.
In the illustrated embodiment, special purpose hardware, such as an application specific integrated circuit (ASIC) 620, is coupled to bus 610. The special purpose hardware is configured to perform operations not performed by processor 602 quickly enough for special purposes. Examples of application specific ICs include graphics accelerator cards for generating images for display 614, cryptographic boards for encrypting and decrypting messages sent over a network, speech recognition, and interfaces to special external devices, such as robotic arms and medical scanning equipment that repeatedly perform some complex sequence of operations that are more efficiently implemented in hardware.
Computer system 600 also includes one or more instances of a communications interface 670 coupled to bus 610. Communication interface 670 provides a one-way or two-way communication coupling to a variety of external devices that operate with their own processors, such as printers, scanners and external disks. In general the coupling is with a network link 678 that is connected to a local network 680 to which a variety of external devices with their own processors are connected. For example, communication interface 670 may be a parallel port or a serial port or a universal serial bus (USB) port on a personal computer. In some embodiments, communications interface 670 is an integrated services digital network (ISDN) card or a digital subscriber line (DSL) card or a telephone modem that provides an information communication connection to a corresponding type of telephone line. In some embodiments, a communication interface 670 is a cable modem that converts signals on bus 610 into signals for a communication connection over a coaxial cable or into optical signals for a communication connection over a fiber optic cable. As another example, communications interface 670 may be a local area network (LAN) card to provide a data communication connection to a compatible LAN, such as Ethernet. Wireless links may also be implemented. For wireless links, the communications interface 670 sends or receives or both sends and receives electrical, acoustic or electromagnetic signals, including infrared and optical signals, that carry information streams, such as digital data. For example, in wireless handheld devices, such as mobile telephones like cell phones, the communications interface 670 includes a radio band electromagnetic transmitter and receiver called a radio transceiver. In certain embodiments, the communications interface 670 enables connection to the communication network 105 for a robust approach to join a personal network at the UE 101.
The term computer-readable medium is used herein to refer to any medium that participates in providing information to processor 602, including instructions for execution. Such a medium may take many forms, including, but not limited to, non-volatile media, volatile media and transmission media. Non-volatile media include, for example, optical or magnetic disks, such as storage device 608. Volatile media include, for example, dynamic memory 604. 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. Signals include man-made transient variations in amplitude, frequency, phase, polarization or other physical properties transmitted through the transmission media. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, CDRW, DVD, any other optical medium, punch cards, paper tape, optical mark sheets, any other physical medium with patterns of holes or other optically recognizable indicia, a RAM, a PROM, an EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave, or any other 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.
In one embodiment, the chip set 700 includes a communication mechanism such as a bus 701 for passing information among the components of the chip set 700. A processor 703 has connectivity to the bus 701 to execute instructions and process information stored in, for example, a memory 705. The processor 703 may include one or more processing cores with each core configured to perform independently. A multi-core processor enables multiprocessing within a single physical package. Examples of a multi-core processor include two, four, eight, or greater numbers of processing cores. Alternatively or in addition, the processor 703 may include one or more microprocessors configured in tandem via the bus 701 to enable independent execution of instructions, pipelining, and multithreading. The processor 703 may also be accompanied with one or more specialized components to perform certain processing functions and tasks such as one or more digital signal processors (DSP) 707, or one or more application-specific integrated circuits (ASIC) 709. A DSP 707 typically is configured to process real-world signals (e.g., sound) in real time independently of the processor 703. Similarly, an ASIC 709 can be configured to performed specialized functions not easily performed by a general purposed processor. Other specialized components to aid in performing the inventive functions described herein include one or more field programmable gate arrays (FPGA) (not shown), one or more controllers (not shown), or one or more other special-purpose computer chips.
The processor 703 and accompanying components have connectivity to the memory 705 via the bus 701. The memory 705 includes both dynamic memory (e.g., RAM, magnetic disk, writable optical disk, etc.) and static memory (e.g., ROM, CD-ROM, etc.) for storing executable instructions that when executed perform the inventive steps described herein for a robust approach to join a personal network. The memory 705 also stores the data associated with or generated by the execution of the inventive steps.
A radio section 815 amplifies power and converts frequency in order to communicate with a base station, which is included in a mobile communication system, via antenna 817. The power amplifier (PA) 819 and the transmitter/modulation circuitry are operationally responsive to the MCU 803, with an output from the PA 819 coupled to the duplexer 821 or circulator or antenna switch, as known in the art. The PA 819 also couples to a battery interface and power control unit 820.
In use, a user of mobile station 801 speaks into the microphone 811 and his or her voice along with any detected background noise is converted into an analog voltage. The analog voltage is then converted into a digital signal through the Analog to Digital Converter (ADC) 823. The control unit 803 routes the digital signal into the DSP 805 for processing therein, such as speech encoding, channel encoding, encrypting, and interleaving. In one embodiment, the processed voice signals are encoded, by units not separately shown, using a cellular transmission protocol such as global evolution (EDGE), general packet radio service (GPRS), global system for mobile communications (GSM), Internet protocol multimedia subsystem (IMS), universal mobile telecommunications system (UMTS), etc., as well as any other suitable wireless medium, e.g., microwave access (WiMAX), Long Term Evolution (LTE) networks, code division multiple access (CDMA), wireless fidelity (WiFi), satellite, and the like.
The encoded signals are then routed to an equalizer 825 for compensation of any frequency-dependent impairments that occur during transmission though the air such as phase and amplitude distortion. After equalizing the bit stream, the modulator 827 combines the signal with a RF signal generated in the RF interface 829. The modulator 827 generates a sine wave by way of frequency or phase modulation. In order to prepare the signal for transmission, an up-converter 831 combines the sine wave output from the modulator 827 with another sine wave generated by a synthesizer 833 to achieve the desired frequency of transmission. The signal is then sent through a PA 819 to increase the signal to an appropriate power level. In practical systems, the PA 819 acts as a variable gain amplifier whose gain is controlled by the DSP 805 from information received from a network base station. The signal is then filtered within the duplexer 821 and optionally sent to an antenna coupler 835 to match impedances to provide maximum power transfer. Finally, the signal is transmitted via antenna 817 to a local base station. An automatic gain control (AGC) can be supplied to control the gain of the final stages of the receiver. The signals may be forwarded from there to a remote telephone which may be another cellular telephone, other mobile phone or a land-line connected to a Public Switched Telephone Network (PSTN), or other telephony networks.
Voice signals transmitted to the mobile station 801 are received via antenna 817 and immediately amplified by a low noise amplifier (LNA) 837. A down-converter 839 lowers the carrier frequency while the demodulator 841 strips away the RF leaving only a digital bit stream. The signal then goes through the equalizer 825 and is processed by the DSP 805. A Digital to Analog Converter (DAC) 843 converts the signal and the resulting output is transmitted to the user through the speaker 845, all under control of a Main Control Unit (MCU) 803—which can be implemented as a Central Processing Unit (CPU) (not shown).
The MCU 803 receives various signals including input signals from the keyboard 847. The keyboard 847 and/or the MCU 803 in combination with other user input components (e.g., the microphone 811) comprise a user interface circuitry for managing user input. The MCU 803 runs a user interface software to facilitate user control of at least some functions of the mobile station 801 for a robust approach to join a personal network. The MCU 803 also delivers a display command and a switch command to the display 807 and to the speech output switching controller, respectively. Further, the MCU 803 exchanges information with the DSP 805 and can access an optionally incorporated SIM card 849 and a memory 851. In addition, the MCU 803 executes various control functions required of the station. The DSP 805 may, depending upon the implementation, perform any of a variety of conventional digital processing functions on the voice signals. Additionally, DSP 805 determines the background noise level of the local environment from the signals detected by microphone 811 and sets the gain of microphone 811 to a level selected to compensate for the natural tendency of the user of the mobile station 801.
The CODEC 813 includes the ADC 823 and DAC 843. The memory 851 stores various data including call incoming tone data and is capable of storing other data including music data received via, e.g., the global Internet. The software module could reside in RAM memory, flash memory, registers, or any other form of writable storage medium known in the art. The memory device 851 may be, but not limited to, a single memory, CD, DVD, ROM, RAM, EEPROM, optical storage, or any other non-volatile storage medium capable of storing digital data.
An optionally incorporated SIM card 849 carries, for instance, important information, such as the cellular phone number, the carrier supplying service, subscription details, and security information. The SIM card 849 serves primarily to identify the mobile station 801 on a radio network. The card 849 also contains a memory for storing a personal telephone number registry, text messages, and user specific mobile station settings.
While the invention has been described in connection with a number of embodiments and implementations, the invention is not so limited but covers various obvious modifications and equivalent arrangements, which fall within the purview of the appended claims. Although features of the invention are expressed in certain combinations among the claims, it is contemplated that these features can be arranged in any combination and order.
The following patent application is incorporated herein by reference in their entireties: co-pending U.S. patent application (Ser. No. 12/489,896) filed Jun. 23, 2009, entitled “Method and Apparatus for In-Application Notice of Independent Message.”