View Full Version : Relief-Mapping depth parameter

09-09-2010, 03:09 AM

I guess most of you know the relief-mapping algorithm:

f2s main frag relief( v2f IN,
uniform sampler2D rmtex:TEXUNIT0, // rm texture map
uniform sampler2D colortex:TEXUNIT1, // color texture map
uniform float4 lightpos, // light position in view space
uniform float4 ambient, // ambient color
uniform float4 diffuse, // diffuse color
uniform float4 specular, // specular color
uniform float2 planes, // near and far planes info
uniform float tile, // tile factor
uniform float depth) // scale factor for height-field depth
f2s OUT;
float4 t,c; float3 p,v,l,s; float2 dp,ds,uv; float d;
// ray intersect in view direction
p = IN.vpos; // pixel position in eye space
v = normalize(p); // view vector in eye space
// view vector in tangent space
s = normalize(float3(dot(v,IN.tangent.xyz),
// size and start position of search in texture space
ds = s.xy*depth/s.z;
dp = IN.texcoord*tile;

I'm just wondering about the depth parameter because I don't get why it controls the height of the heightmap details. I.e. if you put in a terrain map, a bigger depth parameter will result in higher mountains etc.

This s.xy*depth/s.z seems like it's the calculation of the parallax vector as described in Welsh's paper (projection of the eye vector onto the surface) and you can scale it with the depth parameter. This means that smaller depth paramter = shorter parallax vector = smaller sampling stepsize. So how does this scale the heightmap at all?

09-09-2010, 02:07 PM
The depth parameter determines how much to shift the texture coordinate with an angle change, what basically is similar to changing the height of the imaginary height map (no offset = plain surface, hight offset -> more surface height variety).

09-12-2010, 03:30 AM
Yeah sure, but I don't get how exactly this works. I.e. I also found this explanation:

Try to vizualize it mentaly. When the vector length increases, it increases backwards. That is, as the height incresases the origin of the ray is pushed backwards, in the direction of the ray, so that it remains located at the height limit.

If the ray a the surface full of bumps at an oblique angle, you will hopefully notice that increasing the height and pushing the ray origin backwards makes the ray hit the bumps in a lower position. That gives the illusion that the bumps are higher.

So lets say my eye vector hits the top of a mountain. By scaling the depth parameter, the top of my eye vector remains at the top of the mountain (or what does he mean with height limit?) whereas it's length increases backwards.

Given that, I have no idea why scaling the depth parameter has any effect on the surface height since the intersection point between eye vector and surface height profile always remains the same.

09-15-2010, 10:39 AM

09-15-2010, 11:01 AM
If you want to have a real parallax effect, you should perform a full surface VS ray test.

In the rough approximation you posted (I'm using a similar one), the actual intersection is not tracked, and the depth parameter just scales the offset we predict.

09-16-2010, 01:39 AM
It does but it occurs later in the algorithm. Relief-Mapping uses a combination of linear and binary search to sample the height profile but I really don't get how this depth param works and why my results look like how they do when manipulating this parameter.