Acquiring information from sources responsive to naturally-spoken-speech commands provided by a voice-enabled device

Information

  • Patent Grant
  • 10096320
  • Patent Number
    10,096,320
  • Date Filed
    Monday, September 19, 2016
    8 years ago
  • Date Issued
    Tuesday, October 9, 2018
    6 years ago
Abstract
The present invention relates to a system for acquiring information from sources on a network, such as the Internet. A voice browsing system maintains a database containing a list of information sources, such as web sites, connected to a network. Each of the information sources is assigned a rank number which is listed in the database along with the record for the information source. In response to a speech command received from a user, a network interface system accesses the information source with the highest rank number in order to retrieve information requested by the user.
Description
FIELD OF THE INVENTION

The present invention relates to a robust and highly reliable system that allows users to browse web sites and retrieve information by using conversational voice commands. Additionally, the present invention allows users to control and monitor other systems and devices that are connected the Internet or any other network by using voice commands.


BACKGROUND OF THE INVENTION

Currently, three options exist for a user who wishes to gather information from a web site accessible over the Internet. The first option is to use a desktop or a laptop computer connected to a telephone line via a modem or connected to a network with Internet access. The second option is to use a Personal Digital Assistant (PDA) that has the capability of connecting to the Internet either through a modem or a wireless connection. The third option is to use one of the newly designed web-phones or web-pagers that are now being offered on the market. Although each of these options provide a user with access to the Internet to browse web sites, each of them have their own drawbacks.


Desktop computers are very large and bulky and are difficult to transport. Laptop computers solve this inconvenience, but many are still quite heavy and are inconvenient to carry. Further, laptop computers cannot be carried and used everywhere a user travels. For instance, if a user wishes to obtain information from a remote location where no electricity or communication lines are installed, it would be nearly impossible to use a laptop computer. Oftentimes, information is needed on an immediate basis where a computer is not accessible. Furthermore, the use of laptop or desktop computers to access the Internet requires either a direct or a dial-up connection tan an Internet Service Provider (ISP). Oftentimes, such connections are not available when a user desires to connect to the Internet to acquire information.


The second option for remotely accessing web sites is the use of PDAs. These devices also have their own set of drawbacks. First, PDAs with the ability to connect to the Internet and access web sites are not readily available. As a result, these PDAs tend to be very expensive. Furthermore, users are usually required to pay a special service fee to enable the web browsing feature of the PDA. A further disadvantage of these PDAS is that web sites must be specifically designed to allow these devices to access information on the web site. Therefore, a limited number of web sites are available that are accessible by these web-enabled PDAs. Finally, it is very common today for users to carry cell phones, however, users must also carry a separate PDA if they require the ability to gather information from various web sites. Users are therefore subjected to added expenses since they must pay for both cellular telephone service and also for the web-enabling service for the PDA. This results in a very expensive alternative for the consumer.


The third alternative mentioned above is the use of web-phones or web-pagers. These devices suffer many of the same drawbacks as PDAs. First, these devices are expensive to purchase. Further, the number of web sites accessible to these devices is limited since web sites must be specifically designed to allow access by these devices. Furthermore, users are often required to pay an additional fee in order to gain wireless web access. Again, this service is expensive. Another drawback of these web-phones or web-pagers is that as technology develops, the methods used by the various web sites to allow access by these devices may change. These changes may require users to purchase new web-phones or web-pagers or have the current device serviced in order to upgrade the firmware or operating system stored within the device. At the least, this would be inconvenient to users and may actually be quite expensive.


Therefore, a need exists for a system that allows users to easily access and browse the Internet from any location. Such a system would only require users to have access to any type of telephone and would not require users to subscribe to multiple services.


In the rapidly changing area of Internet applications, web sites change frequently. The design of the web site may change, the information required by the web site in order to perform searches may change, and the method of reporting search results may change. Web browsing applications that submit search requests and interpret responses from these web sites based upon expected formats will produce errors and useless responses when such changes occur. Therefore, a need exists for a system that can detect modifications to web sites and adapt to such changes in order to quickly and accurately provide the information requested by a user through a voice enabled device, such as a telephone.


When users access web sites using devices such as personal computers, delays in receiving responses are tolerated and are even expected, however, such delays are not expected when a user communicates with a telephone. Users expect communications over a telephone to occur immediately with a minimal amount of delay time. A user attempting to find information using a telephone expects immediate responses to his search requests. A system that introduces too much delay between the time a user makes a request and the time of response will not be tolerated by users and will lose its usefulness. Therefore, it is important that a voice browsing system that uses telephonic communications selects web sites that provide rapid responses since speed is an important factor for maintaining the system's desirability and usability. Therefore, a need exists for a system that accesses web sites based upon their speed of operation.


SUMMARY OF THE INVENTION

It is an object of an embodiment of the present invention to allow users to gather information from web sites by using voice enabled devices, such as wireline or wireless telephones.


An additional object of an embodiment of the present invention is to provide a system and method that allows the searching and retrieving of publicly available information by controlling a web browsing server using naturally spoken voice commands.


It is an object of another embodiment of the present invention to provide a robust voice browsing system that can obtain the same information from several web sites based upon a ranking order. The ranking order is automatically adjusted if the system detects that a given web site is not functioning, is too slow, or has been modified in such a way that the requested information cannot be retrieved any longer.


A still further object of an embodiment of the present invention is to allow users to gather information from web sites from any location where a telephonic connection can be made.


Another object of an embodiment of the present invention is to allows users to browse web sites on the Internet using conversational voice commands spoken into wireless or wireline telephones or other voice enabled devices.


An additional object an embodiment of the present invention is to provide a system and method for using voice commands to control and monitor devices connected to a network.


It is an object of an embodiment of the present invention to provide a system and method which allows devices connected to a network to be controlled by conversational voice commands spoken into any voice enabled device interconnected with the same network.


The present invention relates to a system for acquiring information from sources on a network, such as the Internet. A voice browsing system maintains a database containing a list of information sources, such as web sites, connected to a network. Each of the information sources is assigned a rank number which is listed in the database along with the record for the information source. In response to a speech command received from a user, a network interface system accesses the information source with the highest rank number in order to retrieve information requested by the user.


The a preferred embodiment of the present invention allows users to access and browse web sites when they do not have access to computers with Internet access. This is accomplished by providing a voice browsing system and method that allows users to browse web sites using conversational voice commands spoken into any type of voice enabled device (i.e., any type of wireline or wireless telephone, LP phone, wireless PDA, or other wireless device). These spoken commands are then converted into data messages by a speech recognition software engine running on a user interface system. These data messages are then sent to and processed by a network interface system. This network interface system then generates the proper requests that are transmitted to the desired web site over the Internet. Responses sent from the web site are received and processed by the network interface system and then converted into an audio message via a speech synthesis engine or a pre-recorded audio concatenation application and finally transmitted to the user's voice enabled device.


A preferred embodiment of the voice browser system and method uses a web site polling and ranking methodology that allows the system to detect changes in web sites and adapt to those changes in real-time. This enables the voice browser system of a preferred embodiment to deliver highly reliable information to users over any voice enabled device. This ranking system also enables the present invention to provide rapid responses to user requests. Long delays before receiving responses to requests are not tolerated by users of voice-based systems, such as telephones. When a user speaks into a telephone, an almost immediate response is expected. This expectation does not exist for non-voice communications, such as email transmissions or accessing a web site using a personal computer. In such situations, a reasonable amount of transmission delay is acceptable. The ranking system of implemented by a preferred embodiment of the present invention ensures users will always receive the fastest possible response to their request.


An alternative embodiment of the present invention allows users to control and monitor the operation of a variety of household devices connected to a network using speech commands spoken into a voice enabled device.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a depiction of the voice browsing system of the first embodiment of the present invention;



FIG. 2 is a block diagram of a database record used by the first preferred embodiment of the present invention;



FIG. 3 is a block diagram of a media server used by the preferred embodiment;



FIG. 4 is a block diagram of a web browsing server used by the preferred embodiment; and



FIG. 5 is a depiction of the device browsing system of the second embodiment of the present invention.





DETAILED DESCRIPTION OF THE INVENTION

A first embodiment of the present invention is a system and method for allowing users to browse information sources, such as web sites, by using naturally spoken, conversational voice commands spoken into a voice enabled device. Users are not required to learn a special language or command set in order to communicate with the voice browsing system of the present invention. Common and ordinary commands and phrases are all that is required for a user to operate the voice browsing system. The voice browsing system recognizes naturally spoken voice commands and is speaker-independent; it does not have to be trained to recognize the voice patterns of each individual user. Such speech recognition systems use phonemes to recognize spoken words and not predefined voice patterns.


The first embodiment allows users to select from various categories of information and to search those categories for desired data by using conversational voice commands. The voice browsing system of the first preferred embodiment includes a user interface system referred to as a media server. The media server contains a speech recognition software engine. This speech recognition engine is used to recognize natural, conversational voice commands spoken by the user and converts them into data messages based on the available recognition grammar. These data messages are then sent to a network interface system. In the first preferred embodiment, the network interface system is referred to as a web browsing server. The web browsing server then accesses the appropriate information source, such as a web site, to gather information requested by the user.


Responses received from the information sources are then transferred to the media server where speech synthesis engine converts the responses into audio messages that are transmitted to the user. A more detailed description of this embodiment will now be provided.


Referring to FIG. 1, a database 100 designed by Webley Systems Incorporated is connected to one or more web browsing servers 102 as well as to one or more media servers 106. The database may store information on magnetic media, such as a hard disk drive, or it may store information via other widely acceptable methods for storing data, such as optical disks. The database 100 contains a separate set of records for each web site accessible by the system. An example of a web site record is shown in FIG. 2. Each web site record 200 contains the rank number of the web site 202, the associated Uniform Resource Locator (URL) 204, and a command that enables the appropriate “extraction agent” 206 that is required in order to generate proper requests sent to and to format data received from the web site. The database record 200 also contains the timestamp 208 indicating the last time the web site was accessed. The extraction agent is described in more detail below. The database 100 categorizes each database record 200 according to the type of information provided by each web site. For instance, a first category of database records 200 may correspond to web sites that provide “weather” information. The database 100 may also contain a second category of records 200 for web sites that provide “stock” information. These categories may be further divided into subcategories. For instance, the “weather” category may contain subcategories depending upon type of weather information available to a user, such as “current weather” or “extended forecast”. Within the “extended forecast” subcategory, a list of web site records may be stored that provide weather information for multiple days. The use of subcategories may allow the web browsing feature to provide more accurate, relevant, and up-to-date information to the user by accessing the most relevant web site. The number of records contained in each category or subcategory is not limited. In the preferred embodiment, three web site records are provided for each category.


Table 1 below depicts two database records 200 that are used with the preferred embodiment. These records also contain a field indicating the “category” of the record, which is “weather” in each of these examples.











TABLE 1








category: weather




URL:URL=http://cgi.cnn.com/cgi-




bin/weather/redirect?zip=_zip




rank: 1




command: web_dispatch.pl weather_cnn




browsingServer: wportal1




browsingServerBackup: wportal2




dateTime: Dec 21 2000 2:15PM




category: weather




URL: URL= http: //weather.lycos.com/wcfiveday.asp?city=zip




rank: 2




command: web_dispatch.pl weather_lycos




browsingServer: wportal1




browsingServerBackup: wportal2




dateTime: Dec 21 2000 1:45PM









The database also contains a listing of pre-recorded audio files used to create concatenated phrases and sentences. Further, database 100 may contain customer profile information, system activity reports, and any other data or software servers necessary for the testing or administration of the voice browsing system.


The operation of the media servers 106 will now be discussed in relation to FIG. 3. The media servers 106 function as user interface systems. In the preferred embodiment, the media servers 106 contain a speech recognition engine 300, a speech synthesis engine 302, an Interactive Voice Response (IVR) application 304, a call processing system 306, and telephony and voice hardware 308 required to communicate with the Public Switched Telephone Network (PSTN) 116. In the preferred embodiment, each media server is based upon Intel's Dual Pentium III 730 MHz microprocessor system.


The speech recognition function is performed by a speech recognition engine 300 that converts voice commands received from the user's voice enabled device 112 (i.e., any type of wireline or wireless telephone, Internet Protocol (IP) phones, or other special wireless units) into data messages. In the preferred embodiment, voice commands and audio messages are transmitted using the PSTN 116 and data is transmitted using the TCP/IP communications protocol. However, one skilled in the art would recognize that other transmission protocols may be used for either voice or data. Other possible transmission protocols would include SIP/VoIP (Session Initiation Protocol/Voice over IP), Asynchronous Transfer Mode (ATM) and Frame Relay. A preferred speech recognition engine is developed by Nuance Communications of 1380 Willow Road, Menlo Park, Calif. 94025 (www.nuance.com). The Nuance engine capacity is measured in recognition units based on CPU type as defined in the vendor specification. The natural speech recognition grammars (i.e., what a user can say that will be recognized by the speech recognition engine) were developed by Webley Systems.


Table 2 below provides a partial source code listing of the recognition grammars used by the speech recognition engine of the preferred embodiment for obtaining weather information.











TABLE 2








?WHAT_IS ?the weather?[info information report conditions]




 ?( (?like in)




 ]




UScities:n




 {<param1 $n.zip> <param2 $n.city> <param3




 $n.state>}




  ( (area code) AREA_CODE:n) {<param1 $n>}




  ( AREA_CODE:n (area code) ) {param1 $n>}




  ( (ZIP_CODE:n (zip ?code) ) {<param1 $n>}




 ]




 )




  ) {<mem 194>}









The media server 106 uses recognition results generated by the speech recognition engine 300 to retrieve a web site record 200 stored in the database 100 that can provide the information requested by the user. The media server 106 processes the recognition result data identifying keywords that are used to search the web site records 200 contained in the database 100. For instance, if the user's request was “What is the weather in Chicago?”, the keywords “weather” and “Chicago” would be recognized. A web site record 200 with the highest rank number from the “weather” category within the database 100 would then be selected and transmitted to the web browsing server 102 along with an identifier indicating that Chicago weather is being requested.


The media servers 106 also contain a speech synthesis engine 302 that converts the data retrieved by the web browsing servers 102 into audio messages that are transmitted to the user's voice enabled device 112. A preferred speech synthesis engine is developed by Lernout and Hauspie Speech Products, 52 Third Avenue, Burlington, Mass. 01803 (www.lhsl.com).


A further description of the web browsing server 102 will be provided in relation to FIG. 4. The web browsing servers 102 provide access to any computer network such as the Internet 110. These servers are also capable of accessing databases stored on Local Area Networks (LANs) or Wide Area Networks (WANs). The web browsing servers receive responses from web sites and extract the data requested by the user. This task is also known as “content extraction.” The web browsing servers 102 also perform the task of periodically polling or “pinging” various web sites and modifying the ranking numbers of these web sites depending upon their response and speed. This polling feature is further discussed below. The web browsing server 102 is comprised of a content extraction agent 400, a content fetcher 402, a polling and ranking agent 404, and the content descriptor files 406. Each of these are software applications and will be discussed below.


Upon receiving a web site record 200 from the database 100 in response to a user request, the web browsing server 102 invokes the “content extraction agent” command 206 contained in the record 200. The content extraction agent 400 allows the web browsing server 102 to properly format requests and read responses provided by the web site 114 identified in the URL field 204 of the web site record 200. Each content extraction agent command 206 invokes the content extraction agent and identifies a content description file associated with the web page identified by the URL 204. This content description the directs the extraction agent where to extract data from the accessed web page and how to format a response to the user utilizing that data. For example, the content description for a web page providing weather information would indicate where to insert the “city” name or ZIP code in order to retrieve Chicago weather information. Additionally, the content description file for each supported URL indicates the location on the web page where the response information is provided. The extraction agent 400 uses this information to properly extract from the web page the information requested by the user.


Table 3 below contains source code for a content extraction agent 400 used by the preferred embodiment.











TABLE 3








 #!/usr/local/www/bin/sybper15




 #$Header:




 /usr/local/cvsroot/webley/agents/service/web_dispatch.pl,v




 1.6




 # Dispatches all web requests




 #http://wcorp.itn.net/cgi/flstat?carrier=ua&flight_no=155&mo




 n_abbr=jul&date=




 6&stamp=OhLN~PdbuuE*itn/ord,itn/cb/sprint_hd




 #http://cgi.cnnfn.com/flightview/rlm?airline=amt&number=300




 require “config_tmp.pl” ;




 #check parameters




 die “Usage: $0 service [params]\n” if $#ARGV < 1;




 #print STDERR @ARGV;




 #get parameters




 my %Services = (




   weather_cnn => ‘webget.pl weather_cnn’,




   weather_lycos => ‘webget.pl




 weather_lycos’,




   weather_weather => ‘webget.pl




 weather_weather’,




   weather_snap => ‘webget.pl




 weather_snap’,




   weather_infospace => ‘webget.pl




 weather_infospace’,




   stockQuote_yahoo => ‘webget.pl stock’,




   flightStatus_itn => ‘webget.pl




 flight_delay’,




   yellowPages_yahoo => ‘yp_data.pl’,




   yellowPages_yahoo => ‘yp_data.pl’,




   newsHeaders_newreal => ‘news.pl’,




   newsArticle_newsreal => ‘news.pl’,




   );




 # test param




 my $date = ‘date’;




 chop ( $date );




 my ( $short_date ) = $date =~ / \s+ (\w{3}\s+\d{1,2}\s+/;




 my %Test = (




   weather_cnn => ‘60053’,




   weather_lycos => ‘60053’,




   weather_weather => ‘60053’,




   weather_snap => ‘60053’,




   weather_infospace => ‘60053’,




   stockQuote_yahoo => ‘msft’,




   flightStatus_itn => ‘ua 155’ .




 $short_date,




   yellowPages_yahoo => ‘tires 60015’,




   newsHeaders_newsreal => ‘1’ ,




   newsArticle_newsreal => ‘1 1’,




   );




 die “$date: $0: error: no such service: $service (check this




 script)\n”




 unless $Services {$service };




 # prepare absolute path to run other scripts




 my ( $path, $script ) = $0 =~ ml{circumflex over ( )} (*/) ([{circumflex over ( )}/]*)|;




 # store the service to compare against datatable




 my $service_stored = $service;




 # run service




 While ( !( $response = ‘$path$Services [$service }@param’ ) )




 {




  # response failed




  # check with test parameters




  $response = ‘$path$Services{service }$Test{$service




 }” ;




  if ( $response ) {




     $service = &switch_service ( $service );




 #   print “Wrong parameter values were supplied:




 $service -




 @param\n”;




 #   die “$date: $0: error: wrong parameters: $service




 -




 @param\n”;




  }




  else {




     # change priority and notify




     $service = &increase_attempt ( $service ) ;




  }




 }




 # output the response




 print $response;




 sub increase_attempt {




  my ( $service ) = @_;




  my ( $service_name ) + split ( /_/, $service );




  print STDERR “$date: $0: attn.: changing priority for




 service:




 $service\n”;




  # update priority




  &db_query( “update mcServiceRoute ”




   / “set priority = ( select max ( priority )




 from




 mcServiceRoute “




   . “where service = ‘$service_name’ ) + 1




 “




   . “ date = getdate( ), ”




   . “attempt = attempt + 1 ”




   . “where route = ‘$script $service’ ” );




  # print “---$route===\n”;




   # find new route




   my $route = @{&db_query ( “select route from




  mcServiceRoute “




       . “where service =




  ‘$service_name’ ”




       . “and attempt < 5




  “




       . “order by




  priority ”)




       } -> [0] {route };




   &db_query ( “update mcServiceRoute “




     . “set attempt = ) “




     . “where route = ‘$script $service’ ” )




    if ( $route eq “$script $service_stored” ) ;




      or $route eq “$script $service_stored” ) ;




   ( $service_name, $service ) = split ( / \ s + /, $route );




   die “$date: $0: error: no route for the service:




  $service (add




  more) \n”




     unless $service;




    return $service;




  }




  sub switch_swervice {




    my ( $service ) = @_;




    my ( $service name ) = split ( /_/, $service );




    print STDERR “$date: $0: attn.: changing priority for




   service:




   $service\n”;




    # update priority




    &db_query ( “update mcServiceRoute “




       . “set priority = ( select max ( priority )




from




mcServiceRoute ”




     . “ where service = ‘$service_name’ ) + 1,









     . “ date = getdate ( ) ”




     . “ where route = ‘$script $service’ ” );




#  print “---$route===\n”;




  # find new route




  my $route = @ {$db_query ( “select route from




mcServiceRoute ”




       . “where service =




‘$service name’ ”




       . “ and attempt < 5









       . “ order by priority ”)




      } - > [0] {route };




  die “ $date: $0: error: there is the only service:




$route (add




more) \n”




   if( $route eq “$script $service”




    or $route eq “$script $service_stored” ) ;




  ( $service_name, $service ) = split ( / \s+/, $route );




  die “$date: $0: error: no route for the service:




$service (add




more) \n”




    nless $service;




   return $service;




} -









Table 4 below contains source code of the content fetcher 402 used with the content extraction agent 400 to retrieve information from a web site.









TABLE 4







# !/usr/local/www/bin/sybper15


#-T


# -w


# $Header:


/usr/local/cvsroote/Webley/agents/service/webget.pl,v 1.4


# Agent to get info from the web.


# Parameters: service_name [service_parameters], i.e. stock


msft or weather


60645


# Configuration stored in files service_name.ini


# if this file is absent the configuration is received from


mcServices table


# This script provides autoupdate to datatable if the .ini


file is newer.


$debug= 1;


use URI : : URL;


use LWP : : UserAgent;


use HTTP : : Request : : Common;


use Vail : : VarList;


use Sybase : : CTlib;


use HTTP : : Cookies;


#print “Sybase: : CTlib $DB_USER, $DB_PWD, $DB_SRV;” ;


open (STDERR, “>>$0.log” ) if $debug;


#open ( STDERR, “>&STDOUT” ) ;


$log = ‘date’;


#$response = ‘./url.pl


http://cgi.cnn.com/cgi-bin/weather/redirect?zip=60605” ‘;


#$response = ‘pwd’;


#print STDERR “ ls = $response\n” ;


#$response = ‘ls’;


#print STDERR “ls = $response\n”;


chop ( $log ) ;


$log .= “pwd=” . ‘pwd’;


chop ( $log );


#$debug2 = 1;


my $service = shift;


$log .= “ $service: “. Join( ‘ : ’, @ARGV ) . “\n” ;


Print STDERR $log if $debug;


#$response = ‘./url.pl


“/http://cgi.cnn.com/cgi-bin/weather/redirect?zip=60605” ’;


my @ini = &read_ini ( $service );


chop ( @ini );


my $section = “ “ ;


do ($section = &process_section ( $section ) }while $section;


#$response = ‘./url/pl


“http://cgi.cnn.com/cgi-bin/weather/redirect?zip=60605” ‘;


exit;


sub read_ini {


 my ( $service ) = @_;


 my @ini= ( );


 # first, try to read file


 $0 =~ m|{circumflex over ( )} (.*/) [{circumflex over ( )}/]*|;


 $service = $1 . $service;


 if( open ( INI, “$service.ini” ) ) {



  @ ini =( <INI> );




  return @ ini unless ( $DB_SRV );




  # update datatable




  My $file_time = time − int ( ( -M “$service.ini” )



* 24*


3600 ) ;


#  print “time $file_time\n”;



  my $dbh = new Sybase: : CTlib $DB_USR, $DB_PWD,



$DB_SRV;



  unless ( $dbh) {



    print STDERR “webget.pl: Cannot connect to


dataserver $DB_SRV:$DB_USR:$DB_PWD\n”;


    return @ini;



  }




  my @row_refs = $dbh ->ct_sql ( “select lastUpdate



from


mcServices where service = ‘$service’ ”, undef, 1 );


 if ($dbh -> RC } == CS_FAIL) {



  print STDERR “webget.pl: DB select from



mcServices


failed\n”;



  return @ini;



 }


 unless (defined @ row_refs ) {



  # have to insert




  my ( @ini_escaped ) = map {



    ( my $x = $_ ) =~ s / \’ / \ ‘ \’ / g;


    $x;



  }@ini;




  $dbh-> ct_sql ( “insert mcServices values (



‘$service’,


‘@ini_escaped’, $file_time )” );



  if( $dbh-> {RC } =− CS_FAIL ) {



    print STDERR “webget,pl: DB insert to


mcServices failed\n”;



  }




  return @ini;



 }


 Print “time $file_time:”.$row_refs [ 0 ] -


>{‘lastUpdate’


}. “ \n” ;



  if( $file_time > $row_refs [0] => {‘lastUpdate’ })



{


    # have to update


    my ( @ini_escaped ) = map {


     (my $x = $_) =~s/ \‘/ \‘\‘/g;


     $x;


    }@ini;


    $dbh->ct_sql ( “update mcServices set config =


‘@ini_escaped’, lastUpdate = $file_time where service =


‘$service’ ” );


    if( $dbh -> {RC } ==CS_FAIL ) {


     print STDERR “webget.pl: DB update to


mcServices failed\n”;


    }



  }




  return @ini;



 }


 else {



  print STDERR “$0: WARNING: $service.ini n/a in” .



‘pwd’


    . “Try to read DB\n”;


 }


 # then try to read datatable


 die “webget.pl: Unable to find service $service\n”


unless ( $DB_SRV)


) ;


 my $ dbh = new Sybase : : CTlib $DB_USR, $DB_PWD, $DB_SRV;


 die “webgetlpl: Cannot connect to dataserver


$DB_SRV : $DB_USR: $DB_PWD\n” unless ( $dbh );


 my @row_refs = $dbh -> ct_sql ( “select config from


mcServices where


service = ‘$service’ ”, undef, 1 );


 die “webget.pl: Unable to find service $service\n”


unless ( defined


@row_refs ) ;


 $row_refs [0] -> {‘config’ } =~ s/\n /\n\r/g;


 @ini = split ( / \ r /, $row_refs [0] -> {‘config’ } );


 return @ini;


} -


############################################################


sub process_section {


 my ( $prev_section ) = @_;


 my ( $section, $output, $content );


 my %Param;


 my %Content;


#  print” ######################\n”;



  foreach ( @ini ) {



#   print;


#   chop;



    s/ \s+ $ / /;




    s/ {circumflex over ( )} \s + / /;




    # get section name




    if ( /{circumflex over ( )}\ [ (.*) / ] ) {



#    print “$_: $section:$prev_section\n”;



     last if $section;




     next if $1 eq “print” ;




     next if $prev_section ne ” ” and $prev_section



ne $1;



     if( $prev_section eq $1 ) {



      $prev_section = ” ”


      next;



      }




      $section = $1;




    }




    # get parameters




    push ( @{$Param{$1 }}, $2) if $section and



/ ([{circumflex over ( )}=]+) − (.*)/ ;


 }


#  print” ++++++++++++++++++++++++++++++++++\n”;



  return 0 unless $section;



#  print “section $section\n”;



  # substitute parameters with values




  map {$Param{URL } -> [ 0 ] =~ s/$Param{ Input } -> [ $_



] / $ARGV [ $_


] / g



  }0 . . $#{$Param{Input } };




  # get page content




  ( $Content{‘TIME’ }, $content ) = &get_url_content (



${$ Param {URL


} } [ 0 ] ) ;


 # filter it


 map {



  if ( / \” ([{circumflex over ( )}\”] + ) \” ([{circumflex over ( )}\”]*) \” / or



/ \ / ( [{circumflex over ( )} \ / ] + ) \ / ( [ {circumflex over ( )} \ / ] *) \ / / )


{


    my $out = $2; $content =~ s/$1/$out/g;



  }



 -}@{$Param {“Pre-filter” } };


#print STDERR $content;



  #do main regular expression




  unless ( @values = $content =~



/$ {$Param {Regular_expression } } [ 0


]/ ) {



  &die_hard ( ${$Param{Regular_expression } } [0 ],



$content


);



  return $section;



 }


 %Content = map { ( $Param[Output } -> [ $_ ], $values [ $_


] )


 }0 . . $#{$Param{Output }} ;


 # filter it


 map {



  if ( / ([{circumflex over ( )}\”]+) \ ” ([{circumflex over ( )}\”] +) \ = ( [{circumflex over ( )}\”] +) \ “ /



    or / ([{circumflex over ( )}\ /]+) \ / ([{circumflex over ( )} \ / ] + ) \ / ( [ {circumflex over ( )} \ / ] * ) \ / / ) {


     my $out =$3;


    $Content {$1 } =~ s/$2/$out/g;



  }



 _}@{Param {“Pre-filer” } };


#print STDERR $content;


 # do main regular expression


 unless ( @values = $content =~


/${$Param{Regular_expression } } [ 0


]/ ) {



  &die_hard( ${$Param{Regular_expression}} [ 0 ],



$content


);



  return $section;



 }


 %Content= map { ( $Param{Output }->[ $_ ], $values [ $_


] )


 }0 .. $#{$Param{Output }};


  #filter it


  map {


   if ( / ( [ {circumflex over ( )} \”] +) \ “ ( [{circumflex over ( )}\”]+) \ “ ( [ {circumflex over ( )} \ “ ] * ) \ “ /


    or / ( [{circumflex over ( )}\ / ] + ) \ / ( [{circumflex over ( )} \ / + ) \ / ( [{circumflex over ( )} \ / ]* ) \ / / ) {


     my $out = $3;


    $Content {$1 } =~ s/$2/$out/g;


   }


 }@{$Param{“Post-filter” } };


 # calculate it


 map {


   if { / ( [ {circumflex over ( )} =] + ) = (.*) / ) {


     my $eval =$2;


     map {$eval =~ s/$_/$Content {$_} / g


     } keys %Content;


    $Content {$1 } = eval ($eval ) ;


   }


 }@{$Param{Calculate }};


# read section [print]


foreach $i ( 0 .. $#ini ) {


 next unless $ini [ $i ] =~ /{circumflex over ( )}\ [print \ ] /;


 foreach ( $i + 1 . . $#ini ) {


   last if $ini [ $_ ] =~ /{circumflex over ( )}\ [.+\]/;


  $output .= $ini [ $_] . ″\n″;


 }


 last;


}


# prepare output


map {$output =~ s/$_/$Content{$_} / g


}keys %Content;


print $output;


-return 0;


}


#######################################################


sub get_url_content {


 my ( $url ) = @_;


 print STDERR $url if $debug;


 # $response= ′./url.pl ′$url′ ′;


 $response= ′./url.pl ′$url′ ′;


 return( $time - time, $response );


 my $ua = LWP: :UserAgent->new;


 $ua->agent ( ′Mozilla/4.0 [en] (X11; I; freeBSD 2.2.8-


STABLE i386)′


) ;


# $ua->proxy( [′http′, ′https′],


′http://proxy.webley:3128/′ ) ;


# $ua->no_proxy( ′webley′, ′vail′ );



 my $cookie=HTTP::Cookies->new;




 $ua->cookie_jar( $cookie ) ;




 $url = url $url;




  print ″$url\n″ if $debug2;




 my $time = time;




 my $res= $ua->request( GET $url ) ;




 print ″Response: ″ . ( time - $time ″sec\n″ if



$debug2;



 return ( $time - time, $res->content ) ;



}]


######################################################


sub die_hard {



 my ( $re, $content ) = @_;




 my ( $re_end, $pattern ) ;




 while ( $content !~ /$re/ ) {



   if ($re=~ s/(\([″\(\))+\) [″\(\) | *$) / / ) {


    $re_end = $1 . $re_end;


   }


   else {


    $re_end = $re;


    last;


   }



 }




 $content =~ /$re/;




 Print STDERR “The regular expression did not match:\n



$ re\n


Possible misuse:


$re end: \n


Matched:


$&\n


Mismatched:


$′\n


″ if $debug;



 if( $debug ) {



    print STDERR ″Content:\n $content\n″ unless


$’; -



 }



}


#######################################################









Table 5 below contains the content descriptor file source code for obtaining weather information from the web site www.cnn.com that is used by the extraction agent 400 of the preferred embodiment.











TABLE 5








[cnn]




Input=_zip




URL=http://cgi.cnn.com/cgi-bin/weather/redirect?zip=_zip




Pre-filter=″\n″ ″




Pre-filter=″<[{circumflex over ( )}< >]+>″″




Pre-filter=/ \s+/ /




Pre-filter=″ [ \ ( \ ) \ | ] ″ !″




Output=_location




Output=first_day_name




Output=first_day_weather




Output=first_day_high_F




Output=first_day_high_C




Output=first_day_low_F




Output=first_day_low_C




Output=second_day_name




Output=second_day_weather




Output=second_day_high_F




Output=second_day_high_C




Output=second_day_low_F




Output=second_day_low C




Output=third_day_name




Output=third_day_weather




Output=third_day_high_F




Output=third_day_high_C




Output=third_day_low_F




Output=third_day_low_C




Output=fourth_day_name




Output=fourth_day_weather




Output=fourth_day_high_F




Output=fourth_day_high_C




Output=fourth_day_low_F




Output=fourth_day_low_C




Output=undef




Output=_current_time




Output=_current_month




Output=_current_day




Output=_current_weather




Output=_current_temperature_F




Output=_current_temperature_C




Output=_humidity




Output=_wind




Output=_pressure




Output=_sunrise




Output=_sunset




Regular_expression=Author &nbsp; (.+) Four Day Forecast




(\S+) (\S+) HIGH




(\S+) F (\S+) C LOW (\S+) F (\S+) C (\S+) (\S+) HIGH (\S+) F




( \S+) C LOW




(\S+) F (\S+) C (\S+) (\S+) HIGH (\S+) F (\S+) C LOW (\S+) F




(\S+) C (\S+)




(\S+) HIGH (\S+) F (\S+J C LOW (\S+) F (\S+) C ( .+) Current




Conditions (. +)




! local ! , (\S+) (\S+) (. t) Temp: (\S+) F, (\S+) C Rel.




Humidity: ( \S+) Wind:




(. +) Pressure: ( .+) Sunrise: ( .+) Sunset: ( .+) Related Links




Post-filter=_current_weather″ p/″ partly ″




Post-filter=_current_weather″l/″little ″




Post-filter=_current_weather″m/″mostly ″




Post-filter=_current_weather″t-/″thunder″ -




Post-filter=_wind″N″North″




Post-filter=_wind″E″East ″




Post-filter=_wind″S″South ″ --




Post-filter=_wind″W″West fl




Post-filter=_wind/mph/miles per hour/




Post-filter=_wind/kph!/kilometers per hour/




Post-filter=_wind″ \s+ !″, ”




[print]




Current weather in_location is_current_weather.




Temperature is _current_temperature_F Fahrenheit,




_current_temperature_C




Celsium.




Humidity is_humidity.




Wind from the _wind.









Table 6 below contains the content descriptor file source code for obtaining weather information from the web site www.lycos.com that is used by the extraction agent 400 of the preferred embodiment.











TABLE 6








[lycos]




Input=zip




Input=city




URL=http://weather.lycos.com/wcfiveday.asp?city=zip




Pre-filter=″\n” ”




Pre-filter=″</TD>”td″




Pre-filter=″<!.*?->″″




Pre-filter=″<br>″_br_″




Pre-filter=/alt=″/>alt=/




Pre-filter=″<[{circumflex over ( )}< >]+>″″




Pre-filter=″&nbsp;″ ″




Pre-filter=/ \s+/ /




Output=_location




Output=_current_weather




Output=_current_temperature_F




Output=_humidity




Output=_winddir




Output=_windspeed




Output=_windmeasure




Output=_pressure




Output=first_day_name




Output=second_day_name




Output=third_day_name




Output=fourth_day_name




Output=fifth_day_name




Output=first_day_weather




Output=second_day_weather




Output=third_day_weather




Output=fourth_day_weather




Output=fifth_day_weather




Output=first_day_high_F




Output=first_day_low_F




Output=second_day_high_F




Output=second_day_low_F




Output=third_day_high_F




Output=third_day_low_F




Output=fourth_day_high_F




Output=fourth_day_low_F




Output=fifth_day_high_F




Output=fifth_day_low_F




Output=_windkmh




Regular expression=Guide My Lycos (.+) Click image to




enlarge




alt=([{circumflex over ( )}″]+) ″ (?:.+) Temp: (\(d+) (?:.+)F _br_ Humidity:




(\S+) (?: .+) Wind: ( .+?)




_br_




Output=_current_temperature_C




Post-filter=_location″_br_″ ″




Post-filter=_current_weather″p/″partly ″




Post-filter=_current_weather″m/″mostly ″




Post-filter=_current_weather″t-/″thunder ″




Post-filter=_winddir″@″ at″




Post-filter=_winddir/mph/miles per hour/




Post-filter=_wind/kph!/kilometers per hour/




Calculate=_current_temperature_C=int ( (_current_temperature_F




−32) * 5/9)




Calculate=_windkmh=int(_windspeed*1.6)




[print]




The current weather in _location is _current_weather.




The current temperature is _current_temperature_F_Farenheit




_current_temperature_C Celcius.




Humidity is _humidity.




Winds _winddir.









Once the web browsing server 102 accesses the web site specified in the URL 204 and retrieves the requested information, the information is forwarded to the media server 106. The media server uses the speech synthesis engine 302 to create an audio message that is then transmitted to the user's voice enabled device 112. In the preferred embodiment, each web browsing server 102 is based upon Intel's Dual Pentium III 730 MHz microprocessor system.


Referring to FIG. 1, the operation of the robust voice browser system will be described. A user establishes a connection between his voice enabled device 112 and a media server 106. This may be done using the Public Switched Telephone Network (PSTN) 116 by calling a telephone number associated with the voice browsing system 118. Once the connection is established, the media server 106 initiates an interactive voice response (WR) application 304. The IVR application plays audio messages to the user presenting a list of options, such as, “stock quotes”, “flight status”, “yellow pages”, “weather”, and “news”. These options are based upon the available web site categories and may be modified as desired. The user selects the desired option by speaking the name of the option into the voice enabled device 112.


As an example, if a user wishes to obtain restaurant information, he may speak into his telephone the phrase “yellow pages”. The FIR application would then ask the user what he would like to find and the user may respond by stating “restaurants”. The user may then be provided with further options related to searching for the desired restaurant. For instance, the user may be provided with the following restaurant options, “Mexican Restaurants”, “Italian Restaurants”, or “American Restaurants”. The user then speaks into the telephone 112 the restaurant type of interest. The IVR application running on the media server 106 may also request additional information limiting the geographic scope of the restaurants to be reported to the user. For instance, the IVR application may ask the user to identify the zip code of the area where the restaurant should be located. The media server 106 uses the speech recognition engine 300 to interpret the speech commands received from the user. Based upon these commands, the media server 106 retrieves the appropriate web site record 200 from the database 100. This record and any additional data, which may include other necessary parameters needed to perform the user's request, are transmitted to a web browsing server 102. A firewall 104 may be provided that separates the web browsing server 102 from the database 100 and media server 106. The firewall provides protection to the media server and database by preventing unauthorized access in the event the firewall for web browsing server 108 fails or is compromised. Any type of firewall protection technique commonly known to one skilled in the art could be used, including packet filter, proxy server, application gateway, or circuit-level gateway techniques.


The web browsing server 102 then uses the web site record and any additional data and executes the extraction agent 400 and relevant content descriptor file 406 to retrieve the requested information.


The information received from the responding web site 114 is then processed by the web browsing server 102 according to the content descriptor file 406 retrieval by the extraction agent. This processed response is then transmitted 30 to the media server 106 for conversion into audio messages using either the speech synthesis software 302 or selecting among a database of prerecorded voice responses contained within the database 100.


As mentioned above, each web site record contains a rank number 202 as shown in FIG. 2. For each category searchable by a user, the database 100 may list several web sites, each with a different rank number 202. As an example, three different web sites may be listed as searchable under the category of “restaurants”. Each of those web sites will be assigned a rank number such as 1, 2, or 3. The site with the highest rank (i.e., rank=1) will be the first web site accessed by a web browsing server 102. If the information requested by the user cannot be found at this first web site, then the web browsing server 102 will search the second ranked web site and so forth down the line until the requested information is retrieved or no more web sites left to check.


The web site ranking method and system of the present invention provides robustness to the voice browser system and enables it to adapt to changes that may occur as web sites evolve. For instance, the information required by a web site 114 to perform a search or the format of the reported response data may change. Without the ability to adequately monitor and detect these changes, a search requested by a user may provide an incomplete response, no response, or an error. Such useless responses may result from incomplete data being provided to the web site 114 or the web browsing server 102 being unable to recognize the response data messages received from the searched web site 114.


The robustness and reliability of the voice browsing system of the present invention is further improved by the addition of a polling mechanism. This polling mechanism continually polls or “pings” each of the sites listed in the database 100. During this polling function, a web browsing server 102 sends brief data requests or “polling digital data” to each web site listed in database 100. The web browsing server 102 monitors the response received from each web site and determines whether it is a complete response and whether the response is in the expected format specified by the content descriptor file 406 used by the extraction agent 400. The polled web sites that provide complete responses in the format expected by the extraction agent 400 have their ranking established based on their “response lime”. That is, web sites with faster response times will be will be assigned higher rankings than those with slower response times. If the web browsing server 102 receives no response from the polled web site or if the response received is not in the expected format, then the rank of that web site is lowered. Additionally, the web browsing server contains a warning mechanism that generates a warning message or alarm for the system administrator indicating that the specified web site has been modified or is not responsive and requires further review.


Since the web browsing servers 102 access web sites based upon their ranking number, only those web sites that produce useful and error-free responses will be used by the voice browser system to gather information requested by the user. Further, since the ranking numbers are also based upon the speed of a web site in providing responses, only the most time efficient sites are accessed. This system assures that users will get complete, timely, and relevant responses to their requests. Without this feature, users may be provided with information that is not relevant to their request or may not get any information at all. The constant polling and reranking of the web sites used within each category allows the voice browser of the present invention to operate efficiently. Finally, it allows the voice browser system of the present invention to dynamically adapt to changes in the rapidly evolving web sites that exist on the Internet.


It should be noted that the web sites accessible by the voice browser of the preferred embodiment may use any type of mark-up language, including Extensible Markup Language (XML), Wireless Markup Language (WML), Handheld Device Markup Language (HDML), Hyper Text Markup Language (HTML), or any variation of these languages.


A second embodiment of the present invention is depicted in FIG. 5. This embodiment provides a system and method for controlling a variety of devices 500 connected to a network 502 by using conversational speech commands spoken into a voice enabled device 504 (i.e., wireline or wireless telephones, Internet Protocol (EP) phones, or other special wireless units). The networked devices may include various household devices. For instance, voice commands may be used to control household security systems, VCRs, TVs, outdoor or indoor lighting, sprinklers, or heating and air conditioning systems.


Each of these devices 500 is connected to a network 502. These devices 500 may contain embedded microprocessors or may be connected to other computer equipment that allow the device 500 to communicate with network 502. In the preferred embodiment, the devices 500 appear as “web sites” connected to the network 502. This allows a network interface system, such as a device browsing server 506, a database 508, and a user interface system, such as a media server 510, to operate similar to the web browsing server 102, database 100 and media server 106 described in the first preferred embodiment above. A network 502 interfaces with one or more network interface systems, which are shown as device browsing servers 506 in FIG. 5. The device browsing servers perform many of the same functions and operate in much the same way as the web browsing servers 102 discuss above in the first preferred embodiment. The device browsing servers 506 are also connected to a database 508.


Database 508 lists all devices that are connected to the network 502. For each device 500, the database 508 contains a record similar to that shown in FIG. 2. Each record will contain at least a device identifier, which may be in the form of a URL, and a command to “content extraction agent” contained in the device browsing server 506. Database 508 may also include any other data or software necessary to test and administer the device browsing system.


The content extraction agent operates similarly to that described in the first embodiment. A device descriptor file contains a listing of the options and functions available for each of the devices 500 connected on the network 502. Furthermore, the device descriptor file contains the information necessary to properly communicate with the networked devices 500. Such information would include, for example, communication protocols, message formatting requirements, and required operating parameters.


The device browsing server 506 receives messages from the various networked devices 500, appropriately formats those messages and transmits them to one or more media servers 510 which are part of the device browsing system. The user's voice enabled devices 504 can access the device browsing system by calling into a media server 510 via the Public Switched Telephone Network (PSTN) 512. In the preferred embodiment, the device browsing server is based upon Intel's Dual Pentium III 730 MHz microprocessor system.


The media servers 510 act as user interface systems and perform the functions of natural speech recognition, speech synthesis, data processing, and call handling. The media server 510 operates similarly to the media server 106 depicted in FIG. 3. When data is received from the device browser server 506, the media server 510 will convert the data into audio messages via a speech synthesis engine that are then transmitted to the voice enabled device of the user 504. Speech commands received from the voice enabled device of the user 504 are converted into data messages via a speech recognition engine running on the media server 510. A preferred speech recognition engine is developed by Nuance Communications of 1380 Willow Road, Menlo Park, Calif. 94025 (www.nuance.com). A preferred speech synthesis engine is developed by Lernout and Hauspie Speech Products, 52 Third Avenue, Burlington, Mass. 01803 (www.lhsl.com). The media servers 510 of the preferred embodiment are based on Intel's Dual Pentium III 730 MHz microprocessor system. A specific example for using the system and method of this embodiment of the invention will now be given.


First, a user may call into a media server 510 by dialing a telephone number associated with an established device browsing system. Once the user is connected, the IVR application of the media server 510 will provide the user with a list of available systems that may be monitored or controlled based upon information contained in database 508.


For example, the user may be provided with the option to select “Home Systems” or “Office Systems”. The user may then speak the command “access home systems”. The media server 510 would then access the database 508 and provide the user with a listing of the home subsystems or devices 500 available on the network 502 for the user to monitor and control. For instance, the user may be given a listing of subsystems such as “Outdoor Lighting System”, “Indoor Lighting System”, “Security System”, or “Heating and Air Conditioning System”. The user may then select the indoor lighting subsystem by speaking the command “Indoor Lighting System”. The IVR application would then provide the user with a set of options related to the indoor lighting system. For instance the media server 510 may then provide a listing such as “Dining Room”, “Living Room”, “Kitchen”, or “Bedroom”. After selecting the desired room, the IVR application would provide the user with the options to hear the “status” of the lighting in that room or to “turn on”, “turn off”, or “dim” the lighting in the desired room. These commands are provided by the user by speaking the desired command into the users voice enabled device 504. The media server 510 receives this command and translates it into a data message. This data message is then forwarded to the device browsing server 506 which routes the message to the appropriate device 500.


The device browsing system 514 of this embodiment of the present invention also provides the same robustness and reliability features described in the first embodiment. The device browsing system 514 has the ability to detect whether new devices have been added to the system or whether current devices are out-of-service. This robustness is achieved by periodically polling or “pinging” all devices 500 listed in database 508. The device browsing server 506 periodically polls each device 500 and monitors the response. If the device browsing server 506 receives a recognized and expected response from the polled device, then the device is categorized as being recognized and in-service. However, if the device browsing server 506 does not receive a response from the polled device 500 or receives an unexpected response, then the device 500 is marked as being either new or out-of-service. A warning message or a report may then be generated for the user indicating that a new device has been detected or that an existing device is experiencing trouble.


Therefore, this embodiment allows users to remotely monitor and control any devices that are connected to a network, such as devices within a home or office. Furthermore, no special telecommunications equipment is required for users to remotely access the device browser system. Users may use any type of voice enabled device (i.e., wireline or wireless telephones, IP phones, or other wireless units) available to them. Furthermore, a user may perform these functions from anywhere without having to subscribe to additional services. Therefore, no additional expenses are incurred by the user.


The descriptions of the preferred embodiments described above are set forth for illustrative purposes and are not intended to limit the present invention in any manner. Equivalent approaches are intended to be included within the scope of the present invention. While the present invention has been described with reference to the particular embodiments illustrated, those skilled in the art will recognize that many changes and variations may be made thereto without departing from the spirit and scope of the present invention. These embodiments and obvious variations thereof are contemplated as falling within the scope and spirit of the claimed invention.

Claims
  • 1. A system comprising: (a) at least one data processor, the at least one data processor operatively coupled to a plurality of communication data networks;(b) at least one speaker-independent speech-recognition engine operatively coupled to the data processor;(c) memory accessible to the at least one data processor and storing at least:(i) an instruction set querying of information to be retrieved from a plurality of sources, the instruction set comprising: an indication of the plurality of sources, each identified by a source identifier, and each identifying certain information to be retrieved from the source identifier, and(ii) at least one recognition grammar executable code corresponding to each instruction set and corresponding to data characterizing audio containing a naturally-spoken-speech command including an information request,(d) wherein the at least one speaker-independent-speech-recognition engine is adapted (i) to receive the data characterizing audio containing the naturally-spoken-speech command from a voice-enabled device via a first of the plurality of communication data networks, (ii) to recognize phenomes in the data characterizing audio containing naturally-spoken-speech commands to understand spoken words, and (iii) to generate recognition results data,(e) wherein the at least one data processor is adapted to (i) select the corresponding at least one recognition grammar executable code upon receiving the data characterizing the audio containing the naturally-spoken-speech command and to convert the data characterizing the audio containing the naturally-spoken-speech command into a data message for transmission to a network interface adapted to access a second of the plurality of communication data networks; and (ii) to retrieve the instruction set corresponding to the recognition grammar executable codes provided by the at least one speaker-independent-speech-recognition engine and to access the information source queried by the instruction set to obtain at least a part of the information to be retrieved, and(f) at least one speech-synthesis device operatively coupled to the at least one data processor, the at least one speech-synthesis device configured to produce an audio message relating to any resulting information retrieved from the plurality of information sources, and to transmit the audio message to the voice-enabled device.
  • 2. The system of claim 1, wherein the plurality of communication data networks includes the Internet.
  • 3. The system of claim 1, wherein the plurality of communication data networks include a local-area network.
  • 4. The system of claim 1, wherein the voice-enabled device is a telephone.
  • 5. The system of claim 1, wherein the speaker-independent-speech-recognition engine is adapted to analyze the phonemes to recognize conversational naturally-spoken-speech commands.
  • 6. The system of claim 1, wherein the speaker-independent-speech-recognition engine is adapted to recognize the naturally-spoken-speech commands.
  • 7. The system of claim 1, wherein the instruction set executable code further comprises: a content descriptor associated with each information-source identifier, the content descriptor pre-defining a portion of the information source containing the information to be retrieved.
  • 8. The system of claim 1, further comprising: a database operatively connected to the data processor, the database adapted to store the information gathered from the information sources in response to the information requests.
  • 9. The system of claim 8, wherein each recognition grammar executable code and each instruction set for querying of information to be retrieved are stored in the database.
  • 10. The system of claim 1, wherein the voice-enabled device is an IP telephone.
  • 11. The system of claim 1, wherein the voice-enabled device is a cellular phone.
  • 12. The system of claim 1, wherein the voice-enabled device is a personal computer.
  • 13. The system of claim 1, wherein the voice-enabled device is a media player appliance.
  • 14. The system of claim 1, wherein the voice-enabled device is a television or other video display device.
  • 15. A method comprising: (a) providing at least one data processor, the data processor operatively coupled to a plurality of communication data networks;(b) providing at least one speaker-independent-speech-recognition engine operatively coupled to the at least one data processor(c) providing memory accessible to the data processor storing at least: (i) an instruction set for querying of the information to be retrieved from a plurality of sources, the instruction set comprising: an indication of the plurality of sources, each identified by a information-source identifier, and each identifying certain information to be retrieved from the information-source identifier, and(ii) at least one recognition grammar executable code corresponding to each instruction set and corresponding to data characterizing audio containing a naturally-spoken-speech command including an information request,(d) the at least one speaker-independent-speech-recognition engine: (i) receiving the data characterizing audio containing the naturally-spoken-speech command from the voice-enabled device via a first of the communication data networks,(ii) recognizing phenomes in the data characterizing audio containing the naturally-spoken-speech commands to understand spoken words, and(iii) generating recognition-results data,(e) the least one data processor programmed to: (i) select the corresponding at least one recognition grammar executable code upon receiving the data characterizing audio containing the naturally-spoken-speech command and convert the data characterizing audio containing naturally-spoken-speech command into a data message for transmission to a network interface adapted to access a second of the one communication networks; and(iii) retrieve the instruction set corresponding to the recognition grammar executable provided by the at least one speaker-independent-speech-recognition device and access the information source identified by the instruction set to obtain at least a part of the information to be retrieve; and(f) providing at least one speech-synthesis device operatively connected to the at least one data processor, and by the at least one speech-synthesis device: (i) produce an audio message relating to any resulting information retrieved from the plurality of information sources, and (ii) transmit the audio message to the voice-enabled device.
  • 16. The method of claim 15, wherein the plurality of communication data networks includes the Internet.
  • 17. The method of claim 15, wherein the plurality of communication data networks include a local-area network.
  • 18. The method of claim 15, wherein the voice-enabled device is a telephone.
  • 19. The method of claim 15, wherein the speaker-independent-speech-recognition engine is adapted to analyze the phonemes to recognize conversational naturally-spoken-speech commands.
  • 20. The method of claim 15, wherein the speaker-independent-speech-recognition engine is adapted to recognize the naturally-spoken-speech commands.
  • 21. The method of claim 15, wherein the instruction set executable code further comprises: a content descriptor associated with each information-source identifier, the content descriptor pre-defining a portion of the information source containing the information to be retrieved.
  • 22. The method of claim 15, further comprising: providing a database and operatively connecting the database to the data processor and storing the information gathered from the information sources in response to the information requests in the database.
  • 23. The method of claim 22, wherein each recognition grammar executable code and each instruction set are stored in the database.
  • 24. The method of claim 15, wherein the voice-enabled device is an IP telephone.
  • 25. The method of claim 15, wherein the voice-enabled device is a cellular phone.
  • 26. The method of claim 15, wherein the voice-enabled device is a personal computer.
  • 27. The method of claim 15, wherein the voice-enabled device is a media player appliance.
  • 28. The method of claim 15, wherein the voice-enabled device is a television or other video display device.
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of application Ser. No. 13/462,819, entitled “Robust Voice Browser System and Voice Activated Device Controller,” filed May 3, 2012, which is a continuation of application Ser. No. 12/973,475, entitled “Robust Voice Browser System And Voice Activated Device Controller,” filed Dec. 20, 2010, which is a continuation of application Ser. No. 12/030,556, entitled “Robust Voice Browser System And Voice Activated Device Controller,” filed Feb. 13, 2008, now U.S. Pat. No. 7,881,941, which is a continuation application of application Ser. No. 11/409,703, entitled “Robust Voice Browser System And Voice Activated Device Controller,” filed Apr. 24, 2006, now U.S. Pat. No. 7,386,455, which is a continuation application of application Ser. No. 10/821,690, entitled “Robust Voice Browser System And Voice Activated Device Controller,” filed Apr. 9, 2004, now U.S. Pat. No. 7,076,431, which is a continuation application of application Ser. No. 09/776,996, entitled “Robust Voice Browser System And Voice Activated Device Controller,” filed Feb. 5, 2001, now U.S. Pat. No. 6,721,705, which claims priority to U.S. Provisional Application Ser. No. 60/180,344, entitled “Voice Activated Information Retrieval System,” filed Feb. 4, 2000 and U.S. Provisional Application No. 60/233,068, filed Sep. 15, 2000, entitled “Robust Voice Browser System and Voice Activated Device Controller, all assigned to the assignee of the present application. The subject matter in the above-identified applications is incorporated herein by reference.

US Referenced Citations (379)
Number Name Date Kind
174465 Bell Mar 1876 A
3728486 Kraus Apr 1973 A
4058838 Crager et al. Nov 1977 A
4100377 Flanagan Jul 1978 A
4158750 Sakoe et al. Jun 1979 A
4313035 Jordan Jan 1982 A
4327251 Fomenko et al. Apr 1982 A
4340783 Sugiyama et al. Jul 1982 A
4340797 Takano et al. Jul 1982 A
4340800 Ueda et al. Jul 1982 A
4371752 Matthews Feb 1983 A
4481574 DeFino et al. Nov 1984 A
4489438 Hughes Dec 1984 A
4500751 Darland et al. Feb 1985 A
4513390 Walter et al. Apr 1985 A
4523055 Hohl et al. Jun 1985 A
4549047 Brian et al. Oct 1985 A
4584434 Hashimoto Apr 1986 A
4585906 Matthews et al. Apr 1986 A
4596900 Jackson Jun 1986 A
4602129 Matthews et al. Jul 1986 A
4635253 Urui et al. Jan 1987 A
4652700 Matthews et al. Mar 1987 A
4696028 Morganstein et al. Sep 1987 A
4713837 Gordon Dec 1987 A
4747127 Hansen et al. May 1988 A
4748656 Gibbs et al. May 1988 A
4755932 Diedrich Jul 1988 A
4757525 Matthews et al. Jul 1988 A
4761807 Matthews et al. Aug 1988 A
4763317 Lehman et al. Aug 1988 A
4769719 Endo Sep 1988 A
4771425 Baran et al. Sep 1988 A
4776016 Hansen Oct 1988 A
4782517 Bernardis et al. Nov 1988 A
4792968 Katz Dec 1988 A
4799144 Parruck et al. Jan 1989 A
4809321 Morganstein et al. Feb 1989 A
4811381 Woo et al. Mar 1989 A
4837798 Cohen et al. Jun 1989 A
4847891 Kotani Jul 1989 A
4850012 Mehta et al. Jul 1989 A
4852149 Zwick et al. Jul 1989 A
4852170 Bordeaux Jul 1989 A
4866758 Heinzelmann Sep 1989 A
4873719 Reese Oct 1989 A
4879743 Burke et al. Nov 1989 A
4893333 Baran et al. Jan 1990 A
4893335 Fuller et al. Jan 1990 A
4903289 Hashimoto Feb 1990 A
4903291 Tsurufuji et al. Feb 1990 A
4905273 Gordon et al. Feb 1990 A
4907079 Turner et al. Mar 1990 A
4918722 Duehren et al. Apr 1990 A
4922518 Gordon et al. May 1990 A
4922520 Bernard et al. May 1990 A
4922526 Morganstein et al. May 1990 A
4926462 Ladd et al. May 1990 A
4930150 Katz May 1990 A
4933966 Hird et al. Jun 1990 A
4935955 Neudorfer Jun 1990 A
4935958 Morganstein et al. Jun 1990 A
4941170 Herbst Jul 1990 A
4942598 Davis Jul 1990 A
4953204 Cuschleg, Jr. et al. Aug 1990 A
4955047 Morganstein et al. Sep 1990 A
4956835 Grover Sep 1990 A
4959854 Cave et al. Sep 1990 A
4967288 Mizutori et al. Oct 1990 A
4969184 Gordon et al. Nov 1990 A
4972462 Shibata Nov 1990 A
4974254 Perine et al. Nov 1990 A
4975941 Morganstein et al. Dec 1990 A
4985913 Shalom Jan 1991 A
4994926 Gordon et al. Feb 1991 A
4996704 Brunson Feb 1991 A
5003575 Chamberlin et al. Mar 1991 A
5003577 Ertz et al. Mar 1991 A
5008926 Misholi Apr 1991 A
5020095 Morganstein et al. May 1991 A
5027384 Morganstein Jun 1991 A
5029196 Morganstein Jul 1991 A
5036533 Carter et al. Jul 1991 A
5054054 Pessia et al. Oct 1991 A
5065254 Hishida Nov 1991 A
5086385 Launey et al. Feb 1992 A
5095445 Sekiguchi Mar 1992 A
5099509 Morganstein Mar 1992 A
5109405 Morganstein Apr 1992 A
5128984 Katz Jul 1992 A
5131024 Pugh et al. Jul 1992 A
5133004 Heileman, Jr. Jul 1992 A
5146452 Pekarske Sep 1992 A
5166974 Morganstein Nov 1992 A
5179585 MacMillan et al. Jan 1993 A
5193110 Jones et al. Mar 1993 A
5195086 Baumgartner et al. Mar 1993 A
5233600 Pekarske Aug 1993 A
5243643 Sattar et al. Sep 1993 A
5243645 Bissell et al. Sep 1993 A
5249219 Morganstein et al. Sep 1993 A
5255305 Sattar Oct 1993 A
5263084 Chaput et al. Nov 1993 A
5276729 Higuchi et al. Jan 1994 A
5287199 Zoccolillo Feb 1994 A
5291302 Gordon et al. Mar 1994 A
5291479 Vaziri et al. Mar 1994 A
5303298 Morganstein et al. Apr 1994 A
5307399 Dai et al. Apr 1994 A
5309504 Morganstein May 1994 A
5325421 Hou et al. Jun 1994 A
5327486 Wolff et al. Jul 1994 A
5327529 Fults et al. Jul 1994 A
5329578 Brennan et al. Jul 1994 A
5333266 Boaz et al. Jul 1994 A
5347574 Morganstein Sep 1994 A
5355403 Richardson, Jr. et al. Oct 1994 A
5359598 Steagall et al. Oct 1994 A
5365524 Hiller et al. Nov 1994 A
5365574 Hunt et al. Nov 1994 A
5375161 Fuller et al. Dec 1994 A
5384771 Isidoro et al. Jan 1995 A
5404231 Bloomfield Apr 1995 A
5408526 McFarland et al. Apr 1995 A
5414754 Pugh et al. May 1995 A
5416834 Bales et al. May 1995 A
5426421 Gray Jun 1995 A
5432845 Burd et al. Jul 1995 A
5436963 Fitzpatrick et al. Jul 1995 A
5459584 Gordon et al. Oct 1995 A
5463684 Morduch et al. Oct 1995 A
5475791 Schalk et al. Dec 1995 A
5479487 Hammond Dec 1995 A
5495484 Self et al. Feb 1996 A
5497373 Hulen et al. Mar 1996 A
5499288 Hunt et al. Mar 1996 A
5515427 Carlsen et al. May 1996 A
5517558 Schalk May 1996 A
5526353 Henley et al. Jun 1996 A
5533115 Hollenbach et al. Jul 1996 A
5537461 Bridges et al. Jul 1996 A
5555100 Bloomfield et al. Sep 1996 A
5559611 Bloomfield et al. Sep 1996 A
5559859 Dai et al. Sep 1996 A
5566236 Melampy et al. Oct 1996 A
5603031 White et al. Feb 1997 A
5608786 Gordon Mar 1997 A
5610910 Focsaneanu et al. Mar 1997 A
5610970 Fuller et al. Mar 1997 A
5611031 Hertzfeld et al. Mar 1997 A
5630079 McLaughlin May 1997 A
5652789 Miner et al. Jul 1997 A
5657376 Espeut et al. Aug 1997 A
5659597 Bareis et al. Aug 1997 A
5666401 Morganstein et al. Sep 1997 A
5675507 Bobo, II Oct 1997 A
5675811 Broedner et al. Oct 1997 A
5689669 Lynch et al. Nov 1997 A
5692187 Goldman et al. Nov 1997 A
5699486 Tullis et al. Dec 1997 A
5712903 Bartholomew et al. Jan 1998 A
5719921 Vysotsky et al. Feb 1998 A
5721908 Lagarde et al. Feb 1998 A
5724408 Morganstein Mar 1998 A
5737395 Irribarren Apr 1998 A
5742596 Baratz et al. Apr 1998 A
5742905 Pepe et al. Apr 1998 A
5752191 Fuller et al. May 1998 A
5758322 Rongley May 1998 A
5761294 Shaffer et al. Jun 1998 A
5764639 Staples et al. Jun 1998 A
5764736 Shachar et al. Jun 1998 A
5764910 Shachar Jun 1998 A
5774860 Bayya et al. Jun 1998 A
5787298 Broedner et al. Jul 1998 A
5793993 Broedner et al. Aug 1998 A
5794205 Walters et al. Aug 1998 A
5796791 Polcyn Aug 1998 A
5799063 Krane Aug 1998 A
5799065 Junqua et al. Aug 1998 A
5809282 Cooper et al. Sep 1998 A
5809481 Baron et al. Sep 1998 A
5812796 Broedner et al. Sep 1998 A
5819220 Sarukkai et al. Oct 1998 A
5819306 Goldman et al. Oct 1998 A
5822727 Garberg et al. Oct 1998 A
5823879 Goldberg et al. Oct 1998 A
5832063 Vysotsky et al. Nov 1998 A
5832440 Woodbridge Nov 1998 A
5835570 Wattenbarger Nov 1998 A
5838682 Dekelbaum et al. Nov 1998 A
5867494 Krishnaswamy et al. Feb 1999 A
5867495 Elliott et al. Feb 1999 A
5870550 Wesinger, Jr. et al. Feb 1999 A
5873080 Coden et al. Feb 1999 A
5881134 Foster et al. Mar 1999 A
5881135 Watts et al. Mar 1999 A
5884032 Bateman et al. Mar 1999 A
5884262 Wise et al. Mar 1999 A
5884266 Dvorak Mar 1999 A
5890123 Brown et al. Mar 1999 A
5905476 McLaughlin et al. May 1999 A
5914951 Bentley et al. Jun 1999 A
5915001 Uppaluru Jun 1999 A
5917817 Dunn et al. Jun 1999 A
5926789 Barbara Jul 1999 A
5940598 Strauss et al. Aug 1999 A
5943399 Bannister et al. Aug 1999 A
5946389 Dold Aug 1999 A
5953392 Rhie et al. Sep 1999 A
5974124 Schlueter et al. Oct 1999 A
5974413 Beauregard et al. Oct 1999 A
5991292 Focsaneanu et al. Nov 1999 A
5995615 Miloslavsky Nov 1999 A
5999525 Krishnaswamy et al. Dec 1999 A
5999611 Tatchell et al. Dec 1999 A
5999965 Kelly Dec 1999 A
6012088 Li et al. Jan 2000 A
6014437 Acker et al. Jan 2000 A
6014626 Cohen Jan 2000 A
6018710 Wynblatt et al. Jan 2000 A
6021181 Miner et al. Feb 2000 A
6021190 Fuller et al. Feb 2000 A
6031904 An et al. Feb 2000 A
6038305 McAllister et al. Mar 2000 A
6044107 Gatherer et al. Mar 2000 A
6047053 Miner et al. Apr 2000 A
6052372 Gittins et al. Apr 2000 A
6067516 Levay et al. May 2000 A
6078580 Mandalia et al. Jun 2000 A
6081518 Bowman-Amuah Jun 2000 A
6081782 Rabin Jun 2000 A
6091808 Wood et al. Jul 2000 A
6101472 Giangarra et al. Aug 2000 A
6104803 Weser et al. Aug 2000 A
6115737 Ely et al. Sep 2000 A
6115742 Franklin et al. Sep 2000 A
6130933 Miloslaysky Oct 2000 A
6131095 Low et al. Oct 2000 A
6137863 Brown et al. Oct 2000 A
6144991 England Nov 2000 A
6157705 Perrone Dec 2000 A
6161128 Smyk Dec 2000 A
6178399 Takebayashi et al. Jan 2001 B1
6185535 Hedin et al. Feb 2001 B1
6188683 Lang et al. Feb 2001 B1
6195357 Polcyn Feb 2001 B1
6199076 Logan et al. Mar 2001 B1
6201814 Greenspan Mar 2001 B1
6201863 Miloslavsky Mar 2001 B1
6208638 Rieley Mar 2001 B1
6215858 Bartholomew et al. Apr 2001 B1
6230132 Class et al. May 2001 B1
6233318 Picard et al. May 2001 B1
6243373 Turock Jun 2001 B1
6252944 Hansen, II et al. Jun 2001 B1
6269336 Ladd et al. Jul 2001 B1
6285745 Bartholomew et al. Sep 2001 B1
6327572 Morton et al. Dec 2001 B1
6330538 Breen Dec 2001 B1
6349132 Wesemann et al. Feb 2002 B1
6353661 Bailey, III Mar 2002 B1
6366575 Barkan et al. Apr 2002 B1
6366578 Johnson Apr 2002 B1
6424945 Sorsa Jul 2002 B1
6430282 Bannister et al. Aug 2002 B1
6434529 Walker et al. Aug 2002 B1
6445694 Swartz Sep 2002 B1
6446076 Burkey et al. Sep 2002 B1
6456699 Burg et al. Sep 2002 B1
6459910 Houston Oct 2002 B1
6477240 Lim et al. Nov 2002 B1
6477420 Struble et al. Nov 2002 B1
6490627 Kaira et al. Dec 2002 B1
6505163 Zhang et al. Jan 2003 B1
6529948 Bowman-Amuah Mar 2003 B1
6532444 Weber Mar 2003 B1
6539359 Ladd et al. Mar 2003 B1
6546393 Khan Apr 2003 B1
6560604 Fascenda May 2003 B1
6584439 Geihufe et al. Jun 2003 B1
6587822 Brown et al. Jul 2003 B2
6593944 Nicolas et al. Jul 2003 B1
6594348 Bjurstrom et al. Jul 2003 B1
6594692 Reisman Jul 2003 B1
6606611 Khan Aug 2003 B1
6618039 Grant et al. Sep 2003 B1
6618726 Colbath et al. Sep 2003 B1
6618763 Steinberg Sep 2003 B1
6636831 Profit, Jr. et al. Oct 2003 B1
6654814 Britton et al. Nov 2003 B1
6665640 Bennett et al. Dec 2003 B1
6687341 Koch et al. Feb 2004 B1
6704024 Robotham et al. Mar 2004 B2
6718015 Berstis Apr 2004 B1
6721705 Kurganov Apr 2004 B2
6724868 Pradhan et al. Apr 2004 B2
6732142 Bates et al. May 2004 B1
6763388 Tsimelzon Jul 2004 B1
6771732 Xiao et al. Aug 2004 B2
6775264 Kurganov Aug 2004 B1
6785266 Swartz Aug 2004 B2
6807257 Kurganov Oct 2004 B1
6812939 Flores et al. Nov 2004 B1
6823370 Kredo et al. Nov 2004 B1
6859776 Cohen Feb 2005 B1
6888929 Saylor et al. May 2005 B1
6922733 Kuiken et al. Jul 2005 B1
6941273 Loghmani et al. Sep 2005 B1
6964012 Zirngibl et al. Nov 2005 B1
6964023 Maes et al. Nov 2005 B2
6965864 Thrift et al. Nov 2005 B1
6996609 Hickman et al. Feb 2006 B2
6999804 Engstrom et al. Feb 2006 B2
7003463 Maes et al. Feb 2006 B1
7024464 Lusher et al. Apr 2006 B1
7050977 Bennett May 2006 B1
7075555 Flores Jul 2006 B1
7076431 Kurganov Jul 2006 B2
7089307 Zintel et al. Aug 2006 B2
7145898 Elliott Dec 2006 B1
7146323 Guenther et al. Dec 2006 B2
7185197 Wrench, Jr. Feb 2007 B2
7327723 Kurganov Feb 2008 B2
7386455 Kurganov Jun 2008 B2
7506022 Wang Mar 2009 B2
7516190 Kurganov Apr 2009 B2
7881941 Kurganov Feb 2011 B2
7974875 Quilici Jul 2011 B1
8098600 Kurganov Jan 2012 B2
8131267 Lichorowic et al. Mar 2012 B2
8131555 Carriere Mar 2012 B1
8185402 Kurganov May 2012 B2
8380505 Konig et al. Feb 2013 B2
8775176 Gilbert et al. Jul 2014 B2
8838074 Kurganov Sep 2014 B2
8843141 Kurganov Sep 2014 B2
8874446 Carriere Oct 2014 B2
9377992 Kurganov Jun 2016 B2
9451084 Kurganov Sep 2016 B2
9769314 Kurganov Sep 2017 B2
20010011302 Son Aug 2001 A1
20010032234 Summers et al. Oct 2001 A1
20010040885 Jonas et al. Nov 2001 A1
20010047262 Kurganov Nov 2001 A1
20010048676 Jimenez et al. Dec 2001 A1
20020006126 Johnson et al. Jan 2002 A1
20020059402 Belanger May 2002 A1
20020064149 Elliott et al. May 2002 A1
20020087327 Lee et al. Jul 2002 A1
20020090114 Rhoads et al. Jul 2002 A1
20020104025 Wrench, Jr. Aug 2002 A1
20030002635 Koch et al. Jan 2003 A1
20040160913 Kubler et al. Aug 2004 A1
20040193427 Kurganov Sep 2004 A1
20050025133 Swartz Feb 2005 A1
20050030179 Script et al. Feb 2005 A1
20050074104 Swartz Apr 2005 A1
20050102147 Ullrich et al. May 2005 A1
20060190265 Kurganov Aug 2006 A1
20070206737 Hickman Sep 2007 A1
20070263601 Kurganov Nov 2007 A1
20080189113 Kurganov Aug 2008 A1
20080228494 Cross Sep 2008 A1
20110054898 Phillips et al. Mar 2011 A1
20110091023 Kurganov Apr 2011 A1
20120179464 Newman et al. Jul 2012 A1
20120253800 Goller et al. Oct 2012 A1
20130006638 Lindahl Jan 2013 A1
20130191122 Mason Jul 2013 A1
20130317823 Mengibar Nov 2013 A1
20140046660 Kamdar Feb 2014 A1
20140111415 Gargi et al. Apr 2014 A1
20140123010 Goldstein May 2014 A1
20150185985 Kang et al. Jul 2015 A1
20150234636 Barnes, Jr. Aug 2015 A1
20150334080 Tamayo Nov 2015 A1
20150339745 Peter et al. Nov 2015 A1
20180007201 Kurganov Jan 2018 A1
Foreign Referenced Citations (13)
Number Date Country
1329852 May 1994 CA
0572544 Dec 1993 EP
0794650 Sep 1997 EP
2211698 Jul 1989 GB
2240693 Aug 1991 GB
2317782 Apr 1998 GB
1-258526 Oct 1989 JP
9107838 May 1991 WO
9118466 Nov 1991 WO
9609710 Mar 1996 WO
97034401 Sep 1997 WO
97037481 Sep 1997 WO
98023058 May 1998 WO
Non-Patent Literature Citations (66)
Entry
Ross, Randy, “Retrieve E-mail from a Telephone”, Oct. 7, 1996, pp. 1-2, available at http://resna.org/ProfessOrg?Sigs?SIGSites/sig11/archive/juggler.htm (accessed on Dec. 8, 2006). Printout indicates that the article was originally printed in PC World.
Sartori, M., “Speech Recognition”, Apr. 1995, pp. 1-9, Mercury Communications, available at www.gar.co.ukltechnologLwatch/speech.htm (accessed Mar. 15, 2005).
Schmandt et al., “A Conversational Telephone Messaging Systems”, IEEE Transactions on Consumer Electronics, 1984, vol. CE-30, No. 3, pp. xxi-xxiv.
Schmandt et al., “Phone Shell: The Telephone as Computer Terminal”, ACM Multimedia, 1993, 11 pgs.
Schmandt et al., “Phone Slave: A Graphical Telecommunictions Interface”, Proceedings of the SID, 1985, vol. 26/1, pp. 79-82.
Secretarial Branch Exchanged, IBM Technical Disclosure Bulletin, vol. 26 (5), Oct. 1983, pp. 2645-2647.
Shimamura, et al., “Review of the Electrical Communication Laboratories”, vol. 418 (33), No. 1, Tokyo, Japan, 1985, pp. 31-39.
The VMX Systems Product Reference Manual: Product Description Volume, May 1994, vol. 1, release 7.1, VMX, Inc. (Octel Communications Corp.) San Jose, CA USA.
Update Subject Matter Eligibility, Jul. 2015, 33 pages.
VMXworks Product Reference Manual: vol. 3 Programmer's Guide, Jul. 1994, vols. 3 & 4, Release 3.1, Octel Communications corp., Milpitas, CA, USA.
Wikipedia Definition of “Internet”, available at http://en.wikipedia.org/wiki/Internet. Retrieved on Feb. 10, 2016, pp. 24-26.
Wildfire Communication, Inc., Harvard Business School, Mar. 21, 1996, Publ. No. 9-396-305, pp. 1-22.
WordPerfect: New Telephony Features Boost Office, WordPerfect Office TechBrief, 1994, Info-World Publishing. Co., vol. 10, Issue 2, pp. 2-3.
Yang, C., “INETPhone—Telephone Services and Servers on the Internet”, Apr. 1995, University of North Texas, pp. 1-6.
A PABX that Listens and Talks, Speech Technology, Jan./Feb. 1984, pp. 74-79.
Amended Complaint, Parus Holdings. Inc. v. Web Telephony LLC & Robert Swartz, Case No. 06-cv-01146 (N.D. III.) Jul. 10, 2006, 14 pages.
AT&T, Press Release, “At&T Customers Can Teach Systems to Listen and Respond to Voice”, Jan. 17, 1995, pp. 1-2, Basking Ridge, NJ., available at www.lucent.com/press/0195/950117.gbb.html (accessed Mar. 15, 2005).
Bellcore Technology Licensing, “The Electronic Receptionist—A Knowledge-Based Approach to Personal Communications”, 1994, pp. 1-8.
Brachman et al., “Fragmentation in Store-and-Forward Message Transfer”, IEEE Communications Magazine, vol. 26(7), Jul. 1998, pp. 18-27.
Brief of Appellees, submitted on Jun. 20, 2016 to the United States Court of Appeals for the Federal Circuit, 53 pages.
Business Phone Systems for Advanced Offices, NTT Review, vol. 2 (6), Nov., 1990, pp. 52-54.
Cole et al., “An Architecture for a Mobile OSI Mail Access System”, IEEE Journal on Selected Areas in Communications, vol. 7 (2), Feb. 1989, pp. 249-256.
Data Communications Networks: Message Handling Systems, Fasciele, VIII. 7—Recommendations XAOO-XA30, 38 pages, date unknown.
DAX Systems, Inc., Press Release, “Speech Recognition Success in DAX's Grasp”, Nov. 22, 1995, pp. 1-2, Pine Brook, NJ.
Defendants Answer to the Amended Complaint and Demand for Jury Trial, Parus Holdings, Inc. v. Web Telephone LLC & Robert Swartz, Case No. 06-cv-01146 (N.D. 111.), Aug. 10, 2006, 14 pages.
Examples: Abstract Ideas, 2014, 20 pages.
Faxpak Store and Forward Facsimile Transmission Service, Electrical Communication, vol. 54 (3),1979, pp. 251-255.
Garcia et al, “Issues in Multimedia Computer-Based Message Systems Design and Standardization”, NATO ASI Series, vol. 1-6, 1984, 18 pgs.
Globecom '85 IEEE Global Telecommunications Conference, New Orleans, LA., Dec. 2-5, 1985 pp. 1295-1300.
Hemphill et al., “Speech-Aware Multimedia,” IEEE MultiMedia, Spring 1996, vol. 3, No. 1, pp. 74-78, IEEE. As indicated on the cover page of the journal, which is attached hereto as Attachment 4, the reference was received by Cornell University on Mar. 25, 1996.
Hemphill et al., “Surfing the Web by Voice,” ACM Multimedia 95—Electronic Proceedings, Nov. 5-9, 1995. San Francisco, CA.
Hunt et al., “Long-Distance Remote Control to the Rescue”, Chicago Tribune, Jun. 15, 2002, Section 4, p. 15
IBM AIX DirectTalk/6000 Version 1 Release 6 Improves Your Voice Processing Services to Callers and Customers, Announcement Number: 295-489, Nov. 28, 1995, 27 pages.
IBM Announcement Letter No. A95-893, retrieved on Mar. 9, 2015, 10 pages.
IBM, AIX DirectTalk/6000 Release 6: Speech Recognition with the BBN Hark Recognizer, SC33-1734-00, Feb. 1996, 250 pages.
IBM, AIX DirectTalk/6000: General Information and Planning, Release 6, GC33-1720-00, Dec. 1995, 162 pages.
IBM, DirectTalkMail: Administration, Release 6, SC33-1733-00, Feb. 1996, 274 pages.
Introducing PIC SuperFax, First PC/Fax System to Run Under Windows, Pacific Image Communications, Pasadena, CA, Date Unknown, (received at COMDEX show, Nov. 3, 1987), 4 pgs.
Joint Appendix, submitted on Sep. 16, 2016, to the United States Court of Appeal for the Federal Circuit, 406 pages.
Juggler by PureSpeech, p. 1, available at http://members.aol.com/compqanda1/juggler.html (accessed on Dec. 8, 2006).
Kubala et al., “BYBLOS Speech Recognition Benchmark Results”, Workshop on Speech & Natural Language, Feb. 19-22, 1991.
Ly, “Chatter: A Conversational Telephone Agent”, submitted to Program in Media Arts & Sciences, MIT, 1993, pp. 1-130.
Maeda, et al., “An Intelligent Customer-Controlled Switching System”, IEEE Global Telecommunications Conference, Hollywood, Florida, Nov. 28-Dec. 1, 1988, pp. 1499-1503.
Markowitz, J., “The Ultimate Computer Input Device May Be Right Under Your Nose”, Byte, Dec. 1995, pp. 1-13, available at www.byte.com/artI9512/sec8/art1.htm (accessed Mar. 15, 2005).
Marx et al., Mail Call: Message Presentation and Navigation in a Nonvisual Environment: SIGCHI Conference on Human Factors in Computing Systems, Vancouver, B.C., Canada, Apr. 13-18, 1996.
Marx, M., “Toward Effective Conversational Messaging” (Thesis). As indicated on the cover page, the thesis was presented to the Departmental Committee on Graduate Students, Program in Media Arts and Sciences, School of Architecture and Planning, Massachusetts Institute of Technology on May 12, 1995.
McGraw-Hill Dictionary of Scientific & Technical Terms 1101, 6th ed. 2003, (Referenced in Amendment and Reply Under 37 CFR 1.111 filed for U.S. Appl. No. 10/877,366 on Apr. 24, 2009) No copy is provided but please inform if a copy of this dictionary is required.
Memorandum Opinion and Order, Oct. 8, 2015, 27 pages.
Newton, Harry, Newtons Telecom Dictionary—The Official Glossary of Telecommunications and Voice Processing Terms, Dec. 1992, 6 pages.
Opening Brief of Appellant Parus Holdings, Inc., submitted on Mar. 8, 2016, to the United States Court of Appeal for the Federal Circuit, 236 pages.
Oye, Phil, “Juggler”, p. 1, available at http://www.philoye.com/workljuggler/index.shtml (accessed on Dec. 8, 2006).
Paper No. 10, Denying Institution of Covered Business Method Patent Review CBM2015-00109 and CBM2015-00149, Nov. 9, 2015, 19 pages.
Paper No. 10, Denying Institution of Covered Business Method Patent Review CBM2015-00110 and CBM2015-00150, Nov. 9, 2015, 20 pages.
Paper No. 10, Denying Institution of Covered Business Method Patent Review CBM2015-00111 and CBM2015-00151, Nov. 9, 2015, 19 pages.
Paper No. 10, Denying Institution of Covered Business Method Patent Review CBM2015-00112 and CBM2015-00152, Nov. 9, 2015, 18 pages.
Perdue et al., Conversant® 1 Voice System: Technical Journal, pp. 1-14.
Plaintiff Parus Holdings, Inc.'s Supplemental Responses to Defendant Web Telephony LLC's First Set of Interrogatories (Nos. 13-17), Parus Holdings,Inc. v. Web Teleghony LLC & Robert Swartz, Case No. 06-cv-01146 (N. D. III.), Oct. 31, 2006, 32 pages.
Print outs of Internet web site, “Wildfire Communications, Inc.,”, Nov. 5, 1997, including print outs of http://www.wildfire.com (1 pg); http://www.wildfire.com/consumerhome.html (2 pgs.); http://www.wildfire.com/106.html (2 pgs.); http://www.wildfire.com/carrierhome.html (2 pgs.); http://www.wildfire.com/sfandb.html (3 pgs); http://www.wildfire.com/ about.html (1 pg.); http://www.wildfire.com/abtmgmt.html (3 pgs); http://www.wildfire.com/scoop.html (2 pgs.); and http://www.wildfire.com/intel.html (1 pg.); and http://www.wildfire.com/msft.html (2 pgs).
Proceedings of the IFIP World Computer Congress, Dublin, Ireland, Sep. 1-5, 1986.
PureSpeech Announces Juggler PC Systemfor First Quarter of 1997, HighBeam Research, Sep. 19,1996, pp. 1-3, available at httg://www.highbeam.com/doc/1G1-186909545.html (accessed on Dec. 8, 2006).
PureSpeech, “Meet the Voice of Juggler!”, pp. 1-3, the date of Nov. 18, 1996 is shown at the top of p. 1.
PureSpeech's Juggler, Teleconnect, Dec. 1996 issue, p. 36.
Putz, Steve, Interactive Information Services Using World-Wide Web Hypertext, First Int'l Conference on World-Wide Web (May 25-27, 1994), 10 pages.
Reply Brief of Appellant Parus Holdings, Inc., submitted on Sep. 6, 2016, to the United States Court of Appeal for the Federal Circuit, 40 pages.
Plaintiff Parus Holdings, Inc.'s Supplemental Responses to Defendant Web Telephony LLC's Second Set of Interrogatories (Nos. 13-17), Parus Holdings,Inc. v. Web Telephony LLC & Robert Swartz, Case No. 06-cv-01146 (N.D. III.), Oct. 31, 2006, 31 pages.
Judgment without Opinion for Parus Holdings Inc., v. Sallie Mae Bank, Navient Solutions Inc., PNC Bank, N.A., Suntrust Bank, Suntrust Mortgage Inc., 2016-1179, 2016-1180, 2016-1181, entered Feb. 27, 2017 (2 pages).
Provisional Applications (2)
Number Date Country
60233068 Sep 2000 US
60180344 Feb 2000 US
Continuations (6)
Number Date Country
Parent 13462819 May 2012 US
Child 15269776 US
Parent 12973475 Dec 2010 US
Child 13462819 US
Parent 12030556 Feb 2008 US
Child 12973475 US
Parent 11409703 Apr 2006 US
Child 12030556 US
Parent 10821690 Apr 2004 US
Child 11409703 US
Parent 09776996 Feb 2001 US
Child 10821690 US