The present invention generally pertains to computer-generated audio, and more specifically, to a method and system for adjusting reverberation of computer-generated sounds.
The tremendous advancements made in computer technology and price/performance over the past few decades has revolutionized computer graphics. For example, early personal computers featured games that provided only monochromatic images, or chalky, low-resolution images including only a few colors at a time. By contrast, today's video games present realistic, three-dimensional images in thousands of colors. Sports games feature likenesses of players that are so accurate and detailed that the players' faces actually can be recognized in the computer animation. In fact, such clarity is possible not only on personal computers, but on video game systems retailing for less than $150. Similarly, movie studios continually expand their use of computer graphics in creating feature films, making the unreal believable. Computer graphics have been used to create increasingly better special effects, as well as entirely computer-generated feature films. Still more films feature live actors in movies where one or more of the other characters are entirely computer-generated, and/or some or all of the backdrops are computer-generated.
In support of improved computer graphics, computer audio hardware systems have improved a great deal. Instead of a single tinny-sounding internal speaker used to generate beeps and monophonic tones in early personal computers, current audio hardware is able to generate high fidelity music and multi-channel surround sound. For example, the Microsoft Corporation's XBOX™ gaming system includes a media communications processor (MCP) with a pair of digital signal processors capable of processing billions of instructions per second. In addition to providing network access and performing other functions, the MCP includes an audio system capable of driving a six-speaker, surround sound audio system. Furthermore, the audio system is capable of precisely controlling audio reverberation for generating three-dimensional audio in conformance with the Interactive Audio Special Interest Group (IASIG) of the MIDI Manufacturers Association Interactive 3D Audio Rendering Guidelines—Level 2.0 Specification (I3DL2). This specification is also recognized by personal computer-based audio systems, such as Microsoft Corporation's DirectSound™ audio specification, as well as by other audio systems.
Audio systems adhering to the I3DL2 specification (and other audio systems) can provide very realistic three-dimensional sound. For example, the I3DL2 specification recognizes twelve different input values that can be set to precisely tailor audio effects, including: ROOM, ROOM_HF, ROOM_ROLLOFF_FACTOR, DECAY_TIME, DECAY_HF_RATIO, REFLECTIONS, REFLECTIONS_DELAY, REVERB, REVERB_DELAY, DIFFUSION, DENSITY, and HF_REFERENCE.
The ROOM value generally adjusts the potential loudness of non-reverb sounds by setting an intensity level and low-pass filter for the room effect, with a value ranging between −10000 mB and 0 mB. The default value is −10000 mB. The ROOM_HF value determines the proportion of reverberation that includes high frequency sounds versus low frequency sounds. More specifically, ROOM_HF specifies the attenuation of reverberation at high frequencies relative to the intensity at low frequencies. ROOM_HF can be a value between −10000 mB and 0 mB. The default value is 0 mB. The ROOM_ROLLOFF_FACTOR value determines how quickly sound intensity attenuates over distance, in the environment. For example, ROOM_ROLLOFF_FACTOR might be used to model an environment consisting of warm, moist air, which squelches sound more quickly than cool, dry air. ROOM_ROLLOFF_FACTOR is a ratio that can include a value between 0.0 and 10.0, and the default value is 0.0.
In addition to these values that control propagation effects of sound, other values more specifically relate to the reverberation of sound. The DECAY_TIME value specifies the decay time of low frequency sounds until the sound becomes inaudible and can be set between 0.1 and 20.0 seconds, with a default value of 1.0 seconds. The DECAY_HF_RATIO value determines how much faster high frequency sounds decay than do low frequency sounds. DECAY_HF_RATIO can be set between 0.1 and 2.0, with a default value of 0.5.
The REFLECTIONS value determines the intensity of initial reflections relative to the ROOM value and can be set between −10000 mB and 1000 mB, with a default value equal to −10000 mB. The REFLECTIONS_DELAY value specifies the delay time of the first sound reflection, relative to the directly received sound and can be set between 0.0 and 0.3 seconds, with a default value of 0.02 seconds. The REVERB value determines the intensity of later reverberations, relative to the ROOM value or, generally, how “wet” the reverberation level is in terms of the overall sound. REVERB can be set to a value between −10000 mB and 2000 mB, and the default value is −10000 mB. The REVERB_DELAY value specifies the time limit between the early reflections and the late reverberation, relative to the time of the first reflection. REVERB_DELAY can be set between 0.0 and 0.1 seconds, with a default value of 0.04 seconds. The DIFFUSION value controls the amplitude intensity of reverberation in the late reverberation decay and can be set between 0.0% and 100.0%, with a default value of 100.0%. The DENSITY value represents the percentage of the modal density in the late reverberation decay, which can be thought of as the portion of surfaces reverberating distinct sounds. Density can be a value between 0.0% and 100.0%, with a default value of 100.0%. Finally, the HF_REFERENCE value sets the delineation point between which sounds are considered high frequency as opposed to low frequency, for purposes of any frequency-based distinction, such as applied in the DECAY_HF_RATIO. HF_REFERENCE can be set anywhere in the audible range between 20.0 Hz and 20,000.0 Hz. The default value is 5000.0 Hz.
Clearly, sound engines recognizing the I3DL2 specification and similar specifications provide software designers and creators tremendous control in tailoring the reverberation of sound to provide a realistic three-dimensional auditory experience. Unfortunately, however, with all of the capabilities provided by the I3DL2 specification and other such specifications, the capability of the audio system and other computer components affecting sound tends to be underutilized. Although systems recognizing the I3DL2 specification provide great control, I3DL2 also imposes a tremendous amount of work for software engineers to determine and set the myriad values needed to appropriately generate realistic sound effects within a computer-generated environment.
For example, consider a street racing game in which a user controls an automobile as it races around in a city. The track or course followed by the auto will pass through open areas, past buildings, under bridges, and encounter various types of objects. As any driver of an actual automobile will readily understand, objects in the nearby environment affect how the sound generated by the automobile reverberates and how the quality of the sound heard inside the automobile changes as the automobile passes near and past the objects. Thus, to create “believable” reverb effect for sound in such a game, as the automobile is driven around the track, the different parameters provided in the I3DL2 specification all need to be appropriately set—either at spaced apart intervals, or for each object or set of objects encountered by the auto in the virtual environment. This process can literally involve person years to accomplish for a single game. Therefore, unfortunately, when deadlines approach or budgets dwindle as the coding of a game reaches the deadline for completion, the resources devoted to setting these parameters may be reduced or cut. As a result, the quality and realism of the reverb sounds experienced by users of the game may be unsatisfactory, or at least unremarkable.
Not only is setting these reverb parameters incredibly labor intensive, but it also is prone to human bias and error, so that the results can be unpredictable and unrealistic. As a further example, a game might involve a character that moves through different rooms of a building. Creation of the reverb parameters for a single environment might be divided between multiple audio designers. Unfortunately, each of the designers may have different predispositions and preferences regarding the audio quality. As a result, as the character passes from a room configured by a first audio designer to a room configured by a second audio designer, even if the rooms are very similar, the reverberations may be noticeably different. Certainly, in a well-designed game, movement between areas should be as seamless as possible, and significant shifts in audio effects should only occur when moving between significantly different types of spaces. Unwarranted shifts in audio quality thus detract from the realism and the user's appreciation and enjoyment of the game.
Thus, although the capabilities exist in computer systems and gaming systems to provide for realistic three-dimensional audio, the reality of achieving these capabilities may exceed the resources of programmers and designers creating a game or other form of virtual environment. As a result, the dimensional qualities of the audio generated may be somewhat unrealistic.
It would thus be highly desirable to improve the method used for creating computer-generated audio to enable a realistic sound quality to be achieved. Specifically, it would be desirable to simplify the process of setting audio parameters to provide for reverb effects that appropriately match the virtual environment portrayed in the video portion of the computer generation. This approach should greatly reduce the resources, time, and cost involved by eliminating the need for manually setting these parameters. Further, it would be desirable to automatically set the parameters so as to ensure smooth consistent transitions in the sound produced by the computer when moving between different portions of the computer-generated virtual environment.
One of the advantages of the present invention is that it provides a fast, non-labor-intensive method for setting reverb parameters for a computer-generated environment. As described above, to simulate the physical world, computer systems such as personal computers include reverb engines, but these reverb engines can require that as many as a dozen or more parameters be set to fully and realistically control the reverberation of sounds relative to the environment in which the sounds appear to be heard. In the physical world, the reverberation of sounds is determined by a combination of factors, including the composition of objects that reflect the sounds and the location of those objects relative to the source of the sounds and the listener. Comparably, for a computer-generated environment, embodiments of the present invention determine how objects present in the computer-generated environment would cause sound to reverberate as if in the real world and generate resulting reverberation parameters that can be applied to produce corresponding realistic sounding reverberation effects when the game is executed by a user. The reverberation parameters are created and stored for different points throughout a computer-generated environment. Thus, when the computer-generated environment is rendered, the reverberation parameters are retrieved and applied when generating sounds in the environment.
In addition to simplifying the process of setting reverberation parameters, embodiments of the present invention also ensure that reverberation parameters are set more consistently than might occur if the parameters were subjectively manually set, particularly if set by different persons. Setting reverberation parameters manually can yield inconsistent results. The settings of the reverberation parameters manually applied by a human designer in different parts of the environment may result in unnatural-sounding reverb when the listener's (i.e., the user's) point of hearing passes from one part of the virtual environment to another. The juxtaposition of the sets of parameters resulting from a user passing from one area to the other may expose unnatural changes in the degree of reverberation, reverb delay, decay time, proportion of high frequency reverberations, and other attributes. Moreover, multiple human audio designers working with different portions of a computer-generated environment may have significantly different tendencies and preferences that may be revealed only when the computer-generated environment is rendered, when those differences result in clearly audible discontinuities. By contrast, embodiments of the present invention automatically generate reverberation parameters based on features existing in the computer-generated environment, and thus, the parameters are consistently based on structures in the virtual environment and not subjective preferences of human designers that can vary dramatically between designers.
One aspect of the present invention is thus directed to a method for automatically deriving reverberation characteristics for a computer-generated environment from graphics data describing visually displayable contents of the computer-generated environment. A position of interest is selected in the computer-generated environment. The graphics data describing a portion of the computer-generated environment viewable from the position of interest when the computer-generated environment is rendered are accessed. Reverberation characteristics are derived for the position of interest from the graphics data describing each of a plurality of points in the portion of the computer-generated environment. The reverberation characteristics are derived at least in part from a distance of each point from the position of interest and a hardness value associated with the point.
The reverberation characteristics include at least one of property set values usable by a reverberation engine, and a plurality of environmental parameters from which the property set values are calculable when the computer-generated environment is rendered. The property set values are configured to be supplied to a reverberation engine conforming to at least one of the IA3DL2 specification and the EAX specification. The environmental parameters for the points include at least one of a mean distance to the points, a mode distance to the points, a median distance to the points, a mean hardness associated with the points, and a total number of points in the portion of the computer-generated environment. A subset of the points may be selected that describe the portion of the computer-generated environment viewable from the position of interest, the subset including points within at least one of a distance range from the position of interest and a lateral range relative to the position of interest. A plurality of subsets of points describing the portion of the computer-generated environment may be identified, with each of the plurality of subsets of points including points at a plurality of mode distances from the position of interest and having a plurality of mode hardnesses of points at a particular distance. Separate delay lines relating to each of the plurality of subsets of points may be used in developing the reverberation characteristics for the position of interest. The environmental parameters also may include a total number of points within the subset.
A portion of the property set values are derived in proportion to the total number of points within the subset relative to the total number of points. The property set values so derived preferably include at least one of a reverb decay time and a reverb volume. A portion of the property set values are proportional to the mean hardness of the points, including at least one of a decay high frequency ratio, a room high frequency attenuation, and a reflections delay time. In addition, a portion of the property set values are proportional to the distances to the points from the position of interest, the portion of the property set values including at least one of a decay time, a reflections intensity, a reflections delay time, and a reverb intensity.
The graphics data may include a cubemap describing the visually displayable contents of the computer-generated environment viewable from the position of interest. The reverberation characteristics for the position of interest are thus based on points representable on a plurality of faces of the cubemap. The reverberation characteristics derived from each of the plurality of faces is weighted according to at least one of a face with which the point is associated, and a position within the face with which the point is associated.
The hardness value is derivable from a feature with which the point is associated and may be retrieved from a hardness value table listing hardness values associated with compositions of features potentially included in the computer-generated environment.
A plurality of reverberation characteristics for the position of interest from the graphics data may be derived to correspond to a plurality of aspects of the position of interest. Each of the plurality of reverberation characteristics then are applied to audio channels corresponding to the aspects of the position of interest upon execution of the computer-generated environment. The aspects of the position of interest may correspond to at least one of lateral sides of the position of interest and forward and rearward faces of the position of interest. The plurality of reverberation characteristics for the position of interest may be determined by identifying a plurality of secondary positions of interest corresponding to the aspects of the position of interest, and determining the reverberation characteristics for each of the secondary positions of interest.
The reverberation characteristics may be derived in a pre-processing step performed before the computer-generated environment is visually rendered. The distance from the position of interest to each of the plurality of points is stored in a depth buffer, and the hardness of each of the plurality of points is stored in a stencil buffer. The reverberation characteristics are stored in association with the position of interest such that the reverberation characteristics are retrievable when the computer-generated environment is visually rendered.
A series of reverberation characteristics for a plurality of positions of interest within the computer-generated environment may be calculated, where the plurality of positions include at least one of a plurality of positions selected by an operator, and a plurality of positions at predetermined intervals along an exemplary path through the computer-generated environment. Reverberation characteristics for an additional position for which the reverberation characteristics were not previously calculated are derivable by interpolating the reverberation characteristics for at least two other positions of interest proximate to the additional position.
An operator can be enabled to adjust at least one of an allowable range of reverberation characteristics and operands used in deriving the property set values from the reverberation characteristics. Reverberation characteristics may be adjusted for the position of interest by using reverberation characteristics for an alternate position of interest that is either ahead or behind the position of interest in the computer-generated environment.
Another aspect of the present invention is directed to a memory medium having machine executable instructions stored for carrying out steps and a system configured to execute steps that are generally consistent with the steps of the method described above.
The foregoing aspects and many of the attendant advantages of this invention will become more readily appreciated as the same becomes better understood by reference to the following detailed description, when taken in conjunction with the accompanying drawings, wherein:
Identifying Visually Representable Features in Generating Reverberation Parameters
Position of interest 150 is at the center of cubemap 100. Cubemap 100 includes six faces, one for each face of the described cube. With z-axis 130 indicating the direction of motion, a face 160 is a forward face of cubemap 100 and a face 165 is a rear face of the cubemap 100. Thus, while traveling forward in the computer-generated environment, a user sees forward face 160 while rear face 165 lies behind the user. Similarly, a left face 170 and a right face 175 indicate what appears to the sides of the user as the user proceeds through the computer-generated environment, while an upper face 180 and a lower face 185 indicate what lies above and below the user, respectively. To those familiar with computer-generated environments, cubemap 100 represents a complete environment around position of interest 150 such that, as the user turns a field of view horizontally or vertically, faces 160-185 fully represent a simulated three-dimensional space about the position of interest.
As shown in
In describing reverberation, positions where reverberation is high are referred to as “wet,” while positions where reverberation is low are referred to as “dry.”
In computer-generated environments it is desirable to accurately recreate or simulate these reverb effects to add to the realism, drama, and/or ambiance of the computer-generated environment. As described above, with so many reverberation parameters to set, manual calibration of reverberation parameters responsive to features 210-250 would represent a highly labor-intensive task, open to undesirable variations based solely on individual designer predispositions or preferences. Embodiments of the present invention determine position and characteristics of features such as 210-250 and then automatically generate appropriate reverberation characteristics that are applied when the computer-generated environment is rendered.
Determining Reverberation Characteristics from Graphics Data
For purposes of illustration,
Furthermore, as is true in an actual physical environment, it is not only the features appearing ahead that may have an affect on reverberation of sound, but also, for example, features on left faces 460 and 560, overhead faces 470 and 570, and right faces 480 and 580.
By contrast, in the case of cubemap 500 (
As described above, while personal computer systems and gaming systems include reverberation engines that enable reverberation of sounds to be modeled, these reverberation engines may require as many as a dozen or more properties to be set in order to control of the reverberation effects. Embodiments of the present invention, however, use the environmental information obtainable from the graphics data to identify features in the computer-generated environment, around successive points of interest, that will reflect sound and derive the reverberation characteristics needed to control a reverberation engine for each point of interest as necessary when the computer generated environment reaches that point of interest.
In one embodiment of the present invention, reverberation characteristics are preferably derived in a pre-processing step. Once the graphics data controlling the appearance of the computer-generated environment have been created, an embodiment of the present invention derives reverberation characteristics for one or more positions of interest in the computer-generated environment. These reverberation characteristics can then be applied when the computer-generated environment is rendered and experienced by a user, so that the sound heard at each location includes a realistic reverberation. In one embodiment of the present invention, reverberation characteristics are derived in preprocessing for a plurality of positions of interest, and when the computer-generated environment is executed, reverberation attributes for a present position of interest are derived by interpolating reverberation characteristics for the present position from a number of proximate positions of interest for which preprocessed reverberation characteristics previously were derived.
Alternatively, in a suitably capable processing system, reverberation characteristics are derivable in real time as the graphics data is rendered for viewing when the computer-generated environment is executed. Reverberation characteristics thus are derived for each specific position of interest. Thus, as changed in the computer-generated environment occur, such as a wall being exploded or otherwise removed from a user, the reverberation characteristics are adjusted accordingly, in real time. It will be appreciated that a real time generation of such reverberation characteristics are derived from the graphics data in a manner comparable to the way that the reverberation characteristics are derived from the graphics data in preprocessing. It also should be appreciated that real time derivation of reverberation characteristics, although increasing demand for computing resources upon executing the computer-generated environment that would be involved in interpolating between predetermined values, will result in reverberation characteristics that may be more accurate to the computer-generated environment than interpolated values derived from preprocessed values.
As is well understood in computer graphics, visually representable features are comprised of a plurality of points. To visually render the features in a meaningful way, each of these points is located at a certain distance relative to the position of the interest from which the features are viewed. As a result, features that appear in the foreground and, thus, in front of other features, and are associated with a particular composition, are associated with a shorter distance relative to the position of interest so that foreground features are rendered in front of background features. In addition, each of the features is associated with a composition type, or texture, so that the features will be rendered in an appropriate shade or color, and will reflect or indicate shadows appropriate to the albedo of the material of which the feature is comprised. In visually rendering such features, a distance from the position of interest to the point is read into a depth buffer for the point, while the reflectance is read into a stencil buffer. These buffers often are joined and make up different portions of a single buffer.
Embodiments of the present invention use the distance to these points and the composition of these points to determine the reverberation characteristics attributable to each. In one embodiment of the present invention, for selected faces of a cubemap, distances to points within a certain lateral range on the cubemap face are determined, and a compositional hardness of each point is also determined. From the distances to the points, the hardness of the points, and the proportion of the surveyed area populated by these points, suitable environmental parameters can be automatically derived. Thus, without an operator manually setting the reverb properties for a myriad of points, an embodiment of the present invention can automatically derive the parameters for one or more positions of interest. Environmental parameters for a plurality of positions of interest, such as along a spline following an expected path through the computer-generated environment, can be derived and stored. Ultimately, upon rendering of the computer-generated environment, reverberation property set values, such as I3DL2 values, can be calculated from these environmental parameters or otherwise retrieved and applied to sounds generated within the computer-generated environment to provide desirable sound reverberation.
Deriving Environmental Parameters Affecting Reverberation of Sound
Enlarged array 610b shows information derived from points in array 610a. Specifically, from each sector 612, two figures are derived. A distance 614 indicates the distance from the position of interest to the point. A hardness 616 represents a relative hardness of the material of which the point is composed. Distance 614 actually is a value associated with each point on face 480, whereas hardness value 616 is derived from a texture associated with the point. From the texture associated with each point, a hardness value representative of the material represented by the texture can be substituted. A hardness, in one embodiment of the invention, is an eight-bit value assigned to represent the relative hardness of various compositions. A look-up table may be used that lists hardness values associated with various compositions or textures, as shown in exemplary Table 1, below.
The hardness values are eight-bit binary values represented as two-digit hexadecimal values. The hardness values, as shown in Table 1, range from a softest value having the least unit reverberation, or 0F (16), to a hardest value having the greatest unit reverberation, or FF (255). In one embodiment of the present invention, the hardness values are scaled to a decimal value in the range between 0.0 and 1.0, where 0.0 represents the softest, least reverberant materials, and 1.0 represents the hardest, most reverberant materials.
Referring back to
Referring to
In one embodiment of the present invention, a distance range and a lateral range relative to the position of interest are set to determine the portion of each face that is evaluated. Thus, in order to reduce processing demands, not every point of each face is evaluated, and points at a distance considered too far to affect reverberation are preferably ignored. It is assumed for the sake of the examples shown in
From the data read into the depth and stencil buffers, intermediate values representing the environment portrayed on the sampled portions of the faces are calculated. In one embodiment of the present invention, these intermediate vales include a mean distance, a mode distance, a median distance, and a mean hardness for each face. The mean distances and mean hardness can be mathematically determined by totaling the values for these parameters that are stored in the depth and stencil buffers, respectively, and dividing by the number of points sampled. For example, the mean distance for points included in array 610b is approximately 81 units, and the mean hardness is approximately 92. The mean distance for points included in array 650b is 5.75 feet and the mean hardness is 223.
To determine the most represented or mode distance and the median distance, histograms 700 and 760 shown in
Embodiments of the present invention may use histogram analysis to further refine analysis of the computer-generated environment. For example, using information derived from histograms about the computer-generated environment, multiple mode distances may be used to determine distance to multiple features of the computer-generated environment in order to derive reverberation characteristics associated with those multiple features. Thus, as shown in
For example, in evaluating the graphics data, it may determined that a first mode distance range 10-15 meters away from the position of interest, and points at the first mode distance includes 40% of the points being evaluated. A second mode distance may be at a distance range 20-25 meters away from the position of interest, and points at the second mode distance includes 36% of the points being evaluated. For points at the first mode distance, a first composition histogram may indicate that a first mode hardness having a maximum hardness of FF, while at the second mode distance, a second composition histogram may indicate a first mode hardness having a lesser hardness value of CF. From these environmental aspects, reverberation attributable to the points having a first mode hardness at the first mode distance and second mode distance can be determined and used to simulate the reverberation. Alternatively, any desired number of mode distances and/or mode hardnesses at each of these distances, or any desired number of mode hardnesses and/or mode distances for each of these hardnesses, can be used to derive a plurality delay lines to create a more detailed reverberation profile for the computer-generated environment.
In sum, by identifying multiple features in the graphics data and analyzing the composition of and distance to the features, embodiments of the present invention may more closely approximate the manner in which reverberation of sound occurs in the physical world. Thus, although additional processing resources are required in deriving environmental parameters associated with multiple features and/or multiple distances in either preprocessing or real-time processing of the computer-generated environment, a more realistic set of assessment reverberation characteristics may result.
Furthermore, in another embodiment of the present invention, a plurality of reverberation characteristics may be derived for each position of interest. The plurality of reverberation characteristics may correspond to a plurality of aspects of the position of interest, such as left and right sides of the position of interest or forward and rearward faces of the position of interest. As a result, if separate left and right and/or forward and rear audio channels are available, reverberation characteristics can be applied to each of those channels to provide a more vivid or realistic multi-dimensional experience. Thus, for example, if in the computer generated environment, the position of interest includes a wide open space to a left side and a confined space of hard surfaces to the right side, reverberation will be applied to more accurately apply reverberation such that a user will experience more reverberation from a right audio channel than a left audio channel.
To derive the multiple sets of reverberation characteristics corresponding to the different aspects of the position of interest, secondary positions of interest actually may be derived from each position of interest, with reverberation characteristics derived for each of the secondary positions of interest. Thus, using the previous example where the position of interest includes a wide open space to a left side and a confined space of hard surfaces to the right side, a secondary left position of interest may be defined as offset to the left of the position of interest by a predetermined amount, while a secondary right position of interest may be defined as offset to the right of the position of interest by a predetermined amount. By determining the reverberation characteristics for both the secondary left position of interest and secondary right position of interest, appropriate reverberation characteristics may be derived to apply to separate left and right audio channels.
Adjustment of Values Affecting Reverberation
In one embodiment of the present invention, these values are then combined to derive an overall value for selected faces of the cubemap in reaching an overall environmental assessment used in determining the reverberation for the position of interest. In combining selected faces, a total number of points sampled and a total number of points within a prescribed range of distances are counted, as further described below. In one embodiment of the invention, the mean distances and mean hardness determined for each face may be weighted rather than simply based upon an average. For example, in the example of an automobile racing environment, it may be desirable to attribute more reverberation to features looming ahead to allow a enable a user to more realistically sense the effect on sound caused by such features before the features pass from view. Accordingly, features positioned forward toward the direction of expected motion may be assigned a higher weight than those in the other directions, i.e., on the other faces of the cubemap. Similarly, when values from the faces are combined to represent an overall value surrounding the position of interest, values of particular faces may be weighted more heavily. Thus, in the example of the automobile racing game, if it is desirable for dramatic effect (or to provide greater realism) to attribute more reverb to overpasses, overhead signs, and tunnels, the overhead face may be assigned greater weight.
In one embodiment of the present invention, weights assigned, ranges used in sampling features, and various other variables affecting reverberation may be adjusted by an operator via a user interface.
Moving the cursor to some options invokes a submenu enabling values related to the option to be adjusted, as shown in
In addition to making adjustments that affect how an embodiment of the present invention will derive values from faces of the cube map, an operator also may tune values of the property set that will determine the reverberation at runtime.
Similarly,
Logical Steps for Automatically Deriving and Applying Reverberation Parameters
In one embodiment of the present invention, environmental characteristics are derived from cubemaps surrounding a plurality of positions of interest throughout the computer-generated environment. These environmental parameters include the mean distances, mean hardness, median distances, mode distances, number of points evaluated, and number of points in range, as described above, in connection with
Flow diagram 900 in
At a step 912, flow diagram 900 accesses a next position of interest in the computer-generated environment. The positions of interest for which environmental parameters are derived can be selected in a number of ways. In one embodiment of the present invention, using the example of an automobile racing simulation, the positions of interest might be chosen to represent a plurality of positions at pre-selected intervals around a race course. For example, the positions of interest might be designated as being spaced apart every two meters from a starting point of the course, through its finish line. At a step 914, data describing a next face of the cubemap for the position of interest are accessed. At a step 916, as described above in connection with
Once the face has been rendered to store the distance and hardness in the appropriate buffers, at a step 922, distance histograms are generated, as described above in connection with
At a decision step 928, it is determined if all the faces have been processed. If not, flow diagram 900 loops to step 914 to access data for the next face of the cubemap for the current position of interest. On the other hand, if it is determined at decision step 928 that all the cubemap faces for the current position of interest have been processed, at a step 930 the environmental parameters are combined and/or weighted to derive the composite environmental parameters for the current position of interest. At a step 932, the environmental parameters are associated and/or stored in connection with the current position of interest so that the environmental parameters can be retrieved when the computer-generated environment is rendered upon execution.
At a decision step 934, it is determined if preprocessing has been completed for all the positions of interest. If not, flow diagram loops to step 912 where the data for the next position of interest is accessed, and the successive steps are performed for that position of interest, as described above. On the other hand, if it is determined at decision step 934 that preprocessing is complete for all positions of interest, the reverberation preprocessing ends at a step 936.
It should be appreciated that the process described by flow diagram 900 is largely automatic. Environmental parameters from which the property set values can be derived are determined from the graphics data. Operators and designers are enabled to adjust values and repeat preprocessing until they are satisfied with the results. However, operator intervention is not required. The option that enables an operator to selectively modify the automatically selected values is thus very different from conventional methods that require reverberation property set values to be assigned manually throughout the computer-generated environment.
Derivation of environmental parameters as described in connection with
From the data for each cube face, the values are combined to determine overall environmental parameters:
It will be appreciated that, in one embodiment of the invention, it may be desirable to emphasize reverberation for overhead structures appearing on overhead cubemap faces for dramatic effect. Accordingly, a mode distance for the overhead face, “TopModeDistance” may be included in the overall derivation to ensure emphasis to be attributed to a most-commonly occurring distance of features appearing overhead. As described above, data for each face is partially derived using straightforward histogramatic analysis:
With the reverberation characteristics being derivable from the environmental parameters that were automatically determined and stored according to flow diagram 900, reverberation property set values are readily generated at runtime according to the logical steps illustrated in flow diagram 1000 of
Regardless of whether the environmental parameters were preprocessed and simply retrieved for the position of interest at step 1010 or were determined by interpolation at step 1016, at a step 1018, the reverberation property set values are calculated. In one embodiment of the present invention, the reverberation property set values are derived by linear interpolation. As described in connection with
In one embodiment of the present invention, interpolation is performed using a conventional linear interpolation. For example, a “LerpClamp” routine may be invoked to determine linear interpolation, based on provided values between a predetermined minimum and maximum:
The reverberation for each position of interest can thus readily be determined at runtime as the user moves about in the computer-generated environment. The results are consistent and realistic, and more importantly, are determined without requiring manual setting of parameters for each potential position of interest in the environment. Accordingly, a substantial savings in labor is achieved, and the resulting reverberation effects heard at runtime are typically much more realistic.
Exemplary Computing System for Implementing Present Invention
With reference to
A number of program modules may be stored on the hard disk, magnetic disk 1129, optical disk 1131, ROM 1124, or RAM 1125, including an operating system 1135, one or more application programs 1136, other program modules 1137, and program data 1138. A user may enter commands and information in PC 1120 and provide control input through input devices, such as a keyboard 1140 and a pointing device 1142. Pointing device 1142 may include a mouse, stylus, wireless remote control, or other pointer. Other input devices (not shown) may include a microphone, joystick, haptic joystick, yoke, foot pedals, game pad, satellite dish, scanner, camera, or the like. These and other input/output (I/O) devices are often connected to processing unit 1121 through an I/O device interface 1146 that is coupled to the system bus 1123. The term I/O interface is intended to encompass each interface specifically used for a serial port, a parallel port, a game port, a keyboard port, a Firewire (IEEE 1394) port, and/or a universal serial bus (USB) interface. A display 1147 can be connected to system bus 1123 via an appropriate interface, such as a video graphics adapter 1148. It will be appreciated that PCs are often coupled to other peripheral output devices (not shown), such as speakers (through a sound card or other audio interface—not shown) and printers.
The present invention may be practiced on a single machine, although PC 1120 can also operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 1149. Remote computer 1149 may be another PC, a server (which is typically generally configured much like PC 1120), a router, a network PC, a peer device, or a satellite or other common network node, and typically includes many or all of the elements described above in connection with PC 1120, although only an external memory storage device 1150 has been illustrated in
When used in a LAN networking environment, PC 1120 is connected to LAN 1151 through a network interface or adapter 1153. When used in a WAN networking environment, PC 1120 typically includes a modem 1154, or other means such as a cable modem, Digital Subscriber Line (DSL) interface, or an Integrated Service Digital Network (ISDN) interface for establishing communications over WAN 1152, such as the Internet. Modem 1154, which may be internal or external, is connected to the system bus 1123 or coupled to the bus via I/O device interface 1146, i.e., through a serial port. In a networked environment, program modules, or portions thereof, used by PC 1120 may be stored in the external memory storage device 1150. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers may be used, such as wireless communication and wide band network links.
Although the present invention has been described in connection with the preferred form of practicing it and modifications thereto, those of ordinary skill in the art will understand that many other modifications can be made to the present invention within the scope of the claims that follow. Accordingly, it is not intended that the scope of the invention in any way be limited by the above description, but instead be determined entirely by reference to the claims that follow.