Examples described herein relate generally to an intermediate computing device that uses near-field acoustic signals to configure an end-user device.
There exists numerous kinds of consumer devices that can receive services and resources from a network service. Such devices can operate applications or provide other functionality that links the device to a particular account of a specific service. For example, e-reader devices typically link to an online bookstore, and media playback devices often include applications which enable the user to access an online media library. In this context, the user accounts can enable the user to receive the full benefit and functionality of the device.
According to embodiments described herein, an intermediate device is operated to play back an acoustic configuration file for an end-user device. The acoustic configuration file can embed configuration parameters that are detectable by the end-user device. In particular, the end-user device can use the configuration parameters in conjunction with performing select operations, such as operations to configure the end-user device for communication with the network service.
In an embodiment, an intermediate device determines a set of configuration parameters based on information determined by the intermediate device. The intermediate device generates at least a portion of an acoustic configuration file that embeds the configuration parameters. Additionally, the intermediate device plays back the acoustic configuration file to generate an acoustic signal that conveys the configuration parameters to the end-user device.
According to some embodiments, the acoustic configuration file includes content. In one implementation, the content of the audio configuration file includes music. In a variation, the audio configuration file includes voice, such as a message from a source (e.g., network service) directing instructions or other notification. Still further, in some variations, the audio output from the acoustic configuration file is provided within an in-audio frequency (10 Hz<fs<22.05 kHz). In other variations, the audio output from the acoustic configuration file is provided in an out-of-band frequency range (100 kHz>fs>22.05 kHz).
In still another embodiment, an intermediate device receives a first acoustic configuration file from a network service. The first acoustic configuration file can include a first set of configuration parameters. The intermediate device can also determine a second set of configuration parameters, using, for example, local resources of the mobile computing device. The intermediate device can generate a second acoustic configuration file that includes the first acoustic configuration file. The second acoustic configuration file can include the first of configuration parameters as well as the second set of configuration parameters.
One or more embodiments described herein provide that methods, techniques and actions performed by a computing device are performed programmatically, or as a computer-implemented method. Programmatically means through the use of code, or computer-executable instructions. A programmatically performed step may or may not be automatic.
One or more embodiments described herein may be implemented using programmatic modules or components. A programmatic module or component may include a program, a subroutine, a portion of a program, or a software or a hardware component capable of performing one or more stated tasks or functions. As used herein, a module or component can exist on a hardware component independently of other modules or components. Alternatively, a module or component can be a shared element or process of other modules, programs or machines.
Furthermore, one or more embodiments described herein may be implemented through instructions that are executable by one or more processors. These instructions may be carried on a computer-readable medium. Machines shown or described with figures below provide examples of processing resources and computer-readable mediums on which instructions for implementing embodiments of the invention can be carried and/or executed. In particular, the numerous machines shown with embodiments of the invention include processor(s) and various forms of memory for holding data and instructions. Examples of computer-readable mediums include permanent memory storage devices, such as hard drives on personal computers or servers. Other examples of computer storage mediums include portable storage units, such as CD or DVD units, flash or solid state memory (such as carried on many cell phones and consumer electronic devices) and magnetic memory. Computers, terminals, network enabled devices (e.g., mobile devices such as cell phones) are all examples of machines and devices that utilize processors, memory, and instructions stored on computer-readable mediums. Additionally, embodiments may be implemented in the form of computer-programs, or a computer usable carrier medium capable of carrying such a program.
System and Device Description
The network service 120 includes multiple servers and other computing resources that provide various services in connection with one or more applications that are installed on the computing device. By way of example, network service 120 can provide e-book services which communicate with an e-book application on the e-reader device 110. The e-book services provided through network service 120 can, for example, include services in which e-books are sold, shared, downloaded and/or stored.
The e-reader device 110 can correspond to any computing device on which applications and application resources (e.g., e-books, media files, documents) can be rendered and consumed. For example, the e-reader device 110 can correspond to, for example, a tablet, telephony/messaging device (e.g., smart phone) or portable computing device. In one implementation, for example, e-reader device 110 can run an e-reader application that links the device to the network service 120 and enables e-books provided through the service to be viewed and consumed. In another implementation, the e-reader device 110 can run a media playback or streaming application which receives files or streaming data from the network service 120. In examples described herein, the e-reader device 110 also includes an acoustic input component for receiving a sound generated from the playback of the acoustic configuration file 102. The acoustic input component can correspond to a non-specialized, multipurpose microphone.
By way of example, the e-reader device 110 can be equipped with hardware and software to optimize certain application activities, such as reading electronic content (e.g., e-books). For example, the e-reader device 110 can have a tablet like form factor, although variations are possible. In some cases, the e-reader device 110 can also have an E-ink display.
In variations in which the mobile computing device 150 is employed as an intermediate device, the mobile computing device 150 can correspond to, for example, a tablet, handset or telephony/messaging device (e.g., smart phone) or portable computing device. The mobile computing device 150 can include, for example, resources for establishing network connectivity, as well as the ability to receive messages or otherwise communicate with the network service 120. The mobile computing device 150 can be equipped with an acoustic output component to output encoded near-field acoustic signals to the e-reader device 110. In some variations, the acoustic output component can correspond to non-specialized, mufti-purpose speakers typically employed to output music or other audio content.
In additional detail, the network service 120 can include a device interface 128 and an acoustic interface 138. The device interface 128 communicates with individual devices that access the service. Among other resources, the network service 120 can include a resource store 122 and a user account store 124. The user account store 124 can associate the e-reader device 110 with a user and with an account 125. The account 125 can also be associated with one or more application resources (e.g., e-books), which can be stored in the resource store 122. As described further, the user account store 124 can retain metadata for individual accounts 125 to identify resources that have been purchased or made available for consumption for a given account. The e-reader device 110 may be associated with the user account 125, and multiple devices may be associated with the same account. As described in greater detail below, the e-reader device 110 can store resources (e.g., e-books) that are purchased or otherwise made available to the user of the e-reader device 110, as well as to archive e-books and other digital content items that have been purchased for the user account 125, but are not stored on the particular computing device.
The acoustic interface 138 of the network service 120 operates to generate the acoustic configuration file 102 for the e-reader device 110. In one implementation, the device interface 128 obtains an identifier of the e-reader device 110, and identifies an account 125 (if any) that is associated with the identifier. A set of configuration parameters 121 can be obtained for the account 125. The set of configuration parameters 121 can correspond to, for example, the account identifier, login and password for the identified account, and/or payment information associated with the account. In variations, the set of configuration parameters 121 can also include, for example, preferences of the user, settings of the user account or its devices, and/or identification of resources (e.g., e-books) that the user has downloaded or has permission to download. The acoustic interface 138 encodes the set of configuration parameters 121 into acoustic data, and then packages the acoustic data as the acoustic configuration file 102.
In one implementation, configuration parameters can be embedded as an in-audio frequency range (10 Hz<fs<22.05 kHz) such as at approximately 18 kHz. In a variation, the configuration parameters can be embedded as an out-of-band frequency range (100 kHz>fs>22.05 kHz). The acoustic configuration file can further include audio content, such as music or voice (e.g., message or instruction). When the acoustic configuration file 102 includes audio content provided in an out-of-band range, the configuration parameters can be communicated without additional audio noise that would interfere with human listening of the audio configuration file.
Multiple kinds of encoding techniques can be employed in order to embed information such as configuration parameters in the acoustic configuration file. In particular, the configuration parameters can be encoded as audio data using a spread spectrum technique and/or an electrical water marking technique For example, in one implementation, a modulation technique such as provided by orthogonal frequency-division multiplexing (OFDM) can be used. In variations, the encoding scheme can be provided by a digital water marking technique, including techniques that employ Data Encryption Standard (“DES”) as well as Rivest, Shamir, Adleman (“RSA”) encoding.
The network service 120 can store the acoustic configuration file 102 (e.g., linked with the user account 125), or alternatively store and/or transport the acoustic configuration file 102 to a designated destination. For example, once the acoustic configuration file 102 is generated, the file can be messaged or otherwise communicated to an email address or other network location associated with the account 125 of the e-reader device 110.
Once transported, the acoustic configuration file 102 can be played back in proximity to the e-reader device 110 for purpose of configuring that device. In particular, the e-reader device 110 can be configured to utilize the set of configuration parameters 121 to, for example, access and utilize the network service 120. For example, as described in greater detail below, the e-reader device 110 can process acoustic signals received from the playback of the acoustic configuration file 102 in order to detect and process the set of configuration parameters 121. Once configured, the e-reader device 110 can utilize the set of configuration parameters 121 to access and utilize the network service 120.
According to some embodiments, the acoustic configuration file can be provided in the form of a music file or a voice file. In this way, the user can listen to audio content when outputting the acoustic configuration file on the mobile computing device 150. This allows for the user to listen to music or a voice message (e.g., notification message from the network service 120), while the acoustic signal output is further detected by the e-book device 110 and processed for configuration parameters.
In variations, the configuration parameters 121 can be provided to the e-reader device 110 for purpose of, for example, triggering the e-reader device 110 to perform diagnostics or corrective processes (e.g., de-bugging). As another variation, data sets and programmatic code can be signaled to the e-reader device 110 to facilitate diagnostic or corrective processes.
According to one aspect, the e-reader device 110 includes programmatic logic corresponding to a service interface 108 and an acoustic interface 118. The service interface 108 can communicate and link that device with the network service 120. The acoustic interface 118 can process acoustic signals received through the microphone of the e-reader device 110 for purpose of detecting information items that are embedded in the acoustic signal. In the example of
In some variations, the mobile computing device 150 serves as an intermediate device that receives the acoustic configuration file 102, and then play back the acoustic configuration file 102 in proximity to the e-reader device 110. In one implementation, the mobile computing device 150 can include a service interface 168 for communicating with the network service 120. The mobile computing device 150 can receive the acoustic configuration file 102 from the network service 120 via the service interface 168. In variations, the acoustic configuration file 102 can be received through a messaging interface, such as an e-mail program installed on the mobile computing device 150. Once the acoustic configuration file 102 is received, playback of the acoustic configuration file 102 can be initiated by the user. The mobile computing device 150 can be positioned in sufficient proximity to the e-reader device 110 so that the resulting acoustic signal is detectable by the microphone of the e-reader device 110.
In some embodiments, the mobile computing device 150 can generate additional acoustic data for inclusion in the acoustic configuration file 102. In one implementation, the mobile computing device 150 includes an acoustic interface 158. The mobile computing device 150 can operate to obtain additional information items for purpose of configuring the e-reader device 110, and then the acoustic interface 158 generates additional acoustic data that encodes the determined information. The mobile computing device 150 can determine the additional information items from the network service 120, using for example, network service interface 168. As an addition or variation, the mobile computing device 150 can determine the additional information items from user input. Still further, the mobile computing device 150 can implement processes to programmatically determine information items regarding, for example, local computing environment parameters (e.g. network settings) and other information. In this way, the mobile computing device 150 can utilize the acoustic interface 158 to append or augment the acoustic configuration file 102 with additional acoustic data determined on the mobile computing device 150.
Still further, while an example of
Hardware Description
In some implementations, the processor 210 utilizes the network interface 220 to communicate with the network service 120 (see
In some implementations, the display 230 can correspond to, for example, a liquid crystal display (LCD) or light emitting diode (LED) display that illuminates in order to provide content generated from processor 210. In some variations, the display 230 can be touch-sensitive.
According to some embodiments, the memory 250 stores instructions corresponding to logic for generating encoded acoustic output 253. As an intermediate device, the mobile computing device 200 can receive acoustic configuration file 102 from, for example, network service 120. The processor 210 can playback the acoustic configuration file 102 received through the network interface 220 (e.g., by email) to generate an output acoustic signal 203. The playback of the acoustic configuration file 102 can be performed in sufficient proximity to the end-user device 110 to enable detection of the acoustic signal 203 through the microphone of the end-user device 110.
Some variations provide for the processor 210 to utilize the acoustic output logic 253 to generate an encoded acoustic signal that contains information items that are obtained on the mobile computing device 150. The information items can be determined, for example, from the network service 120, or alternatively from the user providing input to the input mechanism 240 (e.g., user provides password or login information etc.). Additionally, some configuration parameters or information items can be programmatically determined from resources of the mobile computing device 200. By way of example, the programmatically determined information items can include local network settings, which any computing device may need in order to obtain network connectivity from within that local network. The determined information items can be encoded into output acoustic signal 203 using the acoustic output logic 253. As described with an example of
Additionally, in some variations, the mobile computing device 200 can receive an input acoustic signal 231 from the e-reader device 110 via the microphone 222. The e-reader device 200 can store the acoustic input signal 231 as a file in the memory 250, for purpose of communicating it to another computer or location (e.g., network service 120). In some variations, the processor 210 can implement acoustic interpretation logic to interpret the input acoustic signal 231. In such implementations, the processor 210 can store, for example, a data file or set in the memory 250 that represents decoded information determined from the input acoustic signal 231.
Acoustic Interface for Intermediate Device
In an embodiment, the acoustic interface 300 includes a data procurement subsystem 310, a data/sound conversion component 320, a data packager 330, and a playback component 340. The data procurement subsystem 310 provides processes for obtaining various kinds of information, such as account information with the network service, local computing environment information, and/or user preferences. In more detail, the data procurement subsystem 310 can include one or more components corresponding to a local determination process (or processes) 312, a retrieval process 314, and a network service interface 316. In this way, data procurement subsystem 310 can obtain configuration information 315 from one or more sources, including from local and/or network resources, depending on implementation.
The local determination process 312 can include one or more processes that determine information from the user and/or the local operating or network environment. For example, the local determination process 312 can obtain network settings for a local network given a particular environment at a given instance. The network settings can include, for example, the identifier the local network (e.g. SSID) and/or the encryption key or password for accessing the local network. The local determination process 312 can also implement prompts to trigger the user into entering information, such as account information for network service 120 (login and password etc.), payment information for purchasing resources from the network service 120), network settings, and/or other information such as preferences (e.g., desired device settings for the end-user device 110).
The retrieval process 314 can implement processes to retrieve account information from various account sources, including the network service 120, or alternatively other network services or websites. For example, the user can provide input (e.g., through local determination process 312) to specify a desired website and account information maintained for such websites. In one implementation, the retrieval process 314 can access network service 120 to retrieve account information and other information items maintained with the account 125 associated with the end-user device 110. This information can include the login and password, as well as for example, user preferences or other information. In a variation, the retrieval process 314 can utilize locally implemented interface processes 316, such as provided by a locally installed application, in order to obtain information items and other configuration parameters for accessing network service 120. For example, with reference to
The data procurement subsystem 310 can provide configuration information 315 to the data/sound conversion component 320. The data/sound conversion component 320 converts configuration information 315 into audio data 317, in accordance with an encoding scheme such as provided by OFDM or spread spectrum. In one implementation, the data/sound conversion component 320 generates frames of data that represent bytes of information corresponding to the configuration information 315. The audio data 317 can be encoded so as to represent the configuration information 315, and more specifically configuration parameters identified from the account information.
The data packager 330 processes the audio data 317 in order to package data 319. In particular, the packaged acoustic data 319 can be structured according to a predetermined format and protocol so that individual frames embedded in the acoustic signal carry bits of information. The data packager can optionally incorporate content, such as voice content or music with the packaged data 319. The acoustic configuration file 322 can be generated and/or maintained using the packaged acoustic data 319.
The playback component 340 can playback data from the acoustic configuration file 322. In particular, the playback component 340 can output an acoustic signal through the speaker 360 of the intermediate computing device such as shown by mobile computing device 150 in
In some implementations, the mobile computing device 150 receives the acoustic configuration file 322 from, for example, network service 120. For example, a network interface 318 of the intermediate computing device can receive and store the acoustic configuration file 322. The mobile computing device 150 can append or reconfigure the acoustic configuration file 322 using information locally obtained on the intermediate computing device. For example, one or more local determination processes 312 can obtain local network settings that are necessary for e-reader device 110 to achieve connectivity with network service 120.
In one implementation, audio data 317 corresponding to such configuration information 315 is appended or stitched onto an existing acoustic configuration file 322 (e.g., one that is received from the network service 120). The data packager 330 can analyze the data stream of the acoustic configuration file 322 to identify individual frames corresponding to bytes of information. When additional configuration data 315 is obtained by the mobile computing device 150, the data/sound conversion component generates the corresponding acoustic data 317. The data packager 330 can splice or append the data frames corresponding to the acoustic data 317 of the additional configuration information 315 onto the existing stream of the configuration file 322. In this way, the network service 120 can provide an acoustic configuration file 322 that includes some of the configuration parameters necessary for the end-user device 110 to access the network service. Another portion of the configuration parameters for the e-reader device 110 can be obtained locally by the mobile computing device 150 executing processes that obtain, for example, parameters for the local computing environment.
In variations, the mobile computing device 150 (acting as the intermediate device) can also obtain configuration parameters using (i) user input received from the user (e.g., user enters login and password), or (ii) from accessing the network service 120 through an independent connection. Such additional configuration parameters can also be stitched or appended onto the existing acoustic configuration file 322.
Methodology
With reference to an example of
The mobile computing device 150 can playback acoustic configuration file 102 in the vicinity of the e-reader device (420). The proximity of the mobile computing device 150 to the e-reader device 110 can be determined from the characteristics of the resulting acoustic signal generated from the acoustic configuration file 102. In one implementation, the acoustic signal is at an inaudible frequency (e.g., between 22.05 kHz and 100 kHz), but detectable through standard microphones. The vicinity between the mobile computing device 150 and the e-reader device 110 can be based in part on the amplitude of the acoustic signal, as well as a selected frequency and the level of ambient noise present. In one implementation, the mobile computing device 150 is positioned within 10 feet of the microphone of the e-reader device 110. In variations, the mobile computing device 150 is positioned within a foot, and more particularly, within a few inches of the microphone for the e-reader device 110, in order for the acoustic signal from the playback of the acoustic configuration file 102 to be detectable.
With reference to an example of
A set of configuration parameters can be determined based on the information (520). In particular, information items provided by the user can be parsed, then formatted and/or structured to have a form that is usable by a relevant programmatic entity or interface.
The mobile computing device 150 can generate an acoustic configuration file 102 that embeds the configuration parameters (530). For example, the acoustic configuration file 102 can embed (i) password and login information for accessing network service 120, (ii) preferred or desired device settings, and/or (iii) other information as obtained from one or more sources (e.g., network service, user) available to the mobile computing device 150. Once the acoustic configuration file 102 is determined, the mobile computing device 150 is able to play back the acoustic configuration file in the vicinity of the e-reader device 110 (540).
With reference to an example of
The mobile computing device 150 can also determine a second set of configuration parameters (620). The second set of configuration parameters can be determined from local processes and resources of the mobile computing device 150. For example, in one implementation, the mobile computing device 150 can determine settings for accessing and utilizing a local network (622). As another example, the mobile computing device 150 can issue a series of prompts that triggers the user into entering various kinds of input, such as credit card information, device preferences, etc (624).
The mobile computing device 150 can generate a second acoustic configuration file that embeds both the first and second set of configuration parameters (630). In one embodiment, the mobile computing device 150 processes the first acoustic configuration file 102 to determine the first set of configuration parameters, then generates the second acoustic configuration file to replace the first acoustic configuration file.
As a variation, the mobile computing device 150 can generate an acoustic configuration file for the second set of configuration parameters, then append or stitch the second acoustic configuration file to the first acoustic configuration file. For example, the data stream of the first acoustic configuration file can be analyzed to identify data frames representing information items. The frames for the acoustic data of the second configuration file can be stitched at the end of, or in between the frames of the first acoustic configuration file.
Embodiments recognize that on occasion, the purchase of a new device (e.g., e-reader device 110) can be a problematic phase with regards to establishing such devices for ongoing use for a particular user. With regard to the e-reader devices, for example, such devices are often linked to the network service from which e-books can be downloaded. Moreover, the functionality of such devices is significantly limited if the device cannot access the network service from where e-books (or other digital content items) can be downloaded or purchased. Thus, for example, the inability of the user to establish network connectivity, or establish a new account can significantly hinder the user's out-of-box enjoyment of the new device. Conversely, when such users seek help, conventional approaches can sometimes be problematic. If the user is unable to access a network and/or is unable to access a necessary network service, the ability of the manufacturer or provider to remotely troubleshoot the device is also limited.
Among other benefits, examples described herein, on the other hand, enable users to perform configuration processes to achieve network connectivity and/or access to the network service using resources that are typically available to any user. Additionally, the acts required of the user can be significantly simpler to perform than more conventional approaches. Under conventional approaches, for example, the user sometimes has to enter various network settings and/or account information when the user may have little familiarity with what is needed.
In some embodiments, the user can place a phone call to the help center (e.g., technical assistance line), then provide the help center with an e-mail address. The help center can determine configuration parameters for the user end-device, and then programmatically generate the acoustic configuration file 102 and send the acoustic configuration file to the user as an email. The user can select an intermediate device to access the email and to playback the acoustic configuration file 102. For example, the user can place the microphone of the e-reader device 110 adjacent to (or near) the speaker of the mobile computing device 150. The mobile computing device 150 can then playback the attachment in order to generate the acoustic signal for the e-reader device 110. Upon receiving the acoustic transmission, the e-reader device 110 can configure itself with necessary information such as network service login and password, so that the user is able to access the network service.
Additionally, in some variations, the e-reader device 110 can implement diagnostic or corrective processes in order to assist the help center with troubleshooting. For example, the mobile computing device 150 can output an acoustic signal that provides a data set to trigger the e-reader to execute a diagnostic process. Furthermore, the e-reader device 110 can return an acoustic response that can be communicated through the telephonic channel to the network service 120. The acoustic transmission returned from the e-reader device 110 can include information relating to the result of the diagnostic or corrective process. In this way, the e-reader device 110 can be configured, diagnosed, or corrected with transmission of acoustic signals.
As another illustration, rather than generate the acoustic transmission from the network service 120, the network service 120 can package the acoustic configuration file 102 as an attachment to a message. The message can be communicated to an email address provided by the user. The user can operate an intermediate device, such as their mobile handset (e.g., mobile computing device 150), to output the acoustic configuration file 102 in proximity to the e-reader device 110. In turn, the e-reader device 110 can configure itself with configuration parameters and other information items embedded in the acoustic transmission.
Alternatives or Variations
As an alternative or variation, an audio configuration file such as described with various examples herein can be provided in the form of a media file. Thus, for example, audio-visual content can include acoustic configuration parameters that are detectable to, for example, an end-device. A user can playback the media file to receive audio/video content on, for example, the mobile computing device 150, while at the same time, the user can have the e-reader device detect and process configuration parameters in the detectable audio signal. As mentioned in some other examples, the encoding of the audio signal can use either in-audio-range or out-of-audio range frequencies.
In variations, the mobile computing device 150 can output video content that includes visual encoding. For example, the display of the mobile computing device 150 can output visual encoding, and a camera component of the e-reader device can detect codes embedded in the visual output. The visual encoding scheme can utilize, for example, still images, moving pictures, or QR codes. In particular, the camera can detect visual information that can be processed for configuration parameters.
Although illustrative embodiments have been described in detail herein with reference to the accompanying drawings, variations to specific embodiments and details are encompassed by this disclosure. It is intended that the scope of embodiments described herein be defined by claims and their equivalents. Furthermore, it is contemplated that a particular feature described, either individually or as part of an embodiment, can be combined with other individually described features, or parts of other embodiments. Thus, absence of describing combinations should not preclude the inventor(s) from claiming rights to such combinations.