Replies: 1 comment 6 replies
-
| Nice approach. Personally, I agree with you that it would be good to attenuate by some non-zero amount, just to keep things real. | 
Beta Was this translation helpful? Give feedback.
                  
                    6 replies
                  
                
            
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
        
    
Uh oh!
There was an error while loading. Please reload this page.
Uh oh!
There was an error while loading. Please reload this page.
-
I wanted to implement dielectrics that both reflects and refract, i' ve came up with
Color color_from_scatter = Color(); for (const auto& ray_t : srec.scattered_rays) { if (ray_t.skip_pdf || ray_t.pdf == nullptr) { color_from_scatter += srec.attenuation * ray_color(ray_t.skip_pdf_ray, depth-10, world, lights); } else { auto light_ptr = std::make_shared<HittablePDF>(lights, rec.point()); MixturePDF p(light_ptr, ray_t.pdf); Ray scattered = Ray(rec.point(), p.generate(), r.time()); auto pdf_value = p.value(scattered.direction()); double scattering_pdf = rec.material()->scattering_pdf(r,rec,scattered); Color sample_color = ray_color(scattered, depth-1, world, lights); color_from_scatter += (srec.attenuation * scattering_pdf * sample_color) / pdf_value; } }the loop goes over all scattered rays (which are just 1 for every other material except dielectrics which will have 2 rays) but the double recursion is very slow (indeed im subtracting a big number from depth instead of just 1), i wanted to ask what is the go-to approach for this kind of functionality and also if i should attenuate the rays (in the dielectrics the attenuation is just Color(1,1,1,)).
The result seems to be decent: on the glass ball you can see some reflection while still being transparent
Beta Was this translation helpful? Give feedback.
All reactions