Sounds may persist after production in a process known as reverberation, which is caused by reflection of the sound in an environment. For example, speech may be generated by users within a room, outdoors, and so on. After the users speak, the speech is reflected off of objects in the user's environment, and therefore may arrive at different points in time to a sound capture device, such as a microphone. Accordingly, the reflections may cause the speech to persist even after it has stopped being spoken, which is noticeable to a user as noise.
Speech enhancement techniques have been developed to remove this reverberation, in a process known as dereverberation. Conventional dereverberation techniques, however, had difficulty in recognizing dereverberation as well as had a reliance on known priors describing the sound, the environment in which the sound is captured, and so on. Consequently, these conventional dereverberation techniques often failed as this prior knowledge is not often practically available.
Sound enhancement techniques through dereverberation are described. In one or more implementations, a method is described of enhancing sound data through removal of reverberation from the sound data by one or more computing devices. The method includes obtaining a model that describes primary sound data that is to be utilized as a prior that assumes no prior knowledge about specifics of the sound data from which the reverberation is to be removed. A reverberation kernel is computed having parameters that, when applied to the model that describes the primary sound data, corresponds to the sound data from which the reverberation is to be removed. The reverberation is removed from the sound data using the reverberation kernel.
In one or more implementations, a method is described of enhancing sound data through removal of noise from the sound data by one or more computing devices. The method includes generating a model using non-negative matrix factorization (NMF) that describes primary sound data, estimating additive noise and a reverberation kernel having parameters that, when applied to the model that describes the primary sound data, corresponds to the sound data from which the reverberation is to be removed, and removing the additive noise from the sound data based on the estimating and the reverberation from the sound data using the reverberation kernel.
In one or more implementations, a system is described of enhancing sound data through removal of reverberation from the sound data. The system includes a model generation module implemented at least partially in hardware to generate a model that describes primary sound data that is to be utilized as a prior that assumes no prior knowledge about specifics of the sound data from which the reverberation is to be removed. The system also includes a reverberation estimation module implemented at least partially in hardware to compute a reverberation kernel having parameters that, when applied to the model that describes the primary sound data, corresponds to the sound data from which the reverberation is to be removed. The system further includes a noise removal module implemented at least partially in hardware to remove the reverberation from the sound data using the reverberation kernel.
This Summary introduces a selection of concepts in a simplified form that are further described below in the Detailed Description. As such, this Summary is not intended to identify essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
The detailed description is described with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different instances in the description and the figures may indicate similar or identical items. Entities represented in the figures may be indicative of one or more entities and thus reference may be made interchangeably to single or plural forms of the entities in the discussion.
Inclusion of reverberation within a recording of sound is readily noticeable to users, such as reflections of sound involving a cathedral effect, and so on. Additionally, differences in reverberation are also readily noticeable to users, such as differences in reverberation as it occurs outside due to reflection off of trees and rocks as opposed to reflections involving furniture and walls within an indoor environment. Accordingly, inclusion of reverberation in sound may interfere with desired sounds (e.g., speech) within a recording, in an ability to splice recordings together, and so on. Conventional techniques involving dereverberation and thus removal of reverberation from a recording of sound, however, require use of speaker-dependent and/or environment dependent training data, which is typically not available in practical situations. As such, these conventional techniques typically fail in these situations.
Sound enhancement techniques through dereverberation are described. In one or more implementations, a model is pre-learned from clean primary sound data (e.g., speech) and thus does not include noise. The model is learned offline and may use sound data that is different from the sound data that is to be enhanced. In this way, the model does not assume prior knowledge about specifics of the sound data from which the reverberation is to be removed, e.g., particular speakers, an environment in which the sound data is captured, and so forth.
The model is then used to learn a reverberation kernel through comparison with sound data from which reverberation is to be removed. Thus, the reverberation kernel is learned through use of the model to approximate the sound data being processed. This technique may also be used to estimate additive noise included in the sound data. The reverberation kernel and the estimate of additive noise are then used to enhance the sound data through removal (e.g., reduction of part) of reverberation and the estimated additive noise. In this way, the sound data may be enhanced without use of prior knowledge about particular speakers or an environment and thus overcome limitations of conventional techniques. Further discussion of these and other examples are described in the following sections and shown in corresponding figures.
In the following discussion, an example environment is first described that may employ the techniques described herein. Example procedures are then described which may be performed in the example environment as well as other environments. Consequently, performance of the example procedures is not limited to the example environment and the example environment is not limited to performance of the example procedures.
The computing device 102, for instance, may be configured as a desktop computer, a laptop computer, a mobile device (e.g., assuming a handheld configuration such as a tablet or mobile phone), and so forth. Thus, the computing device 102 ranges from full resource devices with substantial memory and processor resources (e.g., personal computers, game consoles) to a low-resource device with limited memory and/or processing resources (e.g., mobile devices). Additionally, although a single computing device 102 is shown, the computing device 102 is also representative of a plurality of different devices, such as multiple servers utilized by a business to perform operations “over the cloud” as further described in relation to
The sound capture device 104 may also be configured in a variety of ways. Illustrated examples of one such configuration involves a standalone device but other configurations are also contemplated, such as part of a mobile phone, video camera, tablet computer, part of a desktop microphone, array microphone, and so on. Additionally, although the sound capture device 104 is illustrated separately from the computing device 102, the sound capture device 104 is configurable as part of the computing device 102, the sound capture device 104 may be representative of a plurality of sound capture devices, and so on.
The sound capture device 104 is illustrated as including a sound capture module 106 that is representative of functionality to generate sound data 108. The sound capture device 104, for instance, may generate the sound data 108 as a recording of an environment 110 surrounding the sound capture device 104 having one or more sound sources. This sound data 108 may then be obtained by the computing device 102 for processing.
The computing device 102 is also illustrated as including a sound processing module 112. The sound processing module 112 is representative of functionality to process the sound data 108. Although illustrated as part of the computing device 102, functionality represented by the sound processing module 112 may be further divided, such as to be performed “over the cloud” by one or more servers that are accessible via a network 114 connection, further discussion of which may be found in relation to
An example of functionality of the sound processing module 112 is represented as a sound enhancement module 116. The sound enhancement module 116 is representative of functionality to enhance the sound data 108, such as through removal of reverberation through use of a reverberation kernel 118, removal of additive noise through use of an additive noise estimate 120, and so on to generate enhanced sound data 122.
The sound data 108, for instance, may be captured in a variety of different audio environments 110, illustrated examples of which include a presentation, concert hall, and stadium. Objects included in these different environments may introduce different amounts and types of reverberation due to reflection of sound off different objects included in the environments. Further, these different environments may also introduce different types and amounts of additive noise, such as a background noise, weather conditions, and so forth. The sound enhancement module 116 may therefore estimate the reverberation kernel 118 and the additive noise estimate 120 to remove the reverberation and the additive noise from the sound data 108 to generate enhanced sound data 122, further discussion of which is described in the following and shown in a corresponding figure.
In this example, the primary sound data 204 is clean and thus includes minimal to no noise or other artifacts. In this way, the primary sound data 204 is an accurate representation of desired sound data and thus so too the model 202 provides an accurate representation of this sound data. The model generation module 206 may employ a variety of different techniques to generate the model 202, such as through probabilistic techniques including non-negative matrix factorization (NMF) as further described below, a product-of-filters model, and so forth.
As previously described, the model 202 is generated to act as a prior that does not assume prior knowledge of the sound data 108, e.g., speakers, environments, and so on. As such, the primary sound data 204 may have different speakers or other sources, captured in different environments, and so forth than the sound data 108 that is to be enhanced by the sound enhancement module 116.
The sound enhancement module 116 is illustrated as including a reverberation estimation module 204 and an additive noise estimation module 210. The reverberation estimation module 208 is representative of functionality to generate a reverberation kernel 118. For example, the reverberation estimation module 208 takes as an input the model 202 that describes primary and thus desired sound data and also takes as an input the sound data 108 that is to be enhanced. The reverberation estimation module 208 then estimates a reverberation kernel 118 in a manner such that a combination of the reverberation kernel 118 and the model 202 corresponds to (e.g., mimics, approximates) the sound data 108. Thus, the reverberation kernel 118 represents the reverberation in the sound data 108 and is therefore used by a noise removal module 212 to remove and/or lessen reverberation from the sound data 108 to generate the enhanced sound data 122.
Likewise, the additive noise estimation module 210 is configured to generate an additive noise estimate 120 of additive noise included in the sound data 108. For example, the additive noise estimation module 210 takes an inputs the model 202 that describes primary and thus desired sound data and the sound data 108 that is to be enhanced. The additive noise estimation module 210 then estimates an additive noise estimate 120 in a manner such that a combination of the additive noise estimate 120 and the model 202 corresponds (e.g., mimics, approximates) the sound data 108. Thus, the additive noise estimate 120 represents the additive noise in the sound data 108 and may therefore be used by a noise removal module 212 to remove and/or lessen an amount of additive noise in the sound data 108 to generate the enhanced sound data 122.
In this way, the sound enhancement module 116 dereverberates and removes other noise (e.g., additive noise) from the sound data 108 to produce enhanced sound data 122 without any prior knowledge of or assumptions about specific speakers or environments in which the sound data 108 is captured. In the following, a general single-channel speech dereverberation techniques is described based on an explicit generative model of reverberant and noisy speech.
To regularize the model, a pre-learned model 202 of clean primary sound data 204 is used as a prior to perform posterior inference over latent clean primary sound data 204, which is speech in the following but other examples are also contemplated. The reverberation kernel 118 and additive noise estimate 120 are estimated under a maximum-likelihood framework through use of a model 202 that treats the underlying clean speech as a set of latent variables. Thus, the model 202 is fit beforehand to a corpus of clean speech and is used as a prior to arrive at these variables, regularizing the model 202 and making it possible to solve an otherwise underdetermined dereverberation problem using a maximum-likelihood framework to compute the reverberation kernel 118 and the additive noise estimate 120.
In this way, the model 202 is capable of suppressing reverberation without any prior knowledge of or assumptions about the specific speakers or rooms and consequently can automatically adapt to various reverberant and noisy conditions. Example results in the following on both simulated and real data show that these techniques can work on speech or other primary sound data that is quite different than that used to train the model 202. Specifically, it is shown that a model of North American English speech can be very effective on British English speech.
Notational conventions are employed in the following discussion such that upper case bold letters (e.g. Y, X, and R) denote matrices and lower case bold letters (e.g., y, , λ, and r) denote vectors. A value “f∈{1, 2, . . . , F}” is used to index frequency, a value “t∈{1, 2, . . . , T}” is used to index time, and a value “k∈{1, 2, . . . , K}” is used to index latent components in the pre-learned speech model 202, e.g., NMF model. The value “l∈{0, . . . , L−1}” is used to index lags in time.
Given magnitude spectra (also referred to simply as “spectra” in the following) of reverberant speech “Y∈+F×T,” the general dereverberation model is formulated as follows:
Yft˜P(ΣlXf,t-lRft+λf)Xft˜S(θ) (1)
In the above expression, “P(·)” encodes the observational model and “S (·)” encodes the speech model. In the following, “P(·)” is a Poisson distribution, which corresponds to a generalized Kullback-Leibler divergence loss function.
The model parameter “R∈+F×L” defines a reverberation kernel and “λ∈+F” defines the frequency-dependent additive noise, e.g., stationary background noise or other noise. The latent random variables “X∈+F×T” represent the spectra of clean speech. The pre-learned speech model “S (·),” parametrized by “θ,” acts as a prior that encourages “X” to resemble clean speech. The inference algorithm is used to uncover “X,” and incidentally to estimate “R” and “λ” from the observed reverberant spectra “Y.” An assumption may be made that the reverberant effect comes from a patch of spectra R instead of a single spectrum, and thus the model is capable of capturing reverberation effects that span multiple analysis windows.
A variety of different techniques may be used to form the model 202 by the model generation module 206. For example, non-negative matrix factorization (NMF) has been used in many speech-related applications, including denoising and bandwidth expansion. Here, a probabilistic version of NMF is used with exponential likelihoods, which corresponds to minimizing the Itakura-Saito divergence. Concretely, the model is formulated as follows:
Y
ft˜Poisson(ΣlXf,t-lRfl+λf)
X
ft˜Exponential(cΣkWfkHkt)
W
fk˜Gamma(a, a), Hkt˜Gamma(b, b) (2)
In the above, “a” and “b” are model hyperparameters and “c” is a free scale parameter that is tuned to maximize a likelihood of “Y.” The value “Xf,t-1” is a matrix, “Rfl” is reverb and “λf” is additive noise. For the latent components “W∈+F×K,” an assumption is made that the posterior distribution “q(W|Xclean)” has been estimated from clean speech. Therefore, the posterior is computed over the clean speech “X” as well as the weights “H∈+K×T” which are denoted as “p(X, H|Y).”
To estimate the reverberation kernel “R” and additive noise “λ,” the likelihood of “p(Y|R, λ)” is maximized by marginalizing out latent random variables “X” and “H,” which yields an instance of an expectation/maximization (EM) algorithm.
In the expectation step, the posterior “p(X, H|Y)” is computed using a current value of model parameters. However, this is intractable to compute due to the non-conjugacy of the model. Accordingly, this is approximated in this example via variational inference by choosing the following variational distribution:
q(X,H)=Πt(Πfq(Xƒt))Πkq(Hkt)
q(Xft)=Gamma(Xft; νftX, ρftX)
q(Hkt)=GIG(Hkt; νktH, ρktH, τktH) (3)
GIG denotes the generalized inverse-Gaussian distribution, an exponential-family distribution with the following density:
for “≧0, ρ≧0, and τ≧0.Kν(·)” denotes a modified Bessel function of the second kind. Using the GIG distribution for “q(Hkt)” supports tuning of “q(H)” using closed-form updates.
The variational parameters “{νX, ρX}” and “{νH, ρH, τH}” are tuned such that the Kullback-Leibler divergence between the variational distribution q(X,H) and the true posterior q(X, H|Y) is minimized. This is equivalent to maximizing the following variational objective, in which “St∈+F×L be a patch X[t-L+1:t])”:
The expectations in the first and second terms cannot be computed analytically. However, the lower bounds may be computed on both of them. For the first term, Jensen's inequality is applied and auxiliary variables “φftλ≧0 and φftlR≧0” are introduced where “φftλ+ΣtφftlR=1.” For the second term, auxiliary variables “φftkX≧0 where ΣkφftkX=1 and ωft<0” are introduced to determine the bound. The lower bound of the variational objective in Equation 5 is computed as follows:
where “AΓ(·)” and “AGIG(·)” denote the log-partition functions for gamma and GIG distributions, respectively. Optimizing over “φ's” with Lagrangian multipliers, the bound for the first term in Equation 5 is tightest when:
Similarly, an optimization may be performed over “φftkX” and “ωft” and tighten the bound on the second term as follows:
Given the lower bound in Equation 6, “” is maximized using coordinate ascent, iteratively optimizing each variational parameter while holding each of the other parameters fixed. To update “{νtX, ρtX}” by taking the derivative of “” and setting it to 0, the following is utilized:
Similarly, the derivative of “” with respect to “{νtH, ρtH, τtH}” equals zero and “” is maximized when:
Each time the value of variational parameters changes, the scale “c” is updated accordingly:
Finally, the expectations are as follows, in which ψ(·) is the digamma function:
In the maximization step, given the approximated posterior estimated from the expectation step, the derivative of “” is taken with respect to “λ” and “R” and the following updates are obtained:
The overall variational EM algorithm alternates between two steps. In the expectation step, the speech model attempts to explain the observed spectra as a mixture of clean speech, reverberation, and noise. In particular, it updates its beliefs about the latent clean speech via updating the variational distribution “q(X).” In the maximization step, the model updates its estimate of the reverberation kernel and additive noise given its current beliefs about the clean speech.
A speech model that is considered “good” assigns high probability to clean speech and lower probability to speech corrupted with reverberation and additive noise. The full model therefore has an incentive to explain reverberation and noises using the reverberation kernel and additive noise parameters, rather than considering them part of the clean speech. In other words, the model tries to “explain away” reverberation and noise and leave behind corresponding spectra.
By iteratively performing the expectation and maximization steps, a stationary point of the objective “” is reached. To obtain the dereverbed spectra, the expectation of “X” is taken under the variational distribution. To recover time-domain signals, Wiener filter based approach is taken on the estimated dereverbed spectra “q[X].” In practice, however, it has been noticed that the Wiener filter aggressively takes energy from the complex spectra due to the crudeness of the estimated dereverbed spectra and produces artifacts. Accordingly, in one or more implementations a simple heuristic is applied to smooth “q[X]” by convolving it with an attenuated reverberation kernel “R*,” where “R*f,0=Rf,0 and R*f,l=αRfl for l∈{1, . . . , L−1}. α∈(0,1)” controls the attenuation level to attenuate a tail of the reverberation, which may be used to smooth over artifacts to sound natural.
The speech model “(·)” may take a variety of other forms, such as a Product-of-Filters (PoF) model. The PoF model uses a homomorphic filtering approach to audio and speech signal processing and attempts to decompose the log-spectra into a sparse and non-negative linear combination of “filters”, which are learned from data. Incorporating the PoF model into the framework defined in Equation 1 is straightforward:
Y
ft˜Poisson(ΣlXf,t-lRft+λf)
X
ft˜Gamma(λf, λf Πk exp{−UfkHkt})
H
kt˜Gamma(αk, αk) (14)
where the filters “U∈F×K,” sparsity level “α∈+K,” and frequency-dependent noise-level “γ∈+F” are the PoF parameters learned from clean speech. The expression “H∈+K×T” denotes the weights of linear combination of filters. The inference can be carried out in a similar way as described above. In one or more implementations, an assumption of independence between frames of sound data is relaxed by imposing temporal structure to the speech model, e.g. with a nonnegative hidden Markov model or a recurrent neural network.
In the following, example sound data 108 is obtained from two sources. One is simulated reverberant and noisy speech, which is generated by convolving clean utterances with measured room impulse responses and then adding measured background noise signals. The other is a real recording in a meeting room environment.
For simulated data, three rooms with increasing reverberation lengths (e.g., T60's of the three rooms are 0.25 s, 0.5 s, 0.7 s, respectively) are used. For each room, two microphone positions (near and far) are adopted, which in total provides six different evaluation conditions. In the real recording, the meeting room has a measured T60 of 0.7 s.
Speech enhancement techniques may be evaluated by several metrics, including cepstrum distance (CD), log-likelihood ratio (LLR), frequency-weighted segmental SNR (FWSegSNR), and speech-to-reverberation modulation energy ratio (SRMR). For real recordings, the non-intrusive SRMR is used.
Since the techniques described herein may process each utterance separately without relying on any particular test condition, these techniques are compared with other utterance-based approaches. Two exponential NMF speech models with K=50 are used as the priors used in the dereverberation algorithm, one is from the clean training corpus of British English and the other is from a corpus of American English. In the STFT, a 1024-sample window is used with 512-sample overlap. Model hyper-parameters “α=b=0.1,” reverberation kernel length “L=20” (i.e., 640 ms), and attenuation level “α=0.1” are used.
The speech enhancement results are summarized in
At first glance, the results 302, 402, 502, 602 do not stand out when the reverberant effect is relatively small, e.g., Room 1. However, as “T60” increases, results improve regardless of microphone position.
It is also noted that the techniques described herein perform equally well when using a speech model trained on American English speech and tested on British English speech. That is, the performance is competitive with the state of the art even when training data is not utilized. This robustness to training-set-test-set mismatch allows the techniques described herein to be used in real-world applications where little to no prior knowledge about the specific people who are speaking or the room that is coloring their speech is available. The ability to do without speaker/room-specific clean training data may also explain the superior performance of the techniques on the real recording.
In the above, a general single-channel speech dereverberation model is described, which follows the generative process of the reverberant and noisy speech. A speech model, learned from clean speech, is used as a prior to properly regularize the model. NMF is adapted as a particular speech model into the general algorithm and used to derive an efficient closed-form variational EM algorithm to perform posterior inference and to estimate reverberation and noise parameters. These techniques may also be extended, such as to incorporate a temporal structure, utilize Stochastic variational inference to perform real-time/online dereverberation, and so on. Further discussion of these and other techniques is described in relation to the following procedures and is shown in a corresponding figures.
The following discussion describes dereverberation and additive noise removal techniques that may be implemented utilizing the previously described systems and devices. Aspects of each of the procedures may be implemented in hardware, firmware, or software, or a combination thereof The procedures are shown as a set of blocks that specify operations performed by one or more devices and are not necessarily limited to the orders shown for performing the operations by the respective blocks. In portions of the following discussion, reference will be made to
A reverberation kernel is computed having parameters that, when applied to the model that describes the primary sound data, corresponds to the sound data from which the reverberation is to be removed (block 704). Likewise, additive noise is estimated having parameters that, when applied to the model that describes the primary sound data, corresponds to the sound data from which the additive noise is to be removed (block 706). Continuing with the previous example, the reverberation kernel 118 is estimated such that a combination of the reverberation kernel 118 and the model 202 approximates the sound data to be processed. Similar techniques are used by the additive noise estimation module 210 to arrive at the additive noise estimate 120.
The reverberation is removed from the sound data using the reverberation kernel (block 708) and the additive noise is removed using the estimate of additive noise (block 710). In this way, enhanced sound data 122 is generated without use of prior knowledge as is required using conventional techniques.
Additive noise and a reverberation kernel are estimated having parameters that, when applied to the model that describes the primary sound data, corresponds to the sound data from which the reverberation is to be removed (block 804). As before, the model 202 is used by the sound enhancement module 116 to estimate a reverberation kernel 118 and an additive noise estimate 120, e.g., background or other noise. The additive noise is then removed from the sound data based on the estimate and the reverberation is removed from the sound data using the reverberation kernel (block 806). A variety of other examples are also contemplated, such as to configure the model 202 as a product-of-filters.
The example computing device 902 as illustrated includes a processing system 904, one or more computer-readable media 906, and one or more I/O interface 908 that are communicatively coupled, one to another. Although not shown, the computing device 902 may further include a system bus or other data and command transfer system that couples the various components, one to another. A system bus can include any one or combination of different bus structures, such as a memory bus or memory controller, a peripheral bus, a universal serial bus, and/or a processor or local bus that utilizes any of a variety of bus architectures. A variety of other examples are also contemplated, such as control and data lines.
The processing system 904 is representative of functionality to perform one or more operations using hardware. Accordingly, the processing system 904 is illustrated as including hardware element 910 that may be configured as processors, functional blocks, and so forth. This may include implementation in hardware as an application specific integrated circuit or other logic device formed using one or more semiconductors. The hardware elements 910 are not limited by the materials from which they are formed or the processing mechanisms employed therein. For example, processors may be comprised of semiconductor(s) and/or transistors (e.g., electronic integrated circuits (ICs)). In such a context, processor-executable instructions may be electronically-executable instructions.
The computer-readable storage media 906 is illustrated as including memory/storage 912. The memory/storage 912 represents memory/storage capacity associated with one or more computer-readable media. The memory/storage component 912 may include volatile media (such as random access memory (RAM)) and/or nonvolatile media (such as read only memory (ROM), Flash memory, optical disks, magnetic disks, and so forth). The memory/storage component 912 may include fixed media (e.g., RAM, ROM, a fixed hard drive, and so on) as well as removable media (e.g., Flash memory, a removable hard drive, an optical disc, and so forth). The computer-readable media 906 may be configured in a variety of other ways as further described below.
Input/output interface(s) 908 are representative of functionality to allow a user to enter commands and information to computing device 902, and also allow information to be presented to the user and/or other components or devices using various input/output devices. Examples of input devices include a keyboard, a cursor control device (e.g., a mouse), a microphone, a scanner, touch functionality (e.g., capacitive or other sensors that are configured to detect physical touch), a camera (e.g., which may employ visible or non-visible wavelengths such as infrared frequencies to recognize movement as gestures that do not involve touch), and so forth. Examples of output devices include a display device (e.g., a monitor or projector), speakers, a printer, a network card, tactile-response device, and so forth. Thus, the computing device 902 may be configured in a variety of ways as further described below to support user interaction.
Various techniques may be described herein in the general context of software, hardware elements, or program modules. Generally, such modules include routines, programs, objects, elements, components, data structures, and so forth that perform particular tasks or implement particular abstract data types. The terms “module,” “functionality,” and “component” as used herein generally represent software, firmware, hardware, or a combination thereof. The features of the techniques described herein are platform-independent, meaning that the techniques may be implemented on a variety of commercial computing platforms having a variety of processors.
An implementation of the described modules and techniques may be stored on or transmitted across some form of computer-readable media. The computer-readable media may include a variety of media that may be accessed by the computing device 902. By way of example, and not limitation, computer-readable media may include “computer-readable storage media” and “computer-readable signal media.”
“Computer-readable storage media” may refer to media and/or devices that enable persistent and/or non-transitory storage of information in contrast to mere signal transmission, carrier waves, or signals per se. Thus, computer-readable storage media refers to non-signal bearing media. The computer-readable storage media includes hardware such as volatile and non-volatile, removable and non-removable media and/or storage devices implemented in a method or technology suitable for storage of information such as computer readable instructions, data structures, program modules, logic elements/circuits, or other data. Examples of computer-readable storage media may include, but are not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, hard disks, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or other storage device, tangible media, or article of manufacture suitable to store the desired information and which may be accessed by a computer.
“Computer-readable signal media” may refer to a signal-bearing medium that is configured to transmit instructions to the hardware of the computing device 902, such as via a network. Signal media typically may embody computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier waves, data signals, or other transport mechanism. Signal media also include any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media.
As previously described, hardware elements 910 and computer-readable media 906 are representative of modules, programmable device logic and/or fixed device logic implemented in a hardware form that may be employed in some embodiments to implement at least some aspects of the techniques described herein, such as to perform one or more instructions. Hardware may include components of an integrated circuit or on-chip system, an application-specific integrated circuit (ASIC), a field-programmable gate array (FPGA), a complex programmable logic device (CPLD), and other implementations in silicon or other hardware. In this context, hardware may operate as a processing device that performs program tasks defined by instructions and/or logic embodied by the hardware as well as a hardware utilized to store instructions for execution, e.g., the computer-readable storage media described previously.
Combinations of the foregoing may also be employed to implement various techniques described herein. Accordingly, software, hardware, or executable modules may be implemented as one or more instructions and/or logic embodied on some form of computer-readable storage media and/or by one or more hardware elements 910. The computing device 902 may be configured to implement particular instructions and/or functions corresponding to the software and/or hardware modules. Accordingly, implementation of a module that is executable by the computing device 902 as software may be achieved at least partially in hardware, e.g., through use of computer-readable storage media and/or hardware elements 910 of the processing system 904. The instructions and/or functions may be executable/operable by one or more articles of manufacture (for example, one or more computing devices 902 and/or processing systems 904) to implement techniques, modules, and examples described herein.
The techniques described herein may be supported by various configurations of the computing device 902 and are not limited to the specific examples of the techniques described herein. This functionality may also be implemented all or in part through use of a distributed system, such as over a “cloud” 914 via a platform 916 as described below.
The cloud 914 includes and/or is representative of a platform 916 for resources 918. The platform 916 abstracts underlying functionality of hardware (e.g., servers) and software resources of the cloud 914. The resources 918 may include applications and/or data that can be utilized while computer processing is executed on servers that are remote from the computing device 902. Resources 918 can also include services provided over the Internet and/or through a subscriber network, such as a cellular or Wi-Fi network.
The platform 916 may abstract resources and functions to connect the computing device 902 with other computing devices. The platform 916 may also serve to abstract scaling of resources to provide a corresponding level of scale to encountered demand for the resources 918 that are implemented via the platform 916. Accordingly, in an interconnected device embodiment, implementation of functionality described herein may be distributed throughout the system 900. For example, the functionality may be implemented in part on the computing device 902 as well as via the platform 916 that abstracts the functionality of the cloud 914.
Although the invention has been described in language specific to structural features and/or methodological acts, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as example forms of implementing the claimed invention.