Receiving files using wireless devices can be problematic. For example, the strength of the wireless connection may vary as the wireless device moves from location to location. Even if a connection is made and the device stays in the same location, connectivity can be intermittent or there may be a weak connection, making successful downloading of a large file difficult or impossible. Additionally, mobile download of files through a wireless connection may be disadvantageous due to bandwidth limitations of a wireless network or power requirements of the transmitting device.
Aspects of the headsets, methods, and systems for non-volatile memory in wireless headsets are described herein.
One exemplary embodiment is a headset for storage and presentation of an audio or visual file. The headset includes: at least one speaker or display; non-volatile memory for storing the audio file; and a processor configured to receive the audio file from an external server and play the audio file through the at least one speaker if a playback command is received from the external server.
Another exemplary embodiment is a system for storage and presentation of an audio or visual file. The system includes means for presenting the audio or visual file to a user; means for receiving the audio or visual file from an external server; means for storing the audio or visual file; and means for playing or displaying the audio or visual file through the means for presenting if a playback command is received from the external server.
In another exemplary embodiment, a method relates to storage and presentation of an audio or visual file. The method includes: providing a headset having non-volatile memory and at least one of a speaker and a display; receiving, from an external server, the audio or visual file; storing, in non-volatile memory, the audio or visual file; and playing or displaying the audio or visual file through at least one speaker or display if a playback command is received from the external server.
Another exemplary embodiment is a device for transmitting an audio or visual file. The device includes: a transmitter for transmitting the audio or visual file for storage in a receiving device; wherein the transmitter is further configured to transmit a playback command to the receiving device for triggering the receiving device to play or display the audio or visual file.
Another exemplary embodiment is a system for transmitting an audio or visual file. The system includes: means for transmitting, from a server, the audio or visual file for storage in the receiving device; and means for transmitting, from the server, a playback command, the playback command for triggering the receiving device to play or display the audio or visual file.
In another exemplary embodiment, a method relates to transmitting an audio or visual file. The method includes: transmitting, from a server, the audio or visual file for storage in a receiving device; and transmitting, from the server, a playback command for triggering the receiving device to play or display the audio or visual file that was previously transmitted.
Another exemplary embodiment is a headset for storage and presentation of a visual file. The headset includes: a display; a receiver for receiving the visual file from an external server; non-volatile memory for storing a visual file; and a processor configured to display the visual file through the display if a playback command is received from the external server.
Another exemplary embodiment is a headset for providing audio to a user. The headset includes a speaker; a receiver configured to receive portions an audio stream from an audio streaming source; a non-volatile memory for storing the portions of an audio stream; and a processor configured to store the portions of the audio stream in the non-volatile memory, play the portions of the audio stream based on a playback command, and erase the portions of the audio stream from the non-volatile memory.
The invention is capable of other embodiments and of being practiced or being carried out in various ways. Alternative exemplary embodiments relate to other features and combinations of features as may be generally recited in the claims.
The methods, headsets, systems, and devices described herein provide a way of storing and providing audio or visual content to a user of a device, such as a headset. In various embodiments, audio or visual files may be stored in non-volatile memory housed in a set of headphones, headset, or other listening device. The stored audio or visual files may be played, displayed, or otherwise presented to a user. Storing files in the user device in this manner can be used to eliminate the need to transmit commonly used or fixed-content sounds to an earbud or similar listening device, thereby reducing bandwidth or power requirements for the transmitting device. Additionally, storing audio or visual files is beneficial for when a wireless connection is unavailable or lost.
Such methods may be carried out on a headset including circuitry to store and deliver audio or visual content to a user, for example, through a headset, headphones, one or more earbuds, any mobile speaker or set of speakers, PDA, smartphone, any portable media player, any mobile monitor or display, or any combination of those. The speaker(s) may be capable of producing three-dimensional audio effects beyond left channel and right channel. The speaker(s) may be connected to the headset wirelessly or through a wired connection, or the headset may be a single standalone device.
The headset may include a computer headset, which may include one or more integrated circuits or other processors that may be programmable or special-purpose devices. The headset may include memory which may be one or more sets of memory, which may be persistent or non-persistent, such as dynamic or static random-access memories, flash memories, electronically-erasable programmable memories, or the like. Memory in a headset, headset system, or server may having instructions embedded therein, such that if executed by a programmable device, the instructions will carry out methods as described herein to form headsets and devices having functions as described herein.
User device 12 may communicate with computing device 10 through network 11. User device 12 may be a mobile device connected to or include one or more speakers and/or displays. User device 12 may include, but is not limited to, one of more of: a general-purpose computer, special-purpose computer, laptop, tablet computer, smartphone, PDA, Bluetooth device, media player device, radio receiver or other receiver device, a seat providing a port for plugging in headphones or another listening device, headphones, earbuds, and the like, including any device that is capable of providing audio or visual content to a user through a speaker or display which may or may not be attached to user device 12. User device 12 may communicate with one or more servers 10 through one or more applications that include computer-executable instructions. User device 12 may communicate through one or more network interface devices or network interface circuitry. Alternative embodiments may not involve network 11 at all, and may instead be implemented through peer-to-peer communication between user device 12 and a server or between multiple user devices 12. For example, computing device 10 and user device 12 may communicate with each other through infra-red, radio, Bluetooth, wired connections, or the like.
Computing device 10 may be implemented as a network of computer processors. In some implementations, computing device 10 may be multiple servers, mainframe computers, networked computers, a processor-based device, or a similar type of headset or device. In some implementations, computing device 10 may be a server farm or data center. Computing device 10 may receive connections through a load-balancing server or servers. In some implementations, a task may be divided among multiple computing devices 10 that are working together cooperatively.
The system memory 26 may include one or more suitable memory devices such as, but not limited to, RAM, or any type of volatile memory or data caching mechanism. The computer may include a non-volatile storage medium 24, such as, but not limited to, a solid state storage device and/or a magnetic hard disk drive (HDD) for reading from and writing to a magnetic hard disk, a magnetic disk drive for reading from or writing to a removable magnetic disk, and an optical disk drive for reading from or writing to removable optical disk such as a CD-ROM, CD-RW or other optical media, flash memory, SD card, USB drive, memory stick, or the like. Storage medium 24 may be one or more sets of non-volatile memory such as flash memory, phase change memory, memristor-based memory, spin torque transfer memory, or the like. A storage medium 24 may be external to the devices 10, 12, such as external drive(s), external server(s) containing database(s), or the like. A storage medium 24 may be on-board memory. The drives and their associated computer-readable media may provide non-transient, non-volatile storage of computer-executable instructions, data structures, program modules, audio and visual files, and other data for the computer to function in the manner described herein. Various embodiments employing software are accomplished with standard programming techniques.
The system 2 may also include one or more audio output devices 20, which may be external or internal to user device 12. For example, as discussed above in regard to
User device 12 and computing device 10 may each separately include processor(s) 22, storage medium or media 24, system memory 26, and system bus(es) 28. Computing device 10 may not include an audio output device 20. Computer device 10 may not include a visual output device 23. User device 12 may include one or more audio output devices 20, one or more visual output devices 23, or a combination of devices 20 and 23.
Processor 22 may provide output to one or more visual output devices 23. As illustrated in
According to various embodiments, computer-executable instructions may encode a process of securely sharing access to information. The instructions may be executable as a standalone, computer-executable program, as multiple programs, as mobile application software, may be executable as a script that is executable by another program, or the like.
With reference to
Processor 22 may cause one or more audio or visual files to be stored in non-volatile memory 24 (step 32). The file may include a sound file, a sound or video stream, or clip, video, image, photo, over the air radio streams, chunk(s) or portion(s) of any of those, any combination of those, or the like. The file may be in any format in which audio or visual content can be expressed, such as WAV, AIFF, IFF, AU, PCM, FLAC, WavPack, TTA, ATRAC, AAC, ATRAC, WMA, BWF, SHN, XMF, FITS, 3GP, ASF, AVI, DVR-MS, FLV, F4V, IFF, MKV, MJ2, QuickTime, MP3, MP4, RIFF, MPEG, Ogg, RM, NUT, MXF, GXF, ratDVD, SVI, VOB, DivX, JPEG, Exif, TIFF, RAW, PNG, GIF, BMP, PPM, PGM, PBM, PNM, WEBP, or the like. The file may be a container or wrapper for one or more videos, audio files, images, movies, photos, any combination of those, or the like.
The audio or visual file may contain a ringtone, visual alert, sound effect, visual effect, game sound effect, game visual effect, monologue, dialogue, conversation, informational message, advertisement, or the like.
The audio or visual file may have been preinstalled onto the non-volatile memory 24 before the user device was delivered to a retailer. The audio or visual file may have been preinstalled by a retailer before being delivered to a consumer. A user may download or copy an audio or visual file onto the non-volatile memory 24. The audio or visual file may be recorded onto non-volatile memory 24. The audio or visual file may be removed or added by changing non-volatile memory 24. The audio or visual file may be removed from non-volatile memory according to an expiration schedule. In one embodiment, the expiration schedule is based on a time lapse from a time the audio or visual file, or a portion of the audio or visual file, was stored on non-volatile memory 24 or transferred to the user device. In another embodiment, the expiration schedule is embedded within the audio or visual file. In another embodiment, the expiration schedule is based on user input. In another embodiment, the expiration schedule is provided by a second device (e.g., server 10, etc.). For example, an audio stream transferred from an internet-based audio streaming service may expire after one week. In another example, the audio file may expire after a certain number of plays. In another embodiment, the expiration schedule is based on the capacity of non-volatile memory. For example, if a second audio or visual file is downloaded, and space is needed on non-volatile memory 24 to store the second audio or visual file, a first audio or visual file may expire and be removed from non-volatile memory in order to free up storage space. An expiration schedule may correspond to an entire audio or visual file, or to portions of the audio or visual file.
The audio or visual file may be transmitted from a server 10 and received by a user device 12, which stores the file on non-volatile memory 24. As an example, server 10 may be part of an internet based audio or video service. The file may have been transferred wirelessly or over a wired connection. The file may be received by user device 12 from a transmitter that is external to user device 12.
Processor 22 determines whether a playback command has been received by the user device 12 (step 34). The playback command may be received from server 10. If a playback command was not received, step 34 is repeated. User device 12 waits until a playback command is received. User device 12 may perform other functions while waiting for a playback command or it may be idle. A playback command may be received wirelessly or through a wired connection, or through a combination of wired and wireless connections. The playback command may not be transmitted from the server until a time after the audio or visual file has been stored on the user device 12. For example, the audio or visual file may be downloaded before a scheduled performance or event, and the playback command may be transmitted at the appropriate time at the start or during the performance or event.
A playback command may specify an audio or visual file to be played or displayed, and may include a user selection. The playback command may specify a portion of the audio or visual file to be played or displayed. The playback command may specify a time, or delay until, the audio or visual file is to be played or displayed. The playback command may include commands for pausing, stopping, starting, fast-forwarding, rewinding, or restarting playback. The playback command may be based on a user gesture, user input, a mechanical switch, or sound, etc. User device 12 determines whether the specified file is already stored in non-volatile memory 24. If it is not already stored, the user device 12 transmits a request for the file to be sent to the user device 12. The request is sent to server 10. Server 10 may send, and the user device 12 may receive, a copy of the requested file after the server receives the request. The user device 12 may store this received audio or visual file in the non-volatile memory 24. The received file may be played or displayed (step 36).
If a copy of the file specified in the playback command is already in the non-volatile memory 24, the user device 12 may transmit a request to not send the same file. The request may be transmitted to and received by server 10. Server 10, after receiving this request, may stop transmitting the file or determine to not transmit the file.
Upon receiving part of an audio or visual file, user device 12 may determine that a copy of the file is already in the non-volatile memory 24 and transmit a request to stop sending the file. The server 10, after receiving this request, may stop transmitting the file. If user device 12 determines that a copy of the file is not already in the non-volatile memory 24, user device 12 may continue to receive the file. The received file may be stored in non-volatile memory 24. The received file may be played or displayed (step 36).
If part of the audio or visual file is received, the received portion may be played or displayed, or may include a file header. The file header may be used to determine whether a copy of the file is already in the non-volatile memory 24.
If part of the audio or visual file is received, the received portion may be used for comparison, such as for pattern recognition. The comparison can be used to determine whether a copy of the file is already in non-volatile memory 24. For instance, the first few bars of a song may be transmitted, and that may be used to compare against stored files, such as music files.
If an audio or visual file is received, it may supplant another file in the non-volatile memory. The supplanted file may be another audio or visual file. Whether any or a particular audio visual file is supplanted may depend on a user command. For example, the user may specify whether to supplant a file or discard the incoming file. Determining whether to supplant a file may be based on the amount of available (or “free”) file space there is in the non-volatile memory 24. For instance, if there is enough available memory to save the incoming file without removing the existing files in non-volatile memory 24, then the incoming file may be saved without supplanting any files in the non-volatile memory 24.
If a file is to be supplanted, a user may specify which file to supplant. If a file is to be supplanted, the file chosen to be supplanted may be determined based on a priority of the files. For instance, a file with low priority may be supplanted before a file with a higher priority is selected to be supplanted. If a file is to be supplanted, the file chosen to be supplanted may be determined based on a usage frequency of the files. For instance, a file used less frequently may be supplanted before a file that is more frequently accessed. If a file is to be supplanted, the file chosen to be supplanted may be determined based on the ages of the files. For example, a file that is older may be supplanted before a file that is newer.
If a playback command is received, then the user device 12 may play or display an audio or visual file (step 36). The file may be played or displayed through an audio output device 20 or a visual output device 23. For example, if an audio file is received, the audio represented by the data in the file may be output to one or more speakers or to a device for interpreting or transmitting audio. As another example, if a video file is received, the video represented by the data in the file may be output to a display and its sound track output to one or more speakers or to devices for interpreting or transmitting video and/or audio.
With reference to
The processor 22 determines whether a sensor condition has been met (step 44). If a sensor condition has not been met, step 44 may be repeated. A user device 12 may wait until a sensor condition has been met. A user device 12 may perform other functions while waiting for a sensor condition to be met, or the user device 12 may be idle. A user device 12 may include one or more sensors or may receive data from one or more sensors. A sensor condition may be based on data received from one or more sensors. The sensor condition may be pre-stored in the processor 22 or the non-volatile memory 24. The sensor condition may be received via an external transmission; this can be included within the playback command, or can be delivered by a separate signal. The sensor condition may be based on any number of conditions, including, but not limited to, location data or signal information (e.g., signal strength, type of signal, signal bandwidth, etc.). It should be understood that the scope of the present application is not limited to a certain sensor condition.
For instance, the sensor may be a Global Positioning System (GPS) device or other location-determining device. The sensor condition may be based on the sensed location. For example, if the GPS senses that it is located in a particular location, and the sensor condition is based on being in that area, then the user device 12 may play or display an audio or visual file (step 46). That may be useful, for instance, in an art museum, or other tour situation, in which a user has a headset or other user device 12 which plays an audio file or displays a video when the user device 12 is located in an appropriate area. The audio or visual file may be related to an exhibit near the location of the user device 12. In a tour situation, for example, required or popular files may already be stored on non-volatile memory 24 of a headset 12 so that they need not be downloaded during the tour.
As another example, a sensor condition may be based on the availability of a signal. For instance, if a wireless data connection is unavailable, the user device 12 may play or display audio or visual file(s) that are already stored in the non-volatile memory (step 46). This allows the user to use available files without having to wait for a connection to become available so that the user may download a file. As another example, if a cell phone connection becomes unavailable, a notification sound may automatically play. For instance, an informational message may be played, such as “You have temporarily lost cell phone connectivity.”
In yet another example, a sensor condition may be based on bandwidth availability. For example, if the bandwidth available in a connection is low, the user device 12 may play or display audio or visual files that are already stored in the non-volatile memory (step 46). This allows the user to use available files without having to wait for more bandwidth to become available so that the user may download a file.
If a sensor condition has been met, then user device 12 may play or display an audio or visual file (step 46). The sensor condition may cause user device 12 to play or display the audio or visual file (i.e., the sensor condition may be interpreted by the processor of user device 12 as a playback command, or other command, etc.). This has been described above in relation to step 36 of process 3.
With reference to
Server 10 transmits an audio or visual file for storage in a receiving user device 10 (step 50). The audio or visual file may be as discussed above, in relation to process 3 of
Server 10 may transmit a playback command for triggering the receiving device to play or display an audio or visual file (step 52). The playback command may be as discussed above, in relation to process 3 of
While various inventive embodiments have been described and illustrated herein, those of ordinary skill in the art will readily envision a variety of other means and/or structures for performing the function and/or obtaining the results and/or one or more of the advantages described herein, and each of such variations and/or modifications is deemed to be within the scope of the inventive embodiments described herein.
The above-described embodiments may be implemented using hardware or circuitry, software, or a combination thereof. When implemented in software, the software code may be executed on any suitable processor or collection of processors, whether provided in a single computer system (“computer”) or distributed among multiple computers.
Further, it should be appreciated that a computer may be embodied in any of a number of forms, such as a rack-mounted computer, mainframe, a desktop computer, a laptop computer, a server computer, a cloud-based computing environment, a tablet computer, etc.
Additionally, a computer may be embedded in a device not generally regarded as a computer but with suitable processing capabilities, including a Personal Digital Assistant (PDA), a smart phone, or any other suitable portable or fixed electronic device.
Various embodiments may include hardware devices, as well as program products including computer-readable, non-transient storage media for carrying or having data or data structures stored thereon for carrying out processes as described herein. Such non-transient media may be any available media that can be accessed by a general-purpose or special-purpose computer or server. By way of example, such non-transient storage media may include random-access memory (RAM), read-only memory (ROM), erasable programmable read-only memory (EPROM), electrically erasable programmable read-only memory (EEPROM), field programmable gate array (FPGA), flash memory, compact disk, or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code in the form of computer-executable instructions or data structures and which can be accessed by a general-purpose or special-purpose computer. Combinations of the above may also be included within the scope of non-transient media. Volatile computer memory, non-volatile computer memory, and combinations of volatile and non-volatile computer memory may also be included within the scope of non-transient storage media. Computer-executable instructions may include, for example, instructions and data that cause a general-purpose computer, special-purpose computer, or special-purpose processing device to perform a certain function or group of functions.
In addition to a system, various embodiments are described in the general context of methods and/or processes, which may be implemented in some embodiments by a program product including computer-executable instructions, such as program code. These instructions may be executed by computers in networked environments. The terms “method” and “process” are synonymous unless otherwise noted. Generally, program modules may include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of program code for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps.
In some embodiments, the method(s) and/or system(s) discussed throughout may be operated in a networked environment using logical connections to one or more remote computers having processors. Logical connections may include a local area network (LAN) and a wide area network (WAN) that are presented here by way of example and not limitation. Such networking environments are commonplace in office-wide or enterprise-wide computer networks, intranets and the Internet. Those skilled in the art will appreciate that such network computing environments may encompass many types of computer system configurations, including personal computers, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network personal computers, minicomputers, mainframe computers, and the like.
In some embodiments, the method(s), system(s), device(s) and/or headset(s) discussed throughout may be operated in distributed computing environments in which tasks are performed by local and remote processing devices that may be linked (such as by wired links, wireless links, or by a combination of wired or wireless links) through a communications network. Specifically, computing device 10 and user device 12 may communicate wirelessly or through wired connection(s). Communication may take place using a Bluetooth standard or the like.
In a distributed computing environment, according to some embodiments, program modules may be located in both local and remote memory storage devices. Data may be stored either in repositories and synchronized with a central warehouse optimized for queries and/or for reporting, or stored centrally in a database (e.g., dual use database) and/or the like.
The various methods or processes outlined herein may be coded and executable on one or more processors that employ any one of a variety of operating systems or platforms. Additionally, such software may be written using any of a number of suitable programming languages and/or programming or scripting tools, and also may be compiled as executable machine language code or intermediate code that is executed on a framework or virtual machine. The computer-executable code may include code from any suitable computer programming or scripting language or may be compiled from any suitable computer-programming language, such as, but not limited to, ActionScript, C, C++, C#, Go, HTML, Java, JavaScript, JavaScript Flash, JSON, Objective-C, Perl, PHP, Python, Ruby, Visual Basic, and XML.
In this respect, various inventive concepts may be embodied as a computer readable storage medium (or multiple computer readable storage media) (e.g., a computer memory, one or more floppy discs, compact discs, optical discs, magnetic tapes, flash memories, circuit configurations in Field Programmable Gate Arrays or other semiconductor devices, or other non-transitory medium or tangible computer storage medium) encoded with one or more programs that, when executed on one or more computers or other processors, perform methods that implement the various embodiments of the invention discussed above. The computer-readable medium or media can be transportable, such that the program or programs stored thereon can be loaded onto one or more different computers or other processors to implement various aspects of the present invention as discussed above. The recitation of a module, logic, unit, or circuit configured to perform a function includes discrete electronic and/or programmed microprocessor portions configured to carry out the functions. For example, different modules or units that perform functions may be embodied as portions of memory and/or a microprocessor programmed to perform the functions. Alternatively, circuitry may perform all of the functions that a processor is described as performing herein.
Additionally, it should be appreciated that according to one aspect, one or more computer programs that, when executed, perform methods of the present invention, need not reside on a single computer or processor, but may be distributed in a modular fashion amongst a number of different computers or processors to implement various aspects of the present invention.
Although the foregoing is described in reference to specific embodiments, it is not intended to be limiting or disclaim subject matter. Rather, the invention as described herein is defined by the following claims, and any that may be added through additional applications. The inventors intend no disclaimer or other limitation of rights by the foregoing technical disclosure.