The present invention relates to digital music and digital music players.
Digital music continues to grow in popularity. Millions of people purchase MP3s or other digital music online and via applications on their mobile devices. Millions more subscribe to music services that stream digital music on demand via the Internet or other networks.
Many people who listen to music use a conventional digital music player, such as iTunes®, WinAmp®, or Windows Media Player®. Such digital music players often have a “playlist”—a list of songs that the user has selected and that will be played in the order specified in the list.
A limitation of conventional digital music players is that they do not allow for seamless playback of songs. Namely, when one song in the playlist ends, there is often an abrupt break or a pause before the next song begins. This might be particularly noticeable when a currently playing song has a tempo or pitch that differs from a song that plays next. Moreover, even if a player could blend one song into the next, the transition between the two would not be aligned according to the tempo of each song, and would not take into account what portions of the two songs match on the basis of measure or song section. Additionally, conventional players do not allow a seamless way to layer one song on top of another.
The lack of seamless transition between songs is less than ideal for many users. For example, a user who is listening to dance music, hip hop, or music produced by disc jockeys may wish to have a continual music listening experience, with no audible gap when one song plays and the other begins. Such a user might want a new song to start playing at a particular portion that correlates to a portion of the currently playing song, or wish to layer two songs together. Similarly, a user who is playing music at a party, or in a bar or club may also wish to have music that seamlessly plays in such a manner. Unfortunately, conventional digital music players do not allow for such functionality.
One aspect of an exemplary embodiment involves a method for mixing songs based on measure groupings. Such a process may involve identifying a first measure grouping in a first song and a second measure grouping in a second song, generating a transition based on these measure groupings, and determining if an advance signal has been triggered.
Another aspect of an exemplary embodiment involves a method for mixing songs using frame sequences from a first song and a second song. Each of the frame sequences may include some part of a measure grouping. The method might also involve selecting subsequences from each of the frame sequences and generating a transition based on the subsequences.
A third aspect of an exemplary embodiment may involve an apparatus for mixing music. The apparatus may have a memory unit that stores transition data. This transition data, may include cuepoints that mark one or more measure groupings in songs. The apparatus may also include a transition generation unit, which uses the cuepoints to generate a transition between songs. The apparatus may further have a player that truncates playback of a first song and begins playing the transition in response to an advance signal.
FIGS. 1A-1E—Exemplary Embodiments for Mixing Song Data and Producing Transitions
As represented by the interconnected lines within the program 20, the components within the program 20 may communicate or send data to one another via messages encoded in software and/or hardware, and the program 20 might be implemented in software and/or hardware. The program 20 interfaces with song data 30, which might be one or more songs or other musical compositions or audio files. For example, the song data 30 might include full songs, combinations or mixes of songs, portions of songs, transformed versions of songs (such as time-stretched versions), voice snippets, advertisements, and/or preview clips.
To illustrate, a voice snippet may be a beat-oriented announcement from a disc jockey or radio station, and an advertisement might be an advertising announcement that has a beat and is beat-matched to mix with songs. A preview clip may be, for example, a thirty-second or one minute segment of a song that enables potential customers to hear part of the song before they decide whether to buy it.
It should be understood that this list of song data 30 is meant to be illustrative and not limiting. Many other types of audio or media may be part of the song data 30 such as, for example, multimedia tracks (e.g., video or light tracks cued to music or sound in some way), model-based or sample-based synthesized music, (e.g., grand piano, drum pad sounds), MIDI clips, or beat tracks (e.g., “Latin” rhythms).
The song data 30 may be stored in any number of different formats, such as MP3, Ogg, WAV, and so on. Moreover, the song data 30 may be stored directly on a memory unit on the computer system, such as in random-access memory, read-only memory, flash, or any other storage mechanism. Alternatively, the program 20 may access the song data 30 via a network (such as the Internet, wireless broadband network, or broadcast system) or a physical cable (such as USB, FireWire, etc. cables). It should be understood that the terms “song data”, “song”, and “songs” may be used interchangeably, and that the use of any of these terms encompasses the others. It should also be understood that although the program 20 directly connects with the song data 30 here, any of the components within the program 20 might additionally or alternatively connect directly with the song data 30.
The player 22 transforms the song data 30 into an audio output. As shown in
As noted, the song data 30 might be presented to the player 22 in a variety of formats. Moreover, as shown in
The program 20 could then process the song data 30 to enable it to mix with other songs. Such an embodiment would allow the components described here to connect with “off-the-shelf” standard music players that are not beat-aware or do not have intelligence built-in to mix songs together. Such an external player 32 (which may be implemented in software, hardware, or a combination of the two) would produce the song data 30 to be received by the buffer 23 or other memory unit associated with the program 20. The song data 30 may then be processed by the transition generation unit 26 such that it might be mixed with another song. Alternatively, the program 20 might control the external player 32, muting it while the player 22 plays the song data 30.
Moreover, the buffer 23 or another buffer (which might be in the program 20 or the interface 33) might be used as a look-ahead buffer that can be used to identify the next song that is being played by the external player 32. This might be useful when the program 20 is trying to identify the next song being played so it can generate a beat-matched, measure-aware transition to that song.
The interface 33 that enables the external player 32 to communicate with the program may be implemented in software and/or hardware. For example, the interface 33 may be a pass-through device that can be fitted on any conventional music player and that connects separately to the computer system. Alternatively, the interface 33 may be part of the program 20, or it might be a software add-on or hardware addition to the external player 32.
It should be understood that the player 22 and/or any accompanying buffer 23 might have various physical components attached to or integrated within it. For example, the player 22 might be part of a physical speaker system that transforms electrical signals into sound. Or the player 22 might simply output the song data 30 or some electronic transformation of it to a physical speaker device. The player 22 might also just play the song data 30 provided to it, or alternatively, buffer additional data that it then outputs to the physical speaker device.
Other types of intelligence might be part of the player 22 as well, such as software or hardware that enable the player 22 to store the song data 30 for later retrieval and playback, to simultaneously buffer and play back streams of the song data 30, to pause and resume playback, or to jump to a specific location in the song data 30. Indeed, in some embodiments, the entire program 20 may be colloquially referred to as “the player” by users. It should be understood that the preceding description is not meant to be limiting and is intended merely to show exemplary features that might be part of the player 22. For example, the player 22 might concatenate one or many buffered streams together or fade out one song while fading in another.
As shown in
The program 20 also includes transition data 24, which may be generated based on the song data 30. The transition data 24 may be stored on the same memory unit as the song data 30, or it might be stored on a separate memory unit. Alternatively, similar to the song data 30, in some embodiments the program 20 may access the transition data 24 via a network or a physical cable.
As shown in
For example, the cuepoints 40 might mark boundaries of the measure groupings by marking “startpoints” that partition the song data 30 into the measure groupings. Alternatively, the cuepoints 40 might be separated from the boundaries of measure groupings by some number of frames; for example, each of the cuepoints 40 might mark a point prior to the start of a measure grouping by some pre-specified offset. The cuepoints 40 might also specify a midpoint or some other point that identifies a measure grouping. In an exemplary embodiment, the cuepoints 40 may be determined by one or more people who listen to the song data 30 and identify the measure groupings.
It should be understood that this description is exemplary and not meant to be limiting, and that the cuepoints 40 might be used in any way to identify a part of the song. For example, in some embodiments, each of the cuepoints 40 might identify a set of points in the song. Or each of the cuepoints 40 might actually be a range of values corresponding to the range of frames encompassed by a measure grouping.
The cuepoints 40, as well as beats or other position markings in the song, may be marked off based on frame number, time, sample segment, or in any other way in which the song data 30 may be discretized. It should be understood that “frame number” as used throughout this specification is a flexible term that covers any index or other way of measuring a position or sample in a song. For example, frame number may refer to an absolute frame number, which identifies a frame by its position in the song data 30 relative to a start of the song data 30 (e.g., the beginning of a song). In such a scheme, when a song is sampled at 44,100 samples per second (a standard sampling frequency that is often used), a sample pulled after exactly 10 seconds of playback from the beginning of the song will have a frame number of 441,001 (or approximately that number, if there is an offset or some distortion that affects the frame numbers).
A sample that is identified by such a frame number may contain one frame (e.g., if the audio output is mono) or two frames (e.g., if the audio output is stereo), or some other number of frames (e.g., for surround sound or other forms of more complicated audio playback). So in some embodiments, a frame number may be used to identify more than one actual frame of audio data, depending on the number of frames contained within a sample identified by the frame number. Alternatively, each frame within a sample may be separately identified through a frame number. Returning to the example above, if a song sampled at 44,100 samples per second is a stereo song, a sample pulled after exactly 10 seconds of playback might have two frame numbers associated with it, with one corresponding to each audio output channel (e.g., the frame numbers might be 882,001 and 882,002, which equals 2*441,001).
A frame number might also encompass a relative frame number, which marks the number of frames from some other arbitrary point in the song data 30 rather than the beginning. Alternatively, a frame number may refer to a time stamp, which measures the time in the song relative to the beginning of the song data 30. Or a frame number might encompass a relative time stamp, which measures the time in the song relative to some other arbitrary time in the song data 30.
The preceding discussion is intended merely to illustrate some of the ways in which a frame number may be used. Many other ways of marking frames and using frame numbers are possible, such as by using some transformation (e.g., function) of an absolute frame number, relative frame number, time stamp, or relative time stamp.
Returning to the cuepoints 40, they may also be used for purposes not directly related to cutting or appending to the song data 30. For example, cuepoints 40 might be used as a general reference point to indicate what portion of the song data 30 the player 22 has reached. To illustrate, if the player 22 or its playhead reach a cuepoint that corresponds to a final portion or measure grouping in the song data 30, the player 22 might provide a signal to the program 20 that a transition to a new song may be wanted soon.
The cuepoints 40 might also serve as section boundaries between different portions of the song data 30. These section boundaries might, for example, be the beginning or ending points of musical measures or musical sections (like chorus, verse, bridge, intro, outro, etc.) in the song data 30. Of course, the preceding description is intended to be exemplary and not limiting as to the potential uses of the cuepoints 40 in the present embodiment.
The transition data 24 might also include elements other than cuepoints 40. For example, as shown in
This list is just exemplary, and other information may also be part of the transition data 24. For example, the transition data 24 and/or parameters 48 might also include duration adjustments, beat drop-out locations, and beat rate adjustments.
The program 20 also includes the transition generation unit 26. This unit 26 may be comprised of software and/or hardware components that manipulate or otherwise treat the transition data 24 in a number of different ways. For example, the transition generation unit 26 might select a subset (i.e., one or more, up to and including all) of the cuepoints 40 when mixing together the song data 30. Alternatively, as shown in
Also in
The transition generation unit 26 might also include a combiner unit 37, which might combine frame values for frames based on the particular frame mapping. The combiner unit 37 (or alternatively, another component in the program 20) might use the cuepoints 40 in the transition data 24 to partition, reorder, join together, or mix together the song data 30. The combiner unit 37 (or other component) might further use the parameters 48, such as bass and treble profiles in transition data 24, to vary the volume and dynamic range of specific frequencies of the song data 30 over time. The combiner unit 37 may also be implemented in software and/or hardware. Discussed later in this description are exemplary embodiments showing how frame values might be combined.
This description of the transition generation unit 26 is not meant to be limiting, and many other ways of transition generation are possible. For example, the unit 26 might also use filters in the parameters 48 to transform and process the song data 30. Moreover, it should be understood that in other embodiments, any of the components 35-37 within the transition generation unit 26 might be combined, separated from the unit 26, or removed altogether. For example, the cuepoint selection unit 35, the sequencer unit 36 and/or the combiner unit 37 may be joined together or separate from the unit 26. Alternatively, the unit 26 might have a separate mapping unit (not shown) that generates a frame mapping between frames and/or subsequences that the combiner unit 37 uses when combining frame values.
In
Although some of the components in
Furthermore, it should be noted that although the transition data 24 and the song data 30 are not shown as interconnected in these embodiments, they may be connected in any way. For example, the transition data 24 and the song data 30 might be interspersed together when stored. In one embodiment, the transition data 24 might be stored in a header within the song data 30. Such an embodiment would allow the song data 30 and the transition data 24 to be available together, such that the program 20 might have the ability to mix song data 30 without accessing a remote network or other external data.
In another embodiment, the cuepoints 40 (or any parameters 48) might be marked within the song data 30, perhaps by some sequence of frame values or silent frames at various points corresponding to measure groupings in the song 30. For example, the cuepoints 40 might correspond to some arbitrary frame value (e.g., 0.013) or some sequence of frame values (e.g., 0.12, 0.013, 0, −0.11) that has been predetermined. When the program 20 encounters a frame or sequence of frames in the song data 30 with these values, it could recognize the position of the frame as a cuepoint for the song data 30. The cuepoint might mark, for example, the boundary of a measure grouping in the song data 30. Alternatively, the cuepoint might mark a point that is some predetermined offset from the boundary of the measure grouping, so the boundary of the measure grouping can be determined using the cuepoint and the offset.
If the sequence of frame values used to encode the cuepoints 40 in the song data 30 is relatively short, it will likely not be audible by a person listening to the song data 30 as it is played back. For example, some listeners cannot discern snippets of less than about 10 milliseconds of song data 30, which corresponds to about 440 frames if the song data 30 is sampled at 44,100 samples per second. Other listeners may not discern snippets on the order of about 100 milliseconds of song data 30, which would correspond to about 4400 frames at the 44,100 sampling frequency. So if the cuepoints 40 are encoded within the song data 30 in sufficiently small segments, it is possible they will have no discernible impact on playback of the song data 30.
FIGS. 2A-2E—Exemplary Embodiments for Mixing Song Data Using a Network
As noted previously, the player 22, the program 20, and the song data 30, may be physically connected on the same computer system or connected remotely via a network. For example, as shown in
Messages 27 may stream from the server 32 to the program 20 in both directions. In the embodiment shown in
It should be understood that any of these components might be distributed between the server 32 and program 20 in a variety of ways. For example, as discussed regarding the embodiment shown in
Such an embodiment might be useful, for example, for mobile devices. The program 20 could be any program or “app” on the mobile device, and the server 32 could stream the transition data 24 to the program 20, which could in turn generate the transition 50. The transition data 24 may then be cached with the program 20 or restreamed to the program 20 each time the data 24 is used.
Alternatively, the server 32 might stream in one file certain parts of the song data 30 relating to sections of a song that might be used in generating a transition (e.g., this might be a song chosen by the user via the user interface 28). This would enable the program 20 to get the data it might need for generating a transition in just one URL request to the server 32, as well as possibly economizing on the amount of data that the program 20 receives over the network 29. The server 32 might select what portions to stream based on information that the program first provides. This procedure could also extend to multiple songs that the user may wish to play or mix; relevant parts of the songs rather than the whole songs might then be received in one download.
Of course, many other variations are possible.
When transferred over the network 29, it might also be possible to obfuscate or encode the song data 30 and/or transition data 24 in any number of different ways. For example, the server 32, program 20, or some other device or program might reorder portions of the song data based on a fundamental unit. For example, the server 32 might reorder eighth note segments of the song data 30 when delivering it to the program 20. This might make the song data 30 sound different from the actual underlying song, which might render it unlistenable without a decoder that unscrambles the song data 30.
This scrambling/unscrambling might be done on the level of a frame—for example, the entity delivering the song data 30 (e.g., the server 32) might store a secret seed integer that is used to randomize the order of frames in the song data 30. The entity receiving the song data (e.g., the program 20), which might be reordering frames anyway to generate a transition 50, might also use the secret seed integer to reconstruct the original order of frames in the song data 30.
Various degrees of scrambling/unscrambling could also be used, based on the application desired. For example, the song data 30 could be minimally reordered to sound slightly inaccurate when played, but the reordering may not be so serious as to prevent the song data 30 from being able to be coded into a compressed format, such as MP3.
A similar use of secret keys or other obfuscation methods could also be used on the transition data 24, which could render it useless unless it is descrambled. This might help prevent the transition data 24 (e.g., the cuepoints 40) from being intercepted and stolen when it is transferred over the network 29.
A simple form of obfuscation might relate to delivering transition data 24 only for particular, non-standard versions of the song data 30. For example, the server 32 might only deliver “pre-elongated” song data 30 to the program 20. Such song data 30 might, for example, involve time-stretching the song data 30 such that they have more frames (e.g., are slower) than the underlying songs.
A reason to do this might relate to computational and accuracy limitations in time-stretching songs—since it is often easier and less computationally intensive to compress songs (which involves removing frames) rather than elongate songs (which involves adding frames), the server 32 might pre-elongate the song data 30 using a high quality computing system. The extent to which the song data 30 is pre-elongated might be based, for example, on the song with the highest beats-per-minute (BPM) count in the song data 30.
The server 32 may then deliver the pre-elongated versions of the song data 30 to the program 20, which may then perform the computationally-simpler operation of compressing the song data 30 as appropriate when playing the songs or generating a transition 50. So by delivering a pre-elongated version of a song, one might be able to deliver a higher quality song that will be less susceptible to audio degradation when it is later contracted.
If pre-elongated versions of songs are being transmitted as the song data 30, the program 20 would likely rely on transition data 24 (including cuepoints 40) that has been determined based on the pre-elongated versions of the songs. This might act as a simple form of obfuscation for the transition data 24—since the cuepoints 40 are for pre-elongated versions of the songs, the cuepoints 40 might not be useful if standard versions of the songs are used.
It should be understood that the preceding embodiments are not meant to be limiting, and are intended to merely provide exemplary layouts of the components between a server 32 and a program 20.
FIGS. 3A-3D—Exemplary Embodiments for Selecting and Mixing Song Data
Turning now to
The program 20 also identifies a second song 312 to be played, where two frame sequences 312a and 312b of the song 312 are shown here. The first song 304 and/or the second song 312 may be specified by the user, or chosen automatically by the program 20. For example, the user may specify a playlist of songs in the user interface 28 (an exemplary user interface 28 will be described in more detail later in connection with
The program 20 may then select a second startpoint 316 for the second song 312. This second startpoint 316 may be one of the cuepoints 40 associated with the transition data 24 for the second song 312. Similar to the first startpoint 304, the second startpoint 316 might be a dominant beat or a marking at the start of a measure grouping in the second song 312, though this may vary according to the embodiment at issue. Moreover, while one second startpoint 316 is depicted in
In the present embodiment, the program 20 uses the first startpoint 302 and the second startpoint 316 to determine where to end playback of the first song 304 and where to begin playback of the second song 312. It should be understood that both of these might vary in different embodiments (e.g., playback may start or end at some other point as determined by the program 20).
The program 20 may generate a transition 50 to be played in between the two songs 304, 312. In one embodiment, this transition 50 may be a simple pre-made segment that does not rely on any of the parameters 48 or other cuepoints 40 of the two songs. In another embodiment, the transition 50 might be a volume cross-fade (e.g., fading out the first song 304 while increasing the volume of the second song 312).
Another transition 50 would involve the transition generation unit 26, which could use parameters 48 from the first song 304 and/or the second song 312 to generate a transition 50, as depicted in
Regardless of how the transition 50 is generated and what song data 30 it contains,
As used throughout this specification, “frame sequence” (such as frame sequences 304a, 312b mentioned above) should be understood as general terms that encompass any sequence of consecutive or non-consecutive frames taken from one or more songs. Here, the frame sequence 304a is shown as a sequence of consecutive frames taken from the portion of the first song 304 prior to the first startpoint 302. This portion of the song may, but need not be, a measure grouping. A frame sequence may sometimes contain just a subset of the frames in a measure grouping. Moreover, as discussed in more detail below in connection with
Returning to our discussion on how a transition between the first song 304 and the second song 312 might occur,
Alternatively, the advance signal 318 may be produced by the program 20, perhaps in response to the status of playback of the first song 304. For example, as the first song 304 nears its end—a fact that may be captured by the fact that the playhead has passed one of the final cuepoints 40 for the first song 304—the program 20 may initiate a transition to the second song 312. Such a process will entail either creating or using a pre-made transition 50 to fill the gap between the first startpoint 302 and the second startpoint 316.
In yet another embodiment, the advance signal 318 may be triggered based on a playback mode selected by the user. For example, if the user wishes to cycle through songs quickly or preview songs in a playlist, he or she may select a “quick transition” mode that will automatically move from a currently playing song (e.g., the first song 304) to a next song in the playlist (e.g., the second song 312) after a certain amount of time. This amount of time may be a set number (e.g., “transition to the new song after 30 seconds”) or it might depend on the song being played (e.g., “transition to a new song after playback of one measure grouping in the currently playing song”).
Alternatively, the program 20 may automatically trigger the advance signal 318 based on what it decides will sound best. For example, the program 20 may determine that a certain measure grouping in the first song 304 sounds particularly good with another measure grouping in the second song 312, so it might switch between these songs 304, 312 such that these measure groupings are part of the transition 50.
More generally, the program 20 may match portions of any songs specified in a playlist or list of songs that the user has, and switch between them according to a determination by the program 20 as to what transitions will sound best. Alternatively, the program 20 may merely recommend which transitions it believes will sound good but leave it to the user to initiate the transition (e.g., by requiring the user to push an advance button on the user interface 28). How the program 20 may utilize user feedback/information and/or automated mechanisms to make these determinations and recommendations is discussed in more detail below.
It should be understood that in many embodiments, a number of factors may be used to determine the sequence of playback of the first song 304, the transition 50, and the second song 312. For example, the program 20 (or one of its components, such as the transition generation unit 26 or, if there is one, the cuepoint selection unit 35) may determine a ranking that prioritizes the one or more cuepoints in the first song in terms of which cuepoints might be better as a place to start a transition. Such a priority ranking may depend on playhead position, and the program 20 may update the ranking as the playhead advances. For example, the cuepoints that rank highest might be those that have a frame number greater than the frame number associated with the playhead (since those cuepoints have yet to be reached by the playhead). In particular, the next cuepoint that the playhead will hit (e.g., the cuepoint with the lowest frame number greater than the frame number for the playhead) might receive a high rank, since it is the nearest cuepoint to the playhead.
In generating a priority ranking for the first song cuepoints, the program 20 may consider other factors other than position of the playhead and receipt of the advance signal 318. For example, given that time-stretching and generating a transition takes time, the program 20 might consider this latency when selecting a first song cuepoint. This latency might be relevant because if the playhead is sufficiently close to the next cuepoint it will reach, there may not be enough time to generate the transition 50 for playback if one has not been generated yet. The program 20 may then prioritize a later cuepoint as a preferred cuepoint in the first song. Alternatively, the program 20 might address this latency problem by pre-rendering transitions for one or more of the cuepoints in the first song, so that they are more quickly available for playback.
The program 20 may choose among cuepoints in the second song 312 and/or first song 304 based on other factors as well. For example, a signal from the user or from a component within the program 20 may affect which transition is generated by the program 20. A program signal may be, for example, a status of the program window on the user interface 28, a timeout signal, a central processing unit load signal, and a memory signal.
To illustrate, if a user window has been minimized, this might be a sign that the user is unlikely to trigger an advance button on the user interface 28, perhaps making it less likely that the advance signal 318 is forthcoming. So instead of expending resources preparing transitions for all cuepoints in the first song 304 (on the theory that the user might trigger the advance signal 318 at any moment), it might make more sense for the program 20 to prepare a transition for just the last cuepoint in the first song 304, since it is likely that the first song 304 will play out until that point. Indeed, it might make sense for the program 20 to prepare this transition first as a matter of course, such that a beat-matched transition between the first song 304 and the second song 312 is assured.
Other signals might instruct the program 20 to change which transitions it is rendering and how. For example, a timeout signal might indicate that a process is taking longer than a set amount of time, suggesting that the program 20 should not try to generate more transitions. Similarly, a central processing load signal, which might indicate whether the CPU is having a difficult time running computations, and a memory signal, which might indicate that a memory unit is running out of space, might also help the program 20 choose which transitions to render (or not to render).
User-generated factors may also affect how the program 20 chooses among cuepoints and decides what to render. For example, the program 20 and/or the server 32 may collect information from users about transitions that sound good between various songs. Some of this might be direct feedback from a user, who might, for example, vote on transitions that he thought sounded good or bad. This feedback may be submitted via the user interface 28. Other user information (e.g., history of transitions played, preferences selected by the user, choice of songs in a playlist, choice of songs purchased, amount of time spent listening to particular songs or songs in a genre, etc.) may also be used to determine optimal transitions.
The program 20 may utilize the user feedback/information from a particular user to customize transitions for that user. For example, the program 20 may know that a particular user enjoys transitions from one particular artist (e.g., Nirvana) to another (e.g., Nine Inch Nails), and dislikes one particular transition involving a certain measure grouping in the first song 304 and another measure grouping in the second song 312.
Additionally, or alternatively, the program 20 may aggregate user information to determine default cuepoint choices. For example, based on user feedback and/or other information gathered from users, the program 20 might determine that one particular transition between the first song 304 and the second song 312 sounds particularly good to most users, and that most songs from two particular artists do not sound good when combined.
Additionally, the program 20 might use some kind of automated mechanism to determine which transitions sound good to users. One way to do this might be to use particular sonic attributes of songs in order to determine if they would sound good when mixed together. For example, the program 20 and/or server 32 might calculate a volume envelope for songs in the song data 30. This volume envelope may, for example, measure the amplitude or energy of different frequencies or frequency bands in the songs. Based on these values, it might be determined that certain songs are more likely to sound better than others when combined.
For example, suppose the program 20 is trying to mix a frame sequence beginning with the first startpoint 302 with some portion of the second song 312. The program 20 might consider the volume envelope of that frame sequence, either by analysis or by loading values for an analysis that was done previously. Suppose this frame sequence has a high volume in high-range and low-range frequencies, but has a low volume in the mid-range frequencies. When choosing a second song startpoint from among the cuepoints 40 in the second song 312, the program 20 might seek out one of the cuepoints 40 that corresponds to a portion of the second song 312 with a high volume in the mid-range frequencies and a low volume elsewhere. If this portion of the second song 312 is combined with the frame sequence, the resulting transition 50 may have a more even volume across frequency levels. This might be pleasing to the ears and hence, might be a better portion of the second song 312 to choose for mixing.
FIGS. 4A-4G—Exemplary Embodiments for Generating a Transition
Turning now to
The start and end points of each of these subsequences corresponds to a beat in the song 700. A measure like measure 701 is typically described as having four beats (you count either the measure startpoint 702 or the measure endpoint 703, in addition to the three beats within the measure). It should be understood that in other embodiments, measures might not be divided into equal subsequences, beats might not be equally spaced in a measure, and a measure might have more or less than four beats. It should also be understood that subsequences (such as the subsequences 702a, 702b, 702c, 702d) may sometimes be colloquially be referred to as beats, rather than the start and end points of these subsequences being called beats.
As
The time-stretching performed here might be done by the transition generation unit 26. Alternatively, the time-stretching might be done on a server (such as the server 32 in
Time-stretching generally implies that the number of frames in a song has been increased or decreased while the underlying sound of the song remains the same. For example, if a segment of a song is time-stretched by removing frames from the segment, it might sound as if it has been sped up. If a segment of a song is time-stretched by adding frames to the segment, it might sound as if it has been slowed down. The pitch of the segment (e.g. musical key) might also change when a song is time-stretched, though sound stretch libraries that preserve pitch during time-stretching operations might also be used.
Since in the present embodiment, the second song subsequences 602a, 602b, 602c, 602d are longer than their corresponding first song subsequences 702a, 702b, 702c, 702d, this implies that the transition generation unit 26 (or server 32, if that does the time-stretching) has added frames to generate time-stretched subsequences 722a, 722b, 722c, 722d, which have substantially the same number of frames as the second song subsequences 602a, 602b, 602c, 602d, respectively.
As an alternative to time-stretching, subsequences 702a, 702b, 702c, 702d could be changed into subsequences 722a, 722b, 722c, 722d by simply adding some extra frames and not performing a typical time-stretching operation. These extra frames may be arbitrary—for example, they might be silent frames (e.g., with a frame value of 0), they could be other frames from some portion of the song 700, or they may be frames received from some external song.
Turning to
For example, in place of subsequence 722b in measure 721, we see that subsequence 722a has been placed in measure 721q. This will generate a “loop” effect at the level of a subsequence, as subsequence 722a will now play twice in a row if this measure is played.
We also see that subsequence 722c in measure 721 has been replaced by subsequence 777 in measure 721q. Subsequence 777 might be a set of external frame values, such as another portion of the first song 700 (before or after it has been time-stretched), a portion of the second song 600, or some other piece of song data 30 altogether. For example, subsequence 777 might comprise some kind of external sound (e.g., a ring of a bell, a portion of another song, a percussive element). This example shows how the program 20 might replace subsequences, parts of subsequences, or individual frames of a song by external frames (e.g., frames from outside the particular subsequence or measure being altered).
Additionally,
This example illustrates how the program 20 might partition a subsequence into smaller frame segments and then operate on those frame segments. For example, the program 20 may divide a subsequence into an even number of frame segments, and then loop one or more of those frame segments.
In some embodiments, it might be advantageous to loop frame segments that are at the beginning or the end of a frame sequence, because these might be desirable parts of a song to repeat or otherwise mix. For example, the first measure following a cuepoint (e.g., first measure in a measure grouping) might have a larger or more recognizable downbeat than other measures, so it might be a better measure to loop. Alternatively, for a next song to be played (e.g., the second song 600 here), the last measure in a measure grouping that is used in a transition will have aural continuity with the rest of the song, which will be played following the transition. Accordingly, looping this segment may also be desirable.
These examples should illustrate that different embodiments of the program 20 might perform any number of different operations on frame sequences and subsequences (including segments within subsequences). For example, the program 20 may change the number of frames (which may involve time-stretching) of any subsequence or set of subsequences. It might reorder the frames within a subsequence (e.g., reverse the order of frames), or change the order of subsequences. The program 20 might repeat portions of a subsequence to generate a loop within a subsequence, or repeat subsequences to generate a loop effect at the subsequence level. Or the program 20 might replace one or more of the frame values in a subsequence with an external frame value, which might come from the same song as the subsequence or from some other song data 30.
It should be understood that this list is not exhaustive, as the program 20 might do other things in other embodiments. For example, the program 20 might add an offset to any given subsequence by prepending it to the beginning or appending it to the end of the subsequence. This which might extend the length of the subsequence and whatever measure might contain the subsequence. This offset may, for example, be another portion of a song that begins on one beat and ends on another beat.
Although the operations are shown as being performed on the time-stretched measure 721 of the first song to generate measure 721q, it should be understood that these operations may be performed on time-stretched or non-time-stretched versions of any song. For example, in an alternate embodiment, the program 20 may add an offset or reorder frames of the measure 601 of the second song 600, or loop subsequences in measure 701 of the first song 700.
Moreover, in an exemplary embodiment, the user interface 28 may permit a user to select between various transition modes that determine how the program 20 operates on frame sequences and subsequences. For example, each transition mode might specify a different generic mapping between subsequences or frames in a first song (e.g., a currently playing song, like the first song 700 here) and a second song (e.g., a next song to be played, like the second song 600 here). The program 20 may then apply the generic mapping to map one or more of the subsequences in the currently playing song to one or more subsequences in the song to be played next. For example, in the embodiment shown in
Turning now to
In
For example, here we have two measures (the time-stretched measure 721 and the second song measure 601) that are aligned along measure boundaries (measure boundary 722 aligns with measure boundary 602, and measure boundary 723 aligns with measure boundary 603). The measures 721, 601 are also aligned along beats (e.g., frame subsequences 722a, 722b, 722c, 722d, have substantially the same number of frames as subsequences 600a, 600b, 600c, 600d, respectively).
The program 20 may form the transition measure 901 by simply adding frame values for corresponding frames in the two measures 721, 601, such that the frame value for the measure boundary 722 adds together with the frame value for the measure boundary 602, and frame values for subsequent frames in the time-stretched measure 721 add together with frame values for subsequent frames in the measure 601.
It should be noted here that songs do not need to be perfectly aligned for them to be combined in this manner. For example, the time-stretched measure 721 might merely be substantially aligned with the second song measure 601, with subsequences 722a, 722b, 722c, 722d, merely having substantially the same number of frames as subsequences 600a, 600b, 600c, 600d, respectively.
Whether songs are substantially aligned might depend on a number of factors, such as the degree of accuracy desired for the audience at issue. For example, true audiophiles may demand a higher level of accuracy than the average user. One possible test, though not necessarily the only one, for whether sequences or subsequences are substantially aligned would be to see if a listener (e.g., an average listener, an especially keen listener, etc.) can discern any misalignment if the two supposedly aligned songs are combined and played. As noted earlier, a misalignment greater than about 10 milliseconds of song data 30, which corresponds to about 440 frames if the song data 30 is sampled at 44,100 samples per second, might be discernible to some listeners. Other listeners may only respond to a misalignment on the order of about 100 milliseconds of song data 30, which would correspond to about 4400 frames at the 44,100 sampling frequency. It should be understood that these values are exemplary and that a larger degree of misalignment may be acceptable in certain embodiments.
In addition to adding frame values, combining two songs might involve applying any number of filters, effects, overlays, or any other processing to a transition (such as the transition 50 or the transition measure 901). For example, the transition generation unit 26 might filter the transition measure 901 (and/or some part of the first song 700 or the second song 600) prior to it being played. In one embodiment, the unit 26 might apply a band filter (not shown). This filter might alter frame values in different frequency bands of a song based on a desired playback profile. The filter might also determine the relative mix of a playback parameter (e.g., high frequency band volume, mid frequency band volume, low frequency band volume) based on the parameters 48 for the songs being mixed. Similarly, the unit 26 may use some form of volume normalization to ensure that no song being played varies by more than a certain threshold in its volume as compared to other songs being played. Using a filter and/or volume normalization in the present embodiment could help make a transition between songs smoother.
Additionally, the transition generation unit 26 might also shift the pitch of a transition based on the musical keys of the songs at issue. Here, the unit 26 might shift the pitch of the measure 901 based on the musical key of the first song 700 and the second song 600.
Turning to
For example, suppose the first song 700 has a tempo of 108 beats-per-minute (BPM), and the second song 600 has a tempo of 100 BPM. Thus, the first song 700 is faster than the second song 600. Since the first song 700 will be played first, followed by the transition measure 901, and then the second song 600 (see the discussion in connection with
The program 20 might accomplish this, for example, by linearly decreasing the tempo in the transition by 2 BPM for each of the four subsequences in the transition measure 901. To accomplish this linear ramping effect, the transition generation unit 26 may time-stretch the transition measure subsequences 902a, 902b, 902c, 902d into final transition measure subsequences 922a, 922b, 922c, 922d, respectively, which in total comprise a final transition measure 921.
As is apparent from the diagram, final transition measure subsequence 922a is shorter as compared to the other final transition measure subsequences 922b, 922c, 922d, implying that it also has the fastest tempo. This makes sense, since it is the first subsequence to play, and hence its tempo will be closest to that of the first song 700. Conversely, we see that the last of the subsequences, subsequence 922d, has the longest length, and hence it has a tempo closest to that of the second song 600.
It should be understood that in other embodiments, the program 20 might choose any arbitrary speed profile in generating the final transition measure 921. For example, the program 20 might speed up the transition rapidly at first and then slow down, or vice-versa. The program 20 also might alter the tempo such that it increases or decreases speed across any single subsequence. Alternatively, the program 20 might not use any ramp at all, in effect playing the transition measure 901 just as it is.
Moreover, it should be noted that the length of the final transition measure 921 need not depend on the tempo of the first song 700, the tempo of the second song 600, the length of the first measure 701, or the length of the second measure 601. Indeed, the length of the final transition measure 921, and the length of any of the final transition measure subsequences 922a, 922b, 922c, 922d, might be any arbitrary length. These lengths may depend, for example, on a particular effect that a user wants, or a particular transition mode that a user has selected. For example, if a user wants a transition between the first song 700 and 600 to sound very slow, without any kind of ramping effect, the program 20 could elongate (e.g., using time-stretching) both the first measure 701 and second measure 601 by whatever desired amount, which still ensuring that the subsequences within the measures 701, 601 are aligned as before (so the transition still sounds beat-aligned).
It should also be noted that the present embodiment does not require any time-stretching (or any other operation of adding/removing frames) to be done in any particular order. For example, while the present embodiment described measure 701 in the first song 700 as being time-stretched first (
To illustrate, both measure 701 and measure 601 of the second song 601 may be time-stretched such that subsequences 702a, 702b, 702c, 702d and subsequences 602a, 602b, 602c, 602d have the same length as final measure subsequences 922a, 922b, 922c, 922d, respectively. Then the time-stretched subsequences for the first song 700 and the second song 600 may be combined to generate the same final transition measure 901 as before. Other ways of generating a beat-aligned transition involving the first song 700 and the second song 600 may also be used.
Turning to
In
It should be understood that all of the previous statements and supplementary explanation made in relation to the embodiment depicted in
FIGS. 5A-5G—Further Exemplary Embodiments for Generating a Transition
In the present embodiment, the program 20 seeks to mix the measure grouping 730 with a measure grouping 1430 for a second song 1400. The measure grouping 1430 has eight measures in it—1430a, 1430b, 1430c, 1430d, 1430e, 1430f, 1430g, 1430h. So measure grouping 730 and measure grouping 1430 have different numbers of measures in them. In other embodiments, the measure groupings for the two songs being mixed may have the same number of measures in them.
In
It should be understood that in alternate embodiments, the time-stretched measures for the first song might be matched up against different measures in the measure grouping 1430. For example, the time-stretched measures for the first song might have been matched up against the last six measures of the measure grouping 1430 instead (i.e., 1430c, 1430d, 1430e, 1430f, 1430g, 1430h). More generally, it should be understood that any subset of measures in a measure grouping for a first song (e.g., a song that is currently playing) may be matched with any subset of measures in a measure grouping for a second song (e.g., a song that is to be playing next).
In
For example, comparing measure grouping 1430 and measure grouping 1430q, we see that measure 1430a has been replaced by measure 1430b. This will cause measure 1430a to play twice in a row in a “loop.” Additionally, measure 1430g has been replaced by measure 1430e in measure grouping 1430q, which will cause this measure 1430e to play twice in a non-consecutive fashion.
We further see that measure 1430d from the measure grouping 1430 is actually comprised of two parts, segment 1496 and segment 1498. In measure grouping 1430q, segment 1498 has been replaced by segment 1499, a set of external frames that might have come from some external source, similar to subsequence 777 discussed earlier. Segments 1496 and 1499 have then been placed where measure 1430d used to be in measure grouping 1430. This example shows how a measure may be partitioned into smaller frame segments, which might be looped or replaced with external frames.
These examples should illustrate that different embodiments of the program 20 can perform any number of different operations on measure groupings and measures, similar to the operations they could perform on frame sequences and subsequences as discussed in connection with
As in the context of sequences and subsequences, it should be understood that this list is not exhaustive, as the program 20 might do other things in other embodiments. For example, the program 20 might prepend (or append) an offset to any given measure.
Moreover, although the operations shown here are being performed on the measure grouping 1430 (in order to generate the measure grouping 1430q), it should be understood that these operations may be performed on any type of measure or measure grouping, whether time-stretched or not, or whether performed on a currently playing song or an enqueued song.
Additionally, as in the context of
Turning now to
In
In
As in the context of
As before, the measure groupings need not be perfectly aligned to be combined in this manner, Whether the measure groupings are substantially aligned might depend on a number of factors, such as the sensitivity of the audience to misaligned beats or frames (see previous discussion in connection with
Now looking at
Also similar to the previous discussion in connection with
Turning to
It should be understood that all of the previous statements and supplementary explanation made in relation to the embodiments encompassed by
Before turning to
Moreover, in alternate embodiments, the program 20 might generate transitions not just with song data 30, but also with data related to other media, such as videos or lights. For example, the program 20 might take video that is already synced to an existing audio track (like a music video). After generating a map of beats for the song, which might be done via an automated program, the program 20 might take the audio/video track and mix it with another audio track in a manner similar to that described above.
More generally, the present embodiment might map a media track (e.g., video, lights) and an audio track (e.g., song data) when both have cuepoints associated and beats associated with them. The media track and audio track may then be mixed based on these cuepoints and beats.
Alternatively, the program 20 might output a signal based on the beats of the songs and transitions it is playing. Such beats might allow the program 20 to synchronize with a separate beat-aware player (such as a computer running a different version of the program 20) or to a graphical display or lighting system or any other human interface system that might use a sequence of pulse data to trigger an action. For example, the program 20 might output the beats to a lighting system that might flash whenever a beat occurs. Or the program 20 might output the beats to graphical display or projection unit, such as a slide projector, a movie projector, a computer attached to a liquid crystal display screen, and the like. This graphical display or projection unit may show pictures (e.g., flash pictures, or switch between pictures in a slideshow) at the same rate as the beats outputted by the program 20.
FIGS. 6A-6B—Exemplary Embodiments Using Multiple Measure Groupings
Turning now to
In
This alignment in measure groupings 1130, 1430 could have possibly occurred naturally (e.g., without any action by the program 20), but more likely resulted from time-stretching operations on one or both of the songs 1100, 1400. Either way, given this alignment, these two measure groupings 1130, 1430 may be combined, for example, in a manner similar to that specified in connection with
The remaining measure groupings in the songs are not aligned. However, the program might perform one or more operations to make them aligned. For example, as shown at the bottom of
By adding the external measure grouping 995 to the second song 1400, the measure groupings 1432, 1434 in the second song 1400 now align with the measure groupings 1134, 1136 in the first song 1100. As such, these measure groupings may now be combined, for example, in the fashion specified in
Turning to
At the bottom of
Regardless, by adding the external measure grouping 997, it becomes possible to combine the first song 1200 and the second song 1400 across multiple measure groupings. In particular, three measure groupings 1230, 1232, 1234 in the first song 1200 may be combined with two measure groupings 1430, 1432, and two other measure groupings 1232, 1236 (at the end of the first song 1200 as shown in
While the present embodiments show how multiple measure groupings may be combined in two songs, it should be understood that by mapping cuepoints and measure groupings, it becomes possible to combine any number of songs in any number of ways. For example, after the first song 1200 and the second song 1400 have been combined in the manner specified in
This process may be iterated any number of times as desired by the user, who may select his preferences via the user interface 28. Additionally, as discussed previously in connection with
FIGS. 7A-7B—Exemplary User Interface
Now turning to
The user interface 28 shown here has a current song listing 1318 that identifies the title and artist of the currently playing song. There is also a graphical section 1334 showing a waveform 1332 and cover art 1336 for the song, and a progress meter 1330 showing how much of the song has been played.
The progress meter 1330 may have a scrubber 1331 that a user may adjust to move around to different portions of the song. In an exemplary embodiment, if the user drops the scrubber 1331 at a point in the song, the song may immediately start playback at that point. Alternatively, dropping the scrubber 1331 may cause the program 20 to initiate a beat-matched transition from the current portion of the song that is playing to a portion at or near where the scrubber 1331 was dropped. In other words, instead of having an abrupt discontinuity in playback when the scrubber 1331 is moved, the player 22 may maintain a beat-matched sound by mixing the currently playing song with itself at or near the point where the scrubber 1331 is set to resume playback.
If the currently playing song has a constant or nearly constant beats-per-minute count, then beat-matching where the scrubber 1331 drops may take minimal computational effort, since no time-stretching or adding/removing frames would be used to generate the transition. In yet another embodiment, dropping the scrubber 1331 at another point in the song may cause it to jump to the nearest beat, cuepoint or measure startpoint and begin playback there once the playhead reaches the next beat, cuepoint, or measure startpoint in the currently playing section of the song.
Returning to the user interface 28, the exemplary embodiment here also has various control buttons, including a play button 1302 that triggers playback of a currently loaded song. Pressing the play button 1302 while a song is currently playing may cause the song to pause playing, to fade out, or to stop immediately, depending on the specific implementation used. Alternatively, other embodiments may include a separate pause and/or stop button.
The interface 28 also has a volume control button 1310, which might be used to raise or lower the volume. Alternatively, the interface 28 may have a slider (not shown) to accomplish this functionality.
Additionally, the interface 28 has an advance button 1304, which might trigger an advance signal, such as the advance signal 318 shown in
If the advance button 1304 is pressed twice in a row, it might indicate that a user wishes to skip directly to the next song 1390 without a transition. In such a case, the transition might be skipped and the next song 1390 will be directly played. Alternatively, the next song 1390 may be faded into the current song, or the interface 28 may have a separate button to initiate this kind of skip functionality. This kind of fast advance may also be triggered by pressing the advance button 1304 during playback of a transition.
The interface 28 also has a loop button 1308, which might be a button that stays depressed until it is pressed again (the button 1308 might change graphically to indicate that it is depressed). Depending on user preferences and on the mode in which the player 22 is set, pressing the loop button 1308 might cause the player 22 to loop a currently playing song, measure grouping, measure, or sequence or subsequence of frames. Alternatively, a loop might not be initiated until the playhead reaches the next loopable section of the currently playing song.
If the loop button 1308 is undepressed (e.g., it is selected again after it has been depressed), the program 20 may then transition out of the repetitive beat and back into the current song. The playback experience might thus resemble entering a repetitive loop after the button 1308 is depressed and then resuming playback after it is undepressed. Such a mode may enable a user to play a current song for longer than its runtime, giving her more time to decide on what she wants to hear next.
Other buttons on the user interface 28 might include a positive ratings buttons 1312 and a negative ratings button 1314. Based on which button 1312, 1314 (if any) is pressed, the program 20 may be able to discern whether a user liked a particular song or transition to a song. This information may be sent to the server 32 over the network 29 using messages 27. As described earlier, this information may be used to tailor the player 22 to a particular user's preferences. It might also be used to aggregate information on user preferences and determine player 22 and/or program 20 settings for other users.
The exemplary interface 28 may also have various customizable buttons 1320-1326. These might be programmed by the user or take certain preset values that may be altered. The buttons 1320-1326 shown here are merely exemplary, and it should be understood that their nature might vary widely.
For example, in the present embodiment, button 1320 is listed as a “Flashback” button. Pressing this button might cause the player 22 to auto-populate the playlist with songs from a particular past era that the user enjoys. For example, if the user enjoys 1980s music, he could program the Flashback button 1320 such that pressing it loads 1980s music into his playlist. What songs are loaded, and in what order, might be determined by the program 20, which might account for song characteristics in order to choose a playlist that sounds best when songs transition from one to another.
This same concept may be applied to particular artists (“Lady Gaga” button 1322 will put Lady Gaga songs in the playlist), genres (“House” button 1324 will put various house music in the playlist), albums, or any arbitrary favorite selection. A customizable button might also load in pre-specified playlists that are generated by the user, someone else (e.g., an expert music listener) or the program 20 itself. For example, the “Party Mix” button 1326 might load various party music that the user has selected into the playlist.
Another part of the interface 28 may be a variable display 1340, which changes depending on which of a set of tabs 1338, 1342, 1344 has been selected. In the exemplary embodiment shown in
User interface 28 also includes a preview tab 1342. In some embodiments, such a tab might play preview clips of songs that are in the playlist, or other songs to which a user may want to listen (if, for example, one of the customizable buttons 1320-1326 is depressed). Preview clips might be particularly useful to sample music that the user does not yet own and is considering purchasing. Transitions to these preview clips may be a beat-matched, measure-aware transition in an exemplary embodiment.
The preview clips might also be based on songs in the playlist; selecting the preview tab 1342 may thus cause the player to only play small portion of the next song 1390 and subsequence songs in the playlist, to help the user determine whether they are worth playing for longer. If a user decides to stay on a particular song, she may click the preview tab 1342 or some other pre-specified button again to stay on the song that is playing
In an alternative embodiment, selecting the preview tab 1342 may cause the player 22 to preview part of the next song 1390 while the current song is still playing. Many users may find this useful, as it would enable them to see what the next song 1390 sounds like without having to stop playback of the currently playing song. Indeed, this might be particularly useful for systems that have only one audio output (and so previewing the next song 1390 without playing it would be difficult). So by playing the next song 1390 on top of the current song, the user may preview what the song sounds like. This might also be useful for testing an audience's reaction to the preview portion of the next song 1390, which might be useful in determining whether the entire next song 1390 should be played.
The exemplary embodiment also includes a radio tab 1344. Selecting this tab 1344 may allow the user to select a radio station, which may, for example, be an Internet radio station. A variety of such stations might be available; their names or a description of them might be shown in the display 1340 when the tab is selected, allowing the user to select one. When a radio station is selected, the program 20 may initiate a beat-matched transition from the currently playing song (which may be from the user's personal collection and pulled from his playlist) to whatever song happens to be playing on the radio station that was selected. If, for example, a song in the playlist is selected again, the program 20 may initiate another beat-matched transition back to that song from whatever song was playing in Internet radio.
In this sense, the present embodiment might allow a user to seamlessly switch between an Internet radio station and a song in a playlist. Such a playlist song may be any kind of song data 30.
Additionally, during Internet radio playback, advertisers may be able to intersperse commercial audio advertisements that are beat-matched and are mixed with other song data 30 being broadcast on the radio. Such a mode of advertising might be less disruptive to the radio experience, while still allowing advertisers to get their message across to listeners.
Other tabs not shown in the present embodiment are also possible. For example, the interface 28 might have a playlists tab. Selecting this tab may cause a list of playlists to appear that the user might select. As mentioned previously, these playlists may be automatically generated by the program 20 and/or server 32, or they may be generated by the user or another individual. The interface 28 might also have an “About” tab, which provides information on the player 22 and/or program 20, and a “Transitions” tab, which describes the various transition mappings available between songs
Turning to
In this playlist 1348 (which may look very different in other embodiments), we see that for each entry, there is a listing of the song name 1360, artist name 1370, and running time 1380 of the song.
We also see there are transition types 1350 listed for each song. In the present embodiments, these types 1350 describe the kind of transition that would be used when introducing the song. For example, for the next song 1390, we see that the song will be introduced using a “Type B” style transition. The second queued song 1392, on the other hand, is being introduced by a “Type A” style transition
These different transition types might be, for example, some specific mapping at a frame, subsequence, frame sequence, measure, measure grouping, and/or multiple measure groupings level, Many examples of such possible mappings were discussed previously in connection with
It should be understood that any part of the user interface 28 may be laid out in other embodiments in a way different from the way shown in
Alternatively, the interface 28 may present an intermediate song interface, which allows the user to select a sequence of songs that will allow a more gradual and subtle between the currently playing song and some target song that the user wants to play. The program 20 may determine such an exemplary playback sequence in various ways (e.g., analysis from previous user sessions, use of volume envelopes, pitch analysis of songs, etc.).
FIG. 8—Exemplary Method for Playing a Transition
Turning now to
The method begins when a user (or some other person or mechanical process) initiates playback of a song or other audio file (step 800). In this step 800, the player 22 may begin playing song data 30 received from a buffer (such as playback buffer 23) that is filled by the program 20 or some component outside the program (e.g., external player 32 in
In step 802, the player 22 continues to play the current song (e.g., the first song 304, as shown in
In step 804, the player 22 determines whether to advance to the next song (e.g., the second song 312) while continuing to play the current song. The decision whether to advance may depend, for example, on whether the program 20 has received a signal to advance (such as the advance signal 318 as shown in
If the program 20 decides not to advance, it may proceed to step 806, where the program 20 checks whether the current song is nearing its end. Similar to the decision in step 804, the decision in step 806 might depend on receiving the advance signal 318. The advance signal 318 might be generated by the program 20 itself, which tracks what portion of the first song 304 is playing. For example, the program 20 might track a playhead frame number, which might be a frame number associated with a frame of the song that is currently playing. If the playhead frame number gets close to a frame number associated with the end of the song, the program 20 might decide to advance to the next song. This might cause the program 20 or a component within the program 20 to trigger the advance signal 318, which in turn triggers the advance. It should be understood as before that “advance signal” should be construed broadly—a signal in this context might be an actual electrical signal (e.g., a flag that is raised, or variable value that is changed in response to getting near the end of the song) or it might be any other way in which the program 20 becomes aware that the end of the song is approaching.
If the current song is not nearing its end, the program 20 will go back to step 802 and continue playing the current song. The program 20 will then proceed once again to step 804, and this cycle will continue until, for example, the advance signal 318 is received.
If in either step 804 or 806, the answer to the question at issue is in the affirmative (e.g., an advance signal 318 is received), then the program 20 will seek to advance to the next song. In such an instance, the program 20 will proceed to step 808, which checks whether an appropriate transition (such as transitions 50, 50a shown in
Whether a transition is available may depend on whether it has been rendered and is ready for playback. This might depend on the playhead location within the current song, the location of the next song at which the program 20 seeks to enter, what transition mode the user might have chosen via the user interface 28, and any number of other factors, such as the processing capacity of the computer system running the program 20, the availability of cuepoints 40 for mixing purposes, and latency over the network 29. For example, in a “smooth transition mode” (which might be, for example, the “Type A” transition discussed earlier in connection with
It should also be noted that a transition does not necessarily have to be “pre-rendered” in order for it to be considered ready. In some embodiments, a transition may be rendered in real-time, right before or at playback time.
Regardless of when or how it is rendered, in the present embodiment, if the program 20 determines that an appropriate transition is not available, then the program 20 will cycle back to step 802 and keep playing the current song. If the program 20 determines that an appropriate transition is ready, the program 20 will then proceed at the appropriate time to step 810, which involves playing the transition. It should be noted that the program 20 may move to this step 810 at any time—depending on the embodiment at issue, the program need not wait until the playhead reaches one of the cuepoints 40 in the currently playing song.
After the program 20 plays the transition in step 810, it will proceed to step 812, which will involve loading a new song into the player 22. This step may involve looking at what song has been specified by the user as the next song 1390 in the user interface 28. Alternatively, the program 20 may adopt certain default rules to govern the choice of the next song. For example, if the user has not specified a next song, or for some reason the next song that the user has specified is not available for playback, the program 20 may choose another song, such as the song that just played (referred to as the current song above) and play that or some portion of that again. Or the program 20 may loop portions of songs to fill time until an appropriate next song has been identified and is ready for playback.
After the next song has been loaded in step 812, the method will go back to step 800, and the player 18 will begin playback of the next song. The method will then proceed again, as the next song will become the currently playing song and the program 20 will identify a new next song to be played (e.g., this might be the second queued song 1392, as shown in
Although
FIG. 9—Exemplary Method for Determining Transition Rendering
We now turn to
Rendering involves steps previously discussed in this specification, such as time-stretching or changing the number of frames in one or more songs, filtering frames, applying a linear ramp, and so on (see discussion in connection with
In step 854, the program 20 determines whether the rendering of the transition is complete. If it is not, the program 20 continues rendering by proceeding back to step 852. If rendering is complete, the program 20 proceeds to step 856, where it determines if there are more transitions to render. Whether there are more transitions to render will depend on factors similar to the ones listed above and previous portions of this specification.
If the program 20 determines there are no more transitions to render, then the process moves to step 860 and terminates. Otherwise, if there are more transitions to render, the program 20 proceeds to step 858, where it loads in the one or more new songs that will be rendered by the program 20. The program 20 then returns back to step 850, where it begins rendering the new transition.
As with the previous flow chart in
It should be understood that a wide variety of additions and modifications may be made to the exemplary embodiments described within the present application. For example, in alternate embodiments, the user interface 28 may give users the ability to purchase songs they hear on the Internet radio or via preview clips. Additionally, the order of steps 804, 806, and 808 in
It is therefore intended that the foregoing description illustrates rather than limits this invention and that it is the following claims, including all of the equivalents, that define this invention:
This application is a continuation of prior U.S. patent application Ser. No. 13/281,405, entitled “System and Method for Mixing Song Data Using Measure Groupings,” and filed Oct. 25, 2011, by the present inventor, Michael Yang (“'405 application”). This application claims priority to and incorporates by reference the '405 application.
Number | Name | Date | Kind |
---|---|---|---|
5747716 | Matsumoto | May 1998 | A |
5919047 | Sone | Jul 1999 | A |
6066792 | Sone | May 2000 | A |
6175632 | Marx | Jan 2001 | B1 |
6294720 | Aoki | Sep 2001 | B1 |
6307141 | Laroche et al. | Oct 2001 | B1 |
6343055 | Ema et al. | Jan 2002 | B1 |
6344607 | Cliff | Feb 2002 | B2 |
6489549 | Schmitz et al. | Dec 2002 | B2 |
6538190 | Yamada et al. | Mar 2003 | B1 |
6696631 | Smith et al. | Feb 2004 | B2 |
6888999 | Herberger et al. | May 2005 | B2 |
6889193 | McLean | May 2005 | B2 |
6933432 | Shteyn et al. | Aug 2005 | B2 |
6967905 | Miyashita et al. | Nov 2005 | B2 |
7081582 | Basu | Jul 2006 | B2 |
7208672 | Camiel | Apr 2007 | B2 |
7216008 | Sakata | May 2007 | B2 |
7220911 | Basu | May 2007 | B2 |
7424117 | Herberger et al. | Sep 2008 | B2 |
7525037 | Hansson et al. | Apr 2009 | B2 |
7842878 | Vorobyev | Nov 2010 | B2 |
7855333 | Miyajima et al. | Dec 2010 | B2 |
7855334 | Yamashita et al. | Dec 2010 | B2 |
7999167 | Yoshikawa et al. | Aug 2011 | B2 |
8069036 | Pauws et al. | Nov 2011 | B2 |
20030205124 | Foote et al. | Nov 2003 | A1 |
20060112808 | Kiiskinen et al. | Jun 2006 | A1 |
20060155400 | Loomis | Jul 2006 | A1 |
20070076547 | Rahman et al. | Apr 2007 | A1 |
20070259650 | Felder | Nov 2007 | A1 |
20070261537 | Eronen et al. | Nov 2007 | A1 |
20080282870 | Carrick et al. | Nov 2008 | A1 |
20090048694 | Matsuda et al. | Feb 2009 | A1 |
20090049979 | Naik et al. | Feb 2009 | A1 |
20090223352 | Matsuda et al. | Sep 2009 | A1 |
20100142521 | Evans et al. | Jun 2010 | A1 |
20110112672 | Brown et al. | May 2011 | A1 |
20110276864 | Oules | Nov 2011 | A1 |
20120215935 | Woods | Aug 2012 | A1 |
Number | Date | Country |
---|---|---|
0932157 | Jul 1999 | EP |
2365616 | Feb 2002 | GB |
2007036846 | Apr 2007 | WO |
2007060605 | May 2007 | WO |
Entry |
---|
DJ 2 Degrees. “iDJ App by Numark Review.” crossfadr.com (Internet publication). Aug. 16, 2011. Available at (as of Feb. 3, 2012): http://crossfadr.com/2011108/16/idj-app-by-numark-review/. |
Opam, Kwame. “Minimash Lets You Pretend to Be an iPad DJ While It Does All the Work.” Gizmodo.com (Internet publication). Aug. 15, 2011. Available at (as of Feb. 3, 2012): http://gizmodo.com/5830954/minimash-lets-you-pretend-to-be-an-ipad-dj-while-it-does-all-the-work. |
Parker, Nick and Van Buskirk, Eliot. “Beat Parade Spins Short-Attention-Span DJ Sets from a Single Song.” Evolver.fm (Internet publication). Feb. 18, 2011. Available at (as of Feb. 3, 2012): http://evolver.fm/2011/02/18/beat-parade-spins-short-attention-span-dj-sets-from-a-single-song/. |
Fingas, Jon. “Review: Djay for iPad.” macnn.com (Internet publication). Dec. 26, 2010. Available at (as of Feb. 3, 2012): http://www.macnn.com/reviews/djay-for-ipad.html. |
Number | Date | Country | |
---|---|---|---|
Parent | 13281405 | Oct 2011 | US |
Child | 13316486 | US |