test_ssf_fresnel_dielectric_conductor.c (1780B)
1 /* Copyright (C) 2016-2018, 2021-2025 |Méso|Star> (contact@meso-star.com) 2 * 3 * This program is free software: you can redistribute it and/or modify 4 * it under the terms of the GNU General Public License as published by 5 * the Free Software Foundation, either version 3 of the License, or 6 * (at your option) any later version. 7 * 8 * This program is distributed in the hope that it will be useful, 9 * but WITHOUT ANY WARRANTY; without even the implied warranty of 10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 11 * GNU General Public License for more details. 12 * 13 * You should have received a copy of the GNU General Public License 14 * along with this program. If not, see <http://www.gnu.org/licenses/>. */ 15 16 #include "ssf.h" 17 #include "test_ssf_utils.h" 18 19 #include <rsys/math.h> 20 21 int 22 main(int argc, char** argv) 23 { 24 struct ssf_fresnel* fresnel; 25 struct ssf_fresnel* dummy; 26 struct mem_allocator allocator; 27 (void)argc, (void)argv; 28 29 mem_init_proxy_allocator(&allocator, &mem_default_allocator); 30 CHK(ssf_fresnel_create(&allocator, &fresnel_dummy, &dummy) == RES_OK); 31 CHK(ssf_fresnel_create 32 (&allocator, &ssf_fresnel_dielectric_conductor, &fresnel) == RES_OK); 33 34 CHK(ssf_fresnel_dielectric_conductor_setup(NULL, 1.0, 1.0, 1.0) == RES_BAD_ARG); 35 CHK(ssf_fresnel_dielectric_conductor_setup(fresnel, 1.0, 1.0, 1.0) == RES_OK); 36 CHK(ssf_fresnel_dielectric_conductor_setup(dummy, 1.0, 1.0, 1.0) == RES_BAD_ARG); 37 38 /* TODO eval a dielectric->conductor Fresnel term on a reference */ 39 /*CHK(ssf_fresnel_eval(fresnel, 1) == ref);*/ 40 41 CHK(ssf_fresnel_ref_put(fresnel) == RES_OK); 42 CHK(ssf_fresnel_ref_put(dummy) == RES_OK); 43 44 check_memory_allocator(&allocator); 45 mem_shutdown_proxy_allocator(&allocator); 46 CHK(mem_allocated_size() == 0); 47 return 0; 48 } 49