The present application is related to patent application Ser. No. 11/840,416 titled “Method and Apparatus for Performing Audio Ducking”, filed on even date herewith, and which is incorporated herein by reference in its entirety.
Audio mixing is used for sound recording, audio editing, and sound systems to balance the relative volume, frequency, and dynamical content of a number of sound sources. Typically, these sound sources are the different musical instruments in a band or vocalists, the sections of an orchestra, announcers and journalists, crowd noises, and so on.
Sometimes audio mixing is done live by a sound engineer or recording engineer, for example at rock concerts and other musical performances where a public address system (PA) is used. Audio mixing may also be done in studios as part of multi-track recording in order to produce digital or analog audio recordings, or as part of an album, film, or television program. An audio mixing console, or mixing desk, or mixing board, has numerous rotating controls (potentiometers) and sliding controls (faders which are also potentiometers) that are used to manipulate the volume, the addition of effects such as reverb, and frequency content (equalization) of audio signals. On most consoles, all the controls that apply to a single channel of audio are arranged in a vertical column called a channel strip. Larger and more complex consoles such as those used in film and television production can contain hundreds of channel strips. Many consoles today, regardless of cost, have automation capabilities so the movement of their controls is performed automatically, not unlike a player piano.
Certain terms used herein will now be defined. RMS (root means square) is a level value based upon the energy that is contained in a given audio signal. Peak value describes the instantaneous maximum amplitude value within one period of the signal concerned. DAW (digital audio workstation) is a software environment used to record, edit and mix audio files. Crest factor is the peak/RMS ratio. Loudness Unit (LU) is a unit that considers the perceived loudness of an audio signal regarding duration and frequency weighting. Keyframes are level changes in an audio track, and wherein the slope of the change or the time required to transition from one level to another can be adjusted.
Conventional mechanisms such as those explained above suffer from a variety of deficiencies. One such deficiency is that the visual designer is collecting all his video and audio files within a timeline application (e.g., Premiere Pro® available from Adobe Systems, Incorporated of San Jose, Calif.) and facing the problem that the entire audio “sequence” has to be mixed. The visual designer may be well versed regarding video editing and processing, but may be much less so when it comes to audio mixing. The usual approach is to set all audio tracks to more or less static values, some more experienced people do some mixing via keyframe setting and adjustment. Fades with program pending fade curves only happen occasionally.
Most timeline applications provide a wide variety tools to mix audio but the average user has no clue how to use all the functionality (knobs and faders, keyframe functionality, etc.) implemented in an application. Conventional time line based applications do not offer audio mixing suggestion to the user. The knobs and faders are set to default values, the user has to set all audio level changes manually, in other words, the user has to mix the audio (for example by changing controls or setting keyframe values). Not only does the mixing have to be done manually by the user, but further the clip volumes are adjusted relatively to each other, and fades for transitions are manually added. This process tends to be cumbersome and time consuming.
Embodiments of the invention significantly overcome such deficiencies and provide mechanisms and techniques that automatically mix complex audio structures within a timeline based application like a Digital Audio Workstation (DAW) or Video Editing Application.
A “Foreground/Background” metaphor is utilized as part of the mixing technique. The method incorporates user information about “prominent” (Foreground) and “non-prominent” (Background) audio that is best explained with mixing a documentary or a movie trailer where the narrator/voice-over is the important component (Foreground) of the audio mix while the remainder of the audio clips comprises the background. The method, however, is not limited to only having foreground/background and in general can be extended to any number of N priorities. A higher priority always keys or controls a lower priority.
In a particular embodiment of a method for providing intelligent audio mixing, a plurality of audio tracks are displayed in a user interface, each track of the plurality of tracks including at least one audio clip. The user designates each audio clip as either a foreground clip or a background clip. The foreground clips are analyzed and equalized level-wise to have the same perceived loudness thereafter. The background clips are analyzed and a loudness distance value between the loudness corrected foreground clips (equal loudness) and the background clips is defined. Dependent on the computed loudness distance keyframes are generated and added to some of the audio clips, thereby providing a fade between levels of the background clips to take into account the loudness corrected foreground clips.
Other embodiments include a computer readable medium having computer readable code thereon for providing audio mixing. The computer readable medium includes instructions for displaying a plurality of tracks in a user interface, each track of the plurality of tracks including at least one audio clip. The computer readable medium also includes instructions for receiving a designation for each audio clip into one of a foreground clip and a background clip. Further, the computer readable medium includes instructions for analyzing and loudness correcting the foreground clips and instructions for analyzing the background clips and defining a loudness distance value between the loudness corrected foreground clips and the background clips. Additionally, the computer readable medium includes instructions for generating and adding keyframes dependent on the computed loudness distance to some of the audio clips, the keyframes providing a fade between levels of the background clips to take into account the loudness corrected foreground clips and instructions for providing a sequenced audio file from the loudness corrected foreground clips, the background clips and the keyframes.
Still other embodiments include a computerized device, configured to process all the method operations disclosed herein as embodiments of the invention. In such embodiments, the computerized device includes a memory system, a processor, communications interface in an interconnection mechanism connecting these components. The memory system is encoded with a process that provides audio mixing as explained herein that when performed (e.g. when executing) on the processor, operates as explained herein within the computerized device to perform all of the method embodiments and operations explained herein as embodiments of the invention. Thus any computerized device that performs or is programmed to perform up processing explained herein is an embodiment of the invention.
Other arrangements of embodiments of the invention that are disclosed herein include software programs to perform the method embodiment steps and operations summarized above and disclosed in detail below. More particularly, a computer program product is one embodiment that has a computer-readable medium including computer program logic encoded thereon that when performed in a computerized device provides associated operations providing audio mixing as explained herein. The computer program logic, when executed on at least one processor with a computing system, causes the processor to perform the operations (e.g., the methods) indicated herein as embodiments of the invention. Such arrangements of the invention are typically provided as software, code and/or other data structures arranged or encoded on a computer readable medium such as an optical medium (e.g., CD-ROM), floppy or hard disk or other a medium such as firmware or microcode in one or more ROM or RAM or PROM chips or as an Application Specific Integrated Circuit (ASIC) or as downloadable software images in one or more modules, shared libraries, etc. The software or firmware or other such configurations can be installed onto a computerized device to cause one or more processors in the computerized device to perform the techniques explained herein as embodiments of the invention. Software processes that operate in a collection of computerized devices, such as in a group of data communications devices or other entities can also provide the system of the invention. The system of the invention can be distributed between many software processes on several data communications devices, or all processes could run on a small set of dedicated computers, or on one computer alone.
It is to be understood that the embodiments of the invention can be embodied strictly as a software program, as software and hardware, or as hardware and/or circuitry alone, such as within a data communications device. The features of the invention, as explained herein, may be employed in data communications devices and/or software systems for such devices such as those manufactured by Adobe Systems Incorporated of San Jose, Calif.
The foregoing will be apparent from the following more particular description of preferred embodiments of the invention, as illustrated in the accompanying drawings in which like reference characters refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention.
Embodiments of the presently disclosed method and apparatus provide an audio mix proposal by proposing relatively corrected track level settings as well as individual keyframe settings per track to accommodate the loudness difference between the foreground and the background tracks/clips. Fades are used to lead in/out of clips with different content.
As shown, computer system 100 of the present example includes an interconnect 111 that couples a memory system 112 and a processor 113 an input/output interface 114, and a communications interface 115.
As shown, memory system 112 is encoded with audio mixing application 140-1. Audio mixing application 140-1 can be embodied as software code such as data and/or logic instructions (e.g., code stored in the memory or on another computer readable medium such as a disk) that support functionality according to different embodiments described herein.
During operation, processor 113 of computer system 100 accesses memory system 112 via the interconnect 111 in order to launch, run, execute, interpret or otherwise perform the logic instructions of the audio mixing application 140-1. Execution of audio mixing application 140-1 produces processing functionality in audio mixing process 140-2. In other words, the audio mixing process 140-2 represents one or more portions of the audio mixing application 140-1 (or the entire application) performing within or upon the processor 113 in the computer system 100.
It should be noted that, in addition to the audio mixing process 140-2, embodiments herein include the audio mixing application 140-1 itself (i.e., the un-executed or non-performing logic instructions and/or data). The audio mixing application 140-1 can be stored on a computer readable medium such as a floppy disk, hard disk, or optical medium. The audio mixing application 140-1 can also be stored in a memory type system such as in firmware, read only memory (ROM), or, as in this example, as executable code within the memory system 112 (e.g., within Random Access Memory or RAM).
In addition to these embodiments, it should also be noted that other embodiments herein include the execution of audio mixing application 140-1 in processor 113 as the audio mixing process 140-2. Those skilled in the art will understand that the computer system 100 can include other processes and/or software and hardware components, such as an operating system that controls allocation and use of hardware resources associated with the computer system 100.
Referring now to
Referring now to
Referring now to
The level correction of the foreground clips serves to equalize the clips level-wise, achieving the same perceived loudness. In one particular embodiment, the average loudness value over all foreground clips is computed and each clip level is adjusted relatively to match to the average loudness value. The measurement of the loudness value can be done by computing the RMS value or other methodologies can be applied (use peak values, crest factors, loudness units, as well as RMS values or various combinations thereof plus additional filtering). This principle can be extended to use additional criteria such as a Crest factor, which is equal to a Peak/RMS ratio. Weighting can be achieved by filtering the audio signal before computing the loudness value. The loudness corrected clips are shown as clips 202a, 204a and 206a. All level values are at a default level. The loudness corrected foreground clips 202a, 204a and 206a now have the same perceived loudness.
Next, all audio clips designated Background are analyzed. Then a preset (either predefined or user selected) is used to define a level “distance” between “Foreground” and “Background” levels. This can be automated if meta data provides information of the kind/genre of the audio. For example if the audio clip is intended as a movie trailer, a smaller distance value would be used since there is not much level difference between the announcer (foreground) and the background audio. On the other hand, if the audio clip were intended as a documentary, a larger distance value would be used since you want a more minimal background when the narrator is speaking.
Referring now to
This continues until keyframe 224 is encountered. At keyframe 224, a level change for track 4 from the first level to the second level is performed at the time clips 202a begins. The level of the music clip 210 is lowered to allow the clip 202a to be heard.
Next keyframe 226 in track 3 is encountered. The transition from first level to second level for clip 208 is lowered immediately since clip 202a is still active. Once clip 202a ends, keyframe 228 is encountered which raises the level of track 3 from the second level to the first level. Additionally keyframe 230 is encountered and transitions track 4 from the second level to the first level.
As clip 208 of track 3 ends, keyframe 232 is encountered which transitions track 4 (clip 212) from the first level to the second level. At this time clip 204a of track 1 is played. Once clip 204a completes, keyframe 234 is encountered which raises the level of track 4 back to the first level from the second level.
The entire mix proposal is now visualized via the keyframe settings. The keyframes can be adjusted (the location and the rate of level change) by the user to fine-tune a mixing session. After the user has finalized the mix proposal, the entire mixed audio is rendered out.
In this example, the final audio mix begins with music clip 210 being played at a first level. The music level is lowered to allow clip 206a to be played in its entirety, after which the music clip 210 is transitioned back to the first level. The music clip 210 is played at that level until voice clip 202a is played in its entirety, while the music is lowered to a second level. Before the voice clip 202a is finished, the level of clip 208 is sharply reduced so as not to conflict with the end of voice clip 202a. Once voice clip 202a is finished, clip 208 has its level transitioned from the second level to the first level. Shortly after the beginning of clip 208 begins, the level of track 4 is transitioned back to the first level. Since there is no clip to play, there is no conflict with clip 208, except at the very end of clip 208 where the music clip 212 plays at the first level before transitioning down to the second level so that voice clip 204a can be heard. Upon the completion of voice clip 204a, the music clip 212 is brought back up to the first level.
A flow chart of the presently disclosed method is depicted in
Referring now to
Processing block 304 states receiving a designation for each audio clip into one of a foreground clip and a background clip. As show in processing block 306, the receiving a designation comprises receiving a designation from a user. The user, by way of the user interface, designates each clip as either a foreground clip or a background clip. In some embodiments this may be done at the track level, wherein each track is designated as either background or foreground and all the clips of the track receive the same designation as the track they belong to.
Processing block 308 recites analyzing and loudness correcting the foreground clips. As shown in processing block 310 loudness correction comprises computing an average loudness value over the foreground clips and adjusting each foreground clip level to match to the average value. As further shown in processing block 312, the analyzing foreground clips comprises determining at least one of RMS values, peak values, crest values and loudness units of the foreground clips.
Processing continues with processing block 314, which states analyzing the background clips and defining a distance value between the corrected foreground clips and the background clips. Presets provided by the application can be used. For example if the audio clip is intended as a movie trailer, a smaller distance value would be used since there is not much level difference between the announcer (foreground) and the background audio. On the other hand, if the audio clip were intended as a documentary, a larger distance value would be used since you want a more minimal background when the narrator is speaking.
Processing block 316 states the analyzing background files comprises determining at least one of RMS values, peak values, crest values and loudness units of the background files. As shown in processing block 318, the distance value is user-defined. Alternately, as shown in processing block 320, the distance value is pre-defined.
Processing block 322 recites adding keyframes to some of the audio clips, the keyframes providing a fade between levels of the background clips to take into account the loudness corrected foreground clips. Processing block 324 discloses adjusting the keyframes according to input received from a user. The user can tweak the locations in the audio where the keyframes occur. Processing block 326 states the fade between levels provided by the keyframes are adjustable. The user can alter the rate of transition from one level to other.
Processing block 328 recites providing a sequenced audio file from the loudness corrected foreground clips, the background clips and the keyframes.
Having described preferred embodiments of the invention it will now become apparent to those of ordinary skill in the art that other embodiments incorporating these concepts may be used. Additionally, the software included as part of the invention may be embodied in a computer program product that includes a computer useable medium. For example, such a computer usable medium can include a readable memory device, such as a hard drive device, a CD-ROM, a DVD-ROM, or a computer diskette, having computer readable program code segments stored thereon. The computer readable medium can also include a communications link, either optical, wired, or wireless, having program code segments carried thereon as digital or analog signals. Accordingly, it is submitted that that the invention should not be limited to the described embodiments but rather should be limited only by the spirit and scope of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
6546188 | Ishii et al. | Apr 2003 | B1 |
7302644 | Holtz et al. | Nov 2007 | B2 |
7512886 | Herberger et al. | Mar 2009 | B1 |
20020109710 | Holtz et al. | Aug 2002 | A1 |
20020175931 | Holtz et al. | Nov 2002 | A1 |
20020186233 | Holtz et al. | Dec 2002 | A1 |
20070292106 | Finkelstein et al. | Dec 2007 | A1 |
20080044155 | Kuspa | Feb 2008 | A1 |