METHOD AND SYSTEM FOR READING FLUENCY TRAINING
A non-transitory processor-readable medium stores code representing instructions to be executed by a processor. The code causes the processor to receive a request from a user of a client device to initiate a speech recognition engine for a web page displayed at the client device. In response to the request, the code causes the processor to (1) download, from a server associated with a first party, the speech recognition engine into the client device; and then (2) analyze, using the speech recognition engine, content of the web page including text in an identified language to produce analyzed content based on the identified language, where the content of the web page is received from a server associated with a second party. The code further causes the processor to send a signal to cause the client device to present the analyzed content to the user at the client device.
Latest Rosetta Stone Ltd. Patents:
- Performing a computerized language teaching lesson using a main computer and a mobile device
- Generating acoustic models of alternative pronunciations for utterances spoken by a language learner in a non-native language
- Method and system for reading fluency training
- Generating acoustic models of alternative pronunciations for utterances spoken by a language learner in a non-native language
- Performing a computerized language teaching lesson using a main computer and a mobile device
This application claims priority to and the benefit of U.S. Provisional Application No. 61/697,521, filed Sep. 6, 2012, entitled “Method and System for Oral Reading Fluency Training,” the disclosure of which is incorporated by reference herein in its entirety.
BACKGROUNDSome embodiments described herein relate generally to language instruction, and, in particular, to a system and method for delivering on-demand oral practiced reading exercises.
Fluency is a fundamental part of the language learning process. It relates to being able to read quickly and effortlessly while imparting the right expression and emotion on words. Practiced oral reading with feedback from human instructors can provide pedagogical benefit for those learning a first language and improve fluency for second language learners as well. Children often practice reading text aloud as part of early literacy curricula. Often, the learner will read out loud while a human teacher listens. The human teacher provides instructional feedback that helps the learner to decode words, and coaches on reading strategies (e.g., sounding out of words) that lead to fluency improvements. While practiced oral reading with feedback from human instructors is known to be beneficial, the lack of availability of human coaches and language educators has led to the development of systems that incorporate computer speech recognition feedback.
Some known systems have been developed to provide practiced oral reading exercises by incorporating computer speech recognition feedback. In such known systems, a computer typically plays the role of a human instructor to actively listen as a learner reads text aloud, to track the location of the spoken words on a computer screen, and to provide various forms of visual and/or audible feedback when errors are detected. Such known systems, however, typically require heavy preprocessing of audio and text content including manual crafting, alignment and/or synchronization of the audio and text content in advance, which can be labor-intensive and often require intervention from human editors. Furthermore, some known systems can require extensive installation of components (e.g., the software solution itself, the content, as well as the computer speech recognition system), thus making them inconvenient to use and difficult to update and maintain.
Accordingly, a need exists for a system and method that can enable oral reading exercises to deliver practice and instructional feedback to a language learner without human intervention, heavy preprocessing or extensive installation of components.
SUMMARYIn some embodiments, a non-transitory processor-readable medium stores code representing instructions to be executed by a processor. The code causes the processor to receive a request from a user of a client device, where the request is to initiate a speech recognition engine for a web page that is displayed at the client device. Content of the web page is received from a server. The content of the web page includes text in a language that can be identified. In response to the request, the code causes the processor to download the speech recognition engine from another server to the client device. The code causes the processor to analyze, using the speech recognition engine, the content of the web page based on the identified language. As a result of the analyzing, analyzed content is produced based on the content of the web page. The code causes the processor to send a signal to cause the client device to present the analyzed content to the user at the client device. The code can enable real-time or substantially real-time visual highlighting of text in synchronization with audio. The code can also analyze the user's voice and provide fluency feedback to the user.
In some embodiments, a fluency training system can provide on-screen visual highlighting of words, sentences, and/or lines of text within the context of a document (e.g., a HyperText Markup Language (HTML) document) where the highlighting is manipulated by oral reading. The highlighting can be performed in real-time (or substantially real-time) as a learner speaks the text of the document, or via prerecorded audio discovered as related to the document's article content. The system can allow language learners to listen to text-synchronized audio recordings on the document and observe visual highlighting as audio is played. Learners using a web browser or mobile device can actively read the article text contained in the document aloud and observe their voice tracked on the viewable page.
A tracking component of the system can provide a combination of real-time (or substantially real-time) word, sentence, and/or line level highlighting. In addition to providing real-time reading position tracking on a web page, the system can also provide fluency feedback along a number of dimensions including, for example, reading rate, slowly spoken words, disfluent word locations, unnatural pause locations, and/or the like. The instruction method can also include the ability to discover audio linked within a document and provide similar visual highlighting in synchronization with the audio, and/or allow for recordings from other learners or reading experts (e.g., stored in a database or embedded as a link in a web page) to be played in synchrony with the text discovered within the document.
In some embodiments, a non-transitory processor-readable medium stores code representing instructions to be executed by a processor. The code includes code to cause the processor to receive a request from a user of a client device to initiate a speech recognition engine for a web page displayed at the client device. The speech recognition engine can be, for example, part of a reading fluency training system.
The non-transitory processor-readable medium stores code to cause the processor to download, in response to the request and from a first server, the speech recognition engine to the client device. The first server can be, for example, a server device configured to store the speech recognition engine (e.g., code or script of the speech recognition engine) such that any client device requesting the speech recognition engine can download the speech recognition engine from the server device. In some instances, the speech recognition engine is not executed at the first server. In some instances, the non-transitory processor-readable medium stores code to cause the processor to download, via a network and into a browser module at the client device, the speech recognition engine using a bookmarklet. In such instances, the browser module can be configured to present the web page at the client device. Furthermore, the request from the user can include an instruction by the user to initiate the bookmarklet when the web page is presented by the browser module.
The non-transitory processor-readable medium also stores code to cause the processor to analyze, using the speech recognition engine and in response to the request, content of the web page to produce analyzed content. In some instances, the content of the web page includes text in an identified language. In such instances, the content of the web page can be analyzed based on the identified language. Additionally, the content of the web page can be received at the speech recognition engine from a second server. The second server can be, for example, a web server configured to host the web page. Such a second server can be associated with a party (e.g., an organization owning or providing the web page) different from a party associated with the first server (e.g., a company owning or providing the speech recognition engine or at least part of the reading fluency training system). In some instances, the first server can be remote from the second server and the client device.
The non-transitory processor-readable medium further stores code to cause the processor to send a signal to cause the client device to present the analyzed content to the user at the client device. In some instances, the content of the web page includes text associated with audio in the identified language. The code to cause the processor to analyze includes code to cause the processor to map a set of spoken words from the audio of the web page to a set of textual words from the text of the web page. As a result, the signal is configured to cause the client device to visually highlight, at a display screen of the client device, each word from the set of textual words when an associated spoken word from the set of spoken words is output at an audio output device.
In some instances, the content of the web page includes text associated with audio in the identified language. In such instances, the non-transitory processor-readable medium can store code to cause the processor to map a set of spoken words from the audio of the web page to a set of textual words from the text of the web page. As a result of the mapping, the signal can be configured to cause the client device to visually highlight, at a display screen of the client device, each word from the set of textual words when an associated spoken word from the set of spoken words is output at an audio output device (e.g., speaker) associated with the client device.
In some instances, the code to cause the processor to analyze the content of the web page is not executed outside the client device. In some instances, the speech recognition engine utilizes an acoustic model and/or a pronunciation lexicon for the identified language of the text to analyze the content of the web page. In some instances, the code to cause the processor to analyze is not executed prior to the request from the user of the client device.
In some embodiments, a method includes receiving content of a web page at a speech recognition engine on a client device in response to a request from a user at the client device to execute the speech recognition engine. The content of the web page includes text in an identified language being taught to the user. The web page is presented to the user on a display screen of the client device. In some embodiments, the speech recognition engine is part of a reading fluency training system.
The method includes determining, via the speech recognition engine, a set of character indices related to the text of the web page when the web page is presented to the user at the client device. In some instances, each character index from the set of character indices can be a plain text character index.
The method also includes mapping, via the speech recognition engine, a set of spoken words to a set of textual words in the text of the web page based on the set of character indices. The mapping occurs when the web page is presented to the user at the client device. The set of textual words is associated with the content of the web page. In some instances, the method can include defining a data structure configured to map the set of character indices to a set of Document Object Model (DOM) element indices associated with the web page.
The method further includes sending a signal to cause the client device to visually highlight, on the display screen presenting the web page, each word from the set of textual words when an associated spoken word from the set of spoken words is output at or produced by an audio device associated with the client device. In some instances, the mapping can include identifying, via the speech recognition engine, each spoken word from the set of spoken words as that spoken word is output at or produced by the audio device.
In some instances, the set of spoken words are produced by the user in real-time (or substantially real-time), and the audio device is an audio input device such as, for example, a microphone. In such instances, the sending includes sending the signal to cause the client device to visually highlight, on the display screen presenting the web page, each word from the set of textual words when the user produces an associated spoken word from the set of spoken words using the audio device associated with the client device. In some other instances, the set of spoken words are from an audio recording, and the audio device is an audio output device such as, for example, a computer speaker. In such instances, the sending includes sending the signal to cause the client device to visually highlight, on the display screen presenting the web page, each word from the set of textual words when an associated spoken word from the set of spoken words in the audio recording is output at the audio device of the client device.
In some embodiments, a method includes receiving a request from a user of a client device to execute, at the client device, a speech recognition engine for a web page when the web page is displayed at the client device. The web page is hosted by a first server. The web page includes text in a language being taught to the user. The method also includes receiving, at the speech recognition engine, an audio file associated with the content of the web page from a database maintained at a second server in response to the receiving the request. The second server can be associated with a party (e.g., a company owning or providing the speech recognition engine) different from a party associated with the first server (e.g., an organization owning or providing the web page). The audio file is linked to the web page by the database and includes a set of spoken words in the language corresponding, at least in part, to the text of the web page. The method further includes sending a signal to cause the client device to output an audio recording from the audio file as the speech recognition engine processes, at the client device, the text of the web page and the audio file.
As used herein, a module can be, for example, any assembly and/or set of operatively-coupled electrical components associated with performing a specific function, and can include, for example, a memory, a processor, electrical traces, optical connectors, software (stored and/or executing in hardware), and/or the like. In some embodiments, a module described herein can be a hardware-based module (e.g., a CPU, a general purpose processor, a DSP (Digital Signal Processor), a FPGA (Field Programmable Gate Array), an ASIC (Application Specific Integrated Circuit)), a software-based module (e.g., a module of computer code stored in memory and/or executed at a processor), and/or a combination of hardware and software-based modules.
As used herein, the singular forms “a,” “an” and “the” include plural referents unless the context clearly dictates otherwise. Thus, for example, the term “a text processing module” is intended to mean a single module or a combination of modules configured to perform functions associated with processing text content of a web page.
The client device 120 can be any type of device configured to send data over the network 170 to and/or receive data from one or more of other devices (e.g., the server devices 150, 160). The client device 120 can be operated by a user 130, and operatively coupled to the network 170 such that the client device 120 can be in communication with the server devices 150, 160. The user 130 can be anyone that operates the client device 120. The user 130 can be anyone (e.g., a language learner, a teacher, a tutor, a researcher, etc.) that uses the reading fluency training system 100. In some embodiments, the client device 120 can be, for example, a desktop computer, a laptop, a smart phone, a tablet, and/or the like. Details of a client device are further illustrated and described with respect to
The server device 150 can be any device configured to host and provide a web page such that the client device 120 can retrieve and display content of the web page. In some embodiments, the server device 150 can be configured to function as, for example, a web server, a network management device, a data repository, and/or the like. For example, the server device 150 can be a web server that hosts and maintains a website including one or multiple web pages. The client device 120 can be a personal computer connected to the server device 150 via an Internet Service Provider (ISP) and the Internet (e.g., the network 170). Thus, the client device 120 can retrieve content of the web page(s) and display the web page(s) on a monitor of the client device 120. In some embodiments, although not shown in
The server device 160 can be any device configured to host and execute a portion of the reading fluency training system 100. As shown in
The processor 162 can be any suitable processing device configured to run and/or execute modules, processes and/or functions associated with providing oral reading training exercises to language learners. In some embodiments, the processor 162 can be a general purpose processor, a FPGA, an ASIC, a DSP, and/or the like.
In some embodiments, the server device 160 can be configured to function as, for example, a server, a controller, a management device, a database, etc., of the reading fluency training system 100. The client device 120 can be configured to host and execute another portion of the reading fluency training system 100, and to interact with the server device 160 to provide oral reading training exercises to a user (e.g., the user 130). In such embodiments, the server device 160 can be configured to, among other functions, retrieve content of a web page from a remote device (e.g., the server device 150), analyze content of a web page, identify a language from text extracted from a web page, store acoustic model(s) and/or pronunciation lexicon(s), and/or the like. Details of the functions of the server device 160 and the client device 120 are further described with respect to
In some embodiments, the reading fluency training system 100 can be configured to enable a method for providing practiced oral reading instructions from textual content found commonly in the form of web pages (e.g., HTML-based web pages). Such a method can, for example, use computer speech recognition mechanisms to provide speech analysis and feedback. Specifically, the reading fluency training system 100 can directly manipulate the content (e.g., HTML-based content) of a web page (or other document) to visually inform a language learner in various ways. In some embodiments, for example, text on the page can be highlighted in synchronization with spoken-word audio. This method allows web content to be orally presented to the language learner with word-based highlighting. Audio can be prerecorded (e.g., linked as a resource to a web page or stored in a database). In other embodiments, the language learner can practice speaking the text presented on the web page by recording live from an audio input device (e.g., a microphone) and to receive visual feedback of reading position. In still other embodiments, the reading fluency training system 100 can manipulate the content on a web page after reading is completed to illustrate various fluency-related feedback mechanisms (e.g., highlighting words on the web page that were read too slowly, not read by the language learner, or mispronounced, etc.). The reading fluency training system 100 and its teaching methods can therefore be used to improve the language learner's reading fluency.
The client device 200 can be similar to the client device 120 shown and described with respect to
The memory 220 can be, for example, a RAM (e.g., a dynamic RAM, a static RAM), a memory buffer, a hard drive, a flash memory, an EPROM, an EEPROM, a ROM, and/or so forth. In some embodiments, the memory 220 can be configured to store instructions to cause the processor 280 to execute modules, processes, functions, and/or the like, associated with the reading fluency training module 230 as described in further detail herein.
The processor 280 can be any suitable processing device configured to run and/or execute the modules, processes and functions associated with the reading fluency training module 230. More specifically, as described in further detail herein, the processor 280 can be configured to execute the modules included in the reading fluency training module 230 (e.g., speech recognition engine (SRE) 260 including reading tracking module 261 and text processing module 262, audio discovery module 235, visual highlighting module 237, feedback module 239). In some embodiments, the processor 280 can be a general purpose processor, a FPGA, an ASIC, a DSP, and/or the like.
The display device 210 can be any suitable device configured to display a web page. The display device 210 can be, for example, a monitor (e.g., a liquid crystal display (LCD) monitor, a cathode ray tube display (CRT) monitor, a tablet monitor), a screen, a projector, and/or the like. The audio input device 240 can be any suitable device configured to receive and store (e.g., record) audio input such as, for example, a microphone, a voice recorder, and/or the like. The audio output device 250 can be any suitable device configured to output audio recordings such as, for example, a speaker, an audio card, and/or the like.
To execute the reading fluency training system, the client device 200 can be configured to implement the reading fluency training module 230. In some embodiments, the reading fluency training module 230 (including the SRE 260) can be instantiated at the client device 200 without installing extra software at the client device 200. That is, a user (e.g., the user 130 in
Similar to
Returning to
Specifically, the audio button 820 indicates audio discovery, and selecting (e.g., clicking) the audio button 820 enables playing the discovered audio associated with the web page. The microphone button 830 enables a user (e.g., a language learner, a teacher, a tutor or a researcher who views the web page) to read text of the web page with tracking being highlighted on the web page. The audio playback button 840 enables the user to hear back her own voice (e.g., playing an audio recording of the user) or others' voices (e.g., playing audio recordings of the other users, playing an audio recording embedded in the web page). The text button 850 enables switch between different views of the web page. For example, selecting (e.g., clicking) the text button 850 can cause switch between a text-normalized view (e.g., a text-only view without any image or video clip, a view with advertisements stripped and only readable text present) of the web page using, for example, Adobe Flash, and an original view (with images, video clips, advertisements, as shown in
In some embodiments, more than one audio recording associated with the web page can be discovered and made accessible to a user (i.e., made available to be played to the user). For example, audio recordings associated with different text passages in the web page can be discovered and made accessible to the user. Furthermore, in some embodiments, multiple audio recordings associated with the same text passage in the web page can be discovered and made accessible to the user. For example, an audio recording of an article produced by an expert broadcaster can be provided, in an audio file linked to the web page (e.g., embedded in the HTML code of the web page), from a web server that hosts the web page (e.g., the server device 150 in
Similar to
Specifically, the audio button 1420 enables playing an audio recording associated with the readable textual content of the web page. The audio recording played by selecting the audio button 1420 can be, for example, an audio recording produced by the user herself, an audio recording produced by another user of the reading fluency training system, an audio recording from an audio file embedded in the web page (e.g., produced by an expert), and/or the like. In other words, the audio button 1420 functions as a combination of the audio button 820 and the audio playback button 840 in
Related to use of the audio button 1420, the selection button 1440 enables the user to select an audio recording from multiple audio recordings associated with the readable textual content of the web page (if such multiple audio recordings are available). In some embodiments, the audio recording(s) presented to the user (e.g., via selecting the selection button 1440) can be selected from a group of associated audio recordings based on a ranking of the audio recordings. For example, the top 5 ranked audio recordings of an article from all the audio recordings produced by the users of the reading fluency training system can be presented to the user. To select and then play an audio recording, the user can select the selection button 1440 to reveal selection of the multiple audio recordings (e.g., in a drop-down menu, in a pop-up window, etc.). After the user selects an audio recording from the multiple audio recordings (e.g., by selecting an icon representing that audio recording) and then selects the audio button 1420, the selected audio recording is played. In some embodiments, once the user produces an audio recording (e.g., by recording her own voice), that audio recording becomes the default for playback. That is, the audio recording produced by the user can be played by selecting the audio button without making a selection using the selection button 1440. In other embodiments, an audio recording can be determined as a default one for playback according to any other suitable rule. For example, the audio recording associated with the web page that was most-recently played by the user can be made the default one. For another example, the audio recording from the audio file embedded within the web page can be made the default one.
Similar to the text button 850 shown and described with respect to
Returning to
Returning again to
As shown in
The audio discovery module 235 can be configured to discover audio associated with a web page displayed at the client device 200 (e.g., via the display device 210). That is, the audio discovery module 235 can be configured to examine the content (e.g., HTML content) of the web page and automatically discover links to audio files that are potentially related to the web page's content. Specifically, after audio discovery is triggered (e.g., by the user clicking the associated bookmarklet on the web browser), the audio discovery module 235 can be configured to perform the following steps.
Step 1: Gather the links associated with audio content (e.g., MP3 links) through various means and audio finding rules. For example, for a first audio finding rule, some web pages refer to the audio as an <a> link in the web page. Such links can be found by searching for the particular signature (e.g., .mp3 extensions) in the links' URLs (uniform resource locators). For a second audio finding rule, some web pages have the audio in SWF audio players. Such audio can be found by iterating through the SWFs in the web page and analyzing the FlashVars of these SWFs looking for URLs with the particular signature (e.g., .mp3 URLs). For a third audio finding rule, some web pages put the audio in a “popup”. Such audio can be detected by searching for links that have some heuristic labeling such as, for example, “MP3”, “Listen”, “Download”, etc. The audio discovery module 235 can then download the popup HTML and recursively invoke the other audio finding rules (e.g., the first and second audio finding rules) on the web page. In some embodiments, one or more of these rules can be used.
Step 2: Sort the audio URLs that are gathered in Step 1 by their edit-distance (e.g., Levenshtein distance) to the web page's URL and then select the audio with the smallest edit-distance. When there is more than one URL, one URL can be selected as the audio that represents the text (e.g., the audio URL is “similar” to the web page URL). In some embodiments, an audio from multiple URLs can be selected based on any other suitable method or rule.
In some embodiments, if no audio is discovered for a web page, or the discovered audio is unrelated to the text of the web page (e.g., the audio does not match the text of the web page), the web page or the audio can be flagged to a back-end server of the reading fluency training system (e.g., the server device 160 in
In some embodiments, as described above with respect to
The audio discovery process performed by the audio discovery module 235 provides a means for real-time (or substantially real-time) text processing. When an audio recording associated with a web page (e.g., produced by a user, embedded within the web page) is discovered, the audio recording can be sent (e.g., streamed) to both the audio output device 250 for playing and the SRE 260 for processing at the same time (or substantially the same time). Specifically, the audio recording can be decoded into small chunks (e.g., every 50 to 250 milliseconds), which are then sent sequentially to the audio output device 250 and the SRE 260. In operation, a user of the client device 200 can select a button (e.g., the audio button 820 in
In some embodiments, implementation of the reading fluency training system does not require pre-alignment of text with the audio. In such embodiments, the reading tracker (e.g., performed by the reading tracking module 261) operates on the audio recording as if the audio recording was input from the audio input device 240 (e.g., a microphone) of the client device 200. Such a method provides instant tracking on an audio file of any arbitrary length. In some embodiments, for example, audio can be streamed into the reading fluency training module 230, hence fully downloading the audio linked onto a web page is not necessary. In some embodiments, the audio found on a web page can be downloaded, decompressed, and processed by the reading fluency training module 230 in real-time (or substantially real-time) while the audio is played out at the client device 200 (e.g., via the audio output device 250). This feature allows the reading fluency training system to immediately (or substantially immediately) begin highlighting words on the display (e.g., the display device 210) of the client device 200 as the audio from the web page is played.
In some embodiments, the audio discovery module 235 can be configured to explore the Document Object Model (DOM) of the web page to find, for example, MP3 anchor tags. In some embodiments, when audio is not discovered as linked to the web page content, the reading fluency training system can use other suitable methods to create an audio rendering of the web page such as, for example, text-to-speech synthesis, crowd sourced recording, and/or the like.
As shown in
In some embodiments, such a text extraction process can be performed at a back-end server (e.g., the server device 160 in
The text processing module 262 can be configured to perform global character index alignment based on the readable textual content extracted from the web page. Specifically, in some embodiments, the SRE 260 accepts a single monolithic block of text and returns character/word indices relative to that block of text. Meanwhile, the web page DOM represents character indices in the context of its individual elements. Thus, as far as the DOM is concerned, the text is fractured into tiny pieces. The text processing module 262 can be configured to implement a mapping between the SRE-modeled text character indices and the webpage DOM character index positions.
In some embodiments, when the text is extracted from the web page, a data structure can be defined that maintains this mapping from plain text character indices to DOM element indices. Such a mapping allows the positions in text as determined by the text processing module 262 to be mapped directly onto controls for character manipulation (e.g., highlighting) on the display of the web page. For example, the mapping process can be performed by sequentially operating the following three steps on each node in the DOM: (1) obtain an index of the current node by determining a current length of the accumulated plain-text string; (2) append the current node and its index to an array; and (3) append the plain-text representation of the current node to the accumulated plain-text string. Eventually, the accumulated plain-text string contains a plain-text representation of each node in the DOM. As a result, when the SRE 260 emits a character index, the array can be searched to locate the node that has the nearest start index. In some embodiments, web page character positions can be calculated in any other suitable methods to avoid the intermediate character-mapping problem.
In some embodiments, the SRE 260 can include acoustic models and/or pronunciation lexicons that provide knowledge, data and/or information about the language of the web page that is being read by the user. In some embodiments, after the SRE 260 is activated for a web page (e.g., by the user selecting the associated bookmarklet on the web browser), the SRE 260 (e.g., via the text processing module 262) can be configured to send the web page's URL to a back-end server (e.g., the server device 160 in
After the language of the text is identified, the back-end server can send a signal indicating the identified language to the SRE 260. Thus, the SRE 260 (e.g., via the text processing module 262) can be configured to download the corresponding acoustic models and/or pronunciation lexicons associated with the identified language from the back-end server. Furthermore, the text processing module 262 can configure the SRE 260 accordingly based on the downloaded acoustic models and/or pronunciation lexicons associated with the language identified for the text of the web page.
In some embodiments, the text processing module 262 can be configured to perform a text normalization process to turn numbers/dates/times into readable text (e.g., $19 to “nineteen dollars”), thus enabling the SRE 260 to lookup or predict the pronunciation more accurately. The text processing module 262 can be configured to implement any suitable methods for text normalization, such as punctuation stripping to reveal the word to be recognized, or extensions to expanding numerals and dates and other ill-formatted data.
The reading tracking module 261 can be configured to map words recognized from the text processing module 262 to character and/or word positions on a reference text that is displayed at the client device 200 (e.g., via the display device 210). In some embodiments, the reading tracking module 261 can be configured to model a reference block of text (e.g., an article) using, for example, a backoff n-gram language model (e.g., n=3). In other embodiments, the reading tracking module 261 can use other suitable modeling methods such as, for example, grammar-based language models, fixed and/or variable length n-gram models.
As audio is provided to (e.g., fed or streamed into) the SRE 260, words can be identified by the reading tracking module 261. The identified word sequence can contain substitutions, deletions, and/or word insertions depending on the accuracy of the user's reading of the text and the accuracy of the underlying machine (e.g., the client device 200 including the reading fluency training module 230). The reading tracking module 261 can be configured to match the words identified to the text to determine reading locations. The reading tracking module 261 can then be configured to convert the text locations into character locations on the web page using the character mapping method described above with respect to the text processing module 262 and
For example, the longest contiguous path in the source text can be determined at regular intervals using the last N words identified by the reading tracking module 261 (e.g., N=13). The end-point of the longest contiguous path of identified and/or recognized words that matches the source text can be considered a candidate for the current reading position. Heuristics related to the number of word matches along the path can be used to determine if the reading position on the web page should be advanced or not. As input audio is received, the reading tracking module 261 can output additional identified and/or recognized words that are then again matched to the source text using the longest contiguous path finding method described above. The frequency of the matching process can control the reactivity of the tracker to the user's voice. In some embodiments, updates can be made, for example, every 50 to 250 milliseconds or more often. In some embodiments, various alternative approaches can be used to solve the text alignment problem for reading tracking. For example, the alignment between the SRE-hypothesized text and the reference text can be made using the Viterbi algorithm in combination with acoustic units smaller than words.
The visual highlighting module 237 can be configured to highlight tracked text on the display of the client device 200 (e.g., via the display device 210). In some embodiments, various methods of highlighting can be used such as, for example, word-by-word highlighting (i.e., the currently spoken word is highlighted), line-by-line highlighting (i.e., the entire line containing the current word is highlighted), sentence-by-sentence highlighting (i.e., the current sentence is highlighted), and/or the like.
In some embodiments, the web browser of the client device 200 can provide APIs that allow for text to be highlighted on the display. For example, text highlighting can be performed using the Range API associated with the web browser. Using information from the Range API, the visual highlighting module 237 can be configured to float a transparent colored div element over the text being tracked, and slide/resize it as needed (e.g., as shown in
The feedback module 239 can be configured to provide instructional feedback regarding the user's oral reading fluency. The feedback can be provided in various methods after the user finishes reading. The feedback can be presented in terms of, for example, reading rate, disfluent pause locations, visual highlighting of slowly spoken words, ill-pronounced words, and other reading errors.
In some embodiments, the feedback module 239 can be configured to compute reading rate in terms of words correct per minute (WCPM) globally as well as a localized reading rate metric for each spoken word. Words that are spoken too slowly can be visually highlighted (e.g., using a color different from highlighting for words spoken at a normal rate) on the display. Significant and disfluent pause locations can also be displayed within the text of the web page and rendered visually by the web browser.
In some embodiments, the feedback module 239 can also detect which words were not read by the user, or those not pronounced well. Such metrics can be tracked over multiple reading sessions and aggregated statistically. In some embodiments, feedback can be made available on the toolbar of the application. For example, the feedback module 239 can be configured to display on the toolbar the overall reading rate and the number of significant pauses made while reading. In some embodiments, the feedback module 239 can be configured to play audio of words that the user stumbled or paused on (e.g., using pre-recordings or text-to-speech synthesis) as well as compare the user's reading with that of other users, or compare to native readings when available through crowd-sourcing. In some embodiments, users can select parts of the text and have the words and phrases synthesized by a computer to provide pronunciation feedback. Other alternatives to this approach include, for example, crowd sourcing of audio recordings from native speakers of the language.
At 420, an article is extracted from the web page. The article can be extracted by, for example, a text processing module (e.g., the text processing module 262 in
Meanwhile, at 428, a URL of an audio file is identified from the web page by, for example, an audio discovery module (e.g., the audio discovery module 235 in
To collect audio from an appropriate source, the reading fluency training module can perform one of three operations in response to the triggering actions by the user: in response to the user selecting the “Hear Story” button (at 510), audio discovered from the web page can be streamed into the SRE (at 518); in response to the user selecting the “Read Story” button (at 512), audio collected by a microphone of the client device can be streamed into the SRE (at 520); in response to the user selecting the “Hear Myself” button (at 514), audio of the user's own recording can be streamed into the SRE (at 522).
Next, at 524, the SRE performs reading tracking on the current position in the audio. The reading tracking can be performed by, for example, a reading tracking module (e.g., the reading tracking module 261 in
At the end, one of two possible events can cause the play of the audio and the tracking operation: the user selects a “Stop” button (at 532) or the end of the audio is detected (at 534). After the training exercise is complete, at 536, the web page is highlighted according to oral fluency feedback. The feedback can be provided by, for example, a feedback module (e.g., the feedback module 239 in
In some embodiments, the reading fluency training system described herein can be used as a social game with learner fluency ranking. Specifically, using a combination of reading fluency metrics computed by the reading fluency training system and a ranking system (e.g., the Elo relative pairwise ranking system), the oral reading fluency of one language learner can be compared and ranked against other language learners in a user population. In such embodiments, the language learners can be scored based on their reading, and the ranking system can be established to group or characterize different language learners based on, for example, their proficiency level with the language.
For example, learner A and learner B each reads a passage of text aloud. The fluency metrics scores for learner A and learner B can then be used to compare learner A's reading to learner B's reading. Higher fluency metrics for learner A indicate a win for learner A and a loss for learner B. Using the ranking system, the learners' outcome can be used to rank learner A and learner B against other learners. Thus, the oral reading exercises can be made more engaging, fun and competitive as an online activity.
In some embodiments, the reading fluency training system described herein can be used to provide a social sharing of read-aloud recordings. For example, a language learner who is a native English speaker can read and record English web pages and share the audio recordings with language learners who wish to learn English. Conversely, a language learner who is a native Spanish speaker but wishes to learn English can contribute native recordings of Spanish web pages and listen to those recordings shared by the native English speakers. Through community-based sharing and contributions of audio recordings, web pages can become playable and synchronized with the text of the web pages using the reading fluency training system and its methods described herein. Furthermore, the community of language learners can rank their shared recordings in terms of, for example, comfort of reading, fluency, clarity, and/or the like, to allow the best native recordings to be easily accessible to other language learners.
In some embodiments, audio recordings produced by users of the reading fluency training system can be updated onto and stored at, for example, a server associated with the reading fluency training system (e.g., the server device 160 in
In some embodiments, the reading fluency training system described herein can be used to provide a social sharing of fluency ranking. In such embodiments, language learners can read passages of text aloud and submit their recordings for feedback from other native language learners of a community of users. Specifically, using crowd-sourcing techniques, language learners can get valuable feedback beyond what is the current state-of-the-art for speech recognition technology. For example, an audio recording made by a language learner can be critiqued by many individuals (not just a single human coach), and later retrieved by that language learner to inform about her reading fluency progress as well as tips to improve her fluency during oral reading.
In some embodiments, the reading fluency training system described herein can be used to support early readers with guided reading modes. In such embodiments, rather than requiring a beginning learner of a language to read an entire passage, an individual sentence can be highlighted and the beginning learner can be prompted to read the individual sentence. The beginning learner can be allowed to advance onto the next sentence if the sentence is read sufficiently well. This method provides an increased accuracy for reading tracking, and allows for more robustness to highly disfluent or mispronounced speech.
In some embodiments, the reading fluency training system described herein can be implemented in a mobile platform. In such embodiments, the SRE and other associated applications of the reading fluency training system can be hosted and executed on a mobile device such as, for example, a tablet or smart phone. In such embodiments, the architecture of the reading fluency training system can be inverted from that for a non-mobile platform (e.g., a web browser application executed at a desktop computer). The architecture for a mobile device can be different from the web browser architecture shown and described with respect to
Specifically, for a mobile device to host and execute a mobile application for the reading fluency training system described herein, the application code for the mobile application includes a web browser component that is configured to present a web page on the mobile device. After the mobile application is launched to present a web page, the web page can include, for example, a “Read Page” button (e.g., without the step of injecting a bookmarklet). In response to selecting the “Read Page” button, code (e.g., JavaScript code) associated with executing the reading fluency training system can be injected into the web browser component. The code can be executed in context of the web page, and thus the mobile application begins initialization. The initialization process for the mobile application is different from that described for the non-mobile platform (shown and described with respect to
In some embodiments, the reading fluency training system described herein can be implemented using alternative visualization and highlighting methods. For example, alternative programming languages and visualization methods such as Adobe Flash can be used to perform on-screen visual highlighting by incorporating computer speech-recognition-based reading tracking. Specifically, the discovered text document can be rendered as “rich text” and the text highlighting can be manipulated using the Adobe Flash text API.
While described herein with respect to
While described herein with respect to
While shown and described with respect to
While shown and described herein as readable textual content being presented in a web browser, in other embodiments, other display applications can be used to present readable text. In such embodiments, the reading fluency training system described herein can be modified accordingly to be executed with the other display applications appropriately. For example, an article can be presented in an HTML-based word processing application executed inside of a web browser (e.g., Google Docs) by opening a document. In some embodiments, the article can be presented in other word processing applications (e.g., Microsoft™ Word). The reading fluency training system can be injected into or embedded within application code of these word processing applications in a similar method as described herein. Furthermore, the reading fluency training system can be executed to visually highlight text in these word processing applications as audio of the text being played or spoken words of the text being produced by a user.
Some embodiments described herein relate to a computer storage product with a non-transitory computer-readable medium (also can be referred to as a non-transitory processor-readable medium) having instructions or computer code thereon for performing various computer-implemented operations. The computer-readable medium (or processor-readable medium) is non-transitory in the sense that it does not include transitory propagating signals per se (e.g., a propagating electromagnetic wave carrying information on a transmission medium such as space or a cable). The media and computer code (also can be referred to as code) may be those designed and constructed for the specific purpose or purposes. Examples of non-transitory computer-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs (CD/DVDs), Compact Disc-Read Only Memories (CD-ROMs), and holographic devices; magneto-optical storage media such as optical disks; carrier wave signal processing modules; and hardware devices that are specially configured to store and execute program code, such as Application-Specific Integrated Circuits (ASICs), Programmable Logic Devices (PLDs), Read-Only Memory (ROM) and Random-Access Memory (RAM) devices. Other embodiments described herein relate to a computer program product, which can include, for example, the instructions and/or computer code discussed herein.
Examples of computer code include, but are not limited to, micro-code or micro-instructions, machine instructions, such as produced by a compiler, code used to produce a web service, and files containing higher-level instructions that are executed by a computer using an interpreter. For example, embodiments may be implemented using Java, C++, or other programming languages (e.g., object-oriented programming languages) and development tools. Additional examples of computer code include, but are not limited to, control signals, encrypted code, and compressed code.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, not limitation, and various changes in form and details may be made. Where methods described above indicate certain events occurring in certain order, the ordering of certain events may be modified. Additionally, certain of the events may be performed concurrently in a parallel process when possible, as well as performed sequentially as described above. Any portion of the apparatus and/or methods described herein may be combined in any combination, except mutually exclusive combinations. The embodiments described herein can include various combinations and/or sub-combinations of the functions, components and/or features of the different embodiments described.
Claims
1. A non-transitory processor-readable medium storing code representing instructions to be executed by a processor, the code comprising code to cause the processor to:
- receive a request from a user of a client device to initiate a speech recognition engine for a web page displayed at the client device;
- download, in response to the request and from a server associated with a first party, the speech recognition engine to the client device;
- analyze, using the speech recognition engine and in response to the request, content of the web page including text in an identified language to produce analyzed content based on the identified language, the content of the web page being received from a server associated with a second party different from the first party; and
- send a signal to cause the client device to present the analyzed content to the user at the client device.
2. The non-transitory processor-readable medium of claim 1, wherein the code to cause the processor to download includes code to cause the processor to:
- download, via a network and into a browser module at the client device, the speech recognition engine using a bookmarklet, the browser module configured to present the web page at the client device.
3. The non-transitory processor-readable medium of claim 1, wherein the code to cause the processor to download includes code to cause the processor to:
- download, via a network and into a browser module at the client device, the speech recognition engine using a bookmarklet such that the request from the user includes an instruction by the user to initiate the bookmarklet when the web page is presented by the browser module.
4. The non-transitory processor-readable medium of claim 1, wherein the code to cause the processor to analyze is not executed outside the client device.
5. The non-transitory processor-readable medium of claim 1, wherein the identified language is a first identified language, the web page is a first web page, the signal is a first signal, and the analyzed content is first analyzed content, the non-transitory processor-readable medium further comprising code to cause the processor to:
- receive a request from the user to initiate the speech recognition engine for a second web page displayed at the client device;
- download, in response to the request associated with the second web page and from the sever associated with the first party, the speech recognition engine into the client device;
- analyze, using the speech recognition engine and in response to the request associated with the second web page, content of the second web page including text in a second identified language to produce second analyzed content based on the second identified language, the content of a second web page being received from a server associated with a third party different from the first party and the second party; and
- send a second signal to cause the client device to present the second analyzed content to the user at the client device.
6. The non-transitory processor-readable medium of claim 1, wherein the speech recognition engine is not executed at the server associated with the first party.
7. The non-transitory processor-readable medium of claim 1, wherein the server associated with the first party is remote from the client device and the server associated with the second party.
8. The non-transitory processor-readable medium of claim 1, wherein the content of the web page includes text associated with audio in the identified language, the code to cause the processor to analyze including code to cause the processor to map a set of spoken words from the audio of the web page to a set of textual words from the text of the web page such that the signal is configured to cause the client device to visually highlight, at a display screen of the client device, each word from the set of textual words when an associated spoken word from the set of spoken words is output at an audio output device associated with the client device.
9. The non-transitory processor-readable medium of claim 1, wherein the speech recognition engine utilizes an acoustic model and a pronunciation lexicon for the identified language of the text to analyze the content of the web page.
10. The non-transitory processor-readable medium of claim 1, wherein the code to cause the processor to analyze is not executed prior to the request from the user of the client device.
11. A method, comprising:
- receiving, at a speech recognition engine on a client device, content of a web page in response to a request from a user at the client device to execute the speech recognition engine, the content of the web page including text in an identified language being taught to the user, the web page being presented to the user on a display screen of the client device;
- determining, via the speech recognition engine, a set of character indices related to the text of the web page when the web page is presented to the user at the client device;
- mapping, via the speech recognition engine, a set of spoken words to a set of textual words in the text of the web page based on the set of character indices, the set of spoken words being associated with the content of the web page; and
- sending a signal to cause the client device to visually highlight, on the display screen presenting the web page, each word from the set of textual words when an associated spoken word from the set of spoken words is output at an audio device associated with the client device.
12. The method of claim 11, wherein the mapping occurs when the web page is presented to the user at the client device.
13. The method of claim 11, wherein each character index from the set of character indices is a plain text character index, the method further comprising:
- defining a data structure configured to map the set of character indices to a set of Document Object Model (DOM) element indices associated with the web page.
14. The method of claim 11, wherein the mapping includes identifying, via the speech recognition engine, each spoken word from the set of spoken words as that spoken word is output at or produced by the audio device.
15. The method of claim 11, wherein the set of spoken words are produced by the user, the audio device is an audio input device, the sending includes sending the signal to cause the client device to visually highlight, on the display screen presenting the web page, each word from the set of textual words when the user produces an associated spoken word from the set of spoken words using the audio device.
16. A method, comprising:
- receiving a request from a user of a client device to execute, at the client device, a speech recognition engine for a web page when the web page is displayed at the client device, the web page hosted by a server associated with the first party, the web page including text in a language being taught to the user;
- receiving, at the speech recognition engine, an audio file associated with the web page from a database maintained by a second party in response to the receiving the request, the audio file being linked to the web page by the database and including a set of spoken words in the language corresponding, at least in part, to the text of the web page; and
- sending a signal to cause the client device to output an audio recording from the audio file as the speech recognition engine processes, at the client device, the text of the web page and the audio file.
17. The method of claim 16, wherein the signal is a first signal, the method further comprising:
- sending a second signal to cause the client device to visually highlight each word of the text of the web page that corresponds to a spoken word from the audio file when that spoken word is output from an audio output device associated with the client device.
18. The method of claim 16, wherein the first party is different from and not affiliated with the second party.
19. The method of claim 16, wherein the user is a first user, the set of spoken words in the audio file is spoken by a second user associated with the second party when the web page is presented to the second user.
20. The method of claim 16, wherein the receiving the request, the receiving the audio file and the sending the signal occur when the web page is presented to the user via a browser module on the client device.
Type: Application
Filed: Aug 22, 2016
Publication Date: May 18, 2017
Patent Grant number: 10210769
Applicant: Rosetta Stone Ltd. (Harrisonburg, VA)
Inventors: Aaron M. Simmons (Boulder, CO), Bryan Pellom (Erie, CO), Karl F. Ridgeway (Boulder, CO)
Application Number: 15/243,479