Wonder if anyone can help me figure this thing out (there is 0 documentation).
I'm trying to figure out how the Gather VOP works on a very basic level, so I decided to make a simple/fast color bleeding shader that simply gathers surrounding diffuse color from an exported color parameter. I figure that combining this output with occlusion should be much faster than full irradiance.
To do this I pipe normalised N into the “dir” input, set the imported variable to the same name as my exported parameter, and create the parameters for samples, maxdist, scope etc. I create a vector constant and wire it straight thru the loop.
It seems to do what I want it to do… The problem is that it always looks as if the Gather is only using 1 sample, regardless of the value I set. It takes longer to render as I increase the samples, but there's no improvement in quality at all.
I suspect I have to more than just wire a constant from from input to output just to make the red error go away I cant see how I can apply what I know about a For Loop to it.
Im stuck.
cheers
S
Gather Vop?
9374 7 2- Serg
- Member
- 511 posts
- Joined:
- Offline
- ophiuchus42
- Member
- 39 posts
- Joined: July 2005
- Offline
Hi, there. Looking at the generated vex code (right click on any node and View Vex Code) it looks like the first added value plugged in to “next” of the gather vop is used for Cf in the gather call. In your setup it is always grabbing the value from the last call. I think all you have to do is plug a second value in to the gather vop, and inside add the first and second together, and plug the sum into the second added output. That seems to generate the correct code. You'll probably also want to divide by the number of samples.
Peter.
Peter.
- Serg
- Member
- 511 posts
- Joined:
- Offline
Thanks Peter,
I did look and compare to the vex documentation… but looking is different than seeing
I will try what you suggested.
Btw it's pretty amazing what you can do with this thing! completely separate shaders talking to each other and all that!
Not to mention being able to sample stuff from the current shader, i.e. for a quick fake sss, displace P along N and use negated N as the dir (thus shooting rays towards the surface), Gather an exported illum model and voila, blurry diffuse lighting
renders and hip coming later.
S
I did look and compare to the vex documentation… but looking is different than seeing
I will try what you suggested.
Btw it's pretty amazing what you can do with this thing! completely separate shaders talking to each other and all that!
Not to mention being able to sample stuff from the current shader, i.e. for a quick fake sss, displace P along N and use negated N as the dir (thus shooting rays towards the surface), Gather an exported illum model and voila, blurry diffuse lighting
renders and hip coming later.
S
- Serg
- Member
- 511 posts
- Joined:
- Offline
Hello,
adding the 0 constant to another 0 constant inside the gather loop worked (confusing or what), it now accumulates and the result gets divided by the number of samples, great
But, it doesn't work if I want to fetch more than one variable, like ray:length (which I want to use for attenuating the intensity with distance). If I do the same (adding the 2 float constants) it either renders black or only 1 sample again.
Also, If I want to sample occluded ambient lighting It doesn't work, it seems to sample N or P instead. However if I plug the occlusion output into another “next” in the gather loop (not wiring it through or anything else), it works… but why?
Anyway here's a render 3m30s on 3 cores (gamma corrected):
the circles are emmissive.
Whats great about this is:
- It will drop right into a non-pbr pipeline
- you can pick exactly what gets sent, which shader receives it and what objects are visible to it.
- bounce can come in an AOV
- whereas the regular “irradiance” shader will run the entire shader for every sample it gathers, with this approach you can decide to only gather the Lambert and a texture, or whatever.
The hip is attached, the shader contains the remnants of the distance attenuation I was talking about. If you want to see ambient light bounce make sure the occlusion gets plugged into the gather and that it gets mixed with the lambert before the “clr” export.
Cheers
S
adding the 0 constant to another 0 constant inside the gather loop worked (confusing or what), it now accumulates and the result gets divided by the number of samples, great
But, it doesn't work if I want to fetch more than one variable, like ray:length (which I want to use for attenuating the intensity with distance). If I do the same (adding the 2 float constants) it either renders black or only 1 sample again.
Also, If I want to sample occluded ambient lighting It doesn't work, it seems to sample N or P instead. However if I plug the occlusion output into another “next” in the gather loop (not wiring it through or anything else), it works… but why?
Anyway here's a render 3m30s on 3 cores (gamma corrected):
the circles are emmissive.
Whats great about this is:
- It will drop right into a non-pbr pipeline
- you can pick exactly what gets sent, which shader receives it and what objects are visible to it.
- bounce can come in an AOV
- whereas the regular “irradiance” shader will run the entire shader for every sample it gathers, with this approach you can decide to only gather the Lambert and a texture, or whatever.
The hip is attached, the shader contains the remnants of the distance attenuation I was talking about. If you want to see ambient light bounce make sure the occlusion gets plugged into the gather and that it gets mixed with the lambert before the “clr” export.
Cheers
S
- Serg
- Member
- 511 posts
- Joined:
- Offline
- dsedov
- Member
- 32 posts
- Joined: July 2005
- Offline
- circusmonkey
- Member
- 2624 posts
- Joined: Aug. 2006
- Offline
Awesome stuff ! This is something thats really useful ! . I have noticed a few fixes in the journal concerning gather loops !
Houdini 10.0.381: Fix a sampling problem with gather loops that would produce line artifacts when sampling with a cone angle in micropolygon rendering.
Just doing a test render the distance arb out does not seem to return anything
r
Houdini 10.0.381: Fix a sampling problem with gather loops that would produce line artifacts when sampling with a cone angle in micropolygon rendering.
Just doing a test render the distance arb out does not seem to return anything
r
Gone fishing
- lisux
- Member
- 581 posts
- Joined: July 2005
- Offline
-
- Quick Links