The present invention relates primarily to the field of telecommunications. More specifically, the present invention relates to a system and method for integrating the processing of conversations transmitted over a telecommunications network with other applications of software resident in that network and the computing-capable devices operating in the context of it.
As general-purpose computing devices have been reduced in size and price, and the mechanisms of connectivity to conversational telecommunication networks have become more open and implementable in them, the stage was set for a unification of their functions with those of telephones. This progressed from both ‘sides’: first, from the standpoint of implementing telecommunications functionality within simulated ‘telephone’-like environments on the PC, then to the addition of standard software applications like games and office apps to handheld phones. Implementation of the present invention in either context is interchangably described herein, as both serve as equivalent platforms to the ultimate embodiment of it in small, handheld devices capable of both functions, which have become known as ‘smartphones’, a word which arose in the late 1990s, and has been defined as a phone with additional software functions.
However, despite a vast market and though it's quickly become one word, the currently extant “SmartPhone” products still don't make the leap across the gap, to combine the “Smart” and “Phone” parts significantly. In particular, their ‘smart’ built-in features and add-on software applications don't significantly utilize the actual conversation content for utility significantly more than other, standard phones (and equivalent telecommunications devices) do. One reason for this is because the technology's heritage has kept a wall in place, or one has been erected on purpose for reasons such as to isolate the phone's mission-critical core telecommunications functionality expected by consumers from the bugs, crashes, security issues and other software vagaries of the more complex software environment of an operating system which hosts a panoply of diverse applications built by various vendors. Barriers to conversation processing in the Apple iPhone, for example, appear to have been purposely placed, with designers cited publically on this point. Smartphone pioneer Steve Jobs was even quoted as explaining the need for limitations as a platform difference: “You don't want your phone to be like a PC. The last thing you want is to have loaded three apps on your phone, and then you go to make a call and it doesn't work anymore.”
This dichotomy between the communications channel of the phone and its ‘smarts’ has inhibited the conceptualization and implementation of a broad range of valuable applications, including social media. This wall can be breached using certain configurations of hardware and software, which applications such as ReminderRing, created to provide customized notifications and other contextualized communications, and related useful embodiments of computer control of online social interactions based on conversation processing, described herein, exemplify. In particular, they realize a functionality in which the content of conversation conducted on a telephone or equivalent communication device including online forums, influences its later functionality, producing changed behavior of that instrument during its subsequent operation and associated adaptive changes to online social interactions. More broadly, they bring both the context and content of a communication to bear in extending the utility of the device through its interface with the user's needs and perceptions.
Human interaction is mediated by the effects of perceiving the presence of other humans. Their verbal and nonverbal cues are of the essence to our nature and function as social animals. Recent psychological experiments and brain MRI results confirm what motivational experts and organizational adepts have always known: that people function both proactively and reactively, the latter particularly in response to stimuli from other folks they are in communication with. Successful business models involve an acknowledgement of this fact, from ADHD coaches to podcasting housework mavens like FlyLady, from squawk-box-driven brokerage boiler rooms to talking-head TV programming.
But as the social web around us has expanded with the aid of electronic communications, the technological limitations of its early implementation have stifled the development of applications of this knowledge to the needs of the end user. Though some relatively feeble attempts to add a bit of face to the interface, such as with programs like Facebook, have succeeded quickly and been imitated by others, most have focused on growing a network faster rather than representing and relating it to each user in a better way. This has further led to a fractured social graph with multiple modes of not just communication, but representation also, with competing networks, identity management and user interfaces. And again, most attempts at improvement have been focused toward the center, not the nodes.
Take, for example, the simple ring tone. A ring tone is an audio segment played to alert the user of a telecommunications device to an incoming phone call or other type of communication. Ring tones are typically stored as digital audio files on a telecommunications device such as a cellular phone. Customizable ring tones have gained in popularity, as they allow users to set a specific ring tone to be played when receiving a call from a specific person recognized by their caller ID. Many carriers (that is, telecommunications service providers) and other businesses offer services whereby users may download specialized ring tones such as songs or other sound effects directly to a device. In the alternative, digital audio files may be uploaded to a telecommunications device and used as a ring tone. Utilities exist which enable users to create their own ring tones based on pre-recorded sounds, allowing mixing of multiple sounds and other forms of audio manipulation.
However, though a diversity of customization options exists for the creation of ring tones, these technologies only facilitate the singular function of identifying the calling party to the user, and that only indirectly through an assigned tone. Other ring tone technologies do not provide the user with any direct, dynamic, or additional information relating to the caller or the probable context of their call. Nor do they take advantage of the proximate source of transmitted vocalizations by the caller, the sound of whose voice can command the user's attention, which is the primary purpose of a call annunciation. Therefore, additional utility would be derived if a ring tone not only aided in identification of the caller, but did so in a more direct fashion, and also provided information as to the probable intent of the caller. [Pretty much everything up until this point probably belonged in the BACKGROUND section, but it's not critical. The fewer changes between this application and its parent, the better.—Matt] The present invention solves this problem through the creation of a ring tone which incorporates the content of previous correspondence with the caller, thus contextualizing the new communication, that is, placing the new call into context for the user.
Moreover, hardly any attempts to help a user associate a call request with his counterparty have penetrated the market, and none have utilized the voice from a prior conversation, which is a natural and effective reminder of the context in which the user will grasp the meaning of the communication.
Furthermore, there is a need in the art for a means for remedying this lack of a humanized, individualized connectivity environment by gathering the separate threads of electronically-mediated connectivity not in their collective cloud, but rather at the individual. By furnishing the user with technology to integrate multimodal streams of communication from other people, and from himself, with representations that are more naturally suited for his sensory and cognitive nature, the current invention furnishes a better system to deal with communication.
In combination with means for conversations to be routed among interested parties, for whom actionable information will be available, it can enable nurturing and instant communication of further utility in social interaction, providing means for collections or even large organizations of people, to engage in interwoven conversation streams. In a business context, those can be corporations or other sets of people. In a commercial context, incentivizing of conversational content can be addressed for advertising and other purposes.
The present invention, referred to henceforward as ReminderRing, can be seen in one mode as a system and method for generating a ring tone or equivalent non-audio annunciation based on one or more prior audio, video, or textual conversation streams. The invention is applicable to communications systems and associated devices, including cellular, local exchange, voice-over-IP, general purpose computers, messaging systems, gaming devices, set-top devices, PDAs, pagers, electronic books, lifestreaming systems, business, medical and other social behavior tracking and management systems, among others.
In one embodiment of the invention, a ring tone is generated from a recorded portion of a conversation with a caller. The ring tone is subsequently played when receiving a call from the same caller, who is identified by caller ID.
In another embodiment of the invention, a ring tone is generated by converting a text message, or portion thereof, to audio speech. The audio speech is then played when receiving a call from the same person, identified by caller ID. Detailed methods are disclosed for implementation of the present invention in both a NetStream-type communications system and a SIP-style communications system.
In another embodiment of the invention, a calendaring system is implemented and integrated into the ReminderRing system. Additional disclosure of this invention's operation demonstrates its even broader use as applied to other telecommunications modalities, with the addition of an integrated personal and/or public private party caller ID system to unify channels of communication by creating an overall system for counterparty identity representation; and in not just for incoming calls and calendared events, but also to announce completion of background tasks, such as for connecting outgoing calls.
This invention discloses a means for remedying this disparate situation by gathering the separate threads of electronically-mediated connectivity not in their collective cloud, as it were, but rather at the individual. By furnishing the user with technology to integrate his multimodal streams of telecommunication from other people, and himself, with representations that are more naturally suited for his sensory and cognitive nature, the current disclosure furnishes a better system to deal with communication.
Part of this system is a breakthrough improvement in annunciation, an idea which has been archetypal to the implementation of communication in the electronic world. For over a century phones have been ringing, alarms chiming, and then speakers chanting ‘you've got mail’ at the world. Central to the present invention is the means to not only indicate symbolically, as ringtones already do, who is calling, emailing or otherwise partaking in a communication event and what it is about, but directly, by using that person's own voice, recorded from a previous call or other venue, as that ‘ring’.
These preferred embodiments of the current invention anchors a comprehensive system, which is herein disclosed, that improves communication by adapting it better to human use at the level of individual connectivity and through that means.
Germane to this is the presentation of alarm and personal reminder and calendaring, and generally communication systems with the storage of portions of relevant conversation streams or communication data streams, or other audible or visual triggers, to enhance them in the fashion herein disclosed, and to obtain the efficiency of integration in a single system. The current embodiments disclose a means by which such personal information management can be effectively integrated with conversation, its monitoring and processing.
For a better understanding of the present invention, reference is made to the below-referenced accompanying drawings. Reference numbers refer to the same or equivalent parts of the present invention throughout the several figures of the drawings.
The present invention is drawn to a system and method for creating a customized communication notification event system based on a previous communication, or any other available data, which may supplement future communications.
With reference to
With reference to
With reference to
At step 340, a sample from this conversation stream is recorded. The recording of the sample may be initiated fully automatically, or automatically as determined by a user-selected setting, or triggered manually in response to a user command. The particular sample recorded may vary in scope and duration, in accordance with various embodiments of the present invention. By way of example, various options for the recorded sample might include the following: the first or last moments of the conversation, a randomly selected portion of the conversation, a concatenated and/or merged stream consisting of portions of the conversation recorded from one or more of the parties at different times during the conversation (e.g. 5 seconds of the conversation every 30 seconds), a portion of the conversation that varies depending upon the time of day, or a portion determined to be the most relevant portion by other analysis and/or human participation. The sample may be assembled from various components of the conversation stream, and/or prior conversation streams, and/or related sources. The selection process may vary for different contexts, and may be adjusted with automatic mechanisms and/or by the user and other humans, including using community and network-based heuristics. Without prejudice to the above generalities, more specific examples of methods of choosing, extracting and processing the sample will be taught later in this disclosure. The sample may include video or any other kind of sampled data from during the conversation, or any previous communication or other data concerning that person, such as unacknowledged emails sent to him. It may be mapped to text by speech recognition algorithms and displayed that way, or vice versa, the conversation may have been in text and be later mapped to speech by a text-to-speech component, and displayed instead of or in addition to being played back in its original mode. Multiple samples may be presented at varying times, both as annunciation rings or as augmentative displays during a voice or other communication. They may be based on only the last conversation, or on many prior communications in a variety of modes such as audio, video and text. In this preferred embodiment, the conversation sample is preferably recorded in a digital audio format, such as MP3, WMA, or AAC, and stored as a file and/or in a call conversation database.
At step 350, in this embodiment, after the conclusion of the conversation, the user has the option to save and/or set the recorded conversation sample as the ringtone for that caller. If the user decides not to save the recorded sample, then at step 360, the sample is discarded. Whereas, if the user decides to set it as the ringtone, that is, for potential later playback, in whole or in part, as an annunciation, then at step 365, the notification option for the caller is set to play the recorded sample as a ringtone when a subsequent call is received from the same caller ID. In additional embodiments of the present invention, the recorded sample may be further processed-such as by applying sound effects, or by combining it with other sounds or music-either before or concurrently as it is used as a ringtone. Additionally, in that potential playback it may be further processed and/or subsequently utilized to annunciate related events, such as the time of an appointment, a missed call or voicemail in a list of such missed calls or voicemails, the need to finish part or all of a project, the need to perform a health-related action, such as exercising or taking a prescribed drug, or the completion of a background task, in particular the completion of an outgoing call to that or a related party, or any other task, activity or event where such utilization could be accomplished.
With reference to
With reference to
With reference to
Prior art mechanisms exist for establishing voice communications between two computers over the internet. An example of a system that can provide such an ability in a personal computer using standard communication mechanisms is disclosed in the book Programming Flash Communication Server, written by Brian Lesser, Giacomo Guilizzoni, Robert Reinhardt, Joey Lott, and Justin Watkins (O'Reilly Media, Inc. 2005; ISBN: 0596005040), incorporated herein by reference. This book, and many systems built using its basic methodology, such as the Ribbit platform, use the Flash standard for conducting the audio stream to computer speakers, in particular by means of the Flash NetConnection and Netstream objects which invoke Adobe Flash proprietary facilities running under a browser such as the open source Firefox. Other books that have covered this topic in detail include Macromedia® Flash™ MX 2004 for Rich Internet Applications, by Phillip Kerman, (New Riders 2003, Print ISBN-10: 0-7357-1366-9) incorporated herein by reference, in which it is noted that two NetStream instances are necessary for simultaneous transmission and receipt of audio or video, as in a telephone. Another book, Flash 8: Projects for Learning Animation and Interactivity, by Rich Shupe; Robert Hoekman, Jr., (O'Reilly 2006, Print ISBN-10: 0-596-10223-2, Print ISBN-13: 978-0-59-610223-4), incorporated herein by reference, analogizes the NetConnection as the phone call made to a company switchboard, and the NetStream as the conversation. These and many other examples incorporate code that implements dual Netstream instances, each providing the sound (and optionally video) architecture, to provide for varying degrees of convenience in telephonic communication. Platforms such as Ribbit instantiate such methods with industrial scaling, dialing code conveniences and bridges to the general phone networks to provide VOIP connectivity to traditional handsets. Migration routes such as Maemo and WinMo have brought the applications and interfaces into small handsets. Many of these platforms further are open to allow developers to address them by creating applications using the existing phone communications mechanism.
To provide for simultaneous Recording capability on top of telecommunications within, an “Open Source” (Linux-based) project which addresses the same NetStream and NetConnection standards can be used on the client side. Furthermore, by operating under Linux, the entire client-side set up is rendered in Open Source and can be modified at will by any programmer, using the project documentations which are publicly available and known to those in the art. Methods for saving files, processing and working with sounds are quotidian within such an enabled context. In particular, an Open Source project which addresses the same NetStream and NetConnection standards that can be used conveniently on the client side, particularly under Linux, is Gnash.
With a commercial phone platform such as Ribbit or equivalent platform which could be commercial or constructed by a software developer, the Gnash “open source” Gnu Public License project provides a full source code library that replaces the Adobe Flash audio handling implementation in a FireFox plug-in. Thus, the code may be modified to retain in memory a copy of each sound as it is played, along with processing it as desired. Gnash and its source code are incorporated herein by reference, a listing of which is provided in the gnash.txt file included in the computer listing appendix described above.
With reference to
Application shell 720, such as a browser (e.g. the open source standard Firefox), provides a shell for plug-ins. Softphone plug-in 730 provides a user interface for a software telephone. API module 740 (for a Netstream-based phone platform such as Ribbit) facilitates interaction with Flash-like module 750 (e.g. Gnash), which handles Netstream-type telecommunications streams communicated over the internet. Sound handler 760 (e.g. SDL) facilitates production of sound.
In accordance with an embodiment of the present invention, presently disclosed is a set of modifications to Gnash to provide for conversation-based ringtone functionality. The Gnash code's implementation of the NetConnection and NetStream class relies on a pair of “sound_handlers.” One sound_handler is designated GST (GStreamer); the other Sound handler of Gnash is designated by SDL, Simple Directmedia Layer.
Either or both sound_handler platforms are modifiable to afford Gnash a recording capability, depending on the additional capabilities desired in a customized ringtone instance. GStreamer is suited for more elaborate sound processing, and required for video; thus, modification of the simpler SDL version suffices for a straightforward telephonic embodiment of the present invention, which clearly can be extended to the video sound handler, too. Four Public Member Functions lie at the crux of the SDL-based Gnash implementation:
1) virtual int create_sound (void *data, int data_bytes, int sample_count, format_type format, int sample_rate, bool stereo) Called to create a sound.
2) virtual long fill_stream_data (void *data, int data_bytes, int sample_count, int handle_id) Called when a stream gets more data.
3) virtual void play_sound (int sound_handle, int loop_count, int offset, long start_position, std::vector<sound_envelope>*envelopes) Play the indexed sample.
4) virtual void delete_sound (int sound_handle) Called when it is done with a sample.
These functions are implemented, for the SDL case, in the source code, (reproduced in the SDL_source.doc file for convenience, and incorporated by reference as listed above).
The SDL library called by these Gnash facilities performs the actual invocation of the OS and/or hardware sound production audio driver type code to make sound from the speakers. The SDL audio runs independently in a separate thread, filled via a callback mechanism to Gnash. Further detail is publicly available from a variety of sources, known to those in the art, such as the book Linux Multimedia Hacks by Kyle Rankin, (O'Reilly Pub 2005, Print ISBN-10: 0-596-10076-0, Print ISBN-13: 978-0-59-610076-6), which will be helpful in tuning the instantiation to a particular specification, and make it clear how to work with sound at this level. Given those teachings, the Gnash sound_play code (a subset of the SDL source code, extracted for convenience in the sound_play.doc file, incorporated by reference as listed above) can be modified; the crux of that mod consists of inserting code at the end, before the close brace and just after the fragment:
if (soundsPlaying=1) {
}
which will thus be invoked as each sound fragment, which has come from the NetStream Flash-like call to GNASH, is passed to the SDL to be played. (Note that the SDL_PauseAudio(0); calling line actually starts the sound fragment playing.) This sound fragment can then be output to longer term memory storage by means readily known in the art, assembling the fragments or further processing them in turn to produce a saved copy of some or all of the input sound stream which will serve as the source for the customized ringtone. Alternately, the SDL library itself can be modified to save such a file from the stream of sound sent to it.
Having those conversation sound files saved by means such as that disclosed above, or other means already known in the art, they may further be associated with keys designating the caller, stored and retrieved from a database on that basis by means well known in the art to enable the production of customized ringtones as described.
Alternatively, any of a number of SIP-type softphones could be modified to provide a basis for practicing the present invention. With reference to
For purposes of implementing the principles of the present invention, wxCommunicator provides an open source project with full source code and documentation that is publicly available and known to those in the art. As it already contains user accessible call record and ringtone functions, one can implement the present invention within its context. In order to facilitate the functions as disclosed herein in accordance with the present invention, wxCommunicator's ringtone function can be modified to retrieve a file selected programmatically instead of by the user, and its recording function changed to record in accordance with an aspect of the invention instead of via a manual start command from the user.
Therefore, in accordance with an embodiment of the present invention, presently disclosed is a set of modifications to wxCommunicator that implement the conversation-based ringtone mechanism. These modifications are applied to the standard version of wxCommunicator, (herein incorporated by reference, a listing of which is supplied in the file wxCommunicator.txt in the computer listing appendix, as indicated above), which compiles with Visual Studio 2005 and runs on Windows XP.
To begin with, it is noted that the line of code in sipxtapiproxy.cpp, in StartRecording: wxString path=wxString::Format(wxT(“% s\\ecordings”), wxGetApp( ).m_Configurator.GetDataPatho);
In the unmodified wxCommunicator source code release specifies the name of the folder in which call recordings are saved as “recordings.” This is changed to save in the same folder, “sounds,” as the ringtones:
wxString path=wxString::Format(wxT(“% s\\ounds”),
wxGetApp( ).m_Configurator.GetDataPatho);
This creates a version of wxCommunicator in which a portion of a phone conversation can be recorded, saved, and manually selected to be subsequently used as a ringtone.
Next, to add functionality the first part of StartRecording's code is changed, so it reads as shown below:
/*************************************************************************/
/*start call recording // mod for reminder-ring */
/*************************************************************************/
bool SipXTapiProxy::StartRecording(PhoneCall *pPhoneCall, wxString call_username) const
{
if (m_SipXInstance && !m_bSipXCallInProgress)
{
wxGetAppo.m_Configurator.GetDataPath( ));
wxGetAppo.m_Configurator.GetDataPath( ));
timeNow.Format(wxT(“% Y-% m-% d % H-% M-% S”)));
}
else
{
}
else
{
}
return false;
}
Thus, the file name under which a recording is saved is unique to the “caller ID” (often called user name in SIP; the terms are applied interchangeably for purposes of the present disclosure). (It is noted that if a ‘bridge’ or ‘gateway’ from PSTN to SIP is used by the caller, instead of a sister SIP phone, the origin PSTN caller-ID code may not be available, or, for instance, will be replaced with a designation of the caller's geographic location such as their city, and thus all calls from that gateway, or through that gateway from a particular city, respectively, may ring the same ringtone; but this example suffices to illustrate the technique that can be applied in other contexts as are described elsewhere in this disclosure.)
Then at the end of phonepanel.h, a declaration is added for rr_username to hold the callerID, making the end of the file read:
And in SipXTApiProxy.h, in order to pass in the caller ID needed to generate a unique reminder ring file name for each ‘caller ID’ (usually related to username in this SIP-related codebase), a parameter is added to the calling sequence of bool StartRecording(PhoneCall *pPhoneCall) const;
In its declaration, making it: bool StartRecording(PhoneCall *pPhoneCall, wxString username_parameter_for_rr) const;
In phonepanel.cpp, OnMyphonepanelRecbuttonClicked call is changed to startRecording to pass in the caller id (i.e., user name), as follows:
void MyPhonePanel::OnMyphonepanelRecbuttonClicked(wxCommandEvent& event)
{
Also in that file, OnPhoneCallNewNotification is modified so it saves the caller ID of an incoming call:
void MyPhonePanel::OnPhoneCallNewNotification(wxCommandEvent &event)
{
The result is then aversion of the wxCommunicator softphone that will allow the user to record conversation and have it automatically saved under a unique identifier as a ringtone, which can be manually chosen from the wxCommunicator ringtone menu. To complete the basic implementation of a conversation-based ringtone one can make the manual choice automatic. A line is added to the end of OnPhoneCallNewNotification, so it is as follows:
void MyPhonePanel::OnPhoneCallNewNotification(wxCommandEvent &event)
{
And additional code to perform the ‘ReloadRingtone’ function is inserted into SipXTapiProxy.h:
The result is the further functionality of playing as a ringtone the last sound recorded by the user of an incoming call from that caller ID. (It is recognized that further refinement of the presently disclosed system may entail addressing the following: various file sizings, error diagnosing, perfect initializations, proper handling of outgoing calls, multiple lines, merging voice streams, conference calls, etc.) To facilitate automatic recording of the line a further modification to phonepanel.cpp is performed:
void MyPhonePanel::OnMyphonepanelAnswerbuttonClick(wxCommandEvent& event)
{
The open source wxCommunicator SIP softphone is modified by making changes to the code for StartRecording, OnMyphonepanelAnswerbuttonClick, OnMyphonepanelRecbuttonClicked, OnPhoneCallNewNotification; adding a global variable rr_username shared between the latter two; and new code to make ReloadRingtone. (These are shown in final modified form in the computer listing appendix in the file modified_wxCommunicator.txt, herein incorporated by reference as described above.) The modified wxCommunicator architecture is illustrated as a block diagram in
Further extending the current invention, wxCommunicator code is used as a foundation for instantiating extensions applying its technology in a similar fashion for reminding a user of an appointment or other calendar-based event, or any other event. To disclose such a mechanism, yet another open source package, known in the art as Rainlendar, is enlisted as an example framework. Rainlendar provides standard pop-up message box reminders and event calendaring functionality in a Windows application, and is incorporated herein by reference. It will be clear to anyone with skill in the art that there are a number of straightforward ways to combine this application with the aforementioned SIPC phone to create a single shared codebase presenting the user with a phone with ReminderRing and a calendar program without ReminderRing.
With both codebases under one roof, a few modifications then suffice to integrate them enough to create a calendaring app with ReminderRing functionality. The Rainlendar architecture is modified by adding additional methods to the “CEntryEvent” object to set and retrieve a parameter which indicates the sound to be used to announce the reminder of that calendar event. In this implementation this is the equivalent of rr_username as employed in the modified wxCommunicator code described in
In this embodiment, illustrating this concept, the reminder sound may have been previously extracted from a phone conversation and stored in memory as previously disclosed (see
To trigger the event audible reminder, the Rainlendar code for CMessageWindow's GetTextFromEvent code, shown below, must be modified to extract from its CEntryEvent parameter its new ‘event’ variable by using the aforementioned GetAudibleReminderFromEvent just as it presently uses GetBriefMessage. A new parameter added to it, like the ‘text’ one it presently uses to return the result, can return the rr_username audible reminder generator. That reminder is then invoked by the caller, which may be supplemented with a text reminder on screen, using the same facilities as for a reminder ring. User settings may have the audible reminder generated be augmented by synthetic speech of the basic text as prolog, or not, as the user chooses. The existing code for CMessageWindow is show below:
void CMessageWindow::GetTextFromEvent(CEntryEvent* event, CFileTime alarmTime, std::string& text)
{
An implementation of it with the modifications described above is shown below, with the modifications:
void CMessageWindow:: GetAudibleReminderFromEvent (CEntryEvent* event, CFileTime alarmTime, std::string& text, wxString& username_parameter_for_rr)
{
As shown in
The relationship between the calendar timing events 180 and the UI 171 is at its simplest a manual indication of a chosen ringtone for each calendar reminder. As shown in
Continuing with
There are many other methods previously known in the art that can equivalently be complemented by these techniques. For example, rather than with a relatively simple personal calendaring system like Rainlendar, the ReminderRing system can be utilized equivalently within the context of a more elaborate systems, ranging up to those integrated with full enterprise-level project management systems. In such cases ReminderRing annunciations can be linked to ongoing events beyond time and appointment rescheduling triggers, to encompass dynamically varying task assignments; and can be acquired at events related to the task assignment or its subsequent modification. For instance, a worker could hear her supervisor's voice from the last staff meeting, conducted by internet-based conferencing under the auspices of the project management system, reminding her that a task assigned then was coming due, or that a resource needed for it had now become available, either using the ReminderRing in the context of a ring, as a separate event or any other manner that would provide utility. Conversely, the project management system could let the boss know that a task was tracking on or had gone off schedule, using the voice of a employee whose work was related to that task, perhaps acquired during a prior conversation concerning it or during an updating of the task status system by him, and with possibly other sounds and natural or synthetic speech, in annunciation. Thus, in such an enterprise-level system, or its equivalent in a diffused cooperative endeavor such as a volunteer political campaign or an open source development project, the ReminderRing assignments could be made indirectly, on the basis of conversations, meetings and telecommunication other than those with the user.
Methods known in the art to provide the project management functionality for the application of the present invention in that expanded but equivalent context include a variety of open-source packages such as eGroupware, the source code of which is known in the art and hereby incorporated by reference.
Additional discussion of these modes of operation follows. Continuing to examine
That store also is loaded by the recording code present in StartRecording 174, so that it contains the information regarding what recordings are available as reminder rings and how they originated. User 170's selected options can activate the modified StartRecording 174 code. To reflect multiple channels of activation,
Further,
The provision of such audio processing and reprocessing, and others as appropriate to the utilization of ReminderRing technology, can be performed by many means known in the art. For example, the Praat and/or Sphinx open source audio processing packages in whole or in part may be merged with source code of ReminderRing as desired, or instantiated inside a console-style shell, such as with anonymous pipes on platforms like a Microsoft Windows computer. The source files for both Praat and Sphinx are known in the art and hereby incorporated by reference.
This invention further provides a personal private caller ID system to unify multiple modes and channels of telecommunication by the user, helping the user keep the modes and channels and their priorities in order as the users are interrupted by time while simultaneously aiding in resolving these multiple modes and channels of communication for the implementation of reminder rings. The multiple modes and channels of communication may include phones, email, instant messaging services (“IM”), social networking applications, social network participations such as game moves or dating requests, voicemail and sound, graphics and video, among many others. As more and more modes of communication are placed on or utilized by the Internet, they may be directly and/or modularly added to the overall ReminderRing system and method. As those transmissions are increasingly facilitated over the Internet, much of their unification for users can proceed via identification of the IP address of the other party or parties, often in the role of ‘caller’. That IP address, and standard caller ID, together with the name or names associated with the caller, their handle(s) on IM, email address(es), among others, is managed in the Private Mapping Database 183 which maintains a party's identity. This mapping, and the overall ReminderRing system, allows the user access to pertinent voice and image recordings which will jog their memory or otherwise relationally stimulate them, for instance as reminder rings or forms of mnemonic assistance. These could occur in a wide range of other contexts such as in alarms, appliances, search engines and so-called ‘lifestreaming’ platforms devoted to reconstituting and presenting in one place disaggregated online personas which are otherwise distributed across various sites, blogs and private records.
This private system of counterparty identity representation, as embodied in the Private ID Mapping Database files 183, may overlap or integrate with more public data storage in which information disclosed by participants or discovered by research can be accessed by the individual user, such as with public mapping databases 176. This will let an individual be able to function much as companies today engaged in telemarketing customer relationship management systems do, by utilizing both their own and purchased databases, both for other humans or systems and, turning the table on the companies, representing and managing one's contacts and relationships with companies.
For example, a user negotiating a home loan might obtain through purchase, public database or company disclosure, an annotated “reverse phone lookup list” that would enable the user to specify to the ReminderRing system that any calls from any originating numbers at a particular mortgage company would be identified, accepted and annunciated using a ReminderRing from the last call from any of them or the cell phone number of the agent the user had been primarily dealing with. This helps remind the user of what task he is dealing with before, and choose whether, he picks up the phone. It is like being prompted to help maintain or return to a “train of thought”, or in this case, a “train of communication”.
Such a reverse lookup on any mode, whether phone call, IP address or other, can also serve to enable more intelligent filtering of incoming calls, routing them to voicemail systems or other destinations. ReminderRings can be used in this context to announce that the call has been filtered or, while audibly or otherwise reviewing a set of voicemails or uncompleted attempts to reach the user, as a prompt to the user for further instructions on the disposition.
Conversely, the user might wish to manage her outgoing call contact target companies with such a Mapping Database 183. Beyond the basic reasons cited above, another example would be to expedite reaching a human being behind the phone tree at a large company. Business services such as Bringo/NoPhoneTrees.com and GetHuman.com already exist to provide general data to do this on the web. A Wall Street Journal article on May 6, 2007, entitled “Get a Human On the Line” told how “Bringo's site then navigates the company's phone tree, calling you back when it connects to a person or when the call is placed in queue for an employee.” As an example of this, for self operation, NoPhoneTrees.com tells its user that to reach a human being at United Airlines she must dial the 800 number but then press nearly a dozen touchtone codes in the proper order and with particular pauses between them. With ReminderRing's Mapping Database 183, this sort of facility for the user can be internalized to a cell phone or other communication device, based on both publically acquired and/or individually known data, then annunciated when connected using a ReminderRing from the last communication stream with that company.
This unification and management function will improve productivity and alleviate frustration.
Additionally, the user 170's ID Mapping Database 183 may be partially or fully loaded from, or shared out to, other ID Mapping Databases 176, whether public, private or commercially available, that is, being created and provided for all the basic mechanisms of commerce such as advertising, sales and other distribution mechanisms as may suit various products and services associated with businesses or individual endeavors in a context relating to that commerce. This invention is amenable to supporting a “business ecosystem” of sources of such information, commercial vendors, nonprofit groups, social networking services, and other organizations, which gather and disseminate such data to augment the private database a user himself will accumulate. For example, a business might furnish an ID Mapping Database to its employees, just as many now hand out a printed list of personnel and their various contact info. These outside (that is, external) ID Mapping Databases 176 are shown at the bottom of
To enable the user 170 to control what, if any, outside ID Mapping Databases 176 he may wish to utilize, and deal with the parameters of how to do that, the User Interface options and Configuration 171 data is shown storing and providing access to such parameters.
Adjunct to accommodating multiple reminder rings for each caller or other communicating person, in
The OnMyPhonepanelRecButtonClicked 178 and OnMyPhonepanelAnswerButtonClick 179 functions are not limited to phone conversations. Likewise, the New Event Notification 180 handles all types of communication events. All the communication means indicated so far, and many more, are handled through functionality equivalent to that disclosed for phone and calendar, and often shared with it in a number of the modules shown. Non-audible indications may be incorporated, as they often are already in systems featuring blinking icons for calls waiting, or flashing menu bars for email arrivals; nothing in this invention precludes its integration with such established means, or others that may arise, even so far as direct neural interfaces.
It will also be apparent to one skilled in the art that simple extensions into further areas will furnish additional beneficial features by being incorporated within a ReminderRing overall context, such as private callers, or semi- or fully automated choice of which mechanism to communicate with a person using, or security features to protect against spoofing.
Looking now at
RR_key_ID 184, which has been discussed earlier is, in essence, the primary internal identifier for a ‘person’, which in some implementations, as mentioned, could also be a set of people or some other constructed abstraction. A RR_key_ID 184 is assigned to each new person through the user interface 171 and/or, optionally, automatically through ToneMapper 175. For example, some default settings may require the user 170 to designate each person individually and request reminder rings for each; the opposite default would be to utilize a reminder ring automatically for all calls; many possibilities clearly lie between these two extremes. Review and potential deletion of RR_key_IDs 184 can be accomplished through the UI and ID Databases and sharing controller 208.
Next, the Private ID Mapping Database 183 includes standard name and address fields, to accommodate a full appointment system if one is embedded with this embodiment, such as Rainlendar, or any other personal information management and display system that is supplemented with the ReminderRing system. Other fields commonly found in such calendar and contact management systems can be accommodated in this fashion as well.
Further, the RR_filenames 177 that govern reminder rings are shown next, at a “person” or RR_key_ID level 184. A simpler implementation could rely solely on a single RR_key_ID 184.
For each new phone call or equivalent, where an RR_filename 177 already exists, ToneMapper 175 will relay that RR_filename 177 and rename it something else which is used as the reminder ring for that call; but ToneMapper 175 will also create an additional RR_filename 177 which will generally be used to record a part of the current call and then become the reminder ring for a subsequent call or other events. Both the new RR_filename 177 and the old RR_filename 177 are kept in the data field. If the current call was incomplete, or too short, or otherwise failed one of the criteria for creating the new RR_filename 177, then that new RR_filename, along with its related files and data, will be deleted 182 by ToneMapper 175 at the next call event. At that time, as shown in
All RR_filename 177 fields generally include a date and time, in order to facilitate advanced rules-based options, for instance randomizing or cycling through or choosing an alternate reminder ring based on the time of day or other information. Other rules may depend upon sensory data, such as amount of ambient light, or geographic location, possibly obtained via geospatial sensors or mapping. The rules are generally set to specified defaults which may be altered by the user 170, using the UI 171.
Private ID Mapping Database 183 further contains data for various types of communications and other possible ReminderRing trigger events: the first such label and its set of fields, labeled Phone, consist of phone numbers and caller ids that are identified with this person record. Note that one person can have many phones, and one phone can be shared by many people; this is the case with all the communications origination indicators stored in this database. Alongside each phone number can be a whole additional set of RR_filenames 177, as multiple alternates for all cases with that number. The next section is Calendar which includes date-times instead of telecommunications origination indicators. Additional information may be present, including, for example, data to support a full personal information management system.
After the Calendar section in Private ID Mapping Database 183 is field “Email”. Besides the RR_filenames 177 as above, this set of “Email” fields introduces two additional concepts. One is flags and other data that indicates and informs possible construction of RR_filenames 177. The flags are shown for this first text-based email communications because text-to-speech conversion may be applicable; however, construction from sound may also be configured. Generally, this construction, be it text-to-speech or from sound, proceeds as usual to make a reminder ring of the previous ‘call’. For example, the subject line of an email may be specified to be speech-synthesized to make a reminder ring for the arrival of the next email, or for all subsequent rings from that person. Construction could result in a reminder ring that repeats some part of the person's message as a reminder ring, for example, the subject line twice to convey urgency.
Further, flags may indicate pre-annunciation, described in more detail later in this disclosure, in which case a ring is ‘pushed’ through to a phone, and ring with a short speech sound or other indicator sent from the caller.
The second concept introduced in the “Email” section is for additional data fields to guard against spoofing (the sending of messages with false addresses of origin). While spoofing can be a problem for any type of transmission, and fields can be included for it in any communications mode, it is particularly prevalent and easy to spoof email.
The next category for Private ID Mapping Database 183 is “Text”, as shown in
Additional field sets are given as examples, which may lie inside or outside an RR_key_ID 184 record. Disambiguation guidance is such an example. Disambiguation guidance - data, defaults and options selected by the user to resolve cases of multiple persons at a single origination address, for instance, sharing a phone. For example, see the examples that follow.
Another additional Private ID Mapping Database 183 section may include “Sharing.” The present invention establishes a platform which will support a “business ecosystem” as James Moore defined it in Harvard Business Review in 1993, that is, a system of interacting entities engaging with one another and the user as an economic community supported by a foundation of interacting organizations and individuals—the organisms of the business world. This economic community produces goods and services of value to customers, who are themselves members of the ecosystem. The member organizations can include suppliers, sales lead producers, advertisers, distributors' competitors, and other stakeholders. This business ecosystem may include add-ons including many types of shared reminder rings and their underlying data for lists of origination addresses, and for the user to allow limited or unlimited sharing of his own data with friends, family, social networking groups, and commercial and nonprofit entities. For example, businesses may have ReminderRing databases that include employees' various phone numbers and email addresses, similar to, for example, those some employers hand out to new employees now. Other datasets may be sold on CD-Rom or cartridges or for download, or any other data transmission system. Some may have security mechanisms. The means for this sharing to occur will require support within this database, in these fields. Other possibilities of sharing include importing existing contacts databases.
Another additional Private ID Mapping Database 183 section may be “Hurdles” or other necessary requirements. Users may set thresholds and methods to govern various methods used by the present invention. For example, they might specify a minimum volume, or length of call, needed to produce from it a subsequent reminder ring.
Though throughout this description RR_key_ID 184 is indicated to correspond to a ‘person’, that designation is for ease of teaching; clearly the actual ‘person’ could be assigned to be more than one (a couple, or family, or classroom, or other group) or a corporation, or government agency, or a nonhuman entity such as an automated bank or brokerage or alarm system, or even a working or companion animal given limited telecommunication means for its owner's convenience in caretaking, for example.
Furthermore, this relatively flat data storage paradigm could be augmented by means known in the art to furnish contact filtering, priorities, stranger contact management, nested person records (for instance, a company with several people in it), or relationships, among others, as part of a more elaborate instantiation of this invention, or in combination with separate means that would be interfaced with.
Shown in
If a RR_key_ID 184 is determined, that RR_key_ID 184 should be mapped to the appropriate RR_filename 177. If there is more than one RR_key_ID 184, for instance for a caller ID or IP address believed to be shared by more than one person, disambiguation 196 of the multiple RR_filenames 177 proceeds by whatever process was made available to and selected by the user; if there are many possibilities for the disambiguation 196 process, the UI options/configuration files 172 will be the primary data source for that process, though some reference to the Private ID Mapping Database 183 may also be involved, and through it even some reference to Public, commercial or other ID Mapping Databases 176 may be obtained.
For illustration so far take for example, a young woman user 170 may have designated that any calls coming from a particular home phone number be annunciated using a snippet of conversation from the last communication with her teenage boyfriend who lives at that home, even if their last conversation had been via an internet-based voice chat utility. A user 170 may have access to rules that specified replacement of a RR_key_ID 184, instead of disambiguation, perhaps temporarily; for instance, to keep the peace during every weekday lunch hour which the young woman often shares with a friendly rival for that boyfriend's attentions, our user might choose settings so that, during that time of day only, her boyfriend's voice snippet from their last conversation would be overridden by his sister's on contacts from all media.
Options also exist where multiple reminder rings may designated for a single RR_key_ID 184, i.e., more than one for a person, although person can mean non-human too, as noted elsewhere. Indeed, there could be separate ReminderRings for each medium, designated by different rules in the UI 171, so that our young friend can hear a snippet from her boyfriend's voice in her last conversation when he calls on the phone, but a different one when he texts her. In this eventuality, each time it is invoked, ToneMapper 175 will proceed to examine and then resolve one RR_filename 177 from among the possibilities 194, again referencing their description as stored in the UI options/configuration files 172 and optionally supported by other data in the Private ID Mapping Database files 183, arriving at a single RR_filename 177.
This RR_filename 177, whether resolved from out of many or a single RR_filename 177, is then checked to make sure it still exists 193, and has not been deleted or failed to be constructed. If it exists, it is passed on from ToneMapper 178 as shown in the lower box labeled “Exit indicating that RR_filename”.
Another course of execution may occur in which there is an RR_key_ID 184 but no RR_filename 177. If so specified, a RR_filename 177 is created 201 and ToneMapper 175 exits indicated the newly created RR_filename 177. This could represent situations such as where a prior text message is to be speech synthesized, such as where no voice recordings exist, but where a flexible speech synthesizer can create a useful personalization. A reason to create the reminder ring instantaneously instead of at a previous time would be memory constraints on the storage of speech compared to text.
Another possibility worth noting in this context is the case in which a user wants to have an incoming caller be able to speak and/or transmit from pre-recorded voicings a sound to be used as the ring. This push-ring, or pre-annunciation mode, is particularly valuable when enabled among a platform of phones installed using the present invention. For this, the actual connection of the phone, in most platform architectures can occur in a preliminary module, where a recording would prompt for a short sound bit, for example a two second segment, then ‘answering’ would result in letting the connection proceed to the user. This protocol is examined in more detail in
Users with many calls could benefit from prioritizing through this means, and this method could also furnish benefit in the case of annunciations where significant information can be delivered in a short‘ring’, the equivalent of subject-line only emails, such as for notices of schedule changes for appointments and project management type ‘reminder’ annunciations.
Incorporated into systems where tracking and chivvying of task accomplishments is essential, such as medical compliance and dynamic interdependent roll-outs, this facility may also be integrated with security measures, in particular, those established to control which ReminderRing will used in announcing which ‘calls’. These modes of operation and their applications are further discussed later in this document.
Continuing meanwhile to examine the ToneMapper 175 functionality, whether in these or other cases ToneMapper 175 calls upon functionality which exists outside ToneMapper 175 itself. In particular, such functionality is shown in
Note that ToneMapper 175 originates all RR_filename 177 identifiers. In a simple phone-only embodiment, RR_key_ID 184 could be simply assigned as a derivative of the caller ID, as was disclosed at length previously in descriptions of more basic embodiments. But in a more elaborate embodiment with demands such as the potential for multiple persons sharing a single caller ID, and having other means of communication beyond audio-only phones, and having the capacity for maintaining a reminder ring used from a prior call despite the occurrence of a new call or calls in the meantime (that is, not overwriting the prior reminder ring, for example in the case of a very short connection, or in the case of an often-called situation where the user does not want the ReminderRing to change constantly, but does want it to change occasionally, say, monthly, or upon some call-length or content threshold), it is better to build out a more flexible system architecture. As shown in
When a call or an equivalent communications event occurs, ToneMapper 175 assigns an RR_filename 177, verifying it is not duplicating any other RR_filename 177. ToneMapper 175 then enters that RR_filename 177 into the Private ID Mapping Database 183, optionally creates the reminder ring sound (see
Assuming two RR_filenames 177 are specified on this communication event, as described above, and now tracking both of them in our continuing commentary, the New Event Notification 180 component then loads 203 the sound related to the first RR_filename 177 and the communication device processes that audio 204, playing it. The New Event Notification 180 component also passes the new RR_filename 177 on to OnMyPhonePanelRecButtonClicked 178 or its equivalent, which hands it off to StartRecording 205 and its adjunct process recording component 206 for possible acquisition of another sound to be stored under this new RR_filename 177. Thus, a new RR_filename 177 is assigned and filled with content, ready to be used in another round.
Beyond that primary course of execution, RR_filenames 177 are also passed for informational, cataloging, and housekeeping functions. When one is successfully filled with content the UI options/configuration file 172 is updated to so indicate, so the user 170 can view and manage by hand if desired, or diagnostics can be run, or sharing programs can utilize that information. Also, when Public databases 176 are used to import sounds, the ID databases and sharing controller 208 updates both the UI options/configuration files 172 and the Private ID Database files 183, along the lines shown in
Besides the event handling role of ToneMapper 175, it may also respond to changes in the Private ID Mapping Database 183 and Public, Commercial, other ID Mapping Database 176, wherein said Database 183 and Database 176 are connected via ID Databases and sharing controller 208, as shown in
ToneMapper 175 may also be accessed by outgoing phone calls or other communications; these, not shown specifically in the accompanying FIGS., because they are a simpler case and are treated similar to an incoming call, by internally generating a call event for ToneMapper 175 to process, except that no RR_filename 177 needs to be provided. Alternatively, outgoing calls also can be provided with an RR_filename 177, which is used to make the ‘ringing’ indicator sound to the user 170 while the target's phone is ringing. This reminds the user 170 while it rings of the last conversation and whom he is calling. Furthermore, if it is known that the target also has a device implementing this invention, the phones can be synchronized through the pre-annunciation system previously mentioned, or by Public and other ID Mapping Databases 176, so that the user 170 can hear the same sound his target person is hearing as a ‘ringer’. This can serve to remind them both of a prior conversation. It will be clear to one of skill in the art that this design requires no further inventive insight to be extended to accommodate that.
In general, flexibility exists in this design for performance optimization by several methods, including using an RR_filename 177 with a large enough capacity to store a sound itself, and to eliminate or reduce the urgency of some of the mentioned steps; the disclosure of this preferred embodiment is to facilitate teaching of the general invention, not to be prejudicial with respect to any particular implementation. Likewise, often throughout this disclosure, for the sake of clarity ReminderRings will be referred to as sounds, though there are other possibilities, as has been mentioned previously. Further, a “call” may be stated but may be easily substituted by another communication event, such as a calendar timing event, or an email, among others.
For an example of the function of the current invention, the following example is provided. First, a user 170 can access the user interface module 171 to import his Microsoft Outlook application's contacts and set a simple constant reminder ring. The Microsoft Outlook application's contacts are then stored in the Private Mapping ID Database 183. The user 170 then calls a friend to discuss his new ReminderRing system while selecting the OnMyPhonepanelRecButtonClicked 178 which activates start recording 205. As previously disclosed, when the user 170 makes the call his friend, two RR_filenames 177 are created. The first RR_filename 177 is checked against the ID Databases and sharing controller 208, which connects databases 183 or 176, for a corresponding RR_key_ID 184 which in turn accesses ToneMapper 175. Because (let us assume) the user has just imported his friend's contact information, there is no currently associated RR_filename 177 and, as such, the ring he hears when calling his friend is generic. When the user 170 terminates the conversation with his friend, process recording 206 is called which processes all or a segment of the audio sample of the conversation. This sample is then stored in memory and the associated RR_filename 177 is stored in RR_filename 177 database/files 207.
Continuing with this example, suppose that a few minutes later, he hears the ReminderRing voice of a friend, taken from the last phone call with her, announcing the arrival of an email from her. This occurs because the incoming event of an email message entered ToneMapper 175 which, as shown in
Presenting now another example of the present invention, a handset with display currently used to show caller IDs at annunciation time could be repurposed to also or instead show ReminderRings of prior text messages or emails from the other party, or scrollable excerpts thereof, both at annunciation time and during the call under user or programmatic control.
Presenting now another example of the present invention, a ReminderRing equipped smart phone equipped with a GPS or other location-finding device may be integrated into location-based management of assets and personnel resources for needs ranging from disaster management to interactive entertainment. For instance, a man walking around an urban setting for social entertainment might have his phone occasionally produce a mix of the already-existing reminder rings of all his acquaintances within a mile of him with the volume of each proportional to their distance from him at that moment, and display their locations on a map, or ring him with a single one when he is within a threshold of 1 block of him. Or imagine, a woman managing the public resources for handling a fast-moving disaster with frequent interruptions of her telecommunications conversations with field assets might set a reminder ring to concatenate the rescue team number and last GPS location designation to the reminder ring of the sound of the last conversation, while highlighting it on a map display with text derived from that speech. Or, a multiplayer conflict simulation game played outside with cell phones could allow reminder rings from nearby players only, simulating some fog of war by making it more difficult to manage communications with those further away.
Presenting now another example of this invention integrated into different contexts, presume a user dealing with the fallout from an identity theft, and further that she is using a ReminderRing enhanced phone and a subscription database for it developed by a third party to deal with situations or occurrences of identity theft and provided to her by her insurance company as part of its coverage of this event. As she conducts conversations with dozens of credit card companies and various representatives of each, she sets ReminderRing using a sounds extracted from the initial conversation she had with that agency, so that whoever at that company calls her back, if the originating number was in the database provided her by the insurance company, she will hear it ring with the name of the company and a reminder of the last call; thus, evincing the utility of the Mapping Database 183 and its associated components 208 and 176 in contextualizing that communication for her.
Presenting now another example of the utility of this invention integrated into different contexts, presume a medical treatment or health maintenance system in which a physician's assistant converses with her patients as follow-up to confirm, explain and enhance compliance with a prescribed treatment program or exercise regimen; and that as part of the insurance company or other payer's program provisions the ReminderRing to be used for her calls on the patient's phone is under her control. After a phone call in which she ascertains that the patient has obtained the appropriate medication, she finds a way to clarify the instructions which the patient reacts well on the phone, promising to perform his duty in the program. After the call, the ReminderRing system, having analyzed the conversation for patterns of speech, prosody and wording, presents her with several potential samples. She chooses one in which her voice is heard cheerily cajoling the patient who then replies “OK, I promise”, and in which the pause between has been reduced by audio processing. Setting this sound snippet of their combined vocalizations as a ReminderRing that will be used for subsequent calls to, and perhaps from or concerning, him, she sets up follow-ups at intervals corresponding to the patient's treatment scheduled. The very annunciation of the call will then remind the patient of his compliance commitment, and make for a more efficient follow-up monitoring program potentially maintaining the originally established rapport even as it may be conducted by other personnel assets. In addition, when the patient or other personnel call the monitoring physician's assistant, she will have an instant reminder of the prior conversation, in audio and/or text display as she prefers, to use in composing her thoughts, again, a boon to efficiency and efficacy.
In environments ranging from white collar health management organizations to independent living by the mentally impaired, to third-world doctor-in-a-phone settings, these sorts of medical applications will enhance the potential for the mobile phone to remind people to get vaccinations, take medicine, or undergo HIV tests.
Presenting now another example of this invention integrated into different contexts, presume a business meeting of a diverse, globally-dispersed team representing various corporate and contractor resources, conducted virtually with web-based meeting tools, in which various tasks are discussed and assigned by the project manager, who operates a project management software system to retain snippets of those conversations and associate them with particular tasks. Weekly reminders can then be set by her for the individual, using their own voices in the meeting referencing the tasks rather than the more generic ones in the project template. When a particular task is completed early, or lags, the adjustments can be noted by the project management software system, and calls initiated to connect the project manager with individuals to inform them of the changed priorities on their own tasks. Those calls can be annunciated with reminder rings associated with those tasks, modified with text-to-speech notices from the system, giving immediate and attention-getting notice to the parties of the basic context of the change order, and when both the parties are reached and connected, each will have been grounded in their memory of the meeting discussion before proceeding to conversation regarding more detailed examination of that task and its implications. This furnishes greater efficiency by contextualizing the associated communications for the participants.
As was described during the discussion of
Examining, then,
Having, then, at a minimum, extracted the new ReminderRing(s) from the communication presented by the Controller 900, the Controlled Unit 901 proceeds to set 935 the ReminderRing as the new ReminderRing for the target identifier(s) into its RR_filename database file(s) 207. Controlled 901 then informs 940 the Controller 900, again by a pre-set signal, such as a short tone, that it has successfully completed its task of accepting new ReminderRing(s). Controller 900 detects this acknowledgement 950 and notes its success 960. The Controlled 901 and Controller 900 then individually check 970 if an indication of pre-annunciation was set. If pre-annunciation was set, both parties proceed as if it were a normal call, with the new ReminderRing being played for the Controlled 901 Unit's user 170, and presumably a regular ‘ringing’ indication or other connection attempt indication provided by the Controller 900 Unit if it has a human user 170.
This disclosure has previously given a variety of examples for how the sound, or other ReminderRings, such as text display or video, could be selected for extraction out of a communications conversation, and how the ReminderRing could be subsequently processed to improve its effectiveness.
Continuing with
To address Gestures 5010 will most immediately require basic recognition processes, such as feature extraction, be applied to the communications conversation and other potential data streams associated with it. Examples of such basic recognition processing units are shown in
Continuing in
Column 5200 of
Next down is the other indicators based module. An example of its application might involve the GPS locator on a phone. The potential for the use of GPS or other location-determining inputs with ReminderRing has been previously mentioned. So in a simple example, this module could be used to select a ReminderRing from when the user was geospatially closest to another person. More complex versions could find useful application in interactive games played while moving around, or in social networking applications, or to facilitate office workers' communications and meetings in a large building. Finally, below, are two combinations items, which illustrates the potential to incorporate any number of more elaborate ReminderRing selection or construction mechanisms to use multiple basic recognizer inputs.
Additional information may be made available to the basic recognizers of Column 5100 or subsequent processors such as the modules of 5200 that enable the subsequent processors to access a system of identification and memory of who is talking so as to vary parameters and adjust to individual habits of communications, languages, and contexts.
Continuing, in Column 5250 of
Comparator 5300 compares its inputs and selects one or more among them to use or seek user 170 consultation regarding, and/or it can integrate their recommendations. For example, in this preferred situation, a simple algorithm suffices for illustration: it examines all the timing intervals suggested. If there is any overlap among them, it selects the most overlapped area, that is, the part in time which has the most votes. If that is shorter than 5 seconds, it adds two seconds before and after, provided, however, that the ends of the conversation stream are not exceeded, of course. If there was overlap, this produces an ‘Integrated’ ReminderRing. It also examines the normalized confidence values. If one of the normalized confidence values is 8, 9 or 10, and no other is greater than 4, it selects the ReminderRing indicated by the highest one. Otherwise Comparator 5300 chooses the two having the highest confidence values, or three there was no ‘Integrated’ one produced. If there is any tie it picks from the tied ones at random. While more elaborate mechanisms may or could exist that can be implemented at this stage, particularly given the possibilities described above for more elaborate inputs, including processed sounds or other data, this mechanism suffices reasonably well, producing one or several outputs, shown nominally as three, which are passed to the next stage. This is shown by the arrows labeled Int. and Sel.; again, this is a nominal situation, and clearly more or less of each could be passed by a more elaborate or flexible Comparator/Integrator functionality.
Receiving these several inputs defining possible ReminderRings, a function 5400 presents the possible ReminderRings to the user 170 for her to choose among, either at the end of the call, or later, as subsequent function. Function 5400 can also allow the combination of ReminderRings through means such as concatenation or rotating and/or random usage. These modes provided by function 5400 can be user 170 selected, along with default conditions for use of a ReminderRing when the user 170 does not choose before the next call or other event invoking that ReminderRing occurs.
The resulting ReminderRing and related data, and/or possibly parameters defining its generation (for instance, at its simplest, the time interval instead of the actual sound) are passed to function 5500 that renders them into form suitable for the actual ReminderRing system as defined previously (presumably Tone File Creator 185 or its equivalent, though more elaborate embodiments of the methodology examined in
Feedback Management System 5600 gauges the effectiveness of the selected ReminderRing by a variety of means, which may, but need not, include user evaluation, efficacy judged externally (for example, through customer surveys, project reporting metrics, medical compliance measurements, and call-answering frequencies, among others) and the results used for adjustment and of the Scoring and Selection modules of Column 5200 to produce better future results. Feedback Management System 5600 may use interactive parametric adjustments by the user 170, or techniques known in the art such as artificial intelligence, artificial evolution and neural networks. As an example, the previously mentioned Praat open source software program source code Feedforward Neural Network learning and classification functionalities may serve as a basis for performing neural network functions within this Feedback Management System 5600.
Turning now to
Turning now to
An example ReminderRing Text Processing Method 6500 is shown for processing the text transcript 6300 in
In the example given, an ‘OK’ is found just before the words “good luck”. Next, using the timing indicators, check if it was preceded by two or more seconds of silence 6700 (from the counterparty; presumably the user was speaking then). If so, it is rejected 6710: subtract one-fourth the duration of the current sentence (in this example, the one with this ‘OK’ in it) and scan again moving forward (toward earlier times) in the transcript and when an ‘OK’ is again found or the scan terminates unsuccessfully, subtract 0.5 from the score 6730. When an ‘OK’ without two or more seconds before it is found 6750, make sure it is in a “sentence” of four or more seconds duration 6760; otherwise, it is another reject, and as in the first time through the example shown here) loop back to look for another ‘OK’, applying just the 0.5 score decrease 6730 this time. Having finally found an acceptable ‘OK’ (in this case, the one just after “matter later”) in a “sentence” lasting four or more seconds, and which also has less than two seconds of silence before it, subtract one-fifth the duration of that “sentence” in seconds from Score 6800. If Score is less than zero 6810 now, give up on ‘OK’, set the ReminderRing as if there was none found and exit. If Score is still greater 6820 than zero, it's an ‘OK’ success: set the ReminderRing audio to the final four seconds of that ‘OK’ sentence, the ReminderRing text to its last eight words (or less if it does not have that many) and exit.
As is the usual case for such processes, the specific numeric values used in this example of
Turning now to
The preceding examples all rely on the processing of telecommunicated conversations to provide utility in an apparatus capable of storing those samples and applying computer code so as to influence subsequent operations in a complex fashion. An additional embodiment showing the utility of conversational processing will now be described called TalkSocial. As an aid to its description an integrated use case narrative will be based on a smartphone—a small, connected device with significant computational capacity and telecommunications ability—with additional applications present which rely on or extend the benefits of conversational data processing.
In this use case for TalkSocial, to be examined in more detail subsequently, a young man finds a restaurant meal and social life using TalkSocial on a pleasant evening in an unfamiliar urban evironment. He uses a variety of functionalities: For instance, shaking a TalkSocial equipped SmartPhone (which action can be detected on an accelerometer-equipped smartphone by means known in the art, as can position and orientation on those equipped with sensors for that purpose) and pointing it at a strip mall down the street, for instance, while saying “Pizza”, can trigger a coupon or other offer from a restaurant there. If the user doesn't like that instance of potential ‘social’ interaction and/or knows someone who does, the user may forward it with his voice on it, for a friend to shake or for it to interrupt him, with a ‘call’ from him. Then, the user, can shake again for another offer. Shaking is used to color the narrative; a button or other mechanism would also work.
The point of this example is that additional prior communications of the user can influence the result. The telecommunications stream of his prior verbal communication has had keywords or other samples extracted, examined and used for content or contextualized communication, according to means described previously: for example, his girlfriend or mother's voice perhaps for persuasion, or directions and related remarks like “walking distance”.
Depending on his settings, if and how he is notified will depend on his communications, location, and prior behaviors, and the social graph—e.g., whether other friends are in the area; plus whether other offers exist, or other businesses, for instance, rise to the occasion as it looks like a party is coalescing.
This example shows how the present invention is able to function in an integrated mode. For instance, it could be used with, or to produce, ‘augmented reality’ displays based on where it is pointed, with arrows or looking‘thru’ with camera, to show what the social suggestion is and the offer applies to, and how to get there.
A user's voice or words transcribed and associated, such as those of a friend or celebrity, could have been just recorded and forwarded along with a “social recommendation”/coupon. Examples ranging from “Pizza!”, peer meme voicing, mom's voice, girlfriend, persuasion reminders, directions with simplified “walking distance” or with ads placements within the communications, such as “turn left at the McDonalds,” to complex scripts sufficient for turn by turn directions, can be played or played back with or without modification for contextualization. Reaching further afield in social interaction, they could include cueing, such as for management, instruction, playacting, job interviews, etc.
Besides that, contextualizing sounds can be played back to the business, for instance, which produced the ad. With augmented reality views, the user can point at a physical location of a building, and critique it or request coupons, etc. That critique is not only communicated back to the business, but contextualized with data about who and where you were, plus the business is enabled in the future to contextualize its further communications with the user.
Those businesses are also enabled to contextualize their communications in general, and to offer targeted and limited promotions, with limitations of number and time, for example.
Additionally, this can help the user contextualize his own communication, to be relayed later as voice ‘background’ or annunciations in conjunction with coupons or other chivvying when targets are near.
Looking now at a particular scenario which serves to demonstrate the combined utility of a number of the modes of action of this invention, we examine
So to start he points his phone at the set of buildings, or otherwise indicates them as a target or has them as a default through proximity, and shakes it to initiate TalkSocial. From his prior behavior the system knows he usually eats at that time of day; from speech recognition of conversations on the phone the software knows that he often uses the word “pizza” in conversation close to that time; and that no phone-mediated meal transactions have occurred, nor has he been at any locations in the last few hours. A set of these types of indicators can each be programmed in or more elaborately evolved; user designation or even crowdsourced creation mechanisms can be deployed, through means known in the art or evident equivalencies and extensions thereof.
Note that syntactic analysis is unnecessary for simple utility in performance; imperfect word extraction of a limited vocabulary will suffice, though more elaborate AI can be introduced and applied as platforms allow.
Alternatively, whether the user points at the buildings or otherwise indicates the direction, he could simply say “pizza” or a simple question regarding it, such as “Where's a good place nearby for pizza?”
In this example scenario, TalkSocial now, as illustrated in
Next, in
Continuing this example scenario, a third shake brings up an offer far more interesting to our user. In it Pizzazz Pizza proposes our user take the 5th seat to help fill their large table for 7, and share the free pitchers of beer they are throwing in if the table's filled in the next 10 minutes. Being more elaborate, this offer is augmented with a recorded sound describing it, which our user allows his phone to voice through its speaker, either by immediate or prior option selection, or default setting. He navigates by manipulating his smartphone, in ways known in the art by manual or voice means, to see some information about the other folks at the table so far. One is a casual friend he's connected with on a social network, another is a friend of hers. The other two responded to the coupon like he did. Looking to recruit additional folks, he selects a general rebroadcast of the coupon to his friends within the distance possible to arrive by then; many of them may have allowed their devices to accept a push message with audio from him, as has been described earlier, so he could add a “10 minutes” shout of his own. The friends hear notification rings with the advertising message as relayed with our without that “10 minutes” modification.
As a next step in the example, the user then issues a confirmation of his intent to accept, and uses the turn-by-turn directions then displayed to begin walking toward the restaurant, while also noting on the display the positions of others in his extended social network of “friends of friends”.
As a further example of the utility of advertising rings, in this case next he hears an incoming communication from the Pizza Palace. He'd almost forgotten about them, but the ringtone announcing it, presuming he opted in for one previously or by default, for instance at the time of providing his feedback message, includes a snatch of his feedback audio “anchovies, yuck!” followed by “pepperoni, mmm . . . ” He chuckles and accepts a display showing and hearing a new offer: “This is Pizza Palace. We're sorry you don't like anchovies, how about a free slice we've cooked up with some spicy new pepperoni instead? It's piping hot and so nearby—stop in and grab one with no obligation.” Holding his phone screen horizontally as he walks, he sees it flash an arrow to his left, and show the storefront. Glancing in that direction, he recognizes the store. For that matter, he can see the Pizzazz Pizza sign now, too.
At this point the user may either turn aside, enter the pizza palace, and show his confirmation screen, a method known in the art, for the free slice; or he continues on his way. Or maybe both, if fast enough and not further distracted by merchants or friends who know his wants and have this invention to help target their fulfillment. If chooses to continue to Pizzazz Pizza in time, and gets there in time, he shows them the confirmation screen and joins the group at the table, which is now full. Introductions and how they got there are immediate conversation starters, with one of the diners turning out to be a regular who is leading an attendance and recruitment contest, and helped initiate the offer.
This example further illustrates the utility of a smartphone the operations of which are enhanced to address the needs of its user because it is “listening in” to conversational exchanges and able to modify its subsequent operation as a result. In addition, it shows the utility of an advertising ring, a pushed notification, provided by means disclosed previously, and in particular of the ability to craft benefit structures depending on interaction via the means disclosed in the present invention.
Additionally, though the above example focuses on user-initiated interactions, it will be apparent to one skilled in the art who has reviewed the above that a “social director” program might apply the same principles to initiate contact with the user, for example through Advertising Rings, in contrast to the user-initiated or business-initiated teachings of the prior figures. That ‘social director’ functionality could reside in independent computer or hybrid intelligence which initiates suggestions to the users in consideration of their wants and needs. Inputs to it could include a vast variety of lifestream data from people or other entities (for instance, phone calls or always-on recordings with transcription or keywords extracted, timestamps, place stamps), the extant social network graph (nodes, connectors, types of them), the user preferences (passive friending parameters, etc.). The outputs are calls, texts, emails with suggestions and referrals. An example of the result of such mediation initiated by an event-driven software intelligence, consider two groups both attending a ball game on a particular night but who usually don't, who apparently have friends in common, and bought enough seats the last couple years that there would be potential economic benefit to communication with each other about splitting a larger admission or add-on package.
The utility of the present invention is manifold, with numerous types of applications. Another important area of application is discovery, particularly as it pertains to using the tastes of social groups similar to oneself to guide one's further exploration of places. This could be explicit, as in the TalkSocial embodiment scenario, above, or implicit (for instance, from the words a user uses words in phone calls) or ambiently acquired by an always-on or automatically-on phone (for instance, triggered by GPS or stillness at a waypoint others have also paused at), could trigger suggestions of further discovery of places people who behaved (including talked) like the user also frequented. This could range from simple Bayesian inference to semantically understanding conversation, and from vendor-neutral search to paid per visit ad placements.
Applications also exist in games, dating, friending, etc. There the message could be an audio, text, image (photo of self or others or item), a barcode, etc. It could be used to make offers on items or even conduct online negotiations at point of purchase. The offers could include monetary considerations such as discounts or bonuses, non-monetary ones such as status enhancements like diplayable badges, competitive situations where virtual points are awarded toward a winning scenario, or any combination thereof.
Games and instructional media could involve “levels” to which a smartphone rose after hearing a particular word or phrase in the communications stream; those levels could result in being able to visualize other items in an AR world. For instance, an AR language learning application might involve showing questions about items viewed through the phone, such as furniture and household tools, which could be labeled with bar codes by the user or automatically recognized by programming, or crowdsourced for identification; correct answers identifying simple objects would trigger the next level of difficulty.
In another direct application, the speed of stating a recognizable answer to a question could trigger the next, enabling a race with a great many more participants because content is downloaded first. In a less direct fashion, rather than a word, an image might be recognized, or a sound; the latter would enable audio treasure and scavenger hunts, with clues exposed on phone only after finding the correct sound. GPS could be used along with that. As a nominal use case, the “game” can simply be one like the Groucho Marx “You Bet Your Life” television show's say-the-secret-word paradigm, with each word potentially being sponsored, such as a brand name or series thereof with levels as described above, where progression through those levels is triggered by the processing of conversation, thus influencing subsequent operations of the communication device to respond consistent with the trigger for each next level.
Augmented Reality (AR) components for such games can project images into the map which depended on the mode of the phone corresponding to a level attained through communications stream recognitions. For instance, a treasure hunt style game might set searchers after a transmission of a pic of a real billboard, a musical tune being played in a retail lobby, a mention of a brand name in a phone call, an image of a particular assigned competitor (or assigned teammate), or a knocking-together with their phone, in the game, and a ‘shot’ of a AR image superimposed on a building. This would allow players in multiple cities to pursue equivalent goals. Serious games could include military and disaster simulations or real-time organizational challenges, with AR showing the extent of flooding or other transportation route interdiction.
As has been noted previously, though notifications in examples and cases such as advertising ringtones, or “ad rings”, have been described for convenience and clarity as simple audio ringers, they could also be composed of other or additional modes of communication, including text, visual, or other sensory communication modes, apart or in combinations such as video.
Turning now to
In one particular scenario described above, a coupon or other offer is presented to the User 2400, and later redeemed through e-commerce and validation means known in the art. The interaction of those means with the user and merchant are shown as the “e-commerce” block 2401.
The contextually-targeted delivery of the advertising proceeds as follows. User 2400 interacts with UI component 2403 to set the system into that mode, the configuration of which with options is stored in files 172. Then as the user conducts conversation or equivalent communication activities, the StartRecording module 205 and then Process Recording module 206 place all or processed portions of the conversation into files 207, plus pass along the associated Event and RR_filenames 2404, which are extended to support this activity with associated data beyond the standard ReminderRing. New Event Notification module 180 receives this information, using it and cached prior contextual placement information, if any is present, to specify ad placement for Context Handler 2406. It also relays these and associated data via internet or other communications medium 2421 to Ad and Feedback Manager (AFM) 2405.
The AFM 2405 software programming, preferably based within a framework such as is commonly employed for operational websites and SaaS advertising management programs to control, track and communicate, reviews and extends the contextual placements and returns them via internet or other communications medium 2421 to New Event Notification module 180. They and/or the extended version are passed on to Context Handler 2406, which may also utilize separate data access and/or loading through the previously described ID Databases and sharing controller 208, which has access to Databases in 176, again via internet or other standard communication means; as mentioned previously, they may be accessed via many means, not only Internet or wireless telecommunications, but even via static media like cartridges or flash drives or CD-ROMs, or could even have been pre-loaded in a handheld phone for release upon payment. This multi-tiered design provides failover placements in situations of network timing issues which are sufficient in an advertising medium, and tracking data for the actual placements can be reported to the merchant by AFM 2405.
The returned placements events are sent to New Event Notification module 160, mediating the playback of samples and/or modification or replacement as instructed by AFM 2405 to fulfill the campaign conducted by Merchant 2408; a marketing campaign with advertising, as was given as a previous example, would be an example. Most advertising data resides in the commercial portion of databases 176, as loaded and managed therein by AFM 2405, though some aspects such as public service announcements or public broadcast media sponsorships are also applicable. Mechanisms for validation and fulfillment of any offers and other commerce mechanisms associated with advertising such as coupons, or the audio equivalent thereof, which are beyond the scope of selected e-commerce package 2401, are handled within Additional Validation and Fulfillment Module (AVFM)2407, with its needed access to databases 176 as informed by AFM 2405.
Tracing through more details of this process starting from the Merchant's point of view, a relatively simple Ad Ring is implemented in this system as follows: A Merchant 2408, in this case the owner of Pizazz Pizza, interacts with a website front end or equivalent user interface, such as a handheld mobile app (or even a pure voice-driven agency such as SIRI, now owned by Apple and provided as an iPhone functionality, or others like it) which is presented by the Ad and Feedback Manager (AFM) 2405. She chooses an audio or other promotion for her business, for instance by selecting among already created ones, synthetic voicing of a text she enters, recording her own voice, or using a previously recorded conversational sample taken by a ReminderRing system of her own, which she found particularly natural and compelling, such as a moment she told a friend “Time for Pizza?Try some Pizazz!”; or any combination of the above, with additional processing or text and images, video, and other multimodal components added and/or transferred by means known in the art for moving files around and submitting them.
Ad and Feedback Manager (AFM) 2405 stores that sample and/or a form of resource locator index for it in database(s) 176. It then prompts her for additional information concerning her targeted context, that is, when and where she'd like the ad to run, and additional options such as the amount she is bidding for placement. The methods for managing ads in this way are known in the art—take, for example, the Google Adwords facility, and its competitors associated with other search engines such as Bing—and various aspects of such functions are even available as separate off-the-shelf components for use by 3rd party developers.
Whether acquired through these kinds of means, or others such as purely verbal interactions utilizing speech recognition, these contextual targeting parameters are also stored in database(s) 176. She then gives payment information such as a credit card to Ad and Feedback Manager 2405, which it checks and registers using the e-commerce system 2401.
Meanwhile, a User 2400 has configured his system to accept Ad Rings, either by interacting with UI 2403, or perhaps by obtaining a phone which has this facility built in, for instance to defray the cost of purchase or operation; such phones could even be offered free, or Users might even be paid, in cash or promotional offers or material, to use such a phone with an Ad Ring facility, that is, an “Ad Phone”. The Ad Phone could provide other services such as described herein, or others. The ads could be delivered occasionally during a conversation, in intervals or overlaying it as background chatter, sounds or music; or when one is not occurring; or in the interval after ‘dialing’ a number, while waiting for a connection or answer; or as an “Ad dial tone” while dialing a number; or as an “Ad Ring” notification ringtone audible to the user and other others in his vicinity. As with ReminderRings, beyond the audio being described herein as one embodiment the ads could constitute other modalities such as text, images, video, motion such as vibration, and others, or any combination thereof.
In this case, consider for a continued example the User 2400 configured a smartphone to accept Ad Rings, by interacting with UI 2403. It stores this information in UI files 172, which is accessible to ToneMapper 175 as shown. By this means when an incoming call occurs, Phone Call Event 2410, ToneMapper 175 detects the Ad Ring configuration, communicating this as part of Event 2404 to New Event Notification component 180. In communication with AFM 2405, over internet or other networks, it determines if an appropriate ad is available, considering available contextual information such as location, demographics of the user plus likely surrounding people within earshot, social networks participation, and the ad targeting configured by Merchant 2408.
If a targeted ad is found appropriate on these bases, New Event Notification component 180 is able to obtain the data required to render it directly from Ad and Feedback Manager 2405. If this occurs within an appropriate interval to enable a ringtone without unacceptable delay, that data is provided to Context Handler 2406 for incorporation into the ringtone by Process Audio component 204, replacing entirely the default ringtone fetched through the LoadedRingtone module 203 (as described previously) or merely modifying it, depending on configuration options.
If the interval is projected by computational processing in New Event Notification 180 to result in an unacceptable delay in rendering the ringtone for the User 2400—a simple test of this in a standard smartphone found to be of utility is to timestamp the Event 2404 and have the New Event Notification component 180 allow 350 milliseconds delay until the completed arrival of all data from AFM 2405 (though the potential for application of more sophisticated extrapolation methodology to this task will be apparent to one skilled in the art) then presentation of the Ad Ring is aborted by New Event Notification 180, allowing Process Audio component 204 to render the default ringtone delivered to it by LoadedRingtone module 203 as usual. Optionally, upon arrival the Ad Ring can be buffered in storage available to New Event Notification component 180, then presented as all or part of the notification ringtone for the subsequent call, thus avoiding the delay on a subsequent ring with looser or no contextual targeting of the ad, and return of parameters detailing the actual context under which it was presented communicated back to AFM 2405.
Continuing now to describe the further function in the Ad Feedback case described in the TalkingSocial scenario above, if the User 2400 has configured his smartphone for this via UI 2403, the delivery of feedback such as the “Anchovies, yuck!” utterance to the Pizza Palace merchant in that scenario is accomplished as follows. After hearing or viewing the ad upon which he wishes to deliver feedback, User 2400 indicates his desire by a specific action such as a pressing a button—for instance, the Rec button previously described and implemented in wxCommunicator, or equivalent means including recognizable verbal or gestural cues, as was discussed previously. UI 2403 can either pass parameters to prime OnMyPhonePanelRecButtonClicked 178 to produce a recording outside a conversation, or the system could be set always enabled to do so, as in the code fragment below (in conjunction with a new routine to set up a dummy phone call record in variable dCall defined to serve this purpose) as shown:
void MyPhonePanel::OnMyphonepanelRecbuttonClicked(wxCommandEvent& event )
{
if(!dCall->m_bIsSoundBeingRecorded)
{/ mod for audio message recording for forwarding or feedback
}
}
This will provide for Start Recording 205, and subsequent flow as disclosed previously for ReminderRing proper, with ProcessRecording 206 storing the sample in Database 207 to be relayed to AFM 2405. This connection can be accomplished in a number of ways, but a modification of Create & Delete Tone Files module 185 to communicate over internet to AFM 2405, as is known in the art using web services, or to it via other network connection and protocol such as a dedicated telecommunications channel, has been found to provide more general utility in application, and will be assumed as the preferred means for the remainder of this document. For clarity in the diagram this connection is depicted in
Besides the merchant these mechanisms also enable features which bring another user, or many more, represented by 2409, into the picture. As was described previously, pass-along advertising, augmented by samples from conversation, processed as described for notification purposes in ReminderRings, can be pushed or otherwise relayed to another user, for instance the friend mentioned in the prior example. That e-commerce implementation comprises means known in the art for e-commerce 2401 and connecting the user, another user merchant and another user as needed for fulfillment. A variety of such services and developer APIs are offered by companies such as Amazon, Kiva, Ebay/Paypal, Square, Google, MobilePayUSA, Foursquare and many others, which provide coupon delivery, check-in, customer recognition, fulfillment and other standard ecommerce and mobile commerce processes. These further enable the present invention to build upon its contextual and conversation processing core to deliver the forms of novel commercial utility disclosed herein.
Each of these other users 2409 has access to a communication system 2420 sufficient for participation at the level needed; for simplicity, 2420 is labeled and described herein as a full additional system such as that which surrounds the original user, though many applications will not require that full level of functionality. These systems communicate with each other through events, such as Phone Call Event 2410, as well as through more direct addition and creation of tone files by Create & Delete Tone Files module 165, in either case via internet or other communications medium.
That phone call event 2410 may be a Push type such as was disclosed in commentary herein regarding
It will be apparent to one skilled in the art that additional, equivalent modes of operation, for example, pass-along ads which have targeting, or expiration times, such as the shared table special described in the prior scenario above, can readily be implemented as well within this system. One such further commercial application is next described within it whose utility is to address the need of advertisers that want to monitor and/or generate word of mouth about products or services.
That filling this need is of utility is evidenced, for example, by the many companies that make a business of trying to measure if people are paying attention to a particular product, ranging from clipping services to social media analytic product vendors and market research consultants. But these address text-based publications and social communications, but not voice phone calls. The present invention as exemplified through the system of
Key to this application is purposing Process Recording component 206 to sample not for later use as Annunciations, but for monitoring of conversation. button press, speech or other sound, gesture or signal, set in UI 2403 or as standard configuration by a manufacturer, and operating to denote the sample, as was described in prior commentary on
Mechanism for archiving in Database(s) 176 and examination of such samples from conversation were described previously, as was the application of speech recognition means to those the samples. The capacity of computational examinations of the samples stored in Database(s) 176 to yield metrics such as statistics on how often a product name is mentioned is thus readily addressable by an analysis program, as part of AFM 2405 accessed by Merchant 2408, or by a separate software front end Analysis and Control module 2411 utilized by an analyst, researcher such as a marketer, or other type of person accessing the data, designated for simplicity as Marketer 2412. Such measurements of occurrence and analysis of context are known in the art and of utility at even a basic level, with their limitations by several factors each addressable for improvement with tradeoffs.
For example, speech recognition limitations can be addressed by using human review of all or just the more difficult cases, and can be accomplished through crowdsourcing using products such as Amazon's Mechanical Turk. Limits of the number of people allowing their conversations to be monitored in this way can be addressed by commercial offers of rewards for participation, such as have been utilized by other market research firms, such as the Nielson Company. In the case of smartphones those rewards can include free or use or ownership of the phone itself, with or without additional advertising, or even cash incentives, as mentioned previously.
Beyond monitoring, providing and packaging of such information and measurement by companies for purposes such as providing market research insights & data, the same mechanisms can be used to address the incentivizing of conversation, making it possible to buy reliable word of mouth advertising. The business case of utility and need for this is exemplified in the text mode by paid bloggers and social media users, with companies such as Izea having been among the pioneers of this approach with offerings such as Sponsored Tweets and SocialSpark for sponsored blog posts. Equivalent offers made to the user of
The present invention, by enabling the use and application of conversation and context in telecommunications, brings and extends this new utility further in that the tracked and archived conversational speech can be linked to the individuals making and taking the calls, not only incenting one or more User 2400 to say particular utterances during conversations on their smartphones, and recognizing when they do, but also possibly to whom, if that is Other Users 2409 of the system.
Further functionality can be obtained by giving the speaker an indication of satisfying the incented behavior, that is, providing an onscreen flag or lamp that lights when the targeted utterance is detected in conversation, that is, the targeted sound has been detected in a voicestream. Speech recognition means for this purpose in real-time can be backstopped by crowdsourced applications or spot-checked or statistically audited among the archived samples by the Marketer 2412, his customers or an independent third-party, using Analysis and Control Module 2411.
Besides conversation itself, a smartphone app can also recognize when an action is taken by the talker, or the person being talked to, such as downloading another app, or going to a location or going there with a friend, or scanning a barcode, or taking a picture of a product. Companies like Izea again, with its WeReward program, and LockerZ, have demonstrated the utility and business case for incenting, monitoring and rewarding such behaviors as produced by more standard advertising means. The present invention enables equivalent tracking and incentives mechanisms to these now known in the art to be applied, monitored and fulfilled as prompted by conversation, and the initiator of such conversation to be rewarded as well for producing the effect.
In particular, this sort of service finds application where the product is ephemeral and quick dispersion of word of mouth is urgent. Possibilities such as movies, games, and pop culture meme-driven product vendors, bands, perhaps with a ringtone music tie-in, are all clear uses. As was described previously, sound recognition need not be limited to speech, for instance, music could also be recognized and Users 2400 incented and tracked in playing it during conversations with friends of particular demographics.
Political, educational and therapeutic applications also exist. Examples of the range of utility cases spans such things as: a person could be receive money for a personal endorsement of show, a product for encouraging people who then try a free sample, a discount for letting a friend know movie times, a reward for propagating a meme such as a brand slogan, a ringtone for playing a band's song in the background while telling another fan of an upcoming local concert, a backstage pass for using that ringtone and taking calls to discuss them in a popular club venue, virtual goods for correlated online purchases by someone in a gaming social network they called and told about a new feature, extra credit for talking about a homework topic with another student; an indication of compliance for discussing an item of prescribed group therapy, a picture with a political candidate for mentioning her name to a number of people who subsequently attended a rally, and many more. The present invention discloses the technology to provide these and other cases of utility by breaking through the barriers that have prevented such contextual conversation-processing in telecommunication.
The present invention can be combined with other techniques of conversational processing for social purposes, and extended to realize additional utility beyond other existing means. Turning now to
That figure shows how such adaptive, interwoven conversation threads may be implemented. In it, elements of Leeds 516
In
These Forums, designated here nominally as most of the numbers from 2501 through 2508, in similarity to the equivalent single numeral designations in Leeds 516
Forum equivalents may also be embedded within other social networking mechanisms, for instance, Facebook or LinkedIn Groups. Regardless of such instantiation, cues can be designated to annotate conversations to provide novel contextual notifications based on conversations in this milieu as in those described earlier for games, advertising, friendship introductions, dating, other matchmaking, and other applications, including incentivized participation.
It will be apparent to one of ordinary skill in the art that this form of Adaptive Forums is able to provide an additional dimension of utility in those contextual conversation processing applications previously described. For instance, the “social director” functionalities previously described as providing computer control of online social interactions based on more general conversation processing, can be tailored to consider conversations on Forums as evidence of compatibility, probability of attendance, and arranging backups for scheduled social events. As mentioned previously, these could range from dating, to helping to fill a table at a restaurant, to more elaborate novel social meet-ups of larger groups sharing interests or dispersed roles in games or social designs. For example, a softball team needs a set of players willing and able to undertake covering particular positions; psychological designs, or heuristic insight or evolution through feedback of software-defined equivalents of good party invitation artistry, can produce pioneering equivalents in a “social director” functional module.
This “social director” functionality can be applied in a voiced, text, video or mix of these and other modes of conversational telecommunication. Their presentation may include functionality as described previously, or as is known in the art from prior work such as that disclosed in Leeds 516, or in other ways not foreseen therein.
Delving further into the utility of computer control of online social interactions based on conversation processing, a set of such preferred embodiments is presented. To begin with,
The advertisement fields may randomly or sequentially display various advertisements, as is well known in the art. Sequential changes of displayed advertisements may be controlled according to words and phrases entered in a chat session or uttered in verbal or equivalent conversation according to personal information on the user and ad targeting guidance stored in cookies and other forms such as database 176 and manager module 2405. A button bar 2630 provides the user with a means to interactively select a manner of how to display or otherwise access data on the user's browser, smart phone or other user-interfaced device.
Although the depicted embodiment shows two chat dialog boxes (2600a and 2600b), any number of chat dialog boxes, or their audio or video equivalents, may be open concurrently, enabling a user to participate in several chat forums simultaneously. As is known in the art, the sizing of the boxes is variable and may be adjustable by the user, automatically shaped to equally share the available screen space, or equivalently configurable in addressing acoustic, video or other modalities of conversation, and implemented using techniques such as drop down menus, function keys, or other common practices in the art. The chat dialog boxes 2600a and 2600b can use the “post-and-wait” chat method, the “scrolling text” chat method, or others, independently of one another.
Personal information may be obtained, stored, updated and saved for future access and processing by means known in the art and disclosed and/or referenced elsewhere herein. Information in header fields such as described in Leeds 516 may guide the disposition and utilization of chat messages among forums, or their equivalent, or push notifications based on them.
Chat messages, identified by headers as is known in the art and can be based on Leeds 516, besides being distributed among chats can also be identified by the user or ‘social director’ mechanism as Shouts, to be tracked in all or a hierarchically configurable subset of multiple conversations, including access/display in one or more Shout Box 2650. This enables the Shout stream delivered to a Box to be customized to a user's interests, including from his or her profile, other internal data, or external social media means explicit or implicit (for instance in prior behavior), including sites visited, profiles, and content of posts/chats, to create a “wall” of intermingled shouts and posts. These conversational snippets are thus rewoven in a way that provides utility to the user, marketers, and analytic inference for other purposes.
The tailoring of this and other conversations' adaption can thus include following a person or interest, as on Twitter and other social media which provide subscription to user broadcasts, but beyond those prior opt-ins the present invention provides for pushed conversations, all without intermediary recommending of friends and other social matchmaking. This has little analog in the natural world; though some mechanisms like ‘overhearing’ and joining conversations in a crowded room such as a party are similar, this means of pushing conversations together, contextualizing and weaving them along with sponsored content, is only provided by the present invention, enabled through the use of telecommunications. In particular, it provides for conversations to be routed among interested parties, for whom actionable information will be available, enabling kindling of conversation, nurturing of discussion, and instant communication. It is thus of more utility than simply replacing the overhearing mechanism in which humans “prick up their ears” to matters touched upon in background conversations that catch their attention or they subconsciously notice.
Particularly when actionable for alertness or alarm, this is an innovation in the present invention. It enables the present invention's ‘social director’ style of applications to be means for a portal instead of just as a matchmaker; for instance, providing a place where large organizations of people can talk at the same time, in asynchronous conversation streams.
In a business context, those can be corporations or other sets of people. In a commercial context, the incentivizing (‘sponsoring’) of conversation, as mentioned earlier, can be enhanced to vary by the number and/or targeted quality of conversations entered.
In a free-ranging adaptive conversational situation, examples of two general categories of interests for the algorithm can include a matrix of interests, for example, categories (art, sports, history . . . ), locations, times (60s, 20s, WWI, Pleistocene), people, products, services, etc.
The methodology for balancing such interests and other factors, and determining into which conversations to place a user of the system, can employ a variety of mechanisms known in the art, aggregated into best fit weighting algorithms and tuned using explicit (e.g., user input to set profile data in configuration storage 172) or implicit (participation, including response to embedded advertising such as sponsored conversation), analogous to the weighting mechanisms described in
Among those, one market in particular in which this computer control of online social interactions based on conversation processing enables a new level of capability is the Singles market, addressing many of the robust and growing set of over 100 million unmarried people, who are 18 and older, in America alone, at the time of this application. Addressed by a diverse collection of dating, matchmaking, and other sites, the opportunities to apply this technology are clearly able to transcend current means of crafting matches based on a limited set of, customarily, a few dozen dimensions of compatibility, by extracting and invoking a near-infinite scale of possibilities for placing the user amid multiple conversations that are found heuristically favorable, plus tracking engagement quality, quantity, and apparent outcomes amid the conversation streams of people chatting or arranging social occasions with each other.
This and other presently described embodiments of the current invention may be implemented in software, hardware, or a combination of both. Furthermore, control mechanisms, programs or data storage contemplated in any or all of the presently described embodiments of the invention may reside wholly or partially on or otherwise utilize networked CPUs, servers, “cloud” or array storage and the like.
Information as herein shown and described in detail is fully capable of attaining the above-described object of the invention, the presently preferred embodiments of the invention, and is, thus, representative of the subject matter which is broadly contemplated by the present invention. The scope of the present invention fully encompasses other embodiments which may become obvious to those skilled in the art, and is to be limited, accordingly, by nothing other than the appended claims, wherein reference to an element in the singular is not intended to mean “one and only one” unless explicitly so stated, but rather “one or more.” All structural, electrical, and functional equivalents to the elements of the above-described preferred embodiment and additional embodiments that are known to those of ordinary skill in the art are expressly incorporated herein by reference and are intended to be encompassed by the present claims. Further, the examples and data contained herein are for illustration purposes only and in no way shall limit this present invention.
Moreover, it is not necessary for a device or method to address each and every problem sought to be solved by the present invention for it to be encompassed by the present claims. Furthermore, no element, component or method step in the present disclosure is intended to be dedicated to the public regardless of whether the element, component, or method step is explicitly recited in the claims. No claim element herein is to be construed under the provisions of 35 U.S. C. 112, sixth paragraph, unless the element is expressly recited using the phrase “means for.”
This application is a Divisional of U.S. patent application Ser. No. 15/373,554, which is based on a Continuation-in-Part and claims priority to U.S. Pat. No. 8,068,604, granted on Nov. 29, 2011 and U.S. Pat. No. 8,553,852, granted on Oct. 8, 2013, all of which are hereby incorporated by reference as if fully set forth herein.
Number | Name | Date | Kind |
---|---|---|---|
5825855 | Astarabadi | Oct 1998 | A |
7027569 | Price | Apr 2006 | B2 |
7127238 | Vandermeijden et al. | Oct 2006 | B2 |
7304983 | Simpson et al. | Dec 2007 | B2 |
7310416 | Henderson | Dec 2007 | B1 |
7805740 | Gilboa | Sep 2010 | B2 |
9269097 | Freeman et al. | Feb 2016 | B2 |
20030026416 | Fusco | Feb 2003 | A1 |
20040067751 | Vandermeijden et al. | Apr 2004 | A1 |
20040190688 | Timmins | Sep 2004 | A1 |
20040235520 | Cadiz et al. | Nov 2004 | A1 |
20050132290 | Buchner | Jun 2005 | A1 |
20060003814 | Moody et al. | Jan 2006 | A1 |
20060111085 | Lee | May 2006 | A1 |
20060148459 | Wolfman et al. | Jul 2006 | A1 |
20060199575 | Moore et al. | Sep 2006 | A1 |
20060215827 | Pfleging et al. | Sep 2006 | A1 |
20070117554 | Amos | May 2007 | A1 |
20070264978 | Stoops | Nov 2007 | A1 |
20080070697 | Robinson et al. | Mar 2008 | A1 |
20080084975 | Schwartz | Apr 2008 | A1 |
20090220067 | Leeds | Sep 2009 | A1 |
Entry |
---|
“Programming Flash Communication Server” by Brian Lesser, et al. (O'Reilly Media, Inc. 2005; ISBN: 0596005040). |
“Macromedia® Flash™ MX 2004 for Rich Internet Applications” by Phillip Kerman (New Riders 2003, Print ISBN-10: 0-7357-1366-09). |
“Flash 8: Projects for Learning Animation and Interactivity” by Rich Shupe, et al. (O'Reilly 2006, Print ISBN-10: 0-596-10223-2, Print ISBN-13: 978-0-59-610223-4). |
“Linux Multimedia Hacks” by Kyle Rankin (O'Reilly Pub 2005, Print ISBN-10: 0-596-10076-0, Print ISBN-13: 978-0-59-610076-6). |
“Get a Human On the Line”, Wall Street Journal article May 6, 2007. |
Number | Date | Country | |
---|---|---|---|
Parent | 15373554 | Dec 2016 | US |
Child | 16593357 | US | |
Parent | 14106167 | Dec 2013 | US |
Child | 15373554 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12039596 | Feb 2008 | US |
Child | 12339429 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13305686 | Nov 2011 | US |
Child | 14106167 | US | |
Parent | 12339429 | Dec 2008 | US |
Child | 13305686 | US |