WO1999014926A1 - Information retrieval system - Google Patents

Information retrieval system Download PDF

Info

Publication number
WO1999014926A1
WO1999014926A1 PCT/GB1998/002544 GB9802544W WO9914926A1 WO 1999014926 A1 WO1999014926 A1 WO 1999014926A1 GB 9802544 W GB9802544 W GB 9802544W WO 9914926 A1 WO9914926 A1 WO 9914926A1
Authority
WO
WIPO (PCT)
Prior art keywords
user
retrieval
conference
users
user interface
Prior art date
Application number
PCT/GB1998/002544
Other languages
French (fr)
Inventor
Neil Finlayson
Original Assignee
British Telecommunications Public Limited Company
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 British Telecommunications Public Limited Company filed Critical British Telecommunications Public Limited Company
Priority to JP2000512338A priority Critical patent/JP2001517031A/en
Priority to EP98940372A priority patent/EP1016258A1/en
Priority to CA002303053A priority patent/CA2303053A1/en
Priority to AU88712/98A priority patent/AU743274B2/en
Publication of WO1999014926A1 publication Critical patent/WO1999014926A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/56Arrangements for connecting several subscribers to a common circuit, i.e. affording conference facilities
    • H04M3/567Multimedia conference systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/954Navigation, e.g. using categorised browsing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/16Arrangements for providing special services to substations
    • H04L12/18Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
    • H04L12/1813Arrangements for providing special services to substations for broadcast or conference, e.g. multicast for computer conferences, e.g. chat rooms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M7/00Arrangements for interconnection between switching centres
    • H04M7/006Networks other than PSTN/ISDN providing telephone service, e.g. Voice over Internet Protocol (VoIP), including next generation networks with a packet-switched transport layer
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2216/00Indexing scheme relating to additional aspects of information retrieval not explicitly covered by G06F16/00 and subgroups
    • G06F2216/15Synchronised browsing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2203/00Aspects of automatic or semi-automatic exchanges
    • H04M2203/50Aspects of automatic or semi-automatic exchanges related to audio conference
    • H04M2203/5009Adding a party to an existing conference
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2203/00Aspects of automatic or semi-automatic exchanges
    • H04M2203/50Aspects of automatic or semi-automatic exchanges related to audio conference
    • H04M2203/5027Dropping a party from a conference
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2203/00Aspects of automatic or semi-automatic exchanges
    • H04M2203/50Aspects of automatic or semi-automatic exchanges related to audio conference
    • H04M2203/5063Centrally initiated conference, i.e. Conference server dials participants
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/42221Conversation recording systems
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/42229Personal communication services, i.e. services related to one subscriber independent of his terminal and/or location
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M7/00Arrangements for interconnection between switching centres
    • H04M7/0024Services and arrangements where telephone services are combined with data services
    • H04M7/0027Collaboration services where a computer is used for data transfer and the telephone is used for telephonic communication

Definitions

  • Teleconferencing is used to describe a facility for allowing the sharing of information between two or more individuals at locations remote from each other, using telecommunications links for the purpose.
  • Teleconferencing facilities include the capability to support voice communication between the parties, with additional capabilities such as the transfer, between the parties to the call, of information in the form of data, text, video images (possibly, but not necessarily, of the parties to the call) etc, such that all parties to the call can study the same data.
  • the facility may be used for multi-way calls between three or more parties, but calls involving only two parties are not excluded.
  • a system is described in the present applicant's International Patent Specification W098/1 3995, published on 2 nd April 1 998, in which users connected together in a teleconference can share a URL with each other. This may be useful for instance when a person wants others with whom he is talking to see the same WWW page at which he is looking.
  • a user either manually types, or copies and pastes, the relevant text string into an HTML (hypertext mark-up language)-generated text box in a shared field to which all the users have access.
  • the shared field contents are made available to other users through a dynamically- generated hyperlink. All other users can then load the document referred to by the URL by clicking on the link.
  • an information retrieval system comprising at least two user interfaces, each user interface having means for accessing an information database system by means of retrieval commands, and wherein at least one, controlling, user interface has means for transmitting, to one or more of the other user interfaces, a signal containing a retrieval command, the other user interfaces being operable under control of the retrieval command signal to transmit the retrieval command to the information database to retrieve a specified item of data.
  • a method of controlling an information retrieval system comprising at least two user interfaces, each user interface having means for accessing an information database system by means of retrieval commands, wherein one, controlling, user interface transmits, to one or more of the other user interfaces, a signal containing a retrieval command, the other user interfaces operating under control of the retrieval command signal to transmit the retrieval command to the information database to retrieve a specified item of data.
  • a user can minimise the amount of data to be transferred between himself and other users, allowing one user to access the data from the correct address on behalf of all the others, without the need to individually generate the retrieval command.
  • This allows one user to take control of other users' user interfaces (for example WorldWideWeb browsers), thereby ensuring that all browsers stay in lockstep throughout an online meeting, seminar, lecture etc.
  • WorldWideWeb browsers for example WorldWideWeb browsers
  • this capability dramatically enhances the utility of the WorldWideWeb for group use, in both synchronous and asynchronous contexts.
  • Many types of application can be envisaged e.g. online business meetings, entertainment, and education.
  • the user interfaces are linked to each other by a server application.
  • the instructions sent from one user to the others by way of the server may be a search instruction, but in general will be the address of the item of information which is to be retrieved.
  • GUI graphical user interface
  • Figure 1 shows a diagram of the system platform and its context
  • Figures 2, 3, 4, 5, 6, and 7 relate to the prior system described in W098/1 3995, and will be discussed later
  • Figure 8 is a schematic representation of the teleconferencing environment within which the system operates
  • Figure 9 is a screenshot when running the system of the invention, with a Java "applet” running in the left-hand frame of a WorldWideWeb browser;
  • Figure 10 illustrates a mam window for the applet;
  • Figure 1 1 illustrates a browser window showing the requested URL in the right hand frame
  • Figure 1 2 is a flow diagram illustrating the processes by which one user controls the browsers of others; Figures 1 3, 1 4 and 1 5 illustrate in more detail the information flows between the client and server applications in the server.
  • Each user has a personal computer 100 and a telephone 1 1 5, connected, respectively through the "Internet” 105 and the normal telephone network (PSTN or ISDN) 1 1 0, with a server 1 20 under the control of an Acculab "Millenium CT" PC-based system 1 35, which provides the teleconferencing facilities to allow coordination between the various users, and between the telephone and internet connections, as described in detail in International Patent Specification W098/1 3995.
  • This teleconferencing system provides a management and control unit for a network-based teleconferencing system, the unit comprising: i) an interface for outputting control signals to a platform for establishing audio connections across a network between users;
  • the network is a telecommunications network while the interface for receiving control signals is an interface to a data network, such as the Internet.
  • a data network such as the Internet.
  • Preferred embodiments can then enable users to enjoy high quality audio- conferencing which they can manage using a World Wide Web screen-based interface.
  • Such embodiments can allow users to work on worldwide web based material yet not require that they i) set up calls via an operator, n) remember DTMF control codes, in) invest in new telephony hardware, or iv) install specialist software.
  • This system avoids the problem, particularly associated with carrying voice signals over packet-switched protocols, that voice quality is contingent upon both the bandwidth of the connection to each user being sufficiently large and the overall performance of the network being above a given threshold. This makes it difficult to guarantee an acceptable level of sound quality for all users at all times. There is also a problem caused by delays in digitally encoding speech from each user; this means that users hear their own voices repeated after a delay at the remote end(s) unless all users wear headphones Finally some service providers are seeking to ban, limit or charge extra for services which use demanding protocols such as Remote Procedure Calls (RPC).
  • RPC Remote Procedure Calls
  • the management and control unit can be supported by Internet-connected servers, such as a Web server for supplying documents, and a Java server for coordinating remote interfaces, whilst the graphical user interface may be provided at a client, also connected to the Internet.
  • the management and control unit can then provide a powerful and very versatile tool in providing audio-conferencing.
  • Conferencing systems can combine the ease of use of a GUI-based system whilst also leveraging the reliable voice quality associated with the phone network.
  • Such systems can impose minimum technical or cognitive requirements on each user and preferably use established protocols wherever possible.
  • the system can allow anybody who has simultaneous access to an Internet (or similar) connection, to provide the graphical user interface, and a separate directly diallable phone line to setup, control, record and clear down high quality teleconferences.
  • the database can be used to maintain updatable information specific to each user
  • This information can include for instance images of the users involved in a teleconference so that, whilst they are using the system, they can see annotated pictures of anybody else who is connected.
  • Teleconferences can be made private and users can change their outgoing telephone number when they move from one location to another
  • this system could be used with other information networks, for example a less extensive network than the Internet, such as a company "Intranet”. Tight integration between software running on the client, the associated WWW server, a teleconferencing platform and a database is possible.
  • a World Wide Web (WWW)-based graphical user interface (GUI) can control a teleconference using this system.
  • No additional software is necessary at the client and the system can be available to any user with a Transmission Control Protocol/Internet Protocol (TCP/IP) connection to the Internet and a phone line.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • the system can be made capable of keeping track of several parallel teleconferences each of which may involve several users.
  • Each user can be shown the appropriate information detailing where they are on the system as well as where others are; this information can be updated whenever changes relating to a given user occur.
  • Each user can preferably control aspects of the system which they have the privileges to change This should preferably be done without creating a conflict.
  • the system of the present invention is an application 170 which may run on any computer forming part of the user group, for example the same computer as that supporting the web server 1 20.
  • the Java server is built on an object- oriented client-server framework written in Java as outlined by David Flanagan [Java in a Nutshell, O'Reilly & Associates Inc.].
  • Java client applets communicate with the Java server 1 70 using "sockets" objects.
  • the job of the server 170 in the system of the invention is to synchronise communication between the applets, and to manage other client requests such as indicating which user is currently in control of the set of group Web browsers.
  • the server is basically responsible for managing state: users are members of groups, may move between groups, and may make use of group resources.
  • the system of the invention offers services which in several respects mirror those of PointCast, Marimba and other 'push' providers.
  • the crucial difference is that content organisation and management is delegated to each client, so that the users can freely control which Web resources are to be broadcast to the group.
  • Figure 8 shows a group of such users' computers 100, 101 , 102 linked through the internet 1 05 to a java server 1 70, which has the individual users identified as a user group by an attribute 1 60 stored in an address file 1 55 stored in the server
  • One user ( 100) is defined as the controlling user, again by means of a server attribute 1 65.
  • each user is identified by the same reference numeral as his or her respective user interface).
  • Each user 1 00, 1 01 , 1 02 has a respective browser program 1 50, 1 51 , 1 52, with which URLs of other websites 145 (only one shown) can be generated for accessing data from the website, again through the internet 105. They are also linked to a Java server
  • FIG. 9 the user currently having control of the system has loaded a pair of frames into Internet Explorer.
  • the left hand frame contains the program - a Java applet.
  • the right hand frame in this example is the target for all URL requests made by the applet.
  • the 'url-push' button in the left-hand frame is used to reveal the main window, shown in Figure 10.
  • Figure 1 2 is a flow diagram showing the main information flows taking place between the users and the server 170.
  • the three users 100, 101 , 102 are all connected as a user group, identified as such in the attribute list 1 55 of the server 170, with a first user 1 00 having control of the browsers 1 51 , 152 of the other users 101 , 1 02.
  • This control facility is stored as another attribute 1 65 in the server 1 70. It will be seen in Figure 1 6 that the attribute 1 65 may be transferred within the server from one user 100 to another 1 01 The user currently having the attribute 1 65 is the controlling user.
  • the main window contains the user interface.
  • Three text fields are used to organise URLs.
  • the controlling user 100 types or pastes URLs into the top text field which is editable (step 902). Pressing the 'Add URL' button results in the new URL being added to the list of URLs shown in the middle text field (step 903).
  • the program conducts an internal check that the URL is of valid construction, and warns the user if this not so (step 904).
  • the middle text field contains the list of URLs that the user wishes to show to other users in the group. Clicking on any URL in the middle field, or clicking on the up/down 'arrow' buttons transfers the URL to the bottom text field (step 905).
  • the controlling user 100 presses the "PushURL” button to drive the URL to the remote users' browsers 1 51 , 1 52 (step 906) .
  • the URL is rapidly distributed to all users (step 907).
  • the applet then forces each user's browser to load the requested URL (step 909), as shown in Figure 1 1 . All the users can then simultaneously view the results of loading the URL.
  • FIGs 1 3, 1 4 and 1 5 illustrate in more detail the processes which take place in the server and clients in order to load a new URL into each browser belonging to the group.
  • Each diagram shows a sequence of messages passed between various objects.
  • Fig. 1 3 illustrates themessage flow in the sender client applet up to the point where the URL is passed down the network to the server.
  • Fig. 14 shows what happens in the Java group-coordination server 1 70 in order to redirect the URL to all clients.
  • Fig. 1 5 shows the response of a receiving applet to the URL pushed at it from the server.
  • the client-server architecture used can be replaced by an architecture in which the applets and application communicate via distributed objects through remote-method-invocation (RMI), CORBA or similar process.
  • RMI remote-method-invocation
  • the Java group-coordination server 1 70 co-ordinates the client user interfaces by allocating connection "objects" 71 2, 71 5 (see Figure 14) to each client. Service requests from the clients 100, (101 , 102) are passed through these connection objects. URLs are broadcast to the group of which the user is currently a member (defined by a connection vector object 714), and the client processors ( 1 01 , 102) then change the page in the user's browser (also defined as an "object” 723). Other objects in the transmitting user's set-up 100 define the URL "push" button on the display of the user 1 00 (object 701 ), the user interface (702), the text field (703), the client (705) and the output (706) .
  • the server 1 70 has objects defining the server itself (71 1 ), the sending user 100 (object 71 2), and the data input (71 3), and the receuivmg user has an object defining the input (object 721 ).
  • Other objects 704, 722 are created during the process.
  • Figure 1 3 illustrates the transmission of a URL from a user 100 to the server 1 70, for onward transmission to other users 101 , 102.
  • this button in practice, by “clicking” on it with his “mouse"
  • a "push URL button” object 701 transmits this event to a browser control interface frame 702
  • This frame 702 is configured to monitor for such an event, and on detecting it (step 802) generates an instruction to send the URL to the server (step 803) .
  • This causes the interface frame 702 to obtain the URL character string from the text field (object 703) and generate a new object "url” (704) (steps 804, 805).
  • This string is then written to the client object 705 (step 806) and thus to an output object 706 (step807)
  • Figure 1 4 shows how the server 1 70 reads URL requests received from one user 100 and routes them out to other client objects 101 , 102.
  • the server object 71 1 and sender's connection socket object 71 2 are set to run (steps 81 1 , 81 2).
  • the connection On receiving a character string the connection sends a message (step 81 3) to an input object 71 3 which in turn instructs the server object 71 1 to control the connection set-up objects 71 4 (step 81 5) and then transmit the URL instruction to each connection 71 5 (step 81 6)
  • Figure 1 5 shows how the receiving "client” 1 01 , 102 responds to such an instruction. Whilst the listener object 721 is set to run (step 821 ) it obtains any URLs transmitted to it from the server 1 70 (step 822). Any such URL is used to create a new "url" object 722 (step 823) which is transmitted to an Applet context object 723, namely the web browser 1 20, causing it to load the URL and access the data required.
  • FIG. 6 shows the process employed when one of the remote users ( 101 ) wishes to take over control from the current controlling user 100.
  • the user 101 transmits a control request (step 910) to the user 100, this request being stored as an attribute of the requesting user in the attribute list 1 55 of the server 1 70.
  • the controlling user's computer 100 On receiving such a control request (step 91 1 ) the controlling user's computer 100 will display the request
  • the controlling user 100 may have the authority to refuse such a request (step 91 2) in which case a message is transmitted to the server 170 and thus to the remote user 101 communicating the refusal.
  • the server 1 70 modifies the existing application objects in the attribute list 1 65 relating to the current controlling user 1 00 and the remote user 1 01 (step 91 3), to record the requesting user 1 01 as the current controlling user and to remove that attribute from the user 100.
  • the user 1 01 has now become the controlling user and can proceed as described above with reference to Figure 1 2 (step 914).
  • the attribute list may allow some users to refuse a control request 910, and others to be required to relinquish control on request from any, or a specified subgroup, of the other users. For example, in Example 2, discussed below, individual participants 101 , 1 02 may be allowed by the initially controlling user 1 00 to take control, but cannot refuse to return control to the controlling user 1 00 when he requests it.
  • the controlling user 100 retains control throughout.
  • a remote user 101 may prepare a URL, and transmit that URL, by way of the server 1 70 (step 901 ) to the controlling user 100.
  • the controlling user may choose to select or refuse a proposed URL (step 902) and, if selecting the URL, will then add it to the list (step 903) as described above with reference to Figure 1 2
  • the process then continues as described with reference to Figure 1 2.
  • the controlling user 100 retains control, "pushing" URLs generated by other users 101 , 102.
  • the controlling user interface 1 00 may use its internal timer to transmit a sequence of "push" commands to control the remote browsers 1 51 , 1 52 such that a sequence of pages may be downloaded to the browsers at a fixed rate.
  • the controlling user 1 00 may also store URLs or sequences of URLs for each user group in a database 1 25, for playback. This can be augmented by audio recordings of group conversations or other teleconference elements, as described in the earlier application.
  • the system of the invention can be exploited in any situation where groups of people distributed over a Wide Area Network need to share visibility of Web pages.
  • Four example scenarios will now be described, with reference to Figure 8. For simplicity, the same reference numerals will be used for analagous performers in these scenarios, but it will be appreciated that different websites and users will be fulfilling these functions in each example scenario.
  • the customer ( 1 01 ) wishes to obtain a mortgage. She checks the WorldWideWeb, and finds that there are a large range of options advertised, some of which offer online financial analysis of her situation. Due to flaws in the design of Web service, or because of safeguards required by the financial services industry to prevent customers making decisions purely on the basis of on-line information, without professional advice, she does not have the URLs needed to "drill-down" from the high-level websites to some key URLs which could prove advantageous to her.
  • the server 170 receives a "push" request from the sales representative's browser 1 51 (step 906), it transmits it (step 907) to any browser identified in the server's attribute list as being linked to the browser 1 50, namely the customer's browser 1 51 .
  • the browser 1 51 On receiving the URL from the sales representative, (step 908) the browser 1 51 , like the browser 1 50, can access the data from the website 145 (step 909).
  • the sales representative can now lead the customer through a series of web pages not otherwise accessible to the customer, the necessary access passwords being included in the URLs transmitted to the customer's browser 1 51 for the purpose, but not being stored by, or known to, the customer 101 herself.
  • the sales representative can offer step-by-step advice to the customer on how to perform the online analysis of her financial situation. When the customer is satisfied with the results she can sign up for the mortgage.
  • a football club having a website 145, wishes to broaden the scope of its match- day media offerings to its supporters. It signs up a radio station (user 100) to deliver multiple telephony/Internet talk-shows linked to live broadcast match commentary, using the telephone/internet interface shown in Figure 1 .
  • the radio station ( 1 00) offers the services of talk-show hosts who are able to select music and sound clips to be played over the telephone in traditional disc jockey fashion, but who are also able to select photographs and other data relating to the match from the website 145 (steps 902-905), and push them to the supporters 101 , 102 (steps 906-908) using the system of the invention, so that the photographs etc can form the context for the supporters' conversations.
  • the supporters 101 , 102 can also access data and photographs (steps 900, 901 ) for submitting to the host for transmission to the other supporters (steps 902, 903: Figure 1 7), so that the supporters can control the context for their discussions under the overall supervision of the host 100.
  • the host 100 may allow one supporter 101 to take control and transmit "push" commands to the host 100 and other supporters 1 Q2 (steps 910- 91 4) himself.
  • a tutor ( 100) can push individual pages (145) from the vast educational resources of the Web to her students ( 101 , 102), located remotely, as they discuss a research project together.
  • each participant's website 1 00, 101 , 102, 145 etc
  • the chairmanship role can be transferred to another participant 1 01 during the teleconference (steps 910-914: Figure 1 6), for example if that other participant 1 01 is to make a presentation to the teleconference.
  • Figure 2 shows a schematic diagram of the server side architecture for the system shown in Figure 1 ;
  • Figure 3 shows a graphical user interface for use at a client browser for the system of Figure 1 .
  • Figures 4, 5, 6 and 7 show functional breakdowns of objects for use in an application residing on a server in a system as shown in Figure 1
  • each user has a personal computer 1 00 with an Internet IP connection 105, and a web browser application which supports HTML3.2 (or later), together with Frames and either Javascript or Jsc ⁇ pt. They must also have a separate telephony connection 1 1 0 with a telephone 1 1 5 which can be directly dialled. Possible network configurations to support this include the use of
  • PSTN Public Switched Telecommunications Network
  • ISDN Integrated Services Digital Network
  • LAN Local Area Network
  • PBX Private Branch Exchange
  • a Worldwide Web server 1 20 which can dynamically produce HTML pages by Simple Query Language (SQL) based reference to a database 1 25. It can also write information to the database 1 25.
  • SQL Simple Query Language
  • the WWW server 1 20 is also connected via a RFC1006 socket level connection 220 to an Acculab Millenium CT (RTM) platform 1 35.
  • RTM Acculab Millenium CT
  • This is a PC-based device, described in copending British patent applications 961 9958.3 filed on 25th September 1 996 and 970771 2.7 filed on 1 6th April 1997 by the same applicant, the contents of which are incorporated herein by reference, which has a number of capabilities including the ability to set up, control and record audio conferences. Prior to its launch as a product it was known as Minor Applications Platform (MAP) .
  • MAP Minor Applications Platform
  • the Millenium CT is connected between a telecommunications network, such as the Public Switched Telecommunications Network (PSTN), and a data network, such as the Internet.
  • PSTN Public Switched Telecommunications Network
  • data network such as the Internet.
  • It accepts incoming service requests over the PSTN via an 1SDN30 connection 1 40. It can also accept incoming service requests in other ways, for instance via a RFC1006 socket level connection as mentioned above. In this case, the protocol will be implemented on both sides of the socket level link. It also provides processing capacity and it can respond to an incoming call or message by identifying and launching an appropriate computing application which calls on and manages resources to run the service requested.
  • the Millenium CT 1 35 is equipped with means for providing audio bridges between conference participants, in the form of digital line interface cards and controls therefor. Additionally, the Millenium CT provides speech related resources, such as recording and delivery. It therefore can provide facilities which are important in communicating with a user during conference set-up and for recording.
  • any device which can accept and send commands over a network connection and use these commands to generate and record audio conferences could be used as an alternative to the Millenium CT. It should be noted there are also a number of equivalent link protocols which could be used in substitution for ISDN30.
  • the Server 1 20 may be any workstation with a WWW server and an object- oriented development environment providing integrated database access.
  • the system shown in Figure 2 provides a "WebRex” (TM) WWW server 1 20, an "Oracle” (TM) database 1 25, and a “NextStep” (TM) operating system, and four objects.
  • the server 1 20 supports an application comprising four objects. These objects 200, 205, 210, 21 5, are further described below. Functions within the objects are called from other objects by name; the NextStep operating system automatically generates the messages interchanged between the objects in a manner similar to Remote Procedure Calls (RPC).
  • RPC Remote Procedure Calls
  • the MAP object 205 The MAP object 205
  • the RFC 1 006 protocol (running over TCP/IP) is implemented in the MAP object 205 and on the Millenium CT 1 35 to provide a reliable peer-to-peer protocol for message passing
  • the MAP object queues a request in a CONFERENCE-REQUEST database table (further discussed below under "The Database”).
  • An initial (HTML) response is sent back to the client indicating that a request is being processed.
  • the MAP object 205 is implemented as an event driven state machine since the requests usually require a number of messages to be interchanged with the
  • the state of the request is stored in the CONFERENCE REQUEST database table entry (further discussed below under "The Database").
  • the MAP object 205 polls the CONFERENCE-REQUEST table for user requests frequently (for instance once every 5 seconds) . Once a request is found, the command sequence is initiated by sending the first command to the Millenium CT 135.
  • the Millenium CT 1 35 polls the Millenium CT 1 35 for a response at regular intervals (for instance once every second); once a response is received the MAP object 205 identifies which conference the response refers to (from a conference number field in the response). It then determines the current state from the request stored in the CONFERENCE REQUEST table and issues the next command to the Millenium CT
  • the messages sent to the Millenium CT 1 35 are: Register Platform (establishes a TCP/IP connection)
  • the Database Interface object 210 This may more simply be called the Database object 210. It provides functions for use by the application and MAP objects 200, 205. The functions store and retrieve information about the people who are using the system and the audio-conferences in an Oracle database 1 25. The functions use embedded SQL.
  • the Millenium CT 1 35 is provided with an application which can receive commands from the MAP object 205 and respond by supplying the functions required. These are for instance establishing audio bridges between the conference participants, delivering speech messages, such as "Please wait", and recording and storing sound for later access.
  • the form of such an application of course is adapted to receive and respond to the messages set out above under "Millenium CT Object 205", and this determines the functionality of the Millenium CT application.
  • the application will be compatible with the operating system of the Millenium CT 1 35 which may for instance be UNIX but could be another operating system.
  • the database 1 25 is used to store information about people using the system and about audio conferences. Any relational or object-oriented database is sufficient though the present system uses an Oracle database accessed using Simple Query Language. This is called from functions in the application and Database objects 200, 210. Oracle sequences are used to generate unique conference numbers.
  • the tables used in the Oracle database are as follows:
  • the database 1 25 holds information which includes the name, phone number and image of each user who is registered with the system. A registered user logs onto the system by starting up their browser 100 and then submitting a request for the system's access URL to the server 1 20.
  • the user's browser 100 uses the javascript "OpenWmdow" command to open up a main window as well as a smaller secondary window 300 which represents the 'meeting-place' .
  • the on-line status field in the PERSON table in the database 1 25 is set to a value of 1 to indicate that they are logged in and their 'heartbeat' is initiated (see under "The Heartbeat process” below) by setting the heartbeat field in the PERSON table for this person to the current time to initiate the heartbeat process.
  • the meeting-place window 300 consists of 4 frames.
  • a column 305 on the left shows a scrollable list of people who are logged on to the system. Beneath this, there is a very small frame 310 which is used to control the update process.
  • a main frame 31 5 which provides details about either a person or a conference.
  • a smaller frame 320 which contains controls for recording the conference, setting privacy or sharing URLs.
  • the application object 200 achieves this by retrieving a list of those who are in the CONFERENCE and PERSON CONFERENCE tables in the database 1 25. It also gets a list of those who are logged on but not in a conference by looking at who has an on-line status of 1 in the PERSON table.
  • the Meeting-place User Interface appears as a window 300 generated by a user's web browser on their personal computer 100
  • Figure 3 shows a point where a user (Philip) has just clicked on the 'ROOM 1 7' link in the logged-on frame 305. This causes the system to show images of Andrew and Debra who are currently talking in this room by accessing the tables in the database 1 25.
  • An icon 325 in the room frame 31 5 also shows that the conference is being recorded.
  • User 'Andrew' has just logged onto the system so the Butler process is showing an indicator 335 adjacent to his name. Selecting the 'Enter Room 17' button causes the system to call up Philip's number and add him in to the conference.
  • the server 1 20 queues the request in the CONFERENCE-REQUEST table.
  • the MAP object 205 subsequently retrieves the request from the table, creates entries in the CONFERENCE and PERSON-CONFERENCE tables, and instructs the Millenium CT 135 to set-up the conference using the following commands:
  • the calls generated by the system are connected together into a telephony based audio-conference and both entries in the PERSON table are updated with the conference number.
  • the MAP object 205 updates the status field (to indicate success) in the CONFERENCE-REQUEST table in the database 1 25.
  • the originator Whilst the conference is being established, the originator is shown a screen of cycling dots (generated by an animated GIF graphic) asking them to wait. Meanwhile a small secondary frame is reloaded using the client-pull HTML construct (for instance every 5 seconds).
  • the server receives a reload request, it inspects the status in the CONFERENCE-REQUEST table. If the status indicates the conference has been set-up, it returns HTML to the updated frame which causes the entire layout of the window to be reloaded.
  • This mechanism thus updates the meeting-place windows 300 of both people to show they are connected in a conference and deletes the request from the CONFERENCE REQUEST table. All other people who are connected to the system also have their meeting-place windows updated to show that the conference is in progress. This is achieved by updating the 'dummy' person entry in the PERSON table with the current time to indicate that the displays should be updated (see “The Update Process” below for details).
  • the rooms frame in the meeting place will inform the user that no telephone has been associated with the machine that they are using. (Note: cookies are set to have a fixed life, for example one year, after which they expire.)
  • the rooms frame will then invite the user to choose a telephone by selecting from a pop-up menu of numbers which are allowable for that particular user. (This page is generated dynamically from information in the ADDRESS table in the database.)
  • a cookie will be written with the information and the frame will reload to show the user's personal information with their new dialback number.
  • the system During initial logon, if the system detects that a cookie has been previously set, it will automatically assign the number from this cookie to the user for the duration of the session. Since the cookie setting activity need only be done rarely, it is possible for a system administrator to tour all machines which will be used and set cookies for each one. In this way, the end user need never have to go through the above process.
  • the user joins an existing conference by clicking on a text link denoting the conference's number. They are then shown the list of participants in the conference. There is also a button which gives the person the option to join the conference.
  • the server 1 20 queues the request in the CONFERENCE-REQUEST table.
  • the MAP object 205 subsequently retrieves the request from the table, creates a new entry in the PERSON-CONFERENCE table, and instructs the Millenium CT 135 to set-up the conference using the following commands:
  • the system starts by making an outgoing call to the person.
  • the person answers the call they are played a message telling them that they are being added to the conference. Whilst the conference is being established the person is shown a screen of cycling dots asking him or her to wait. Meanwhile a small secondary frame is reloaded using the client pull HTML construct (for instance every 5 seconds).
  • the server receives a reload request it inspects the status in the CONFERENCE-REQUEST table. If the status indicates that the conference has been established, it returns HTML to the updated frame which causes the entire layout of the window to be reloaded.
  • This mechanism thus updates the meeting-place windows of both people to show they are connected in a conference and deletes the request from the CONFERENCE-REQUEST table. After a short delay they are added in to the conference and the request is deleted from the CONFERENCE- REQUEST table.
  • the arrival of a new user in a conference is indicated with a short auditory tone, by the temporary display of an indicator such as a coloured dot adjacent to the names of any users who are newly arrived on-line (see the "Butler process" described below) and by the updating of the meeting-place screen 300 of all users.
  • Those users who are in the room in question are shown an image of the person who has just joined. If they move their mouse cursor over this image they are shown the person's name in the status bar of the window.
  • Users may continue to join a conference until it has grown to the maximum size allowable by the system (30 people in the embodiment being described here) . Whenever more than 8 people are present in the same conference the display is changed to show only the names of users rather than their pictures.
  • Users who are already in an established conference can choose to invite other people who are logged on to the system to take part as well. They do this by clicking on the name of such a person in the logged-on frame (only the names of people who are not logged in to a conference are shown as active HTML links at this time). When the person's name is clicked, the user is shown a confirm message in the control frame If they confirm that they do indeed want to invite the person into the conference, the system will initiate a call to that person and try to add them to the conference.
  • a conference continues to exist as long as more than one person is in it. Users can leave a conference at any time by pressing a button on the meeting-place window 300. When this happens, the Millenium CT 1 35 is sent the "Call Clear” command to clear the call, causing the Millenium CT 1 35 to drop the phone connection. The meeting-place 300 is then updated to show the person is no longer in the conference. This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see “The Update Process” below).
  • the Millenium CT 1 35 disconnects the last person if there is only a single person left in a conference after someone has left Once the last person has been disconnected, the MAP object sends a 'conference registration' command to the Millenium CT 1 35 to de-register the conference The meeting-place windows 300 of all users are then updated.
  • the update process works by using the client-pull HTML construct from within a small frame 310 in the meeting-place window 300. Every few seconds (for instance every 1 5 seconds) this window is set to"update".
  • the server 1 20 receives an update request from the update frame 310, it compares the time and date when it last received an update request from the update frame 310 for this user (this is called the heartbeat - see "The Heartbeat Process” below) with the time the meeting-place was last changed. If the information to be displayed has changed since the last time, then a new version of the update page is sent back.
  • the advantage of this approach is that it does not increase traffic to the server, load on the client or visual distraction for the user by reloading all the frames even when nothing applicable to that user has changed. On the other hand it does not require multiple channels to be kept open for each user in the way that a protocol such as "server push" does.
  • the update requests are also used as a 'heartbeat' function which lets the server know the user is still logged in ('alive').
  • the Heartbeat object 21 5 running on the server 1 20 polls the database 1 25 frequently (for instance every 30 seconds). If the heartbeat value in the PERSON table for this user is over a minute old, the heartbeat object 21 5 deems that the user has closed down their meeting-place 300 and left the system. In such cases the user is logged out by updating their online status field in the PERSON table. That user will no longer appear as being on- line in other users' meeting-places.
  • a user When users are connected together in a conference they can share a URL with each other. This may be useful for instance when a person wants others who they are talking with to see the same WWW page that they are looking at.
  • a user either manually types or copies and pastes the relevant text string into an HTML generated text box in the control frame 320 of the meeting-place 300. The user then either presses the 'return' button or activates a 'share URL' button. This causes the URL to be associated with the user for the rest of the conference by storing this URL in the PERSON table for that user. This is indicated visually in the meeting place window 300 of all conference participants by showing a small graphic with the word 'link' beneath the image 330 of the sending user. This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see "The Update Process" above).
  • the colour of the link graphic changes to show that a new link has been specified for that person (this is also stored in the PERSON table).
  • Others in the conference can click on a link graphic to see the associated URL opened up in a new window on their browser.
  • the originator's meeting-place 300 has an additional icon 325 which allows them to record the conference If the originator drops out of the conference leaving others talking, then the recording control is passed to whoever has been in the conference for the next longest time.
  • the idea behind this approach is to avoid conflicting requests for starting and stopping a recording that may be generated if all users have their own recording control.
  • all participants in a conference may have an icon which allows them to record the conference.
  • a person presses the 'start recording' button they are prompted to give the recording a name and to type this into a text entry box.
  • the recording has a separate, system-generated unique name so it is not mandatory that the user give the recording a unique name).
  • the user then submits the recording name using a button.
  • a recording request is then queued with the server 1 20 requesting that the conference be recorded.
  • the MAP object 205 then sends the Millenium CT 1 35 the 'Record Start' message to start recording the conference. Whilst the recording is being initiated, the person is shown the screen of cycling dots asking them to wait. When the recording is started the request is deleted from the CONFERENCE-REQUEST table.
  • the start of the recording is indicated to the users with an auditory tone and a short voice announcement made to the conference.
  • the recording button in the person's meeting-place is replaced by an animated 'record ⁇ ng- ⁇ n-progress' icon (this is pressed again to stop recording).
  • Other users are shown an animated icon indicating that a recording is taking place. This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see “The Update Process" above).
  • the MAP object 205 will automatically stop a recording if the last person leaves a conference and the originator has not specifically stopped the recording. The recording will still be saved in these circumstances.
  • the Millenium CT 1 35 stores the recording as a 64Kbps PCM encoded speech file.
  • the file is subsequently converted and placed on the WWW server where it can be listened to by the conference participants.
  • the file is converted into "RealAudio 3" format thus allowing long sound files to be heard without having to first download the entire file to their computers.
  • Pages on the system can contain links to the RealAudio files representing previously recorded conversations. Since the system uses a database to build HTML pages dynamically it is possible to provide the link to the sound file in the context of a page which indicates when the recording was made, who originated it, and who took part in it. This is achieved by storing this information in the database when the 'Record Save' message is sent to the Millenium CT 135.
  • the system In addition to recording a conference it is possible to use the system to record one's own voice only. This feature can be used for recording voice messages or for pronunciation exercises for example. Whenever a user is on line but not in a conference they have the option of clicking on the 'Record' button in the control frame of the meeting place. When they do this they are prompted to give the recording a name and to type this into a text entry box (the recording has a separate system generated unique name so it is not mandatory that the recording be named with a unique identifier). Once a name has been submitted to the system an outgoing call is initiated to the user's number and they are placed in a private (or "single user") conference in which they are the only participant.
  • the MAP object 205 then sends the Millenium CT 1 35 the 'Record Start' message to start recording the conference.
  • the user hears a voice announcement shortly after the start of the conference to tell them that recording has begun. They also are shown an animated 'recording' icon
  • the user When the user has finished making their recording they can press the animated recording button to stop the recording. This is achieved by sending the Millenium CT 1 35 a ' Record Stop' message. At this stage they are shown a series of icons which allow them to play back, delete, or save the recording. If they choose the 'Play' icon, the 'Playback start' message is sent to the Millenium CT 1 35 and the recording is played back to the user over the phone connection from the beginning. Whilst this is happening the play icon is replaced with an animated version. When the recording reaches the end of playback it loops to start from the beginning again. If the user selects the animated play icon then playback stops. If the user selects 'Save' then the recording is saved to RealAudio format.
  • the system aims to give users the greatest opportunity to see who else is logged on to the system whilst also protecting people from unwanted instrusion. This is done by allowing individuals to set their status as 'Do not disturb' and by letting the originator of a conference set up its status as 'Private' .
  • the 'Do not disturb' status flag is stored in the PERSON table for that user whilst the 'Conference Privacy' status is stored in the CONFERENCE table for that conference. If a person registers themselves as ' Do not disturb' then others will have this status explained to them when they click on the person's picture; they will not be able to enter into a conference with that person. If a conference is private then other people will not be able to enter it and will be shown that it is private when they ask for detail on it. Both "Do Not Disturb" and “Privacy” functions are implemented with toggling on/off controls.
  • Another privacy advantage of embodiments of the present invention is that subscribers to a service need not disclose their phone number to other users - it is held on the database and used to dial calls to the user but need not be visible directly to others.
  • the Sleep Function One of the problems to be overcome with any virtual meeting-place is that users may log on to the system and then leave their computers to go somewhere else. This can lead to other users attempting to set-up conferences with them only to be confronted with answering machines. This problem can be solved as described above under "Removing a Person from a Conference" and this is the preferred method.
  • another solution to this problem is to have the database 1 25 keep a record of all page load requests which are made by a particular user (other than regular meeting-place update requests). Each time such a request is received, a counter is reset. If the counter reaches a designated value (equivalent to, say, 1 0 minutes of elapsed 'silence' from the user) the user will be designated as asleep.
  • the meeting-place window 300 of the person who is designated as asleep changes to tell them this.
  • There is a button labelled 'wake me up' which can be pressed to restore the user's status to 'awake' on the system's database. They will then be able to initiate or be invited into audio conferences once more.
  • Error messages are displayed to the user whenever an audio-conference request (eg set-up a conference or leave a conference) fails.
  • the request usually fails because the Millenium CT 1 35 has been unable to make a call since the called party is either engaged, not answering, or their phone number is unavailable (NU).
  • the Millenium CT 1 35 indicates the reason for failure in the 'Make Call' response message returned to the MAP object 205.
  • the MAP object 205 sets the status in the request in the CONFERENCE-REQUEST table to indicate the reason for failure.
  • the server 1 20 receives a reload request from the client (that is currently displaying the cycling dots) it inspects the status in the request in CONFERENCE-REQUEST table.
  • the system provides the opportunity to bill users on the basis of subscription, usage or some combination of the two. Since all audio conferencing telephone calls are outgoing from the Millenium CT platform 1 35 it is possible to offer users a special tariff for exclusive use with calls to other registered users.
  • the charging structure for other general calls which the user makes need not be adjusted.
  • the database stores a range of allowable dialback numbers for each user. This allows people to use the service from more than one location. Since users are prevented from entering their own dialback numbers, which have to be authorised by a system administrator, the potential for using the system fraudulently to obtain discounted telephone calls to any destination is removed.
  • the database records the name of each user who initiates an audioconference, the duration of that audioconference and the names of people who took part in the conference, together with the lengths of time for which they took part. This data can be used to charge the conference originator, the participants or both parties on a time basis. All such information is stored in the database 1 25 together with time and date stamps.
  • the database 1 25 records the time and date at which each user account is created or closed down This information can be used to facilitate subscription based charging.
  • the butler process is intended to alert users whenever a new person comes on line, for example by playing a sound such as a bell.
  • an indicator 335 e.g. a coloured dot
  • the meeting place window is brought to the front of the browser The indicator persists until a new update takes place or for 2 minutes - whichever period is shorter
  • a 'registerUser' javascript function is called in the layout code for the meeting place window. This function adds the name of the user in question to an array. It also checks a 'previous' array which contains a list of all those users who were present the last time the logged on frame was loaded. If a particular name features in the current list but not in the previous list then it is judged to be new and the function returns a 'true' value to the code in the logged on frame. This is what causes the indicator to be displayed by the name of each new user.
  • the OnLoad' event for this frame is used to call a second 'butler' function in the layout document. This simply checks whether any items in the 'current' array are different from those in the 'previous' array. If this is the case then a java applet is called in the 'tools' frame of the meeting place using the LiveConnect protocol embedded in the browser. The function of this applet is simply to play a sound of a designated name. In the case of the butler a 'bell' sound is played by the client.
  • the registerUser function increments a variable value each time it is called (starting from 0) .
  • the application object 200 deals with the conference controls offered to the user by means of the meeting place screen 300:
  • the MAP object 205 deals with the interface to the Millenium CT 1 35:
  • Heartbeat object 21 5 simply deals with monitoring an area of the database 1 25 and logging out users appropriately: 1 Poll database 2 Log-out person
  • the system allows groups of people to talk to each other and achieve a shared view of information without requiring that participants either learn a complex set of controls or invest in specialist equipment or software at the client end.
  • the equipment at the server end is not particularly complex either and can be readily set up as part of a small business operation, company department or educational service for example.
  • the system is about providing a basis for conversation and information exchange - the exact nature of the conversation and information traded is not constrained so there might be a wide variety of potential uses such as:
  • the system can be deployed either as a small scale set-up involving PC based audio conferencing platforms such as the Millenium CT 1 35, or to provide larger scale services on platforms such as the "integrated Speech Applications Platform” (iSAP) which has been developed by British Telecommunications pic.
  • iSAP integrated Speech Applications Platform
  • the overall group size on any platform is generally limited to 60 users by the system's capacity although a service can be spread over a bank of such platforms running in parallel.
  • the maximum size of an individual group would again tend to be 60 (limited by the capacity of each shelf on the iSAP) although a very much larger overall user group could be catered for.

Abstract

In order to allow several users (100, 101, 102) involved in a telecommunications conference call arranged through the Internet (105) to access and discuss the same item of data from a database (145), provision is made for one user (100) to control the Web browsers of the others (101, 102) by means of a server (170). The controlling user interface (100) transmits a signal containing a retrieval command to the server (170), which passes retrieval command signals to the other users (101, 102), causing them to transmit a retrieval command to the information database (145) to retrieve a specified item of data. This system allows users to synchronise their acccess to the data, ensuring that all users are inspecting the same version and requiring only one user to know the necessary access code (url) for the data to be accessed.

Description

INFORMATION RETRIEVAL SYSTEM
This invention relates to an information retrieval system. It is of particular application to teleconferencing facilities provided over the "Internet" but is not limited thereto. In this specification the term "teleconferencing" is used to describe a facility for allowing the sharing of information between two or more individuals at locations remote from each other, using telecommunications links for the purpose. Teleconferencing facilities include the capability to support voice communication between the parties, with additional capabilities such as the transfer, between the parties to the call, of information in the form of data, text, video images (possibly, but not necessarily, of the parties to the call) etc, such that all parties to the call can study the same data. The facility may be used for multi-way calls between three or more parties, but calls involving only two parties are not excluded. The transfer of data in the form of text or images from one user to another according to standard Internet procedures can be quite lengthy, if the document to be transferred is substantial. In many cases, a document to be studied may itself be available from an information network and could be called up by each user independently. However, it is inconvenient for each user to have to individually generate the necessary address or search request (known as a url: "Uniform Resource Locator"), as such requests require a complex string of alphanumeric and punctuation characters to be entered, for example http://www.bt.co.uk/about/site/how/index.htm. Unless all users enter the same address (which in turn requires that they all know, or are told, the correct character string) they cannot access the same information.
A system is described in the present applicant's International Patent Specification W098/1 3995, published on 2nd April 1 998, in which users connected together in a teleconference can share a URL with each other. This may be useful for instance when a person wants others with whom he is talking to see the same WWW page at which he is looking To share a URL, a user either manually types, or copies and pastes, the relevant text string into an HTML (hypertext mark-up language)-generated text box in a shared field to which all the users have access. The shared field contents are made available to other users through a dynamically- generated hyperlink. All other users can then load the document referred to by the URL by clicking on the link. However, this merely gives the users the necessary character string, and does not control when the individual users access the network using this URL, so different users may be looking at different versions of the same "page". According to the present invention there is provided an information retrieval system comprising at least two user interfaces, each user interface having means for accessing an information database system by means of retrieval commands, and wherein at least one, controlling, user interface has means for transmitting, to one or more of the other user interfaces, a signal containing a retrieval command, the other user interfaces being operable under control of the retrieval command signal to transmit the retrieval command to the information database to retrieve a specified item of data.
According to a second aspect there is provided a method of controlling an information retrieval system comprising at least two user interfaces, each user interface having means for accessing an information database system by means of retrieval commands, wherein one, controlling, user interface transmits, to one or more of the other user interfaces, a signal containing a retrieval command, the other user interfaces operating under control of the retrieval command signal to transmit the retrieval command to the information database to retrieve a specified item of data.
In this way a user can minimise the amount of data to be transferred between himself and other users, allowing one user to access the data from the correct address on behalf of all the others, without the need to individually generate the retrieval command. This allows one user to take control of other users' user interfaces (for example WorldWideWeb browsers), thereby ensuring that all browsers stay in lockstep throughout an online meeting, seminar, lecture etc. When used in conjunction with a textual "chat" application, or a teleconferencing system, this capability dramatically enhances the utility of the WorldWideWeb for group use, in both synchronous and asynchronous contexts. Many types of application can be envisaged e.g. online business meetings, entertainment, and education.
Preferably, the user interfaces are linked to each other by a server application. The instructions sent from one user to the others by way of the server may be a search instruction, but in general will be the address of the item of information which is to be retrieved.
To avoid the possibility of two users attempting to perform this operation simultaneously, a process may be applied wherein the receiving users confirm that they accept control of their user interfaces for this purpose by another user. Alternatively, the system may be set up to have one of the user interfaces designated to have control of the interfaces of other users in a specified group. In this arrangement the other users may themselves transmit a proposed information address to the controlling user, for him to disseminate to the other users. The present invention is particularly suited for use with Internet-based teleconferencing applications, which have recently started to become available They allow groups of people anywhere in the world to talk to each other using packet switched protocols such as RCP. These systems allow teleconferences to be set up and controlled relatively easily via a graphical user interface (GUI). This communicates with a server-based application which controls which people can talk to each other Users can see text labels or images which represent both themselves and other users and can take advantage of the relatively intuitive and powerful control and feedback facets of a graphical user interface. Many of these systems follow a 'rooms' based metaphor in which each teleconference takes place in a different "virtual" room. Users can wander from room to room taking part in conversations as they go.
An embodiment of the invention will be described with reference to an improved teleconferencing system of this type, which is the subject of the International Patent Specification W098/1 3995 referred to above. This, in turn, makes use of the Acculab "Millenium CT" (Registered Trade Mark) platform, a commercially-available PC-based device described in International patent specification W098/1 3993, also published on 2nd April 1 998.
An information retrieval system according to an embodiment of the present invention will now be described, by way of example only, with reference to the accompanying Figures in which:
Figure 1 shows a diagram of the system platform and its context; Figures 2, 3, 4, 5, 6, and 7 relate to the prior system described in W098/1 3995, and will be discussed later Figure 8 is a schematic representation of the teleconferencing environment within which the system operates
Figure 9 is a screenshot when running the system of the invention, with a Java "applet" running in the left-hand frame of a WorldWideWeb browser; Figure 10 illustrates a mam window for the applet;
Figure 1 1 illustrates a browser window showing the requested URL in the right hand frame;
Figure 1 2 is a flow diagram illustrating the processes by which one user controls the browsers of others; Figures 1 3, 1 4 and 1 5 illustrate in more detail the information flows between the client and server applications in the server.
The operative elements of the system will first be described with reference to Figure 1 .
Each user has a personal computer 100 and a telephone 1 1 5, connected, respectively through the "Internet" 105 and the normal telephone network (PSTN or ISDN) 1 1 0, with a server 1 20 under the control of an Acculab "Millenium CT" PC-based system 1 35, which provides the teleconferencing facilities to allow coordination between the various users, and between the telephone and internet connections, as described in detail in International Patent Specification W098/1 3995. This teleconferencing system provides a management and control unit for a network-based teleconferencing system, the unit comprising: i) an interface for outputting control signals to a platform for establishing audio connections across a network between users;
II) an interface for receiving control signals from at least one platform for providing a graphical user interface to a user for use in controlling the network- based teleconferencing system; and in) access to a database for maintaining, including updating, management data relating to one or more existing teleconferences such that the management and control unit can receive control signals input by a user at the graphical user interface in respect of a teleconference, output control signals to the platform for establishing audio connections, thereby establishing a teleconference connection between the user and at least two other users over the network, and output management data to the graphical user interface during an existing teleconference for use by the user in managing the teleconference.
Preferably the network is a telecommunications network while the interface for receiving control signals is an interface to a data network, such as the Internet. Preferred embodiments can then enable users to enjoy high quality audio- conferencing which they can manage using a World Wide Web screen-based interface. Such embodiments can allow users to work on worldwide web based material yet not require that they i) set up calls via an operator, n) remember DTMF control codes, in) invest in new telephony hardware, or iv) install specialist software.
This system avoids the problem, particularly associated with carrying voice signals over packet-switched protocols, that voice quality is contingent upon both the bandwidth of the connection to each user being sufficiently large and the overall performance of the network being above a given threshold. This makes it difficult to guarantee an acceptable level of sound quality for all users at all times. There is also a problem caused by delays in digitally encoding speech from each user; this means that users hear their own voices repeated after a delay at the remote end(s) unless all users wear headphones Finally some service providers are seeking to ban, limit or charge extra for services which use demanding protocols such as Remote Procedure Calls (RPC).
The management and control unit can be supported by Internet-connected servers, such as a Web server for supplying documents, and a Java server for coordinating remote interfaces, whilst the graphical user interface may be provided at a client, also connected to the Internet. The management and control unit can then provide a powerful and very versatile tool in providing audio-conferencing.
Conferencing systems according to preferred embodiments of the present invention can combine the ease of use of a GUI-based system whilst also leveraging the reliable voice quality associated with the phone network. Such systems can impose minimum technical or cognitive requirements on each user and preferably use established protocols wherever possible.
The system can allow anybody who has simultaneous access to an Internet (or similar) connection, to provide the graphical user interface, and a separate directly diallable phone line to setup, control, record and clear down high quality teleconferences.
As described in the earlier cases, the database can be used to maintain updatable information specific to each user This information can include for instance images of the users involved in a teleconference so that, whilst they are using the system, they can see annotated pictures of anybody else who is connected.
Not only is there no need for users to remember control codes but they do not need to know the phone number of other participants. Teleconferences can be made private and users can change their outgoing telephone number when they move from one location to another
Clearly, this system could be used with other information networks, for example a less extensive network than the Internet, such as a company "Intranet". Tight integration between software running on the client, the associated WWW server, a teleconferencing platform and a database is possible.
A World Wide Web (WWW)-based graphical user interface (GUI) can control a teleconference using this system. No additional software is necessary at the client and the system can be available to any user with a Transmission Control Protocol/Internet Protocol (TCP/IP) connection to the Internet and a phone line. The system can be made capable of keeping track of several parallel teleconferences each of which may involve several users. Each user can be shown the appropriate information detailing where they are on the system as well as where others are; this information can be updated whenever changes relating to a given user occur. Each user can preferably control aspects of the system which they have the privileges to change This should preferably be done without creating a conflict.
Finally the entire system is preferably designed so that users can be billed appropriately. The system of the present invention is an application 170 which may run on any computer forming part of the user group, for example the same computer as that supporting the web server 1 20. the Java server is built on an object- oriented client-server framework written in Java as outlined by David Flanagan [Java in a Nutshell, O'Reilly & Associates Inc.]. Java client applets communicate with the Java server 1 70 using "sockets" objects. The job of the server 170 in the system of the invention is to synchronise communication between the applets, and to manage other client requests such as indicating which user is currently in control of the set of group Web browsers. The server is basically responsible for managing state: users are members of groups, may move between groups, and may make use of group resources.
Previous work by Smythe et al on RISE (Real-time Interactive Social Environment), to be found at: http://rιse 1 . labs. bt. com :8000/rιse.bundle/publιc/ιndex. html has led to the development of a sophisticated database-driven Web real-time teleconferencing platform offering such group services. RISE is therefore an ideal environment in which the system of the invention may be exploited.
The system of the invention offers services which in several respects mirror those of PointCast, Marimba and other 'push' providers. The crucial difference is that content organisation and management is delegated to each client, so that the users can freely control which Web resources are to be broadcast to the group.
Figure 8 shows a group of such users' computers 100, 101 , 102 linked through the internet 1 05 to a java server 1 70, which has the individual users identified as a user group by an attribute 1 60 stored in an address file 1 55 stored in the server One user ( 100) is defined as the controlling user, again by means of a server attribute 1 65. (Note that throughout this specification each user is identified by the same reference numeral as his or her respective user interface). Each user 1 00, 1 01 , 1 02 has a respective browser program 1 50, 1 51 , 1 52, with which URLs of other websites 145 (only one shown) can be generated for accessing data from the website, again through the internet 105. They are also linked to a Java server
The system of the invention is operated in a manner which will now be described. The sequence of screenshots shown in Figures 9, 10 and 1 1 , and the information flows shown in Figures 1 3, 14 and 1 5, illustrate how the system of the invention is used. In Figure 9, the user currently having control of the system has loaded a pair of frames into Internet Explorer. The left hand frame contains the program - a Java applet. The right hand frame in this example is the target for all URL requests made by the applet. The 'url-push' button in the left-hand frame is used to reveal the main window, shown in Figure 10.
Figure 1 2 is a flow diagram showing the main information flows taking place between the users and the server 170. The three users 100, 101 , 102 are all connected as a user group, identified as such in the attribute list 1 55 of the server 170, with a first user 1 00 having control of the browsers 1 51 , 152 of the other users 101 , 1 02. This control facility is stored as another attribute 1 65 in the server 1 70. It will be seen in Figure 1 6 that the attribute 1 65 may be transferred within the server from one user 100 to another 1 01 The user currently having the attribute 1 65 is the controlling user.
The main window contains the user interface. Three text fields are used to organise URLs. The controlling user 100 types or pastes URLs into the top text field which is editable (step 902). Pressing the 'Add URL' button results in the new URL being added to the list of URLs shown in the middle text field (step 903). The program conducts an internal check that the URL is of valid construction, and warns the user if this not so (step 904). The middle text field contains the list of URLs that the user wishes to show to other users in the group. Clicking on any URL in the middle field, or clicking on the up/down 'arrow' buttons transfers the URL to the bottom text field (step 905). The controlling user 100 presses the "PushURL" button to drive the URL to the remote users' browsers 1 51 , 1 52 (step 906) . A status message stating "Pushing URL < url > " appears. The URL is rapidly distributed to all users (step 907). A status message stating "Being pushed to URL < url > " appears in all users' windows (step 908) . The applet then forces each user's browser to load the requested URL (step 909), as shown in Figure 1 1 . All the users can then simultaneously view the results of loading the URL.
Figures 1 3, 1 4 and 1 5 illustrate in more detail the processes which take place in the server and clients in order to load a new URL into each browser belonging to the group. Each diagram shows a sequence of messages passed between various objects. Fig. 1 3 illustrates themessage flow in the sender client applet up to the point where the URL is passed down the network to the server. Fig. 14 shows what happens in the Java group-coordination server 1 70 in order to redirect the URL to all clients. Fig. 1 5 shows the response of a receiving applet to the URL pushed at it from the server. The client-server architecture used can be replaced by an architecture in which the applets and application communicate via distributed objects through remote-method-invocation (RMI), CORBA or similar process.
The Java group-coordination server 1 70 co-ordinates the client user interfaces by allocating connection "objects" 71 2, 71 5 (see Figure 14) to each client. Service requests from the clients 100, (101 , 102) are passed through these connection objects. URLs are broadcast to the group of which the user is currently a member (defined by a connection vector object 714), and the client processors ( 1 01 , 102) then change the page in the user's browser (also defined as an "object" 723). Other objects in the transmitting user's set-up 100 define the URL "push" button on the display of the user 1 00 (object 701 ), the user interface (702), the text field (703), the client (705) and the output (706) . the server 1 70 has objects defining the server itself (71 1 ), the sending user 100 (object 71 2), and the data input (71 3), and the receuivmg user has an object defining the input (object 721 ). Other objects 704, 722 are created during the process. Other objects, not involved in the essential processes to be described, and not shown in Figures 1 3, 14 and 1 5, communicate with the database, to store URL requests for example, or to identify who is entitled to 'controller' rights
Figure 1 3 illustrates the transmission of a URL from a user 100 to the server 1 70, for onward transmission to other users 101 , 102. When the user "pushes" this button (step 801 ) (in practice, by "clicking" on it with his "mouse") a "push URL button" object 701 transmits this event to a browser control interface frame 702 This frame 702 is configured to monitor for such an event, and on detecting it (step 802) generates an instruction to send the URL to the server (step 803) . This causes the interface frame 702 to obtain the URL character string from the text field (object 703) and generate a new object "url" (704) (steps 804, 805). This string is then written to the client object 705 (step 806) and thus to an output object 706 (step807)
Figure 1 4 shows how the server 1 70 reads URL requests received from one user 100 and routes them out to other client objects 101 , 102. The server object 71 1 and sender's connection socket object 71 2 are set to run (steps 81 1 , 81 2). On receiving a character string the connection sends a message (step 81 3) to an input object 71 3 which in turn instructs the server object 71 1 to control the connection set-up objects 71 4 (step 81 5) and then transmit the URL instruction to each connection 71 5 (step 81 6)
Figure 1 5 shows how the receiving "client" 1 01 , 102 responds to such an instruction. Whilst the listener object 721 is set to run (step 821 ) it obtains any URLs transmitted to it from the server 1 70 (step 822). Any such URL is used to create a new "url" object 722 (step 823) which is transmitted to an Applet context object 723, namely the web browser 1 20, causing it to load the URL and access the data required.
Figure 1 6 shows the process employed when one of the remote users ( 101 ) wishes to take over control from the current controlling user 100. The user 101 transmits a control request (step 910) to the user 100, this request being stored as an attribute of the requesting user in the attribute list 1 55 of the server 1 70. On receiving such a control request (step 91 1 ) the controlling user's computer 100 will display the request The controlling user 100 may have the authority to refuse such a request (step 91 2) in which case a message is transmitted to the server 170 and thus to the remote user 101 communicating the refusal. However, assuming that the user 100 accepts the request (step 91 2) the server 1 70 modifies the existing application objects in the attribute list 1 65 relating to the current controlling user 1 00 and the remote user 1 01 (step 91 3), to record the requesting user 1 01 as the current controlling user and to remove that attribute from the user 100. The user 1 01 has now become the controlling user and can proceed as described above with reference to Figure 1 2 (step 914).
The attribute list may allow some users to refuse a control request 910, and others to be required to relinquish control on request from any, or a specified subgroup, of the other users. For example, in Example 2, discussed below, individual participants 101 , 1 02 may be allowed by the initially controlling user 1 00 to take control, but cannot refuse to return control to the controlling user 1 00 when he requests it.
In an alternative arrangement shown in Figure 1 7 the controlling user 100 retains control throughout. However a remote user 101 may prepare a URL, and transmit that URL, by way of the server 1 70 (step 901 ) to the controlling user 100. The controlling user may choose to select or refuse a proposed URL (step 902) and, if selecting the URL, will then add it to the list (step 903) as described above with reference to Figure 1 2 The process then continues as described with reference to Figure 1 2. In this embodiment the controlling user 100 retains control, "pushing" URLs generated by other users 101 , 102.
The controlling user interface 1 00 may use its internal timer to transmit a sequence of "push" commands to control the remote browsers 1 51 , 1 52 such that a sequence of pages may be downloaded to the browsers at a fixed rate.
The controlling user 1 00 may also store URLs or sequences of URLs for each user group in a database 1 25, for playback. This can be augmented by audio recordings of group conversations or other teleconference elements, as described in the earlier application. The system of the invention can be exploited in any situation where groups of people distributed over a Wide Area Network need to share visibility of Web pages. Four example scenarios will now be described, with reference to Figure 8. For simplicity, the same reference numerals will be used for analagous performers in these scenarios, but it will be appreciated that different websites and users will be fulfilling these functions in each example scenario.
EXAMPLE 1 BUSINESS - Sales
The customer ( 1 01 ) wishes to obtain a mortgage. She checks the WorldWideWeb, and finds that there are a large range of options advertised, some of which offer online financial analysis of her situation. Due to flaws in the design of Web service, or because of safeguards required by the financial services industry to prevent customers making decisions purely on the basis of on-line information, without professional advice, she does not have the URLs needed to "drill-down" from the high-level websites to some key URLs which could prove advantageous to her.
On some of the Web pages she consults, there is a link to a respective online sales representative 1 00. The customer clicks on such a link, which causes her telephone to ring that of the sales representative 100 (see Figure 1 : link 1 10). Whilst the customer 1 01 is talking to the sales representative 100, the sales representative asks for permission to drive the customer's Web browser 1 51 , and the customer agrees by clicking an acceptance. This creates an association in the server 170, forming a two-member user group in which the customer's browser 1 51 is controlled by the sales representative's browser 1 50. Thus when the server 170 receives a "push" request from the sales representative's browser 1 51 (step 906), it transmits it (step 907) to any browser identified in the server's attribute list as being linked to the browser 1 50, namely the customer's browser 1 51 . On receiving the URL from the sales representative, (step 908) the browser 1 51 , like the browser 1 50, can access the data from the website 145 (step 909). The sales representative can now lead the customer through a series of web pages not otherwise accessible to the customer, the necessary access passwords being included in the URLs transmitted to the customer's browser 1 51 for the purpose, but not being stored by, or known to, the customer 101 herself.
When the customer has located a mortgage option which appears to suit her needs, the sales representative can offer step-by-step advice to the customer on how to perform the online analysis of her financial situation. When the customer is satisfied with the results she can sign up for the mortgage.
EXAMPLE 2 ENTERTAINMENT
A football club, having a website 145, wishes to broaden the scope of its match- day media offerings to its supporters. It signs up a radio station (user 100) to deliver multiple telephony/Internet talk-shows linked to live broadcast match commentary, using the telephone/internet interface shown in Figure 1 . The radio station ( 1 00) offers the services of talk-show hosts who are able to select music and sound clips to be played over the telephone in traditional disc jockey fashion, but who are also able to select photographs and other data relating to the match from the website 145 (steps 902-905), and push them to the supporters 101 , 102 (steps 906-908) using the system of the invention, so that the photographs etc can form the context for the supporters' conversations. The supporters 101 , 102 can also access data and photographs (steps 900, 901 ) for submitting to the host for transmission to the other supporters (steps 902, 903: Figure 1 7), so that the supporters can control the context for their discussions under the overall supervision of the host 100.
Alternatively, the host 100 may allow one supporter 101 to take control and transmit "push" commands to the host 100 and other supporters 1 Q2 (steps 910- 91 4) himself. EXAMPLE 3 EDUCATION
A tutor ( 100) can push individual pages (145) from the vast educational resources of the Web to her students ( 101 , 102), located remotely, as they discuss a research project together.
EXAMPLE 4 ARCHITECTURE & DESIGN
The development of a large engineering project, such as a new airport terminal, involves many interested parties, such as the client, the architects, the intended users (airlines, hotels, consumer outlets) , government organisations and other stakeholders. These parties can spend years shuttling back and forth between meetings concerning the major issues. There will be no generally accessible single repository of design and planning documents, or records of previous meetings. A Web-based 'virtual organisation' can be formed, which allows the management of teleconferenced meetings, the storage of records of such meetings, and ready access of the latest version of the design documents. At a teleconference meeting involving some or all of the participants ( 100, 101 , 102), data from each participant's website ( 1 00, 101 , 102, 145 etc) can be made available to all the others, under the control of a chairman ( 100). The chairmanship role can be transferred to another participant 1 01 during the teleconference (steps 910-914: Figure 1 6), for example if that other participant 1 01 is to make a presentation to the teleconference.
There follows a verbatim description of the preferred embodiment of the aforementioned International patent specification W098/1 3995, which describes the Millenium CT-based teleconferencing facility on which the preferred embodiment of the present invention is based. It should be noted that the United Kingdom applications 961 9958.3 and 970771 2.7 referred to therein have since been used to establish priority for the other International Patent Application, published on 2nd April 1998 as W098/1 3993, to which reference has already been made above. Figure 1 has already been briefly described
Figure 2 shows a schematic diagram of the server side architecture for the system shown in Figure 1 ;
Figure 3 shows a graphical user interface for use at a client browser for the system of Figure 1 , and
Figures 4, 5, 6 and 7 show functional breakdowns of objects for use in an application residing on a server in a system as shown in Figure 1
Referring to Figure 1 , each user has a personal computer 1 00 with an Internet IP connection 105, and a web browser application which supports HTML3.2 (or later), together with Frames and either Javascript or Jscπpt. They must also have a separate telephony connection 1 1 0 with a telephone 1 1 5 which can be directly dialled. Possible network configurations to support this include the use of
a) 2 Public Switched Telecommunications Network (PSTN) lines,
b) an Integrated Services Digital Network (ISDN) 2 connection where one B channel is used for voice and the other for data, or
c) the combination of a Local Area Network (LAN) and Private Branch Exchange (PBX) connection
At the server end of the system, there is a Worldwide Web server 1 20 which can dynamically produce HTML pages by Simple Query Language (SQL) based reference to a database 1 25. It can also write information to the database 1 25.
The WWW server 1 20 is also connected via a RFC1006 socket level connection 220 to an Acculab Millenium CT (RTM) platform 1 35. This is a PC-based device, described in copending British patent applications 961 9958.3 filed on 25th September 1 996 and 970771 2.7 filed on 1 6th April 1997 by the same applicant, the contents of which are incorporated herein by reference, which has a number of capabilities including the ability to set up, control and record audio conferences. Prior to its launch as a product it was known as Minor Applications Platform (MAP) . The Millenium CT is connected between a telecommunications network, such as the Public Switched Telecommunications Network (PSTN), and a data network, such as the Internet. It accepts incoming service requests over the PSTN via an 1SDN30 connection 1 40. It can also accept incoming service requests in other ways, for instance via a RFC1006 socket level connection as mentioned above. In this case, the protocol will be implemented on both sides of the socket level link. It also provides processing capacity and it can respond to an incoming call or message by identifying and launching an appropriate computing application which calls on and manages resources to run the service requested.
The Millenium CT 1 35 is equipped with means for providing audio bridges between conference participants, in the form of digital line interface cards and controls therefor. Additionally, the Millenium CT provides speech related resources, such as recording and delivery. It therefore can provide facilities which are important in communicating with a user during conference set-up and for recording.
For the purposes of the audioconferencing system however, any device which can accept and send commands over a network connection and use these commands to generate and record audio conferences could be used as an alternative to the Millenium CT. It should be noted there are also a number of equivalent link protocols which could be used in substitution for ISDN30.
Server Software Architecture
The Server 1 20 may be any workstation with a WWW server and an object- oriented development environment providing integrated database access. The system shown in Figure 2, provides a "WebRex" (TM) WWW server 1 20, an "Oracle" (TM) database 1 25, and a "NextStep" (TM) operating system, and four objects.
Referring to Figure 2, the server 1 20 supports an application comprising four objects. These objects 200, 205, 210, 21 5, are further described below. Functions within the objects are called from other objects by name; the NextStep operating system automatically generates the messages interchanged between the objects in a manner similar to Remote Procedure Calls (RPC). The application object 200
This is linked into the WWW server 1 20 to provide a set of multiply re-entrant, memory resident functions. These functions are called in an HTML request from the user and allow conferences to be set-up and managed using functions provided by the Millenium CT interface object 205 (or MAP object).
The MAP object 205
This receives requests from the application object 200 and controls the Millenium CT 135 by sending it commands and polling it for commands and for responses to previously sent messages. The RFC 1 006 protocol (running over TCP/IP) is implemented in the MAP object 205 and on the Millenium CT 1 35 to provide a reliable peer-to-peer protocol for message passing
As it may take some time (a few seconds) to process a request from the application object, the MAP object queues a request in a CONFERENCE-REQUEST database table (further discussed below under "The Database"). An initial (HTML) response is sent back to the client indicating that a request is being processed.
The MAP object 205 is implemented as an event driven state machine since the requests usually require a number of messages to be interchanged with the
Millenium CT. The state of the request is stored in the CONFERENCE REQUEST database table entry (further discussed below under "The Database"). The MAP object 205 polls the CONFERENCE-REQUEST table for user requests frequently (for instance once every 5 seconds) . Once a request is found, the command sequence is initiated by sending the first command to the Millenium CT 135. The MAP object
205 polls the Millenium CT 1 35 for a response at regular intervals (for instance once every second); once a response is received the MAP object 205 identifies which conference the response refers to (from a conference number field in the response). It then determines the current state from the request stored in the CONFERENCE REQUEST table and issues the next command to the Millenium CT
1 35.
The messages sent to the Millenium CT 1 35 are: Register Platform (establishes a TCP/IP connection)
Conference Registration (register or de-register a conference with the Millenium
CT)
Call Dial (call a specified telephone number)
Mix all Participants (mix the calls into an audio conference)
Call Clear (remove caller from the conference)
Record Start (start recording the conference)
Record Stop (stop recording the conference)
Record Delete (delete the recording)
Record Save (save the recording to a file)
Playback Start (playback the recording from the beginning)
Playback Stop (stop the playback process)
and the commands returned by the Millenium CT 1 35 are:
• Call clear (call cleared by remote party)
• Record stop (stop recording the conference (run out of resources))
The Database Interface object 210 This may more simply be called the Database object 210. It provides functions for use by the application and MAP objects 200, 205. The functions store and retrieve information about the people who are using the system and the audio-conferences in an Oracle database 1 25. The functions use embedded SQL.
The Heartbeat object 215
This logs users out if it believes the user has closed down their meeting place window and left the system. This is further described under "The Heartbeat Process" below
Millenium CT Application
In order to implement the setting up and management of a conference from the server, the Millenium CT 1 35 is provided with an application which can receive commands from the MAP object 205 and respond by supplying the functions required. These are for instance establishing audio bridges between the conference participants, delivering speech messages, such as "Please wait", and recording and storing sound for later access. The form of such an application of course is adapted to receive and respond to the messages set out above under "Millenium CT Object 205", and this determines the functionality of the Millenium CT application. The application will be compatible with the operating system of the Millenium CT 1 35 which may for instance be UNIX but could be another operating system.
The database The database 1 25 is used to store information about people using the system and about audio conferences. Any relational or object-oriented database is sufficient though the present system uses an Oracle database accessed using Simple Query Language. This is called from functions in the application and Database objects 200, 210. Oracle sequences are used to generate unique conference numbers. The tables used in the Oracle database are as follows:
Figure imgf000020_0001
Logging onto the system
The database 1 25 holds information which includes the name, phone number and image of each user who is registered with the system. A registered user logs onto the system by starting up their browser 100 and then submitting a request for the system's access URL to the server 1 20.
Referring to Figure 3, the user's browser 100 uses the javascript "OpenWmdow" command to open up a main window as well as a smaller secondary window 300 which represents the 'meeting-place' . Additionally the on-line status field in the PERSON table in the database 1 25 is set to a value of 1 to indicate that they are logged in and their 'heartbeat' is initiated (see under "The Heartbeat process" below) by setting the heartbeat field in the PERSON table for this person to the current time to initiate the heartbeat process.
The meeting-place window 300 consists of 4 frames. A column 305 on the left shows a scrollable list of people who are logged on to the system. Beneath this, there is a very small frame 310 which is used to control the update process. In a right hand column, there is a main frame 31 5 which provides details about either a person or a conference. Below this, there is a smaller frame 320 which contains controls for recording the conference, setting privacy or sharing URLs.
As soon as a user logs onto the system, they see the names of all other users who are logged on at that time as well as a list of the current conferences and their participants in the form of a scrollable text list. The application object 200 achieves this by retrieving a list of those who are in the CONFERENCE and PERSON CONFERENCE tables in the database 1 25. It also gets a list of those who are logged on but not in a conference by looking at who has an on-line status of 1 in the PERSON table.
Others will also see the new user's name as soon as their respective meeting-place windows 300 are updated. When the system starts up, users are shown their own image together with the telephone number at which the system is currently programmed to dial them. All audio conferences taking place on the system are given a two or three digit identifier (room number) when they are initiated to assist users in telling each other where to rendezvous (the numbers are taken from a cycling range from 01 to 999). The arrival of a new user online is indicated by the temporary display of an indicator such as a coloured dot 335 adjacent the name (or names) of anybody who is newly arrived (see the "Butler" process below) and by the updating of the meeting-place screen of each user. (Figure 3 shows "Andrew" twice. These are different people.)
Meeting-place User Interface
The Meeting-place User Interface appears as a window 300 generated by a user's web browser on their personal computer 100 Figure 3 shows a point where a user (Philip) has just clicked on the 'ROOM 1 7' link in the logged-on frame 305. This causes the system to show images of Andrew and Debra who are currently talking in this room by accessing the tables in the database 1 25. An icon 325 in the room frame 31 5 also shows that the conference is being recorded. User 'Andrew' has just logged onto the system so the Butler process is showing an indicator 335 adjacent to his name. Selecting the 'Enter Room 17' button causes the system to call up Philip's number and add him in to the conference.
Starting a Conference with Somebody who is Logged Onto the System To find out about another user who is currently connected, the user clicks on the person's name. They are then shown a picture of the person together with a note of the dialback number of the nearest phone (see "Telephone Number Assignment and Mobility" below) There is also a button which gives the user (henceforth called the "originator") the option to set-up a conference Once pressed, the request to set-up a conference is sent to the server 1 20.
The server 1 20 queues the request in the CONFERENCE-REQUEST table. The MAP object 205 subsequently retrieves the request from the table, creates entries in the CONFERENCE and PERSON-CONFERENCE tables, and instructs the Millenium CT 135 to set-up the conference using the following commands:
• Conference Registration (register a conference with the Millenium CT) • Call Dial (to the originator)
• Call Dial (to the other person)
• Mix all Participants (mix the calls into an audio conference) When the originator answers the call they are played a message telling them that an audio conference is being set up and asking them to wait. When the called person answers they too are given a message telling them that a conference is being set up.
Once both parties have answered, the calls generated by the system are connected together into a telephony based audio-conference and both entries in the PERSON table are updated with the conference number. The MAP object 205 updates the status field (to indicate success) in the CONFERENCE-REQUEST table in the database 1 25.
Whilst the conference is being established, the originator is shown a screen of cycling dots (generated by an animated GIF graphic) asking them to wait. Meanwhile a small secondary frame is reloaded using the client-pull HTML construct (for instance every 5 seconds). When the server receives a reload request, it inspects the status in the CONFERENCE-REQUEST table. If the status indicates the conference has been set-up, it returns HTML to the updated frame which causes the entire layout of the window to be reloaded. This mechanism thus updates the meeting-place windows 300 of both people to show they are connected in a conference and deletes the request from the CONFERENCE REQUEST table. All other people who are connected to the system also have their meeting-place windows updated to show that the conference is in progress. This is achieved by updating the 'dummy' person entry in the PERSON table with the current time to indicate that the displays should be updated (see "The Update Process" below for details).
Telephone Number Assignment and Mobility
In environments such as schools, users of the system may wish to log on from any one of a number of terminals. To prevent the user from having to manually assign themselves the telephone number of the nearest phone each time they log on, this number is stored on the hard disk of each client machine. This can be achieved for instance by using a system such as that known as the "Netscape Client-side Cookie". This specifies the telephone number for the machine as well as a text string describing where it is located, for example "Andrew's office". When a user initially logs on to the system, a Javascript function located in the rooms frame of the meeting place will attempt to read any cookie which has previously been set by the system. If no cookie is found, or if a previously set cookie has expired, the rooms frame in the meeting place will inform the user that no telephone has been associated with the machine that they are using. (Note: cookies are set to have a fixed life, for example one year, after which they expire.) The rooms frame will then invite the user to choose a telephone by selecting from a pop-up menu of numbers which are allowable for that particular user. (This page is generated dynamically from information in the ADDRESS table in the database.)
Once a number has been selected from the menu, a cookie will be written with the information and the frame will reload to show the user's personal information with their new dialback number.
During initial logon, if the system detects that a cookie has been previously set, it will automatically assign the number from this cookie to the user for the duration of the session. Since the cookie setting activity need only be done rarely, it is possible for a system administrator to tour all machines which will be used and set cookies for each one. In this way, the end user need never have to go through the above process.
From time to time, it may be necessary to move a computer from one location to another or to use a different telephone line with a particular computer. In these circumstances, either a user or a system administrator can assess a "Phone number setting form" which contains Javascript code broadly similar to that mentioned above. The page has to be manually invoked and occupies a main window of the browser in this case When the page is loaded, the appropriate cookie is read, if there is one, and the current number and location shown. The page also contains a popup menu of legal numbers which is assembled from the database. If a new number is selected, then the existing cookie is overwritten with the updated information. The page is also reloaded which causes the changed number and location to be shown. Joining an Existing Conference
The user joins an existing conference by clicking on a text link denoting the conference's number. They are then shown the list of participants in the conference. There is also a button which gives the person the option to join the conference.
The server 1 20 queues the request in the CONFERENCE-REQUEST table. The MAP object 205 subsequently retrieves the request from the table, creates a new entry in the PERSON-CONFERENCE table, and instructs the Millenium CT 135 to set-up the conference using the following commands:
• Call Dial
• Mix all Participants (mix the calls into an audio conference)
The system starts by making an outgoing call to the person. When the person answers the call they are played a message telling them that they are being added to the conference. Whilst the conference is being established the person is shown a screen of cycling dots asking him or her to wait. Meanwhile a small secondary frame is reloaded using the client pull HTML construct (for instance every 5 seconds). When the server receives a reload request it inspects the status in the CONFERENCE-REQUEST table. If the status indicates that the conference has been established, it returns HTML to the updated frame which causes the entire layout of the window to be reloaded. This mechanism thus updates the meeting-place windows of both people to show they are connected in a conference and deletes the request from the CONFERENCE-REQUEST table. After a short delay they are added in to the conference and the request is deleted from the CONFERENCE- REQUEST table.
The arrival of a new user in a conference is indicated with a short auditory tone, by the temporary display of an indicator such as a coloured dot adjacent to the names of any users who are newly arrived on-line (see the "Butler process" described below) and by the updating of the meeting-place screen 300 of all users. Those users who are in the room in question are shown an image of the person who has just joined. If they move their mouse cursor over this image they are shown the person's name in the status bar of the window. Users may continue to join a conference until it has grown to the maximum size allowable by the system (30 people in the embodiment being described here) . Whenever more than 8 people are present in the same conference the display is changed to show only the names of users rather than their pictures.
Inviting Into a Conference
Users who are already in an established conference can choose to invite other people who are logged on to the system to take part as well. They do this by clicking on the name of such a person in the logged-on frame (only the names of people who are not logged in to a conference are shown as active HTML links at this time). When the person's name is clicked, the user is shown a confirm message in the control frame If they confirm that they do indeed want to invite the person into the conference, the system will initiate a call to that person and try to add them to the conference.
The commands to the Millenium CT under these circumstances are the same as when someone joins a conference (see "Joining an Existing Conference", above). Once the person has answered the phone, they are added into the conference and the meeting-place window 300 is updated for all users.
Removing a Person from a Conference
From time to time, those already in a conference may invite another user to take part but in practice only reach the person's answering machine or voicemail. To recover from this situation, any of the other conference participants may clear the call to the answering machine. They do this by clicking on the name of the "person" that they want to remove in the logged-on frame. This results in a confirmation dialogue which is shown in the control frame. If the action is confirmed, the system will clear the call to the answering machine and remove this "person" from the conference. The conference can then continue as normal with the remaining participants.
The commands to the Millenium CT 1 35 under these circumstances are as when somebody leaves a conference. See "Ending a Conference" below. Ending a Conference
Once created, a conference continues to exist as long as more than one person is in it. Users can leave a conference at any time by pressing a button on the meeting-place window 300. When this happens, the Millenium CT 1 35 is sent the "Call Clear" command to clear the call, causing the Millenium CT 1 35 to drop the phone connection. The meeting-place 300 is then updated to show the person is no longer in the conference. This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see "The Update Process" below).
The Millenium CT 1 35 disconnects the last person if there is only a single person left in a conference after someone has left Once the last person has been disconnected, the MAP object sends a 'conference registration' command to the Millenium CT 1 35 to de-register the conference The meeting-place windows 300 of all users are then updated.
An alternative way of leaving a conference is for users to simply put down their phone. In the current implementation of ISDN in the UK the Millenium CT 1 35 is not notified by the telephone exchange that a person has cleared their call for 2 minutes. (After this time, the exchange sends a "call clear" DASS2 message to the Millenium CT.) A forthcoming modification of the BT network to European ISDN (ETSI) standards should mean that the Millenium CT 1 35 will be able to detect cleared-down calls in the near future
The Update Process
It is necessary to update the meeting-place window 300 of each user who is connected to the system whenever a significant event occurs. These events are when: • A user comes on-line or is logged out (see next section)
• A user enters or leaves an audio conference
• A user shares a URL (see below)
• A user starts or stops recording an audio-conference (see below)
• When the conference privacy status is changed When such an event happens, the time and date at which the event occurred is stored in the GROUPS table (for individual users) and in the CONFERENCE table (for conference related events).
The update process works by using the client-pull HTML construct from within a small frame 310 in the meeting-place window 300. Every few seconds (for instance every 1 5 seconds) this window is set to"update". When the server 1 20 receives an update request from the update frame 310, it compares the time and date when it last received an update request from the update frame 310 for this user (this is called the heartbeat - see "The Heartbeat Process" below) with the time the meeting-place was last changed. If the information to be displayed has changed since the last time, then a new version of the update page is sent back. This includes a javascript function which stipulates that the other frames of the meeting-place 300 should be re-loaded as soon as the update frame is itself loaded (the OnLoad event handler is used) . The advantage of this approach is that it does not increase traffic to the server, load on the client or visual distraction for the user by reloading all the frames even when nothing applicable to that user has changed. On the other hand it does not require multiple channels to be kept open for each user in the way that a protocol such as "server push" does.
The Heartbeat Process
The update requests are also used as a 'heartbeat' function which lets the server know the user is still logged in ('alive'). The Heartbeat object 21 5 running on the server 1 20 polls the database 1 25 frequently (for instance every 30 seconds). If the heartbeat value in the PERSON table for this user is over a minute old, the heartbeat object 21 5 deems that the user has closed down their meeting-place 300 and left the system. In such cases the user is logged out by updating their online status field in the PERSON table. That user will no longer appear as being on- line in other users' meeting-places.
Sharing URLs
When users are connected together in a conference they can share a URL with each other. This may be useful for instance when a person wants others who they are talking with to see the same WWW page that they are looking at. To share a URL, a user either manually types or copies and pastes the relevant text string into an HTML generated text box in the control frame 320 of the meeting-place 300. The user then either presses the 'return' button or activates a 'share URL' button. This causes the URL to be associated with the user for the rest of the conference by storing this URL in the PERSON table for that user. This is indicated visually in the meeting place window 300 of all conference participants by showing a small graphic with the word 'link' beneath the image 330 of the sending user. This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see "The Update Process" above).
If the person stipulates a subsequent link during the course of the same conference then the colour of the link graphic changes to show that a new link has been specified for that person (this is also stored in the PERSON table). Others in the conference can click on a link graphic to see the associated URL opened up in a new window on their browser.
Recording a Conference
Users can choose to record a conference so that they can play it back later. The originator's meeting-place 300 has an additional icon 325 which allows them to record the conference If the originator drops out of the conference leaving others talking, then the recording control is passed to whoever has been in the conference for the next longest time. The idea behind this approach is to avoid conflicting requests for starting and stopping a recording that may be generated if all users have their own recording control.
Alternatively, all participants in a conference may have an icon which allows them to record the conference. When a person presses the 'start recording' button they are prompted to give the recording a name and to type this into a text entry box. (The recording has a separate, system-generated unique name so it is not mandatory that the user give the recording a unique name). The user then submits the recording name using a button. A recording request is then queued with the server 1 20 requesting that the conference be recorded. The MAP object 205 then sends the Millenium CT 1 35 the 'Record Start' message to start recording the conference. Whilst the recording is being initiated, the person is shown the screen of cycling dots asking them to wait. When the recording is started the request is deleted from the CONFERENCE-REQUEST table. The start of the recording is indicated to the users with an auditory tone and a short voice announcement made to the conference. The recording button in the person's meeting-place is replaced by an animated 'recordιng-ιn-progress' icon (this is pressed again to stop recording). Other users are shown an animated icon indicating that a recording is taking place. This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see "The Update Process" above).
When the originator presses the 'stop recording' button, a confirmation dialogue appears in the control frame If the user confirms that they want to stop the recording, the system sends 'Record Stop' and 'Record Save' messages to the Millenium CT 1 35. Once the recording has been saved, the animated recording icon from the person's meeting-place 300 is removed and replaced by the 'start recording' button - other users are also now shown an icon indicating that no recording is taking place This is achieved by updating the entry in the CONFERENCE table to indicate that the displays should be updated (see "The Update process" above) Subsequent parts of the conference may then be recorded if desired.
The MAP object 205 will automatically stop a recording if the last person leaves a conference and the originator has not specifically stopped the recording. The recording will still be saved in these circumstances.
The Millenium CT 1 35 stores the recording as a 64Kbps PCM encoded speech file. The file is subsequently converted and placed on the WWW server where it can be listened to by the conference participants. Preferably, the file is converted into "RealAudio 3" format thus allowing long sound files to be heard without having to first download the entire file to their computers.
Pages on the system can contain links to the RealAudio files representing previously recorded conversations. Since the system uses a database to build HTML pages dynamically it is possible to provide the link to the sound file in the context of a page which indicates when the recording was made, who originated it, and who took part in it. This is achieved by storing this information in the database when the 'Record Save' message is sent to the Millenium CT 135.
Making a Personal Recording
In addition to recording a conference it is possible to use the system to record one's own voice only. This feature can be used for recording voice messages or for pronunciation exercises for example. Whenever a user is on line but not in a conference they have the option of clicking on the 'Record' button in the control frame of the meeting place. When they do this they are prompted to give the recording a name and to type this into a text entry box (the recording has a separate system generated unique name so it is not mandatory that the recording be named with a unique identifier). Once a name has been submitted to the system an outgoing call is initiated to the user's number and they are placed in a private (or "single user") conference in which they are the only participant. As soon as the conference is set up the recording request is automatically queued to the server. The MAP object 205 then sends the Millenium CT 1 35 the 'Record Start' message to start recording the conference. The user hears a voice announcement shortly after the start of the conference to tell them that recording has begun. They also are shown an animated 'recording' icon
When the user has finished making their recording they can press the animated recording button to stop the recording. This is achieved by sending the Millenium CT 1 35 a ' Record Stop' message. At this stage they are shown a series of icons which allow them to play back, delete, or save the recording. If they choose the 'Play' icon, the 'Playback start' message is sent to the Millenium CT 1 35 and the recording is played back to the user over the phone connection from the beginning. Whilst this is happening the play icon is replaced with an animated version. When the recording reaches the end of playback it loops to start from the beginning again. If the user selects the animated play icon then playback stops. If the user selects 'Save' then the recording is saved to RealAudio format. This is achieved by sending the Millenium CT 1 35 a 'Save Recording' message. If the user does not want to keep the recording they can select the 'Delete' icon which removes the recording by sending the Millenium CT 1 35 a ' Delete Recording' message. If the user leaves the private conference without saving their personal recording then the recording will be saved automatically. After choosing to save or delete a recording the user may go on to make more recordings whilst in the same conference
Privacy
The system aims to give users the greatest opportunity to see who else is logged on to the system whilst also protecting people from unwanted instrusion. This is done by allowing individuals to set their status as 'Do not disturb' and by letting the originator of a conference set up its status as 'Private' . The 'Do not disturb' status flag is stored in the PERSON table for that user whilst the 'Conference Privacy' status is stored in the CONFERENCE table for that conference. If a person registers themselves as ' Do not disturb' then others will have this status explained to them when they click on the person's picture; they will not be able to enter into a conference with that person. If a conference is private then other people will not be able to enter it and will be shown that it is private when they ask for detail on it. Both "Do Not Disturb" and "Privacy" functions are implemented with toggling on/off controls.
Another privacy advantage of embodiments of the present invention is that subscribers to a service need not disclose their phone number to other users - it is held on the database and used to dial calls to the user but need not be visible directly to others.
The Sleep Function One of the problems to be overcome with any virtual meeting-place is that users may log on to the system and then leave their computers to go somewhere else. This can lead to other users attempting to set-up conferences with them only to be confronted with answering machines. This problem can be solved as described above under "Removing a Person from a Conference" and this is the preferred method. However, another solution to this problem is to have the database 1 25 keep a record of all page load requests which are made by a particular user (other than regular meeting-place update requests). Each time such a request is received, a counter is reset. If the counter reaches a designated value (equivalent to, say, 1 0 minutes of elapsed 'silence' from the user) the user will be designated as asleep. At this stage if another user clicks on the "sleeping" person's name they will be shown a page in the main frame 31 5 of the meeting-place 300 telling them that the other person is asleep. In such cases, users can manually dial the person or send them email.
The meeting-place window 300 of the person who is designated as asleep changes to tell them this. There is a button labelled 'wake me up' which can be pressed to restore the user's status to 'awake' on the system's database. They will then be able to initiate or be invited into audio conferences once more.
Handling Errors and Unusual States
Error messages are displayed to the user whenever an audio-conference request (eg set-up a conference or leave a conference) fails. The request usually fails because the Millenium CT 1 35 has been unable to make a call since the called party is either engaged, not answering, or their phone number is unavailable (NU). In such cases the Millenium CT 1 35 indicates the reason for failure in the 'Make Call' response message returned to the MAP object 205. The MAP object 205 then sets the status in the request in the CONFERENCE-REQUEST table to indicate the reason for failure. When the server 1 20 receives a reload request from the client (that is currently displaying the cycling dots) it inspects the status in the request in CONFERENCE-REQUEST table. Upon finding that the request has failed it returns an error page to the client 100 describing the reason for failure. The user may then read this and return to the meeting-place 300 by clicking on a "continue" button. If they do not do this the error page will automatically re-load the meeting-place 300 after 30 seconds.
Billing
The system provides the opportunity to bill users on the basis of subscription, usage or some combination of the two. Since all audio conferencing telephone calls are outgoing from the Millenium CT platform 1 35 it is possible to offer users a special tariff for exclusive use with calls to other registered users. The charging structure for other general calls which the user makes need not be adjusted. The database stores a range of allowable dialback numbers for each user. This allows people to use the service from more than one location. Since users are prevented from entering their own dialback numbers, which have to be authorised by a system administrator, the potential for using the system fraudulently to obtain discounted telephone calls to any destination is removed. The database records the name of each user who initiates an audioconference, the duration of that audioconference and the names of people who took part in the conference, together with the lengths of time for which they took part. This data can be used to charge the conference originator, the participants or both parties on a time basis. All such information is stored in the database 1 25 together with time and date stamps. The database 1 25 records the time and date at which each user account is created or closed down This information can be used to facilitate subscription based charging.
The "Butler" Process
The butler process is intended to alert users whenever a new person comes on line, for example by playing a sound such as a bell. At this point an indicator 335 (e.g. a coloured dot) is also shown adjacent to the names of any newly arrived users in the frame 305 and the meeting place window is brought to the front of the browser The indicator persists until a new update takes place or for 2 minutes - whichever period is shorter
For each person's name that appears in the "logged on" frame of the meeting place a 'registerUser' javascript function is called in the layout code for the meeting place window. This function adds the name of the user in question to an array. It also checks a 'previous' array which contains a list of all those users who were present the last time the logged on frame was loaded. If a particular name features in the current list but not in the previous list then it is judged to be new and the function returns a 'true' value to the code in the logged on frame. This is what causes the indicator to be displayed by the name of each new user. Once all names in the logged_on frame have been 'registered' in this way the OnLoad' event for this frame is used to call a second 'butler' function in the layout document. This simply checks whether any items in the 'current' array are different from those in the 'previous' array. If this is the case then a java applet is called in the 'tools' frame of the meeting place using the LiveConnect protocol embedded in the browser. The function of this applet is simply to play a sound of a designated name. In the case of the butler a 'bell' sound is played by the client. The registerUser function increments a variable value each time it is called (starting from 0) . Whenever this value is less than 1 the function still adds the names to the current array but it does not display an indicator near a 'new' name, and the butler function does not generate its bell sound. This is to avoid names appearing as 'new' when the system is starting up
Functional Breakdown of the Objects Supporting the System
Referring to "Server Software Architecture" above, four objects installed at the server 1 20 support the functionality described above. These are the application, Millenium CT, database and Heartbeat objects 200, 205, 210. 21 5. Functionally, these deal as described with different aspects of the system.
Referring to Figure 4, the application object 200 deals with the conference controls offered to the user by means of the meeting place screen 300:
1 Login person
2 Display meeting place 2.1 Do updater
2.2 Display logged-on
2.3 Display room
2.3.1 Change telephone number
2.3.2 Start conference 2.3.3 Invite conference
2.3.4 Join conference
2.3.5 Leave conference
2.3.6 Display error message
3 Display tools 3.1 Share URL
3.2 Start recording
3.3 Stop recording Referring to Figure 5, the database object 210 deals with the interface to the database 1 25:
1 Create conference
2 Get conference-request
5 3 Create person-conference
4 Update conference
5 Create conference-request
6 Get person-conference
7 Update person-conference 10 8 Get conference
9 Update conference request
1 0 Delete person conference
1 1 Delete conference-request 1 2 Delete conference
1 5 1 3 Update person
Referring to Figure 6, the MAP object 205 deals with the interface to the Millenium CT 1 35:
1 Poll conference request table
20 2 Start conference
3 Invite conference
4 Poll Millenium CT
4.1 Record stop response received
4.2 Conference registration response received 25 4.3 Record start response received
4.4 Call clear command received
4.5 Mix all participants response received
4.6 Call clear response received
4.7 Call dial response received
30 4.8 Register platform response received
5 Leave conference
6 Join conference
7 Start recording
8 Stop recording Referring to Figure 7, the Heartbeat object 21 5 simply deals with monitoring an area of the database 1 25 and logging out users appropriately: 1 Poll database 2 Log-out person
Potential Uses for the System
The system allows groups of people to talk to each other and achieve a shared view of information without requiring that participants either learn a complex set of controls or invest in specialist equipment or software at the client end. The equipment at the server end is not particularly complex either and can be readily set up as part of a small business operation, company department or educational service for example. The system is about providing a basis for conversation and information exchange - the exact nature of the conversation and information traded is not constrained so there might be a wide variety of potential uses such as:
• application as an educational tool - in particular for teaching languages
• use by sales teams to encourage greater communication with clients
• use by fan clubs to talk about ongoing or recent events such as football matches • application as part of a customer support system for a product or service
• use as a social meeting device
• use within business as a method for helping geographically separated groups to collaborate
The system can be deployed either as a small scale set-up involving PC based audio conferencing platforms such as the Millenium CT 1 35, or to provide larger scale services on platforms such as the "integrated Speech Applications Platform" (iSAP) which has been developed by British Telecommunications pic. In the case of deployment on a PC based audio conferencing platform such as the Millenium CT 1 35, the overall group size on any platform is generally limited to 60 users by the system's capacity although a service can be spread over a bank of such platforms running in parallel. On the iSAP, the maximum size of an individual group would again tend to be 60 (limited by the capacity of each shelf on the iSAP) although a very much larger overall user group could be catered for. Whatever the scale of the platform on which the audio conferencing takes place it is possible to implement the service in such a way that more than one separate group can share the same platform (or bank of platforms) . Users in group A will see only the names of other users in group A - but not the names of users in group B or C for example. This separation can be achieved entirely through partitioning into groups in the database 1 25.
Whilst the system described above is based on standard PCs and telephones, using separate connections for voice and data, it is envisaged that the approach could be adapted to work equally effectively on systems where both datatypes were sent down the same line This would include Internet based systems. The approach is also adaptable to systems which use mobile telephony, which involve phones with built in web browsers or which use a headset connected via the soundcard of a PC rather than a separate telephone.

Claims

1 . An information retrieval system comprising at least two user interfaces, each user interface having means for accessing an information database system by means of retrieval commands, and wherein at least one, controlling, user interface has means for transmitting, to one or more of the other user interfaces, a signal containing a retrieval command, the other user interfaces being operable under control of the retrieval command signal to transmit the retrieval command to the information database to retrieve a specified item of data.
2. An information retrieval system according to claim 1 , wherein the user interfaces are linked to each other by a server application through which the retrieval command signals are transmitted.
3. An information retrieval system according to claim 2 comprising a management and control unit for a network based teleconferencing system, comprising an interface for establishing connections across a network between users, through which the signals carrying the retrieval commands may be transmitted.
4 An information retrieval system according to claim 1 2 or 3, comprising means for preventing more than one controlling user interface simultaneously transmitting a retrieval command signal to the same group of user interfaces.
5. An information retrieval system according to claim 4, comprising means for permitting different user interfaces to operate as the controlling user interface at different times.
6. An information retrieval system according to claim 4, wherein only one of the user interfaces has the capability to transmit retrieval command signals to the other users.
7. An information retrieval system according to claim 6, wherein at least one other user interface has means for transmitting signals comprising retrieval proposals to the controlling user interface, and the controlling user interface has means for converting said retrieval proposals into retrieval command signals for transmission to the other users.
8. An information retrieval system according to any preceding claim, having means for allowing one user to transmit a timed sequence of retrieval command signals to the other users.
9. An information retrieval system according to any preceding claim, having storage means for storing retrieval commands, and means for extraction of retrieval commands from said storage means for transmission as retrieval command signals.
10. A method of controlling an information retrieval system comprising at least two user interfaces, each user interface having means for accessing an information database system by means of retrieval commands, wherein one, controlling, user interface transmits, to one or more of the other user interfaces, a signal containing a retrieval command, the other user interfaces operating under control of the retrieval command signal to transmit the retrieval command to the information database to retrieve a specified item of data.
1 1 . A method according to claim 10, wherein the user interfaces are linked to each other by a server application through which the retrieval command signals are transmitted.
1 2. A method according to claim 1 0 or 1 1 , arranged to prevent more than one controlling user interface simultaneously transmitting a retrieval command signal to the same group of user interfaces.
1 3. A method according to claim 1 2, wherein different user interfaces of the same user group operate as the controlling user interface at different times.
14. A method according to claim 1 2, wherein only one user interface has the capability to transmit retrieval command signals to the other users.
1 5. A method according to claim 14, wherein one of the other user interfaces transmits signals comprising retrieval proposals to the controlling user interface, and the controlling user interface converts said retrieval proposals into retrieval command signals for transmission to the other users.
16. A method according to any of claims 10 to 1 5, wherein the controlling user interface transmits a timed sequence of retrieval command signals to the other users.
1 7. A method according to any of claims 10 to 1 6, wherein retrieval commands are extracted from a storage means for transmission as retrieval command signals.
1 8. An information retrieval system substantially as described with reference to the drawings.
1 9. A method of controlling an information retrieval system substantially as described with reference to the drawings.
PCT/GB1998/002544 1997-09-18 1998-08-24 Information retrieval system WO1999014926A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP2000512338A JP2001517031A (en) 1997-09-18 1998-08-24 Information retrieval system
EP98940372A EP1016258A1 (en) 1997-09-18 1998-08-24 Information retrieval system
CA002303053A CA2303053A1 (en) 1997-09-18 1998-08-24 Information retrieval system
AU88712/98A AU743274B2 (en) 1997-09-18 1998-08-24 Information retrieval system

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP97307245.7 1997-09-18
EP97307245 1997-09-18

Publications (1)

Publication Number Publication Date
WO1999014926A1 true WO1999014926A1 (en) 1999-03-25

Family

ID=8229514

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/GB1998/002544 WO1999014926A1 (en) 1997-09-18 1998-08-24 Information retrieval system

Country Status (5)

Country Link
EP (1) EP1016258A1 (en)
JP (1) JP2001517031A (en)
AU (1) AU743274B2 (en)
CA (1) CA2303053A1 (en)
WO (1) WO1999014926A1 (en)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001157186A (en) * 1999-09-30 2001-06-08 Internatl Business Mach Corp <Ibm> System and user interface for conference with plural participants
JP2002041429A (en) * 2000-07-26 2002-02-08 Nec Corp Method for holding conference using shared data over the internet, conference system, information processor, and recording medium
WO2002017049A2 (en) * 2000-08-25 2002-02-28 Claripoint Limited Web page access
GB2371949A (en) * 2000-11-29 2002-08-07 Hewlett Packard Co Enhancement of communication capabilities
EP1286525A1 (en) * 2001-08-22 2003-02-26 Siemens Aktiengesellschaft Method for initiating and controlling a synchronized surfing session for a voice conferencing
EP1432171A2 (en) * 2002-12-16 2004-06-23 France Telecom Protocol and system for automatically and simultaneously distributing in Internet electronic documents of different formats
US6912573B2 (en) 2000-02-15 2005-06-28 International Business Machines Corporation Method for acquiring content information, and software product, collaboration system and collaboration server for acquiring content information
EP1868347A2 (en) * 2006-06-16 2007-12-19 Ericsson AB Associating independent multimedia sources into a conference call
EP1328861B1 (en) * 2000-09-14 2014-03-05 Kadrige Remote control method for a computer display screen

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4143285B2 (en) * 2001-10-18 2008-09-03 株式会社コナミデジタルエンタテインメント GAME SERVER DEVICE, GAME MANAGEMENT METHOD, AND GAME MANAGEMENT PROGRAM
JP2003265852A (en) * 2003-03-10 2003-09-24 Konami Co Ltd Game server device, game management method and game management program

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1996037068A1 (en) * 1995-05-16 1996-11-21 Minnesota Mining And Manufacturing Company Data conferencing between remotely located participants
US5594910A (en) * 1988-07-15 1997-01-14 Ibm Corp. Interactive computer network and method of operation
WO1997012448A2 (en) * 1995-09-15 1997-04-03 Edify Corporation Web page synchronization system and method

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5594910A (en) * 1988-07-15 1997-01-14 Ibm Corp. Interactive computer network and method of operation
WO1996037068A1 (en) * 1995-05-16 1996-11-21 Minnesota Mining And Manufacturing Company Data conferencing between remotely located participants
WO1997012448A2 (en) * 1995-09-15 1997-04-03 Edify Corporation Web page synchronization system and method

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001157186A (en) * 1999-09-30 2001-06-08 Internatl Business Mach Corp <Ibm> System and user interface for conference with plural participants
US6912573B2 (en) 2000-02-15 2005-06-28 International Business Machines Corporation Method for acquiring content information, and software product, collaboration system and collaboration server for acquiring content information
JP2002041429A (en) * 2000-07-26 2002-02-08 Nec Corp Method for holding conference using shared data over the internet, conference system, information processor, and recording medium
GB2382436B (en) * 2000-08-25 2005-03-09 Claripoint Ltd Web page access
WO2002017049A2 (en) * 2000-08-25 2002-02-28 Claripoint Limited Web page access
WO2002017049A3 (en) * 2000-08-25 2003-05-22 Claripoint Ltd Web page access
EP1328861B1 (en) * 2000-09-14 2014-03-05 Kadrige Remote control method for a computer display screen
GB2371949A (en) * 2000-11-29 2002-08-07 Hewlett Packard Co Enhancement of communication capabilities
GB2371949B (en) * 2000-11-29 2004-04-07 Hewlett Packard Co Enhancement of communication capabilities
EP1286525A1 (en) * 2001-08-22 2003-02-26 Siemens Aktiengesellschaft Method for initiating and controlling a synchronized surfing session for a voice conferencing
EP1432171A3 (en) * 2002-12-16 2004-07-14 France Telecom Protocol and system for automatically and simultaneously distributing in Internet electronic documents of different formats
EP1432171A2 (en) * 2002-12-16 2004-06-23 France Telecom Protocol and system for automatically and simultaneously distributing in Internet electronic documents of different formats
EP1603270A1 (en) * 2002-12-16 2005-12-07 France Telecom S.A. Method for simultaneously displaying electronic documents of HTML format in Internet
EP1868347A2 (en) * 2006-06-16 2007-12-19 Ericsson AB Associating independent multimedia sources into a conference call
EP1868347A3 (en) * 2006-06-16 2010-07-14 Ericsson AB Associating independent multimedia sources into a conference call

Also Published As

Publication number Publication date
CA2303053A1 (en) 1999-03-25
JP2001517031A (en) 2001-10-02
AU743274B2 (en) 2002-01-24
AU8871298A (en) 1999-04-05
EP1016258A1 (en) 2000-07-05

Similar Documents

Publication Publication Date Title
EP1008258B1 (en) Network-based conference system
US6519628B1 (en) Method and system for customer service using a packet switched network
EP1169834B1 (en) System controlling use of a communication channel
US5742670A (en) Passive telephone monitor to control collaborative systems
US8250141B2 (en) Real-time event notification for collaborative computing sessions
US6418471B1 (en) Method for recording and reproducing the browsing activities of an individual web browser
EP1122926B1 (en) Messaging between terminals in different communities
US8737596B2 (en) Real-time collaboration center
US7921158B2 (en) Using a list management server for conferencing in an IMS environment
US7450567B1 (en) Web-based personal assistant
US20040107250A1 (en) Methods and systems for integrating communication resources using the internet
US9209984B2 (en) Systems and methods to facilitate communications
EP0883306A2 (en) System and method for teleconferencing on an internetwork comprising connection oriented and connectionless networks
JP2008532141A (en) Method and system for enabling systematic real-time conversation between multiple participants
US7421469B1 (en) Initiating a collaborative computing session from an advanced capability telephone
AU743274B2 (en) Information retrieval system
WO1997037484A1 (en) Multimedia document conferencing system
WO2002035782A2 (en) Method and device for transmitting streaming multimedia messages
Gibson et al. Unattended Audioconferencing
IES970916A2 (en) A Teleconferencing System

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 09142434

Country of ref document: US

AK Designated states

Kind code of ref document: A1

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM HR HU ID IL IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 1998940372

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 88712/98

Country of ref document: AU

ENP Entry into the national phase

Ref document number: 2303053

Country of ref document: CA

Ref country code: CA

Ref document number: 2303053

Kind code of ref document: A

Format of ref document f/p: F

NENP Non-entry into the national phase

Ref country code: KR

WWP Wipo information: published in national office

Ref document number: 1998940372

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWG Wipo information: grant in national office

Ref document number: 88712/98

Country of ref document: AU

WWW Wipo information: withdrawn in national office

Ref document number: 1998940372

Country of ref document: EP