US20090013276A1 - Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering - Google Patents

Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering Download PDF

Info

Publication number
US20090013276A1
US20090013276A1 US12/233,880 US23388008A US2009013276A1 US 20090013276 A1 US20090013276 A1 US 20090013276A1 US 23388008 A US23388008 A US 23388008A US 2009013276 A1 US2009013276 A1 US 2009013276A1
Authority
US
United States
Prior art keywords
discovered
filter
filters
objects
code configured
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US12/233,880
Inventor
Patrick Adam Barry
Heather Jean Hartman
Joshua Howard Levy
Shelley Saxena
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
International Business Machines Corp
Original Assignee
International Business Machines Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by International Business Machines Corp filed Critical International Business Machines Corp
Priority to US12/233,880 priority Critical patent/US20090013276A1/en
Publication of US20090013276A1 publication Critical patent/US20090013276A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W8/00Network data management
    • H04W8/005Discovery of network devices, e.g. terminals
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/51Discovery or management thereof, e.g. service location protocol [SLP] or web services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72403User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
    • H04M1/72409User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories
    • H04M1/72412User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality by interfacing with external accessories using two-way short-range wireless interfaces
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W92/00Interfaces specially adapted for wireless communication networks
    • H04W92/16Interfaces between hierarchically similar devices
    • H04W92/18Interfaces between hierarchically similar devices between terminal devices

Definitions

  • the present invention relates generally to an improved data processing system.
  • the present invention provides a method and apparatus for displaying discovered objects to the user.
  • the present invention provides a method, apparatus and computer instructions for adaptively scaling a user interface to an object discovery/display system with policy-driven filtering.
  • Wi-Fi wireless fidelity
  • Bluetooth is a standard protocol, available from bluetooth SIG, for short-range radio links between devices. Bluetooth replaces links currently supported by many cables.
  • Wireless fidelity (Wi-Fi) is a networking technology that uses IEEE 802.11a or IEEE 802.11b standard to provide fast, secure and reliable wireless connectivity.
  • a peer-to-peer environment may use the above technologies to share information between devices or share an Internet connection.
  • available peers meaning other mobile device users
  • available peers are displayed in a user interface to allow the user to interact with the user's peers.
  • the number of available peers or discovered objects becomes large, it becomes difficult and unwieldy for the user to look through the large number of available peers for one with which to interact. This difficulty is magnified by the small displays that are available on most mobile devices, such as mobile phones and PDAs.
  • the issue of how to filter discovered objects in order to adequately display to the user becomes a problem.
  • the present invention provides a method, apparatus and computer instructions for scaling a user interface to an object discovery or display system with policy-driven filtering.
  • the mechanism of the present invention allows users to define rules of filtering or policies, in order to filter the number of discovered objects to be displayed in a user interface.
  • the present invention allows a user to first define a number of filters to apply on discovered objects in an initial setup. The user then defines a target number of discovered objects and a metric for each filter.
  • the present invention dynamically triggers or deactivates defined filters based on the number of discovered objects. If a filter is triggered, the present invention filters discovered objects according to the metric defined for the filter. The present invention then displays filtered discovered objects in the user interface. In the absence of a filter in the initial setup, none of the discovered objects are filtered.
  • FIG. 1 is a pictorial representation of a peer-to-peer environment in which the present invention may be implemented in accordance with a preferred embodiment of the present invention
  • FIG. 2 is a block diagram of a data processing system in which the present invention may be implemented
  • FIG. 3 is an exemplary block diagram of a wireless communication device in which the present invention may be implemented in accordance with a preferred embodiment of the present invention
  • FIG. 4 is a diagram illustrating components used for scaling adaptively to an object discover or display system with policy-driven filtering in accordance with a preferred embodiment of the present invention
  • FIG. 5 is a diagram illustrating an example of adaptive scaling a user interface to an object discovery or display system with policy-driven filtering using the present invention in accordance with a preferred embodiment of the present invention
  • FIG. 6 is a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object is discovered in accordance with the present invention.
  • FIG. 7 is a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object disappears in accordance with the present invention.
  • object discovery is typically performed in a peer-to-peer environment in which an object discovery or display system exists on at least two computing devices that communicate with one another by way of a wireless communication protocol, such as bluetooth or Wi-Fi. Therefore, in order to provide a context in which the present invention may be implemented, the following description of a peer-to-peer environment is provided.
  • FIG. 1 depicts a pictorial representation of a peer-to-peer environment in which the present invention may be implemented.
  • Peer-to-peer environment 100 is an exemplary environment in which the present invention may be implemented.
  • peer-to-peer environment 100 includes clients 108 , 110 , and 112 . These may be, for example, personal computers, network computers or personal digital assistants (PDAs). Peer-to-peer environment 100 also may include additional clients, and other devices not shown. Each client in peer-to-peer environment 100 may be connected to the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational and other computer systems that route data and messages.
  • peer-to-peer environment 100 also includes communication links 120 , 122 and 124 .
  • client 108 connects to the peer discovery system, which resides on client 108 , the peer discovery system tries to connect with other clients, such as client 110 and 112 , through the use of communication links 120 and 122 .
  • Communications links 120 and 122 may be implemented in various forms, such as wire, wireless communication links, or fiber optic cables.
  • communication links 120 and 122 are implemented using bluetooth, which is a common wireless communication protocol.
  • client 110 and 112 are connected through the use of communication link 124 , which is also implemented as a bluetooth connection.
  • a connection is made when the peer discovery system of a first client, such as client 110 , broadcasts a User Datagram Protocol (UDP) message.
  • UDP User Datagram Protocol
  • the peer discovery system of a second client receives the broadcast message and decides whether to make a connection with client 110 . If client 112 accepts client 110 after filtering is performed, a connection is made.
  • client 112 filters discovered objects, such as client 110 , based on a set of established rules in the system and a set of pre-set orders to apply those rules.
  • the user of client 112 may create user defined rules to filter the clients to be displayed in the user interface. These rules may be based on the target number of objects and metrics, such as common interests, and type of hardware used.
  • the peer discovery system displays available clients 110 and 112 to client 108 in a user interface as discovered objects.
  • peer-to-peer environment 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).
  • FIG. 1 is intended as an example, and not as an architectural limitation for the present invention.
  • FIG. 2 a block diagram of a computing device that may be implemented as a client, such as clients 108 , 110 , and 112 in FIG. 1 , is shown in which the present invention may be implemented.
  • Computing device 200 is an example of a computer, such as a laptop computer or a workstation, in which code or instructions implementing the present invention may be located.
  • Computing device 200 employs a peripheral component interconnect (PCI) local bus architecture.
  • PCI peripheral component interconnect
  • AGP Accelerated Graphics Port
  • ISA Industry Standard Architecture
  • Processor 202 and main memory 204 are connected to PCI local bus 206 through PCI bridge 208 .
  • PCI bridge 208 also may include an integrated memory controller and cache memory for processor 202 . Additional connections to PCI local bus 206 may be made through direct component interconnection or through add-in boards.
  • local area network (LAN) adapter 210 small computer system interface SCSI host bus adapter 212 , and expansion bus interface 214 are connected to PCI local bus 206 by direct component connection.
  • audio adapter 216 graphics adapter 218 , and audio/video adapter 219 are connected to PCI local bus 206 by add-in boards inserted into expansion slots.
  • Expansion bus interface 214 provides a connection for a keyboard and mouse adapter 220 , modem 222 , and additional memory 224 .
  • SCSI host bus adapter 212 provides a connection for hard disk drive 226 , tape drive 228 , and CD-ROM drive 230 .
  • Typical PCI local bus implementations will support three or four PCI expansion slots or add-in connectors.
  • An operating system runs on processor 202 and is used to coordinate and provide control of various components within computing device 200 in FIG. 2 .
  • the operating system may be a commercially available operating system such as Windows XP, which is available from Microsoft Corporation. Instructions for the operating system and applications or programs are located on storage devices, such as hard disk drive 226 , and may be loaded into main memory 204 for execution by processor 202 .
  • FIG. 2 may vary depending upon the implementation.
  • Other internal hardware or peripheral devices such as flash read-only memory (ROM), equivalent nonvolatile memory, or optical disk drives and the like, may be used in addition to or in place of the hardware depicted in FIG. 2 .
  • the processes of the present invention may be applied to a multiprocessor data processing system.
  • computing device 200 may not include SCSI host bus adapter 212 , hard disk drive 226 , tape drive 228 , and CD-ROM 230 .
  • the computer to be properly called a client computer, includes some kind of network communication interface, such as LAN adapter 210 , modem 222 , or the like.
  • data processing system 200 may be a stand-alone system configured to be bootable without relying on some type of network communication interface, whether or not computing system 200 comprises some type of network communications interface.
  • Computing system 200 also may include any type of computing device that is capable of running an instant messaging client application without departing from the spirit and scope of the present invention. Examples of such computing devices include, but is not limited to, personal digital assistants (PDAs), laptop computers, network computers, wireless telephones, pager devices, and the like.
  • PDAs personal digital assistants
  • laptop computers network computers
  • wireless telephones pager devices, and the like.
  • Wireless communication device 300 includes a processor 302 for controlling operation of the communication device and a memory 304 .
  • the processor 302 may be a general-purpose microprocessor operating under the control of instructions stored in memory, such as memory 304 , or device-specific circuitry for controlling the operation of the telephone device.
  • Processor 302 is connected by system bus 306 to transmitter 308 , receiver 310 , keypad 314 , display 316 , and audio processor 318 .
  • Keypad 314 may be a keypad and/or buttons.
  • Display 316 may be any type of display device including a liquid crystal display (LCD) or other known displays, such as a cathode ray tube or active matrix display.
  • LCD liquid crystal display
  • Transmitter 308 and receiver 310 are coupled to a telephone signal by couple 324 to provide full duplex communication.
  • the telephone signal may be provided by a telephone line (not shown) in a land-based telephone or an antenna, such as for a wireless telephone.
  • Audio processing circuit 318 provides basic analog audio outputs to speaker 320 and accepts analog audio inputs from microphone 322 .
  • Received signals are demodulated and decoded by receiver 310 .
  • Transmitter 308 encodes and modulates signals passed to it by processor 302 or audio processor 318 .
  • the output of the transmitter is amplified by power amplifier 312 to control the power level at which the signal is transmitted.
  • Processor 302 or audio processor 318 may detect audible call status information and call status codes received by receiver 310 .
  • Memory 304 may include a lookup table associating call status information or call status codes with visual call status information, such as text messages.
  • Processor 302 detects or receives a call status code and displays an appropriate call status message on display 316 .
  • FIG. 3 may vary.
  • the present invention provides a method, apparatus and computer instructions for scaling a user interface adaptively to an object discovery or display system with policy driven filtering.
  • the present invention allows a user to define an initial setup, which includes a number of filters for filtering discovered objects. For each defined filter, the user specifies a target number of discovered objects to be displayed and a metric for determining a peer's desirability. Examples of metric include common interests, prior interaction, and number of prior connections. An example filter may be used to show only objects with common interest in sports if the number of discovered objects is less than 20 or to show only objects that a user interacted before if the number of discovered objects is less than 30.
  • the present invention may dynamically determine which and how many discovered objects are to be displayed in the user interface.
  • the present invention upon detection of a new discovered object, the present invention checks the total number of discovered objects against the user-defined filters to see if one or more filters are triggered based on the target number of objects. A filter is triggered if the number of discovered objects is greater than or equal to the target number of discovered objects defined in the filter. In a similar manner, upon detection of a disappeared object, which decreases the number of discovered objects, the filter is deactivated if the number of discovered objects is less than the target number of discovered objects defined in the filter.
  • the present invention applies the metric, if defined in the initial setup, for the given filter to each discovered object, in order to determine whether the discovered object should be displayed. If the object does not meet the requirements of the metric, the object is ignored. If the object meets the requirements of the metric, the present invention continues with the next triggered filter to determine whether the object meets the metric of the next triggered filter. Once the object meets metric requirements of all triggered filters, the object is displayed. Thus, each discovered object is checked against the metric of each triggered filter before being displayed.
  • the present invention provides a mechanism that dynamically triggers or deactivates filters as the number of discovered object changes.
  • a user may specify a basic filter with a target number of 10, a second filter with a target number of 20 and a third filter with a target number of 30. If the initial number of discovered objects detected is 15, the basic filter is triggered, since 15 is greater than 10. When the number of discovered objects detected is increased to 21, both the first and the second filter are triggered since 21 is greater than 20 and 10. When the number of discovered objects is again increased to 35, all three filters are then triggered since 35 is greater than 30, 20 and 10. When the number of discovered objects is reduced to 27, the first and second filters are triggered since 27 is greater than 20 and 10, however, the third filter is deactivated since 27 is less than 30.
  • FIG. 4 a diagram illustrating components used for scaling adaptively to an object discover or display system with policy-driven filtering is depicted in accordance with a preferred embodiment of the present invention.
  • the present invention may be implemented in a peer-to-peer environment, such as peer-to-peer environment 300 in FIG. 3 .
  • Peer-to-peer environment 400 includes peer discovery systems 402 , 404 and 406 .
  • Peer discovery system 402 may be implemented on client 401
  • peer discovery system 404 may be implemented on client 403
  • peer discovery system 406 may be implemented on client 405 .
  • Client 401 , 403 and 405 may be implemented as client 108 , 110 and 112 in FIG. 1 .
  • Client 401 , 403 and 405 also include user interfaces 407 , 409 and 411 , which display filtered discovered objects.
  • client 401 when client 401 wants to join peer-to-peer environment 400 to interact with other clients, client 401 connects to peer discovery system 402 through the user of user interface 407 .
  • Peer discovery system 402 sends a broadcast message over a local subnet using communication link 410 and 412 , which may be implemented using common wireless communication protocol such as bluetooth and Wi-Fi.
  • the message includes the IP address and port number of client 401 , which provides the receiver client 401 's identity.
  • peer discovery system 404 of client 403 Upon receiving the message from client 401 , peer discovery system 404 of client 403 adaptively filters client 401 based on the user-defined initial setup. If no filter is defined in the initial setup, peer discovery system 404 of client 403 displays client 401 in the user interface. If the current number of objects discovered by client 403 is greater than or equal to the target number specified in one or more filters in the initial setup, at least one filter is triggered. If at least one filter is triggered, peer discovery system 404 then determines whether client 401 meets the metric specified for each filter triggered. If client 401 meets the metric specified for each filter triggered, peer discovery system 404 of client 403 displays client 401 in user interface 409 . If client 401 does not meet the metric specified for each filter triggered, client 401 is ignored by peer discovery system 404 . Similarly, peer discovery system 406 of client 405 adaptively filters client 401 when the message is received through communication link 412 .
  • peer-to-peer environment 500 includes seven clients: client A 502 , client B 504 , client C 506 , client D 508 , client E 510 , client F 512 , and client G 514 .
  • client A 502 is the client of interest and initial setup 520 is the initial setup of client A 502 .
  • the user of client A 502 defines initial setup 520 , which includes two filters: filter 1 522 and filter 2 524 .
  • Filter 1 522 includes a target number of 5 and a metric of interest in sports.
  • Filter 2 524 includes a target number of 2 and also a metric of interest in sports.
  • peer discovery system running on client A 502 detects that there are six nearby clients: client B 504 , C 506 , D 508 , E 510 , F 512 and G 514 .
  • Peer discovery system first clears a CurrentFilterArray 523 , which is a data structure used to store filters triggered by the number of discovered clients.
  • peer discovery system of client A 502 checks the number of discovered clients against the target number specified in defined filters in initial setup 520 . In this example, since the number of discovered clients is 6, which is greater than the target number of 5 defined in filter 1 522 and the target number of 2 defined in filter 2 524 , both filter 1 526 and filter 2 527 are triggered and added to CurrentFilterArray 523 .
  • peer discovery system of client A 502 clears CurrentDisplayedObjectArray 525 , which is a data structure used to store discovered objects that meet metric requirements of filters in CurrentFilterArray 523 .
  • peer discovery system of client A 502 determines whether each discovered object meets the metric defined in the filter.
  • client B 504 meets metric specified in filter 1 526 , which has a common interest in sports.
  • client B 528 is added to CurrentlyDisplayedObjectArray 525 .
  • Peer discovery system of client A 502 determines whether client B 504 meets metric specified for the next filter in CurrentFilterArray 523 , which is filter 2 527 .
  • Client B 504 also meets metric of filter 2 527 , but client B 504 is already stored in CurrentlyDisplayedObjectArray 525 and therefore is not added.
  • Peer discovery system of client A 502 repeats the same process for client C 506 , D 508 , E 510 , F 512 , and G 514 .
  • client C 529 and client D 530 also meet metrics specified for filter 1 526 and filter 2 527 , and are therefore added to CurrentlyDisplayedObjectArray 525 .
  • peer discovery system of client A 502 completes determination of metric requirements for filters stored in CurrentFilterArray 523 , peer discovery system refreshes the user interface of client A 502 and displays all clients stored in CurrentlyDisplayedObjectArray 525 to the user of client A 502 .
  • peer-to-peer environment 531 As clients dynamically join and leave peer-to-peer environment 500 , a different peer-to-peer environment, peer-to-peer environment 531 , emerged.
  • Peer-to-peer environment 531 includes only four of the seven previous clients: client A 532 , client B 534 , client D 536 , and client F 538 .
  • Client A 502 maintains initial setup 520 as specified by the user.
  • peer discovery system of client A 532 detects only three nearby clients: client B 534 , D 536 , and F 538 .
  • Peer discovery system first clears CurrentFilterArray 523 and checks the number of discovered clients against the target number specified in filters of initial setup 520 . In this example, since the number of discovered clients is 3, which is greater than the target number of 2 defined in filter 2 524 , but less than the target number of 5 defined in filter 1 522 , only filter 2 541 is added to CurrentFilterArray 540 .
  • the present invention allows peer discovery system of client A 532 to trigger or deactivate filters dynamically as the number of discovered object changes.
  • filter 2 is added to CurrentFilterArray 540
  • peer discovery system of client A 532 clears CurrentDisplayedObjectArray 542 and determines whether each discovered object meets the metric defined in the filter 2 541 .
  • client B 534 and client D 536 meet metric specified in filter 2 541 , since both have common interests in sports.
  • client B 543 and client D 544 are added to CurrentlyDisplayedObjectArray 542 .
  • peer discovery system of client A 532 completes determination of metric requirements for filter 2 541 stored in CurrentFilterArray 540 , peer discovery system refreshes the user interface of client A 532 and displays all clients stored in CurrentlyDisplayedObjectArray 542 to the user of client A 532 .
  • the user of a client may define one or more filters to filter discovered objects when detected by the client.
  • the user may also define metric requirements for each discovered object for each filter, so that the peer discovery system may adaptively display relevant clients in the user interface.
  • the present invention dynamically triggers and deactivates the filter as the number of discovered objects changes.
  • FIG. 6 a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object is discovered is depicted in accordance with the present invention.
  • the process illustrated in FIG. 6 may be implemented in a data processing system such as computing device 200 in FIG. 2 or wireless communications device 300 in FIG. 3 .
  • the process begins when a new object is discovered by a client (step 602 ).
  • An object such as client 110 in FIG. 1 , may be discovered when the peer discovery system of a client sends a broadcast message to nearby clients.
  • the receiving client clears its current filter array (step 604 ), which is a data structure used to store filters triggered by the number of discovered clients.
  • the peer discovery system of the client checks the initial setup and makes a determination as to whether at least one or more filters are defined (step 606 ). If no filter is defined in the initial setup, the process continues to step 620 . If at least one or more filters are defined in the initial setup, the peer discovery system obtains the target number of discovered objects from the filter stored in the initial setup (step 608 ). Next, a determination is made by the peer discovery system as to whether the number of discovered objects is greater than or equal to the target number obtained in step 608 (step 610 ). If the number of discovered objects is greater than or equal to the target number, the filter is triggered (step 612 ). If the number of discovered objects is less than the target number obtained in step 608 , the process continues to step 616 .
  • the peer discovery system makes a determination as to whether any additional filter is defined in the initial setup (step 616 ). If additional filter is defined in the initial setup, the peer discovery system goes to the next filter defined in the initial setup (step 618 ) and the process continues to step 608 . If no additional filter is defined in the initial setup, the peer discovery system clears the currently displayed object array (step 620 ) and obtains each discovered object (step 622 ).
  • the currently displayed object array is a data structure used to store discovered objects that meet metric requirements of filters in the current filter array.
  • a filter is stored in the current filter array at step 614 when a filter is triggered at step 612 . If no filter is stored in the current filter array, the processor continues to step 630 .
  • the peer discovery system obtains the metric defined from the filter stored in the current filter array (step 626 ) and a determination is made as to whether the discovered object satisfies the metric defined in the filter (step 628 ). Examples of metric include number of previous interactions, type of hardware, and interest in sports. If the discovered object does not satisfy the metric, the process terminates thereafter. If the discovered object satisfies the metric, the peer discovery system adds the object to the currently displayed object array (step 630 ) and refreshes the display of the user interface to show all objects stored in currently displayed object array (step 632 ).
  • the peer discovery system may check the newly discovered object, after satisfying the metric, against the array to determine whether it is currently stored. If it is not stored, the discovered object may be added to the array.
  • FIG. 7 a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object disappears is depicted in accordance with the present invention.
  • the process illustrated in FIG. 7 may be implemented in a data processing system such as computing device 200 in FIG. 2 or wireless communications device 300 in FIG. 3 .
  • the process begins when an object disappears (step 702 ).
  • An object disappears for example, when a client leaves a peer-to-peer environment.
  • the object disappearance causes a decrease in the number of discovered objects.
  • the peer discovery system may obtain each object stored in the currently displayed object array and determines whether the object should be displayed.
  • the present invention provides advantages over current peer-to-peer systems by adaptively filtering and displaying relevant and manageable information to the user without restricting the users' interaction to their social networks.
  • the present invention dynamically adjusts display of discovered objects based on the number of discovered objects and automatically triggers or deactivates one or more filters as appropriate.
  • the present invention gives users control over what information is to be displayed.

Abstract

The present invention provides a method, apparatus and computer instructions for scaling a user interface adaptively to an object discovery or display system with policy driven filtering. A number of filters are defined by the user in an initial setup. The filter includes a target number of discovered objects and a metric for filtering discovered objects. Once the initial setup is complete, the present invention automatically triggers or deactivates the filters and dynamically applies one or more filters based on the number of discovered objects and rules defined by the user. Resulting discovered objects are displayed in the user interface to the user.

Description

    BACKGROUND OF THE INVENTION
  • 1. Technical Field
  • The present invention relates generally to an improved data processing system. In particular, the present invention provides a method and apparatus for displaying discovered objects to the user. Still more particularly, the present invention provides a method, apparatus and computer instructions for adaptively scaling a user interface to an object discovery/display system with policy-driven filtering.
  • 2. Description of Related Art
  • With the increasing use of mobile devices, such as cellular phones, pagers, laptop computers, personal digital assistants (PDAs), communications between users of these devices also increase. Communications are made to exchange information, such as, for example, emails, instant messages, images, and files. Conventionally, when a user wants to communicate with one another through the use of a mobile device, the user first tries to connect to a peer discovery system, which discovers all mobile devices that are within the range of a certain bandwidth. Common wireless communication protocols, such as bluetooth or wireless fidelity (Wi-Fi), are generally used for connecting these mobile devices. Bluetooth is a standard protocol, available from bluetooth SIG, for short-range radio links between devices. Bluetooth replaces links currently supported by many cables. Wireless fidelity (Wi-Fi) is a networking technology that uses IEEE 802.11a or IEEE 802.11b standard to provide fast, secure and reliable wireless connectivity. A peer-to-peer environment may use the above technologies to share information between devices or share an Internet connection.
  • When the mobile device is connected to the peer discovery system, available peers, meaning other mobile device users, are displayed in a user interface to allow the user to interact with the user's peers. However, as the number of available peers or discovered objects becomes large, it becomes difficult and unwieldy for the user to look through the large number of available peers for one with which to interact. This difficulty is magnified by the small displays that are available on most mobile devices, such as mobile phones and PDAs. Thus the issue of how to filter discovered objects in order to adequately display to the user becomes a problem.
  • Currently, existing object discovery or display systems often filter discovered objects using built-in rules, which the user has no control over. In addition, existing systems follow a pre-set order of filtering, where one rule follows another immediately without considering the dynamic nature of discovered objects.
  • Therefore, it would be advantageous to have an improved method, apparatus and computer instructions for scaling a user interface to an object discovery or display system with policy-driven filtering that allows users to define filtering rules and dynamically applies filters to discovered objects as appropriate.
  • SUMMARY OF THE INVENTION
  • The present invention provides a method, apparatus and computer instructions for scaling a user interface to an object discovery or display system with policy-driven filtering. The mechanism of the present invention allows users to define rules of filtering or policies, in order to filter the number of discovered objects to be displayed in a user interface.
  • The present invention allows a user to first define a number of filters to apply on discovered objects in an initial setup. The user then defines a target number of discovered objects and a metric for each filter.
  • Once the initial setup is complete, the present invention dynamically triggers or deactivates defined filters based on the number of discovered objects. If a filter is triggered, the present invention filters discovered objects according to the metric defined for the filter. The present invention then displays filtered discovered objects in the user interface. In the absence of a filter in the initial setup, none of the discovered objects are filtered.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
  • FIG. 1 is a pictorial representation of a peer-to-peer environment in which the present invention may be implemented in accordance with a preferred embodiment of the present invention;
  • FIG. 2 is a block diagram of a data processing system in which the present invention may be implemented;
  • FIG. 3 is an exemplary block diagram of a wireless communication device in which the present invention may be implemented in accordance with a preferred embodiment of the present invention;
  • FIG. 4 is a diagram illustrating components used for scaling adaptively to an object discover or display system with policy-driven filtering in accordance with a preferred embodiment of the present invention;
  • FIG. 5 is a diagram illustrating an example of adaptive scaling a user interface to an object discovery or display system with policy-driven filtering using the present invention in accordance with a preferred embodiment of the present invention;
  • FIG. 6 is a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object is discovered in accordance with the present invention; and
  • FIG. 7 is a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object disappears in accordance with the present invention.
  • DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT
  • As is known in the art, object discovery is typically performed in a peer-to-peer environment in which an object discovery or display system exists on at least two computing devices that communicate with one another by way of a wireless communication protocol, such as bluetooth or Wi-Fi. Therefore, in order to provide a context in which the present invention may be implemented, the following description of a peer-to-peer environment is provided.
  • With reference now to the figures, FIG. 1 depicts a pictorial representation of a peer-to-peer environment in which the present invention may be implemented. Peer-to-peer environment 100 is an exemplary environment in which the present invention may be implemented.
  • In the depicted example, peer-to-peer environment 100 includes clients 108, 110, and 112. These may be, for example, personal computers, network computers or personal digital assistants (PDAs). Peer-to-peer environment 100 also may include additional clients, and other devices not shown. Each client in peer-to-peer environment 100 may be connected to the Internet with network 102 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a backbone of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, government, educational and other computer systems that route data and messages.
  • In the depicted example, peer-to-peer environment 100 also includes communication links 120, 122 and 124. When client 108 connects to the peer discovery system, which resides on client 108, the peer discovery system tries to connect with other clients, such as client 110 and 112, through the use of communication links 120 and 122. Communications links 120 and 122 may be implemented in various forms, such as wire, wireless communication links, or fiber optic cables. In the depicted example, communication links 120 and 122 are implemented using bluetooth, which is a common wireless communication protocol. Similarly, client 110 and 112 are connected through the use of communication link 124, which is also implemented as a bluetooth connection.
  • Typically, a connection is made when the peer discovery system of a first client, such as client 110, broadcasts a User Datagram Protocol (UDP) message. This message is received by available clients over a local subnet. For example, the peer discovery system of a second client, such as client 112, receives the broadcast message and decides whether to make a connection with client 110. If client 112 accepts client 110 after filtering is performed, a connection is made. In the prior art, client 112 filters discovered objects, such as client 110, based on a set of established rules in the system and a set of pre-set orders to apply those rules. However, using the innovative feature of the present invention, the user of client 112 may create user defined rules to filter the clients to be displayed in the user interface. These rules may be based on the target number of objects and metrics, such as common interests, and type of hardware used.
  • Once a connection is made using communication links, such as communication links 120 and 122, the peer discovery system displays available clients 110 and 112 to client 108 in a user interface as discovered objects.
  • In addition to a wireless implementation, peer-to-peer environment 100 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN). FIG. 1 is intended as an example, and not as an architectural limitation for the present invention.
  • Referring to FIG. 2, a block diagram of a computing device that may be implemented as a client, such as clients 108, 110, and 112 in FIG. 1, is shown in which the present invention may be implemented. Computing device 200 is an example of a computer, such as a laptop computer or a workstation, in which code or instructions implementing the present invention may be located. Computing device 200 employs a peripheral component interconnect (PCI) local bus architecture. Although the depicted example employs a PCI bus, other bus architectures such as Accelerated Graphics Port (AGP) and Industry Standard Architecture (ISA) may be used. Processor 202 and main memory 204 are connected to PCI local bus 206 through PCI bridge 208. PCI bridge 208 also may include an integrated memory controller and cache memory for processor 202. Additional connections to PCI local bus 206 may be made through direct component interconnection or through add-in boards. In the depicted example, local area network (LAN) adapter 210, small computer system interface SCSI host bus adapter 212, and expansion bus interface 214 are connected to PCI local bus 206 by direct component connection. To contrast, audio adapter 216, graphics adapter 218, and audio/video adapter 219 are connected to PCI local bus 206 by add-in boards inserted into expansion slots. Expansion bus interface 214 provides a connection for a keyboard and mouse adapter 220, modem 222, and additional memory 224. SCSI host bus adapter 212 provides a connection for hard disk drive 226, tape drive 228, and CD-ROM drive 230. Typical PCI local bus implementations will support three or four PCI expansion slots or add-in connectors.
  • An operating system runs on processor 202 and is used to coordinate and provide control of various components within computing device 200 in FIG. 2. The operating system may be a commercially available operating system such as Windows XP, which is available from Microsoft Corporation. Instructions for the operating system and applications or programs are located on storage devices, such as hard disk drive 226, and may be loaded into main memory 204 for execution by processor 202.
  • Those of ordinary skill in the art will appreciate that the hardware depicted in FIG. 2 may vary depending upon the implementation. Other internal hardware or peripheral devices, such as flash read-only memory (ROM), equivalent nonvolatile memory, or optical disk drives and the like, may be used in addition to or in place of the hardware depicted in FIG. 2. Also, the processes of the present invention may be applied to a multiprocessor data processing system.
  • For example, computing device 200, if optionally configured as a network computer, may not include SCSI host bus adapter 212, hard disk drive 226, tape drive 228, and CD-ROM 230. In that case, the computer, to be properly called a client computer, includes some kind of network communication interface, such as LAN adapter 210, modem 222, or the like. As another example, data processing system 200 may be a stand-alone system configured to be bootable without relying on some type of network communication interface, whether or not computing system 200 comprises some type of network communications interface.
  • The depicted example in FIG. 2 and above-described examples are not meant to imply architectural limitations. Computing system 200 also may include any type of computing device that is capable of running an instant messaging client application without departing from the spirit and scope of the present invention. Examples of such computing devices include, but is not limited to, personal digital assistants (PDAs), laptop computers, network computers, wireless telephones, pager devices, and the like.
  • With reference to FIG. 3, an exemplary block diagram of a wireless communication device in which the present invention may be implemented is depicted in accordance with a preferred embodiment of the present invention. Wireless communication device 300 includes a processor 302 for controlling operation of the communication device and a memory 304. The processor 302 may be a general-purpose microprocessor operating under the control of instructions stored in memory, such as memory 304, or device-specific circuitry for controlling the operation of the telephone device. Processor 302 is connected by system bus 306 to transmitter 308, receiver 310, keypad 314, display 316, and audio processor 318. Keypad 314 may be a keypad and/or buttons. Display 316 may be any type of display device including a liquid crystal display (LCD) or other known displays, such as a cathode ray tube or active matrix display.
  • Transmitter 308 and receiver 310 are coupled to a telephone signal by couple 324 to provide full duplex communication. The telephone signal may be provided by a telephone line (not shown) in a land-based telephone or an antenna, such as for a wireless telephone. Audio processing circuit 318 provides basic analog audio outputs to speaker 320 and accepts analog audio inputs from microphone 322. Received signals are demodulated and decoded by receiver 310. Transmitter 308 encodes and modulates signals passed to it by processor 302 or audio processor 318. The output of the transmitter is amplified by power amplifier 312 to control the power level at which the signal is transmitted.
  • Processor 302 or audio processor 318 may detect audible call status information and call status codes received by receiver 310. Memory 304 may include a lookup table associating call status information or call status codes with visual call status information, such as text messages. Processor 302 detects or receives a call status code and displays an appropriate call status message on display 316. Those of ordinary skill in the art will appreciate that the hardware depicted in FIG. 3 may vary.
  • The present invention provides a method, apparatus and computer instructions for scaling a user interface adaptively to an object discovery or display system with policy driven filtering. The present invention allows a user to define an initial setup, which includes a number of filters for filtering discovered objects. For each defined filter, the user specifies a target number of discovered objects to be displayed and a metric for determining a peer's desirability. Examples of metric include common interests, prior interaction, and number of prior connections. An example filter may be used to show only objects with common interest in sports if the number of discovered objects is less than 20 or to show only objects that a user interacted before if the number of discovered objects is less than 30. Once the initial setup is complete, the present invention may dynamically determine which and how many discovered objects are to be displayed in the user interface.
  • In a preferred embodiment, upon detection of a new discovered object, the present invention checks the total number of discovered objects against the user-defined filters to see if one or more filters are triggered based on the target number of objects. A filter is triggered if the number of discovered objects is greater than or equal to the target number of discovered objects defined in the filter. In a similar manner, upon detection of a disappeared object, which decreases the number of discovered objects, the filter is deactivated if the number of discovered objects is less than the target number of discovered objects defined in the filter.
  • If at least one filter is triggered, the present invention applies the metric, if defined in the initial setup, for the given filter to each discovered object, in order to determine whether the discovered object should be displayed. If the object does not meet the requirements of the metric, the object is ignored. If the object meets the requirements of the metric, the present invention continues with the next triggered filter to determine whether the object meets the metric of the next triggered filter. Once the object meets metric requirements of all triggered filters, the object is displayed. Thus, each discovered object is checked against the metric of each triggered filter before being displayed.
  • In addition, the present invention provides a mechanism that dynamically triggers or deactivates filters as the number of discovered object changes. For example, a user may specify a basic filter with a target number of 10, a second filter with a target number of 20 and a third filter with a target number of 30. If the initial number of discovered objects detected is 15, the basic filter is triggered, since 15 is greater than 10. When the number of discovered objects detected is increased to 21, both the first and the second filter are triggered since 21 is greater than 20 and 10. When the number of discovered objects is again increased to 35, all three filters are then triggered since 35 is greater than 30, 20 and 10. When the number of discovered objects is reduced to 27, the first and second filters are triggered since 27 is greater than 20 and 10, however, the third filter is deactivated since 27 is less than 30.
  • Turning now to FIG. 4, a diagram illustrating components used for scaling adaptively to an object discover or display system with policy-driven filtering is depicted in accordance with a preferred embodiment of the present invention. As depicted in FIG. 4, the present invention may be implemented in a peer-to-peer environment, such as peer-to-peer environment 300 in FIG. 3. Peer-to-peer environment 400 includes peer discovery systems 402, 404 and 406. Peer discovery system 402 may be implemented on client 401, peer discovery system 404 may be implemented on client 403, and peer discovery system 406 may be implemented on client 405. Client 401, 403 and 405 may be implemented as client 108, 110 and 112 in FIG. 1. Client 401, 403 and 405 also include user interfaces 407, 409 and 411, which display filtered discovered objects.
  • In one example implementation, when client 401 wants to join peer-to-peer environment 400 to interact with other clients, client 401 connects to peer discovery system 402 through the user of user interface 407. Peer discovery system 402 sends a broadcast message over a local subnet using communication link 410 and 412, which may be implemented using common wireless communication protocol such as bluetooth and Wi-Fi. The message includes the IP address and port number of client 401, which provides the receiver client 401's identity.
  • Upon receiving the message from client 401, peer discovery system 404 of client 403 adaptively filters client 401 based on the user-defined initial setup. If no filter is defined in the initial setup, peer discovery system 404 of client 403 displays client 401 in the user interface. If the current number of objects discovered by client 403 is greater than or equal to the target number specified in one or more filters in the initial setup, at least one filter is triggered. If at least one filter is triggered, peer discovery system 404 then determines whether client 401 meets the metric specified for each filter triggered. If client 401 meets the metric specified for each filter triggered, peer discovery system 404 of client 403 displays client 401 in user interface 409. If client 401 does not meet the metric specified for each filter triggered, client 401 is ignored by peer discovery system 404. Similarly, peer discovery system 406 of client 405 adaptively filters client 401 when the message is received through communication link 412.
  • Turning now to FIG. 5, a diagram illustrating an example of adaptive scaling a user interface to an object discovery or display system with policy-driven filtering using the present invention is depicted in accordance with a preferred embodiment of the present invention. As depicted in FIG. 5, in this example implementation, peer-to-peer environment 500 includes seven clients: client A 502, client B 504, client C 506, client D 508, client E 510, client F 512, and client G 514.
  • In this example, client A 502 is the client of interest and initial setup 520 is the initial setup of client A 502. The user of client A 502 defines initial setup 520, which includes two filters: filter 1 522 and filter 2 524. Filter 1 522 includes a target number of 5 and a metric of interest in sports. Filter 2 524 includes a target number of 2 and also a metric of interest in sports.
  • When client A 502 receives broadcast messages from all other clients, peer discovery system running on client A 502 detects that there are six nearby clients: client B 504, C 506, D 508, E 510, F 512 and G 514. Peer discovery system first clears a CurrentFilterArray 523, which is a data structure used to store filters triggered by the number of discovered clients.
  • Based on initial setup 520 for client A 502, peer discovery system of client A 502 checks the number of discovered clients against the target number specified in defined filters in initial setup 520. In this example, since the number of discovered clients is 6, which is greater than the target number of 5 defined in filter 1 522 and the target number of 2 defined in filter 2 524, both filter 1 526 and filter 2 527 are triggered and added to CurrentFilterArray 523.
  • Once the filters are added, peer discovery system of client A 502 clears CurrentDisplayedObjectArray 525, which is a data structure used to store discovered objects that meet metric requirements of filters in CurrentFilterArray 523. Next, for each filters stored in CurrentFilterArray 523, peer discovery system of client A 502 determines whether each discovered object meets the metric defined in the filter. In this example, client B 504 meets metric specified in filter 1 526, which has a common interest in sports. Thus, client B 528 is added to CurrentlyDisplayedObjectArray 525.
  • Peer discovery system of client A 502 then determines whether client B 504 meets metric specified for the next filter in CurrentFilterArray 523, which is filter 2 527. Client B 504 also meets metric of filter 2 527, but client B 504 is already stored in CurrentlyDisplayedObjectArray 525 and therefore is not added. Peer discovery system of client A 502 repeats the same process for client C 506, D 508, E 510, F 512, and G 514. In this example, client C 529 and client D 530 also meet metrics specified for filter 1 526 and filter 2 527, and are therefore added to CurrentlyDisplayedObjectArray 525.
  • Once peer discovery system of client A 502 completes determination of metric requirements for filters stored in CurrentFilterArray 523, peer discovery system refreshes the user interface of client A 502 and displays all clients stored in CurrentlyDisplayedObjectArray 525 to the user of client A 502.
  • As clients dynamically join and leave peer-to-peer environment 500, a different peer-to-peer environment, peer-to-peer environment 531, emerged. Peer-to-peer environment 531 includes only four of the seven previous clients: client A 532, client B 534, client D 536, and client F 538. Client A 502 maintains initial setup 520 as specified by the user.
  • In this example, when client A 532 receives broadcast messages from all other clients, peer discovery system of client A 532 detects only three nearby clients: client B 534, D 536, and F 538. Peer discovery system first clears CurrentFilterArray 523 and checks the number of discovered clients against the target number specified in filters of initial setup 520. In this example, since the number of discovered clients is 3, which is greater than the target number of 2 defined in filter 2 524, but less than the target number of 5 defined in filter 1 522, only filter 2 541 is added to CurrentFilterArray 540. Thus, the present invention allows peer discovery system of client A 532 to trigger or deactivate filters dynamically as the number of discovered object changes.
  • Once filter 2 is added to CurrentFilterArray 540, peer discovery system of client A 532 clears CurrentDisplayedObjectArray 542 and determines whether each discovered object meets the metric defined in the filter 2 541. In this example, client B 534 and client D 536 meet metric specified in filter 2 541, since both have common interests in sports. Thus, client B 543 and client D 544 are added to CurrentlyDisplayedObjectArray 542.
  • Once peer discovery system of client A 532 completes determination of metric requirements for filter 2 541 stored in CurrentFilterArray 540, peer discovery system refreshes the user interface of client A 532 and displays all clients stored in CurrentlyDisplayedObjectArray 542 to the user of client A 532.
  • Thus, using the innovative features of the present invention, the user of a client, such as client A 502, may define one or more filters to filter discovered objects when detected by the client. The user may also define metric requirements for each discovered object for each filter, so that the peer discovery system may adaptively display relevant clients in the user interface. In addition, the present invention dynamically triggers and deactivates the filter as the number of discovered objects changes.
  • With reference to FIG. 6, a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object is discovered is depicted in accordance with the present invention. The process illustrated in FIG. 6 may be implemented in a data processing system such as computing device 200 in FIG. 2 or wireless communications device 300 in FIG. 3.
  • As depicted in FIG. 6, in this example implementation, the process begins when a new object is discovered by a client (step 602). An object, such as client 110 in FIG. 1, may be discovered when the peer discovery system of a client sends a broadcast message to nearby clients. Next, the receiving client clears its current filter array (step 604), which is a data structure used to store filters triggered by the number of discovered clients.
  • Then, the peer discovery system of the client checks the initial setup and makes a determination as to whether at least one or more filters are defined (step 606). If no filter is defined in the initial setup, the process continues to step 620. If at least one or more filters are defined in the initial setup, the peer discovery system obtains the target number of discovered objects from the filter stored in the initial setup (step 608). Next, a determination is made by the peer discovery system as to whether the number of discovered objects is greater than or equal to the target number obtained in step 608 (step 610). If the number of discovered objects is greater than or equal to the target number, the filter is triggered (step 612). If the number of discovered objects is less than the target number obtained in step 608, the process continues to step 616.
  • Continuing from step 612, if at least one filter is triggered, the peer discovery system makes a determination as to whether any additional filter is defined in the initial setup (step 616). If additional filter is defined in the initial setup, the peer discovery system goes to the next filter defined in the initial setup (step 618) and the process continues to step 608. If no additional filter is defined in the initial setup, the peer discovery system clears the currently displayed object array (step 620) and obtains each discovered object (step 622). The currently displayed object array is a data structure used to store discovered objects that meet metric requirements of filters in the current filter array.
  • Once a discovered object is obtained, a determination is made by the peer discovery system as to whether at least one or more filters are stored in the current filter array (step 624). A filter is stored in the current filter array at step 614 when a filter is triggered at step 612. If no filter is stored in the current filter array, the processor continues to step 630. If at least one filter is stored in the current filter array, the peer discovery system obtains the metric defined from the filter stored in the current filter array (step 626) and a determination is made as to whether the discovered object satisfies the metric defined in the filter (step 628). Examples of metric include number of previous interactions, type of hardware, and interest in sports. If the discovered object does not satisfy the metric, the process terminates thereafter. If the discovered object satisfies the metric, the peer discovery system adds the object to the currently displayed object array (step 630) and refreshes the display of the user interface to show all objects stored in currently displayed object array (step 632).
  • Once the display of the user interface is refreshed, a determination is made by the peer discovery system as to whether additional filters are stored in current filter array (step 634). If additional filters are stored in the current filter array, the peer discovery system goes to the next filter in the current filter array (step 636) and obtains the metric defined for the next filter (step 626). If no additional filters are stored in the current filter array, the process terminating thereafter.
  • For a more efficient operation, instead of clearing the currently displayed object filter array, the peer discovery system may check the newly discovered object, after satisfying the metric, against the array to determine whether it is currently stored. If it is not stored, the discovered object may be added to the array.
  • Turning now to FIG. 7, a flowchart illustrating an exemplary process for adaptively scaling a user interface to an object discovery or display system with policy-driven filtering when an object disappears is depicted in accordance with the present invention. The process illustrated in FIG. 7 may be implemented in a data processing system such as computing device 200 in FIG. 2 or wireless communications device 300 in FIG. 3.
  • As depicted in FIG. 7, in this example implementation, the process begins when an object disappears (step 702). An object disappears, for example, when a client leaves a peer-to-peer environment. The object disappearance causes a decrease in the number of discovered objects.
  • Next, a determination is made by the peer discovery system as to whether at least one or more filters are stored in the current filter array (step 704). If at least one or more filters are stored in the current filter array, the peer discovery system obtains the target number of the discovered objects from the filter stored in the current filter array (step 706). If no filter is stored in the current filter array, the process continues to step 716. Continuing from step 706, a determination is made by the peer discovery system as to whether the number of discovered objects is greater than or equal to the target number obtained in step 706. If the number of discovered objects is greater than or equal to the target number, the process continues to step 712. If the number of discovered objects is less than the target number, the filter is removed from the current filter array (step 710). The removal of filter deactivates the filter.
  • A determination is then made as to whether any additional filter is stored in the current filter array (step 712). If additional filter is stored in the current filter array, the peer discovery system goes to the next filter in the current filter array and obtains the target number of discovered objects defined in the next filter (step 706). If no additional filter is stored in the current filter array, the peer discovery system clears the currently displayed object array (step 716), which is a data structure used to store discovered objects that meet metric requirements of filters in the current filter array. Then, the peer discovery system obtains each discovered object (step 718).
  • When a discovered object is obtained, a determination is made as to whether at least one or more filters are stored in the current filter array (step 720). If at least one or more filters are stored in the current filter array, the peer discovery system obtains the metric defined in the filter (step 722). If no filter is stored in the current filter array, the process continues to step 726. Once the metric is obtained, a determination is made as to whether the discovered object obtained in step 718 satisfies the metric (step 724). If the discovered object does not satisfy the metric, the process terminating thereafter. If the discovered object satisfies the metric, the discovered object is added to the currently displayed object array (step 726) and the display of all objects in the currently displayed object array is refreshed in the user interface (step 728).
  • After the display is refreshed, a determination is made as to whether additional filters are stored in the current filter array (step 730). If additional filters are stored in the current filter array, the peer discovery system goes to the next filter in the current filter array (step 732) and obtains the metric in the next filter (step 722). If no additional filters are stored in the current filter array, the process terminating thereafter.
  • For a more efficient operation, instead of clearing the currently displayed object array, the peer discovery system may obtain each object stored in the currently displayed object array and determines whether the object should be displayed.
  • Thus, the present invention provides advantages over current peer-to-peer systems by adaptively filtering and displaying relevant and manageable information to the user without restricting the users' interaction to their social networks. In addition, the present invention dynamically adjusts display of discovered objects based on the number of discovered objects and automatically triggers or deactivates one or more filters as appropriate. By allowing the user to define initial setup, the present invention gives users control over what information is to be displayed.
  • It is important to note that while the present invention has been described in the context of a fully functioning data processing system, those of ordinary skill in the art will appreciate that the processes of the present invention are capable of being distributed in the form of a computer readable medium of instructions and a variety of forms and that the present invention applies equally regardless of the particular type of signal bearing media actually used to carry out the distribution. Examples of computer readable media include recordable-type media such a floppy disc, a hard disk drive, a RAM, and CD-ROMs and transmission-type media such as digital and analog communications links.
  • The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to best explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.

Claims (19)

1-18. (canceled)
19. A computer program product, comprising:
a computer recordable-type medium storing computer usable program code for adaptively scaling a user interface to an object discovery system, the computer program product comprising:
computer usable program code configured for receiving a user input to define a plurality of filters to filter discovered objects in an initial setup of a data processing system;
computer usable program code configured for detecting a change in a number of the discovered objects;
in response to detecting the change in the number of the discovered objects, computer usable program code configured for automatically triggering at least one filter of the defined plurality of filters, wherein the triggered at least one filter defines a target number of discovered objects to be displayed in the user interface and a metric for determining a desirability of displaying a discovered object in the user interface;
in response to automatically triggering the at least one filter of the defined plurality of filters, computer usable program code configured for filtering at least one discovered object of the discovered objects by the triggered at least one filter to form at least one filtered discovered object; and
computer usable program code configured for displaying the at least one filtered discovered object in the user interface.
20. The computer program product of claim 19, wherein the metric includes one of a number of previous interactions, a common interest or a type of hardware used.
21. The computer program product of claim 19, wherein the initial setup is defined by a user of the data processing system.
22. The computer program product of claim 19, wherein the computer usable program code configured for automatically triggering at least one filter of the defined plurality of filters comprises:
computer usable program code configured for comparing the target number of discovered objects with the number of discovered objects.
23. The computer program product of claim 19, wherein the computer usable program code configured for filtering at least one discovered object of the discovered objects comprises:
computer usable program code configured for determining whether the at least one discovered object satisfies the metric of the triggered at least one filter.
24. The computer program product of claim 19, wherein the computer usable program code configured for detecting a change in a number of the discovered objects comprises:
computer usable program code configured for receiving a message from at least one discovered object over at least one communication link.
25. The computer program product of claim 24, wherein the communication link includes a bluetooth or Wi-Fi connection.
26. The computer program product of claim 19, wherein the computer usable program code configured for automatically triggering at least one filter of the defined plurality of filters comprises:
computer usable program code configured for automatically deactivating the at least one filter of the defined plurality of filters in response to detecting the change.
27. The computer program product of claim 26, wherein the computer usable program code configured for automatically deactivating the at least one filter of the defined plurality of filters comprises:
computer usable program, code configured for comparing a target number of discovered objects with the number of discovered objects.
28. A data processing system for adaptively scaling a user interface to an object discovery system, comprising:
a bus system;
a storage device connected to the bus system, wherein the storage device includes a set of instructions; and
a processing unit connected to the bus system, wherein the processing unit executes the set of instructions to receive a user input to define a plurality of filters to filter discovered objects in an initial setup of the data processing system, detect a change in a number of the discovered objects, in response to detecting the change in the number of the discovered objects, automatically trigger at least one filter of the defined plurality of filters, wherein the triggered at least one filter defines a target number of discovered objects to be displayed in the user interface and a metric for determining a desirability of displaying a discovered object in the user interface, in response to automatically triggering the at least one filter of the defined plurality of filters, filter at least one discovered object of the discovered objects by the triggered at least one filter to form at least one filtered discovered object, and display the at least one filtered discovered object in the user interface.
29. The data processing system of claim 28, wherein the metric includes one of a number of previous interactions, a common interest or a type of hardware used.
30. The data processing system of claim 28, wherein the initial setup is defined by a user of the data processing system.
31. The data processing system of claim 28, wherein the processing unit executing the set of instructions to automatically trigger at least one filter of the defined plurality of filters comprises:
the processing unit executing the set of instructions to compare the target number of discovered objects with the number of discovered objects.
32. The data processing system of claim 28, wherein the processing unit executing the set of instructions to filter at least one discovered object of the discovered objects comprises:
the processing unit executing the set of instructions to determine whether the at least one discovered object satisfies the metric of the triggered at least one filter.
33. The data processing system of claim 28, wherein the processing unit executing the set of instructions to detect a change in a number of the discovered objects comprises:
the processing unit executing the set of instructions to receive a message from at least one discovered object over at least one communication link.
34. The data processing system of claim 33, wherein the communication link includes a bluetooth or Wi-Fi connection.
35. The data processing system of claim 28, wherein the processing unit executing the set of instructions to automatically trigger at least one filter of the defined plurality of filters comprises:
the processing unit executing the set of instructions to automatically deactivate the at least one filter of the defined plurality of filters in response to detecting the change.
36. The data processing system of claim 35, wherein the processing unit executing the set of instructions to automatically deactivate the at least one filter of the defined plurality of filters comprises:
the processing unit executing the set of instructions to compare a target number of discovered objects with the number of discovered objects.
US12/233,880 2004-01-05 2008-09-19 Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering Abandoned US20090013276A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/233,880 US20090013276A1 (en) 2004-01-05 2008-09-19 Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US10/753,185 US7472185B2 (en) 2004-01-05 2004-01-05 Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering
US12/233,880 US20090013276A1 (en) 2004-01-05 2008-09-19 Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/753,185 Continuation US7472185B2 (en) 2004-01-05 2004-01-05 Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering

Publications (1)

Publication Number Publication Date
US20090013276A1 true US20090013276A1 (en) 2009-01-08

Family

ID=34749356

Family Applications (3)

Application Number Title Priority Date Filing Date
US10/753,185 Expired - Fee Related US7472185B2 (en) 2004-01-05 2004-01-05 Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering
US12/233,880 Abandoned US20090013276A1 (en) 2004-01-05 2008-09-19 Method and Apparatus for Scaling a User Interface Adaptively to an Object Discovery/Display System with Policy Driven Filtering
US12/236,247 Expired - Fee Related US7774452B2 (en) 2004-01-05 2008-09-23 Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US10/753,185 Expired - Fee Related US7472185B2 (en) 2004-01-05 2004-01-05 Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering

Family Applications After (1)

Application Number Title Priority Date Filing Date
US12/236,247 Expired - Fee Related US7774452B2 (en) 2004-01-05 2008-09-23 Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering

Country Status (1)

Country Link
US (3) US7472185B2 (en)

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4682052B2 (en) * 2006-02-10 2011-05-11 キヤノン株式会社 COMMUNICATION DEVICE, COMMUNICATION METHOD, COMMUNICATION DEVICE CONTROL METHOD, AND COMMUNICATION SYSTEM
JP4886463B2 (en) 2006-10-20 2012-02-29 キヤノン株式会社 Communication parameter setting method, communication apparatus, and management apparatus for managing communication parameters
US8082507B2 (en) * 2007-06-12 2011-12-20 Microsoft Corporation Scalable user interface
JP5122201B2 (en) * 2007-07-24 2013-01-16 株式会社エヌ・ティ・ティ・ドコモ Mobile terminal and program
US8199671B2 (en) * 2008-06-09 2012-06-12 Hewlett-Packard Development Company, L.P. Throttling network traffic generated by a network discovery tool during a discovery scan
JP4803306B1 (en) * 2010-04-07 2011-10-26 ソニー株式会社 Battery pack and battery pack manufacturing method
KR20150092359A (en) * 2010-06-23 2015-08-12 퀄컴 인코포레이티드 Event-triggered peer discovery
US8605875B2 (en) 2011-02-24 2013-12-10 International Business Machines Corporation Dynamic call management and display
US9413906B2 (en) * 2012-09-28 2016-08-09 Interactive Memories Inc. Method for making relevant content proposals based on information gleaned from an image-based project created in an electronic interface
US10567566B2 (en) * 2012-10-16 2020-02-18 Nokia Technologies Oy Method and apparatus for providing mechanism to control unattended notifications at a device

Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5787252A (en) * 1995-11-01 1998-07-28 Hewlett-Packard Company Filtering system and method for high performance network management map
US6020876A (en) * 1997-04-14 2000-02-01 Immersion Corporation Force feedback interface with selective disturbance filter
US6233686B1 (en) * 1997-01-17 2001-05-15 At & T Corp. System and method for providing peer level access control on a network
US6389534B1 (en) * 1997-06-30 2002-05-14 Taher Elgamal Cryptographic policy filters and policy control method and apparatus
US20020062375A1 (en) * 2000-11-22 2002-05-23 Dan Teodosiu Locator and tracking service for peer to peer resources
US20020073075A1 (en) * 2000-12-07 2002-06-13 Ibm Corporation Method and system for augmenting web-indexed search engine results with peer-to-peer search results
US6421716B1 (en) * 1998-09-30 2002-07-16 Xerox Corporation System for generating context-sensitive hierarchically ordered document service menus
US20030067912A1 (en) * 1999-07-02 2003-04-10 Andrew Mead Directory services caching for network peer to peer service locator
US20040162871A1 (en) * 2003-02-13 2004-08-19 Pabla Kuldipsingh A. Infrastructure for accessing a peer-to-peer network environment
US7127493B1 (en) * 1998-08-20 2006-10-24 Gautier Taylor S Optimizing server delivery of content by selective inclusion of optional data based on optimization criteria
US7206841B2 (en) * 2001-01-22 2007-04-17 Sun Microsystems, Inc. Rendezvous for locating peer-to-peer resources
US7209949B2 (en) * 1998-05-29 2007-04-24 Research In Motion Limited System and method for synchronizing information between a host system and a mobile data communication device
US7272407B2 (en) * 2003-02-18 2007-09-18 Hewlett-Packard Development Company, L.P. Display on wireless mobile device
US7386588B2 (en) * 1998-05-29 2008-06-10 Research In Motion Limited System and method for pushing information from a host system to a mobile data communication device
US20110092221A1 (en) * 2009-10-16 2011-04-21 Michael Zubas Devices and Methods for Selectively Filtering Message Content

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6829615B2 (en) * 2000-02-25 2004-12-07 International Business Machines Corporation Object type relationship graphical user interface
US7519575B1 (en) * 2001-08-31 2009-04-14 Novell, Inc. Method and apparatus for presenting, searching, and viewing directories
US7627552B2 (en) * 2003-03-27 2009-12-01 Microsoft Corporation System and method for filtering and organizing items based on common elements
US7409644B2 (en) * 2003-05-16 2008-08-05 Microsoft Corporation File system shell

Patent Citations (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5787252A (en) * 1995-11-01 1998-07-28 Hewlett-Packard Company Filtering system and method for high performance network management map
US6233686B1 (en) * 1997-01-17 2001-05-15 At & T Corp. System and method for providing peer level access control on a network
US6020876A (en) * 1997-04-14 2000-02-01 Immersion Corporation Force feedback interface with selective disturbance filter
US6389534B1 (en) * 1997-06-30 2002-05-14 Taher Elgamal Cryptographic policy filters and policy control method and apparatus
US7386588B2 (en) * 1998-05-29 2008-06-10 Research In Motion Limited System and method for pushing information from a host system to a mobile data communication device
US7209949B2 (en) * 1998-05-29 2007-04-24 Research In Motion Limited System and method for synchronizing information between a host system and a mobile data communication device
US7127493B1 (en) * 1998-08-20 2006-10-24 Gautier Taylor S Optimizing server delivery of content by selective inclusion of optional data based on optimization criteria
US6421716B1 (en) * 1998-09-30 2002-07-16 Xerox Corporation System for generating context-sensitive hierarchically ordered document service menus
US20030067912A1 (en) * 1999-07-02 2003-04-10 Andrew Mead Directory services caching for network peer to peer service locator
US20020062375A1 (en) * 2000-11-22 2002-05-23 Dan Teodosiu Locator and tracking service for peer to peer resources
US20020073075A1 (en) * 2000-12-07 2002-06-13 Ibm Corporation Method and system for augmenting web-indexed search engine results with peer-to-peer search results
US7206841B2 (en) * 2001-01-22 2007-04-17 Sun Microsystems, Inc. Rendezvous for locating peer-to-peer resources
US20040162871A1 (en) * 2003-02-13 2004-08-19 Pabla Kuldipsingh A. Infrastructure for accessing a peer-to-peer network environment
US7272407B2 (en) * 2003-02-18 2007-09-18 Hewlett-Packard Development Company, L.P. Display on wireless mobile device
US20110092221A1 (en) * 2009-10-16 2011-04-21 Michael Zubas Devices and Methods for Selectively Filtering Message Content

Also Published As

Publication number Publication date
US20090019144A1 (en) 2009-01-15
US7472185B2 (en) 2008-12-30
US7774452B2 (en) 2010-08-10
US20050160261A1 (en) 2005-07-21

Similar Documents

Publication Publication Date Title
US7774452B2 (en) Method and apparatus for scaling a user interface adaptively to an object discovery/display system with policy driven filtering
US8898260B2 (en) Automatic multimedia upload for publishing data and multimedia content
US20180227322A1 (en) Near real-time detection of suspicious outbound traffic
CN105847168B (en) data transmission method, network server, user terminal and system
US10419968B2 (en) Dynamic selection of TCP congestion control for improved performances
WO2023155074A1 (en) Communication method and apparatus, electronic device, and storage medium
JP4546801B2 (en) Method for providing synchronization notification to client device
US20070242061A1 (en) Mobile auxiliary display model
CN110177128B (en) Data transmission system and method for establishing VPN connection, terminal and VPN proxy thereof
CN106155468B (en) Alarm display method and terminal
CN112272118A (en) Network repairing method, device, storage medium and electronic equipment
WO2023236972A1 (en) Communication environment security warning method and apparatus, terminal device, and storage medium
CN114071544B (en) Network testing method and device and electronic equipment
US7962099B2 (en) System and method for reducing radio frequency interference between a wireless communication device and a speaker
US20150056967A1 (en) System and method for community based mobile device profiling
CN106992893A (en) The management method and device of router
US20140219260A1 (en) Method and apparatus for communicating between mobile devices
CN110489657B (en) Information filtering method and device, terminal equipment and storage medium
GB2514093A (en) Receiving a communication event
CN113839859B (en) Message notification method and related device
JP2006254446A (en) Detection of supported network frequency to enable successful connection to wireless networks
US20050085187A1 (en) Wireless user note server apparatus, methods and computer program products and wireless terminals for use therewith
US20110221607A1 (en) Dynamic Device Adaptation Based on Proximity to Other Devices
JP3759137B2 (en) Wireless communication apparatus and impersonation terminal detection method
US20030023720A1 (en) System and method for remotely monitoring modem status

Legal Events

Date Code Title Description
STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO PAY ISSUE FEE