From 4a9d8a19fd30a4cd55f9f87c013e409d61e22512 Mon Sep 17 00:00:00 2001 From: ReversedGravity Date: Sat, 16 Sep 2023 18:39:21 +0100 Subject: [PATCH] Fixed examples for `::expr` syntax. --- luisa_compute/examples/fluid.rs | 42 ++++----- luisa_compute/examples/mpm.rs | 26 +++--- luisa_compute/examples/path_tracer.rs | 61 ++++++------- luisa_compute/examples/path_tracer_cutout.rs | 65 +++++++------- luisa_compute/examples/ray_query.rs | 24 +++--- luisa_compute/examples/raytracing.rs | 16 ++-- luisa_compute/examples/sdf_renderer.rs | 4 +- luisa_compute/examples/shadertoy.rs | 26 +++--- luisa_compute/tests/autodiff.rs | 90 ++++++++++---------- luisa_compute/tests/misc.rs | 24 ++++-- 10 files changed, 194 insertions(+), 184 deletions(-) diff --git a/luisa_compute/examples/fluid.rs b/luisa_compute/examples/fluid.rs index 6901b2a..8cd3355 100644 --- a/luisa_compute/examples/fluid.rs +++ b/luisa_compute/examples/fluid.rs @@ -72,14 +72,14 @@ fn main() { let index = |xy: Expr| -> Expr { let p = xy.clamp( - make_uint2(0, 0), - make_uint2(N_GRID as u32 - 1, N_GRID as u32 - 1), + Uint2::expr(0, 0), + Uint2::expr(N_GRID as u32 - 1, N_GRID as u32 - 1), ); p.x() + p.y() * N_GRID as u32 }; let lookup_float = |f: &BufferVar, x: Int, y: Int| -> Float { - return f.read(index(make_uint2(x.uint(), y.uint()))); + return f.read(index(Uint2::expr(x.uint(), y.uint()))); }; let sample_float = |f: BufferVar, x: Float, y: Float| -> Float { @@ -96,7 +96,7 @@ fn main() { }; let lookup_vel = |f: &BufferVar, x: Int, y: Int| -> Float2Expr { - return f.read(index(make_uint2(x.uint(), y.uint()))); + return f.read(index(Uint2::expr(x.uint(), y.uint()))); }; let sample_vel = |f: BufferVar, x: Float, y: Float| -> Float2Expr { @@ -106,11 +106,11 @@ fn main() { let tx = x - lx.float(); let ty = y - ly.float(); - let s0 = lookup_vel(&f, lx, ly).lerp(lookup_vel(&f, lx + 1, ly), make_float2(tx, tx)); + let s0 = lookup_vel(&f, lx, ly).lerp(lookup_vel(&f, lx + 1, ly), Float2::expr(tx, tx)); let s1 = - lookup_vel(&f, lx, ly + 1).lerp(lookup_vel(&f, lx + 1, ly + 1), make_float2(tx, tx)); + lookup_vel(&f, lx, ly + 1).lerp(lookup_vel(&f, lx + 1, ly + 1), Float2::expr(tx, tx)); - return s0.lerp(s1, make_float2(ty, ty)); + return s0.lerp(s1, Float2::expr(ty, ty)); }; let advect = device @@ -120,7 +120,7 @@ fn main() { let u = u0.read(index(coord)); // trace backward - let mut p = make_float2(coord.x().float(), coord.y().float()); + let mut p = Float2::expr(coord.x().float(), coord.y().float()); p = p - u * dt; // advect @@ -132,10 +132,10 @@ fn main() { let divergence = device.create_kernel_async::, Buffer)>(&|u, div| { let coord = dispatch_id().xy(); if_!(coord.x().cmplt(N_GRID - 1) & coord.y().cmplt(N_GRID - 1), { - let dx = (u.read(index(make_uint2(coord.x() + 1, coord.y()))).x() + let dx = (u.read(index(Uint2::expr(coord.x() + 1, coord.y()))).x() - u.read(index(coord)).x()) * 0.5; - let dy = (u.read(index(make_uint2(coord.x(), coord.y() + 1))).y() + let dy = (u.read(index(Uint2::expr(coord.x(), coord.y() + 1))).y() - u.read(index(coord)).y()) * 0.5; div.write(index(coord), dx + dy); @@ -169,11 +169,11 @@ fn main() { i.cmpgt(0) & i.cmplt(N_GRID - 1) & j.cmpgt(0) & j.cmplt(N_GRID - 1), { // pressure gradient - let f_p = make_float2( - p.read(index(make_uint2(i.uint() + 1, j.uint()))) - - p.read(index(make_uint2(i.uint() - 1, j.uint()))), - p.read(index(make_uint2(i.uint(), j.uint() + 1))) - - p.read(index(make_uint2(i.uint(), j.uint() - 1))), + let f_p = Float2::expr( + p.read(index(Uint2::expr(i.uint() + 1, j.uint()))) + - p.read(index(Uint2::expr(i.uint() - 1, j.uint()))), + p.read(index(Uint2::expr(i.uint(), j.uint() + 1))) + - p.read(index(Uint2::expr(i.uint(), j.uint() - 1))), ) * 0.5f32; u.write(ij, u.read(ij) - f_p); @@ -186,7 +186,7 @@ fn main() { let ij = index(coord); // gravity - let f_g = make_float2(-90.8f32, 0.0f32) * rho.read(ij); + let f_g = Float2::expr(-90.8f32, 0.0f32) * rho.read(ij); // integrate u.write(ij, u.read(ij) + dt * f_g); @@ -201,7 +201,7 @@ fn main() { let i = coord.x().int(); let j = coord.y().int(); let ij = index(coord); - let d = make_float2((i - N_GRID / 2).float(), (j - N_GRID / 2).float()).length(); + let d = Float2::expr((i - N_GRID / 2).float(), (j - N_GRID / 2).float()).length(); let radius = 5.0f32; if_!(d.cmplt(radius), { @@ -212,8 +212,8 @@ fn main() { let init_grid = device.create_kernel_async::(&|| { let idx = index(dispatch_id().xy()); - u0.var().write(idx, make_float2(0.0f32, 0.0f32)); - u1.var().write(idx, make_float2(0.0f32, 0.0f32)); + u0.var().write(idx, Float2::expr(0.0f32, 0.0f32)); + u1.var().write(idx, Float2::expr(0.0f32, 0.0f32)); rho0.var().write(idx, 0.0f32); rho1.var().write(idx, 0.0f32); @@ -234,8 +234,8 @@ fn main() { let ij = index(coord); let value = rho0.var().read(ij); display.var().write( - make_uint2(coord.x(), (N_GRID - 1) as u32 - coord.y()), - make_float4(value, 0.0f32, 0.0f32, 1.0f32), + Uint2::expr(coord.x(), (N_GRID - 1) as u32 - coord.y()), + Float4::expr(value, 0.0f32, 0.0f32, 1.0f32), ); }); diff --git a/luisa_compute/examples/mpm.rs b/luisa_compute/examples/mpm.rs index 08b2420..15e775c 100644 --- a/luisa_compute/examples/mpm.rs +++ b/luisa_compute/examples/mpm.rs @@ -87,8 +87,8 @@ fn main() { let index = |xy: Expr| -> Expr { let p = xy.clamp( - make_uint2(0, 0), - make_uint2(N_GRID as u32 - 1, N_GRID as u32 - 1), + Uint2::expr(0, 0), + Uint2::expr(N_GRID as u32 - 1, N_GRID as u32 - 1), ); p.x() + p.y() * N_GRID as u32 }; @@ -113,11 +113,11 @@ fn main() { ]; let stress = -4.0f32 * DT * E * P_VOL * (J.var().read(p) - 1.0f32) / (DX * DX); let affine = - Expr::::eye(make_float2(stress, stress)) + P_MASS as f32 * C.var().read(p); + Expr::::eye(Float2::expr(stress, stress)) + P_MASS as f32 * C.var().read(p); let vp = v.var().read(p); for ii in 0..9 { let (i, j) = (ii % 3, ii / 3); - let offset = make_int2(i as i32, j as i32); + let offset = Int2::expr(i as i32, j as i32); let dpos = (offset.float() - fx) * DX; let weight = w[i].x() * w[j].y(); let vadd = weight * (P_MASS * vp + affine * dpos); @@ -132,7 +132,7 @@ fn main() { let coord = dispatch_id().xy(); let i = index(coord); let v = var!(Float2); - v.store(make_float2( + v.store(Float2::expr( grid_v.var().read(i * 2u32), grid_v.var().read(i * 2u32 + 1u32), )); @@ -170,15 +170,15 @@ fn main() { ]; let new_v = var!(Float2); let new_C = var!(Mat2); - new_v.store(make_float2(0.0f32, 0.0f32)); - new_C.store(make_float2x2(make_float2(0., 0.), make_float2(0., 0.))); + new_v.store(Float2::expr(0.0f32, 0.0f32)); + new_C.store(Mat2::expr(Float2::expr(0., 0.), Float2::expr(0., 0.))); for ii in 0..9 { let (i, j) = (ii % 3, ii / 3); - let offset = make_int2(i as i32, j as i32); + let offset = Int2::expr(i as i32, j as i32); let dpos = (offset.float() - fx) * DX; let weight = w[i].x() * w[j].y(); let idx = index((base + offset).uint()); - let g_v = make_float2( + let g_v = Float2::expr( grid_v.var().read(idx * 2u32), grid_v.var().read(idx * 2u32 + 1u32), ); @@ -195,14 +195,14 @@ fn main() { let clear_display = device.create_kernel_async::(&|| { display.var().write( dispatch_id().xy(), - make_float4(0.1f32, 0.2f32, 0.3f32, 1.0f32), + Float4::expr(0.1f32, 0.2f32, 0.3f32, 1.0f32), ); }); let draw_particles = device.create_kernel_async::(&|| { let p = dispatch_id().x(); for i in -1..=1 { for j in -1..=1 { - let pos = (x.var().read(p) * RESOLUTION as f32).int() + make_int2(i, j); + let pos = (x.var().read(p) * RESOLUTION as f32).int() + Int2::expr(i, j); if_!( pos.x().cmpge(0i32) & pos.x().cmplt(RESOLUTION as i32) @@ -210,8 +210,8 @@ fn main() { & pos.y().cmplt(RESOLUTION as i32), { display.var().write( - make_uint2(pos.x().uint(), RESOLUTION - 1u32 - pos.y().uint()), - make_float4(0.4f32, 0.6f32, 0.6f32, 1.0f32), + Uint2::expr(pos.x().uint(), RESOLUTION - 1u32 - pos.y().uint()), + Float4::expr(0.4f32, 0.6f32, 0.6f32, 1.0f32), ); } ); diff --git a/luisa_compute/examples/path_tracer.rs b/luisa_compute/examples/path_tracer.rs index aa52bcc..d4da985 100644 --- a/luisa_compute/examples/path_tracer.rs +++ b/luisa_compute/examples/path_tracer.rs @@ -285,10 +285,10 @@ fn main() { let generate_ray = |p: Expr| -> Expr { const FOV: f32 = 27.8f32 * std::f32::consts::PI / 180.0f32; - let origin = make_float3(-0.01f32, 0.995f32, 5.0f32); + let origin = Float3::expr(-0.01f32, 0.995f32, 5.0f32); let pixel = origin - + make_float3( + + Float3::expr( p.x() * f32::tan(0.5f32 * FOV), p.y() * f32::tan(0.5f32 * FOV), -1.0f32, @@ -304,9 +304,9 @@ fn main() { let make_onb = |normal: Expr| -> Expr { let binormal = if_!( normal.x().abs().cmpgt(normal.z().abs()), { - make_float3(-normal.y(), normal.x(), 0.0f32) + Float3::expr(-normal.y(), normal.x(), 0.0f32) }, else { - make_float3(0.0f32, -normal.z(), normal.y()) + Float3::expr(0.0f32, -normal.z(), normal.y()) } ); let tangent = binormal.cross(normal).normalize(); @@ -316,7 +316,7 @@ fn main() { let cosine_sample_hemisphere = |u: Expr| { let r = u.x().sqrt(); let phi = 2.0f32 * std::f32::consts::PI * u.y(); - make_float3(r * phi.cos(), r * phi.sin(), (1.0f32 - u.x()).sqrt()) + Float3::expr(r * phi.cos(), r * phi.sin(), (1.0f32 - u.x()).sqrt()) }; let coord = dispatch_id().xy(); @@ -327,24 +327,24 @@ fn main() { let rx = lcg(state); let ry = lcg(state); - let pixel = (coord.float() + make_float2(rx, ry)) / frame_size * 2.0f32 - 1.0f32; + let pixel = (coord.float() + Float2::expr(rx, ry)) / frame_size * 2.0f32 - 1.0f32; let radiance = var!(Float3); - radiance.store(make_float3(0.0f32, 0.0f32, 0.0f32)); + radiance.store(Float3::expr(0.0f32, 0.0f32, 0.0f32)); for_range(0..SPP_PER_DISPATCH as u32, |_| { - let init_ray = generate_ray(pixel * make_float2(1.0f32, -1.0f32)); + let init_ray = generate_ray(pixel * Float2::expr(1.0f32, -1.0f32)); let ray = var!(Ray); ray.store(init_ray); let beta = var!(Float3); - beta.store(make_float3(1.0f32, 1.0f32, 1.0f32)); + beta.store(Float3::expr(1.0f32, 1.0f32, 1.0f32)); let pdf_bsdf = var!(f32); pdf_bsdf.store(0.0f32); - let light_position = make_float3(-0.24f32, 1.98f32, 0.16f32); - let light_u = make_float3(-0.24f32, 1.98f32, -0.22f32) - light_position; - let light_v = make_float3(0.23f32, 1.98f32, 0.16f32) - light_position; - let light_emission = make_float3(17.0f32, 12.0f32, 4.0f32); + let light_position = Float3::expr(-0.24f32, 1.98f32, 0.16f32); + let light_u = Float3::expr(-0.24f32, 1.98f32, -0.22f32) - light_position; + let light_v = Float3::expr(0.23f32, 1.98f32, 0.16f32) - light_position; + let light_emission = Float3::expr(17.0f32, 12.0f32, 4.0f32); let light_area = light_u.cross(light_v).length(); let light_normal = light_u.cross(light_v).normalize(); @@ -414,13 +414,13 @@ fn main() { let onb = make_onb(n); let ux = lcg(state); let uy = lcg(state); - let new_direction = onb.to_world(cosine_sample_hemisphere(make_float2(ux, uy))); + let new_direction = onb.to_world(cosine_sample_hemisphere(Float2::expr(ux, uy))); *ray.get_mut() = make_ray(pp, new_direction, 0.0f32.into(), std::f32::MAX.into()); *beta.get_mut() *= albedo; pdf_bsdf.store(cos_wi * std::f32::consts::FRAC_1_PI); // russian roulette - let l = make_float3(0.212671f32, 0.715160f32, 0.072169f32).dot(*beta); + let l = Float3::expr(0.212671f32, 0.715160f32, 0.072169f32).dot(*beta); if_!(l.cmpeq(0.0f32), { break_(); }); let q = l.max(0.05f32); let r = lcg(state); @@ -432,28 +432,29 @@ fn main() { }); radiance.store(radiance.load() / SPP_PER_DISPATCH as f32); seed_image.write(coord, *state); - if_!(radiance.load().is_nan().any(), { radiance.store(make_float3(0.0f32, 0.0f32, 0.0f32)); }); + if_!(radiance.load().is_nan().any(), { radiance.store(Float3::expr(0.0f32, 0.0f32, 0.0f32)); }); let radiance = radiance.load().clamp(0.0f32, 30.0f32); let old = image.read(dispatch_id().xy()); let spp = old.w(); let radiance = radiance + old.xyz(); - image.write(dispatch_id().xy(), make_float4(radiance.x(), radiance.y(), radiance.z(), spp + 1.0f32)); + image.write(dispatch_id().xy(), Float4::expr(radiance.x(), radiance.y(), radiance.z(), spp + 1.0f32)); }, ) ; - let display = device.create_kernel_async::, Tex2d)>(&|acc, display| { - set_block_size([16, 16, 1]); - let coord = dispatch_id().xy(); - let radiance = acc.read(coord); - let spp = radiance.w(); - let radiance = radiance.xyz() / spp; - - // workaround a rust-analyzer bug - let r = 1.055f32 * radiance.powf(1.0 / 2.4) - 0.055; - - let srgb = Float3Expr::select(radiance.cmplt(0.0031308), radiance * 12.92, r); - display.write(coord, make_float4(srgb.x(), srgb.y(), srgb.z(), 1.0f32)); - }); + let display = + device.create_kernel_async::, Tex2d)>(&|acc, display| { + set_block_size([16, 16, 1]); + let coord = dispatch_id().xy(); + let radiance = acc.read(coord); + let spp = radiance.w(); + let radiance = radiance.xyz() / spp; + + // workaround a rust-analyzer bug + let r = 1.055f32 * radiance.powf(1.0 / 2.4) - 0.055; + + let srgb = Float3Expr::select(radiance.cmplt(0.0031308), radiance * 12.92, r); + display.write(coord, Float4::expr(srgb.x(), srgb.y(), srgb.z(), 1.0f32)); + }); let img_w = 1024; let img_h = 1024; let acc_img = device.create_tex2d::(PixelStorage::Float4, img_w, img_h, 1); diff --git a/luisa_compute/examples/path_tracer_cutout.rs b/luisa_compute/examples/path_tracer_cutout.rs index 0813423..fa67d3a 100644 --- a/luisa_compute/examples/path_tracer_cutout.rs +++ b/luisa_compute/examples/path_tracer_cutout.rs @@ -291,10 +291,10 @@ fn main() { let generate_ray = |p: Expr| -> Expr { const FOV: f32 = 27.8f32 * std::f32::consts::PI / 180.0f32; - let origin = make_float3(-0.01f32, 0.995f32, 5.0f32); + let origin = Float3::expr(-0.01f32, 0.995f32, 5.0f32); let pixel = origin - + make_float3( + + Float3::expr( p.x() * f32::tan(0.5f32 * FOV), p.y() * f32::tan(0.5f32 * FOV), -1.0f32, @@ -310,9 +310,9 @@ fn main() { let make_onb = |normal: Expr| -> Expr { let binormal = if_!( normal.x().abs().cmpgt(normal.z().abs()), { - make_float3(-normal.y(), normal.x(), 0.0f32) + Float3::expr(-normal.y(), normal.x(), 0.0f32) }, else { - make_float3(0.0f32, -normal.z(), normal.y()) + Float3::expr(0.0f32, -normal.z(), normal.y()) } ); let tangent = binormal.cross(normal).normalize(); @@ -322,7 +322,7 @@ fn main() { let cosine_sample_hemisphere = |u: Expr| { let r = u.x().sqrt(); let phi = 2.0f32 * std::f32::consts::PI * u.y(); - make_float3(r * phi.cos(), r * phi.sin(), (1.0f32 - u.x()).sqrt()) + Float3::expr(r * phi.cos(), r * phi.sin(), (1.0f32 - u.x()).sqrt()) }; let coord = dispatch_id().xy(); @@ -333,24 +333,24 @@ fn main() { let rx = lcg(state); let ry = lcg(state); - let pixel = (coord.float() + make_float2(rx, ry)) / frame_size * 2.0f32 - 1.0f32; + let pixel = (coord.float() + Float2::expr(rx, ry)) / frame_size * 2.0f32 - 1.0f32; let radiance = var!(Float3); - radiance.store(make_float3(0.0f32, 0.0f32, 0.0f32)); + radiance.store(Float3::expr(0.0f32, 0.0f32, 0.0f32)); for_range(0..SPP_PER_DISPATCH as u32, |_| { - let init_ray = generate_ray(pixel * make_float2(1.0f32, -1.0f32)); + let init_ray = generate_ray(pixel * Float2::expr(1.0f32, -1.0f32)); let ray = var!(Ray); ray.store(init_ray); let beta = var!(Float3); - beta.store(make_float3(1.0f32, 1.0f32, 1.0f32)); + beta.store(Float3::expr(1.0f32, 1.0f32, 1.0f32)); let pdf_bsdf = var!(f32); pdf_bsdf.store(0.0f32); - let light_position = make_float3(-0.24f32, 1.98f32, 0.16f32); - let light_u = make_float3(-0.24f32, 1.98f32, -0.22f32) - light_position; - let light_v = make_float3(0.23f32, 1.98f32, 0.16f32) - light_position; - let light_emission = make_float3(17.0f32, 12.0f32, 4.0f32); + let light_position = Float3::expr(-0.24f32, 1.98f32, 0.16f32); + let light_u = Float3::expr(-0.24f32, 1.98f32, -0.22f32) - light_position; + let light_v = Float3::expr(0.23f32, 1.98f32, 0.16f32) - light_position; + let light_emission = Float3::expr(17.0f32, 12.0f32, 4.0f32); let light_area = light_u.cross(light_v).length(); let light_normal = light_u.cross(light_v).normalize(); @@ -386,9 +386,9 @@ fn main() { let p2: Expr = vertex_buffer.read(triangle.z()).into(); let m = accel.instance_transform(hit.inst_id()); let p = p0 * (1.0f32 - hit.bary().x() - hit.bary().y()) + p1 * hit.bary().x() + p2 * hit.bary().y(); - let p = (m * make_float4(p.x(), p.y(), p.z(), 1.0f32)).xyz(); + let p = (m * Float4::expr(p.x(), p.y(), p.z(), 1.0f32)).xyz(); let n = (p1 - p0).cross(p2 - p0); - let n = (m * make_float4(n.x(), n.y(), n.z(), 0.0f32)).xyz().normalize(); + let n = (m * Float4::expr(n.x(), n.y(), n.z(), 0.0f32)).xyz().normalize(); let origin: Expr = ray.load().orig().into(); let direction: Expr = ray.load().dir().into(); @@ -443,13 +443,13 @@ fn main() { let onb = make_onb(n); let ux = lcg(state); let uy = lcg(state); - let new_direction = onb.to_world(cosine_sample_hemisphere(make_float2(ux, uy))); + let new_direction = onb.to_world(cosine_sample_hemisphere(Float2::expr(ux, uy))); *ray.get_mut() = make_ray(pp, new_direction, 0.0f32.into(), std::f32::MAX.into()); *beta.get_mut() *= albedo; pdf_bsdf.store(cos_wi.abs() * std::f32::consts::FRAC_1_PI); // russian roulette - let l = make_float3(0.212671f32, 0.715160f32, 0.072169f32).dot(*beta); + let l = Float3::expr(0.212671f32, 0.715160f32, 0.072169f32).dot(*beta); if_!(l.cmpeq(0.0f32), { break_(); }); let q = l.max(0.05f32); let r = lcg(state); @@ -461,28 +461,29 @@ fn main() { }); radiance.store(radiance.load() / SPP_PER_DISPATCH as f32); seed_image.write(coord, *state); - if_!(radiance.load().is_nan().any(), { radiance.store(make_float3(0.0f32, 0.0f32, 0.0f32)); }); + if_!(radiance.load().is_nan().any(), { radiance.store(Float3::expr(0.0f32, 0.0f32, 0.0f32)); }); let radiance = radiance.load().clamp(0.0f32, 30.0f32); let old = image.read(dispatch_id().xy()); let spp = old.w(); let radiance = radiance + old.xyz(); - image.write(dispatch_id().xy(), make_float4(radiance.x(), radiance.y(), radiance.z(), spp + 1.0f32)); + image.write(dispatch_id().xy(), Float4::expr(radiance.x(), radiance.y(), radiance.z(), spp + 1.0f32)); }, ) ; - let display = device.create_kernel_async::, Tex2d)>(&|acc, display| { - set_block_size([16, 16, 1]); - let coord = dispatch_id().xy(); - let radiance = acc.read(coord); - let spp = radiance.w(); - let radiance = radiance.xyz() / spp; - - // workaround a rust-analyzer bug - let r = 1.055f32 * radiance.powf(1.0 / 2.4) - 0.055; - - let srgb = Float3Expr::select(radiance.cmplt(0.0031308), radiance * 12.92, r); - display.write(coord, make_float4(srgb.x(), srgb.y(), srgb.z(), 1.0f32)); - }); + let display = + device.create_kernel_async::, Tex2d)>(&|acc, display| { + set_block_size([16, 16, 1]); + let coord = dispatch_id().xy(); + let radiance = acc.read(coord); + let spp = radiance.w(); + let radiance = radiance.xyz() / spp; + + // workaround a rust-analyzer bug + let r = 1.055f32 * radiance.powf(1.0 / 2.4) - 0.055; + + let srgb = Float3Expr::select(radiance.cmplt(0.0031308), radiance * 12.92, r); + display.write(coord, Float4::expr(srgb.x(), srgb.y(), srgb.z(), 1.0f32)); + }); let img_w = 1024; let img_h = 1024; let acc_img = device.create_tex2d::(PixelStorage::Float4, img_w, img_h, 1); diff --git a/luisa_compute/examples/ray_query.rs b/luisa_compute/examples/ray_query.rs index 9eb4896..0925868 100644 --- a/luisa_compute/examples/ray_query.rs +++ b/luisa_compute/examples/ray_query.rs @@ -111,10 +111,10 @@ fn main() { let rt_kernel = device.create_kernel::(&|| { let accel = accel.var(); let px = dispatch_id().xy(); - let xy = px.float() / make_float2(img_w as f32, img_h as f32); + let xy = px.float() / Float2::expr(img_w as f32, img_h as f32); let xy = 2.0 * xy - 1.0; - let o = make_float3(0.0, 0.0, -2.0); - let d = make_float3(xy.x(), xy.y(), 0.0) - o; + let o = Float3::expr(0.0, 0.0, -2.0); + let d = Float3::expr(xy.x(), xy.y(), 0.0) - o; let d = d.normalize(); let ray = rtx::RayExpr::new(o + const_(translate), 1e-3, d, 1e9); let hit = accel.query_all( @@ -123,9 +123,9 @@ fn main() { RayQuery { on_triangle_hit: |candidate: TriangleCandidate| { let bary = candidate.bary(); - let uvw = make_float3(1.0 - bary.x() - bary.y(), bary.x(), bary.y()); + let uvw = Float3::expr(1.0 - bary.x() - bary.y(), bary.x(), bary.y()); let t = candidate.committed_ray_t(); - if_!(px.cmpeq(make_uint2(400, 400)).all(), { + if_!(px.cmpeq(Uint2::expr(400, 400)).all(), { debug_hit_t.write(0, t); debug_hit_t.write(1, candidate.ray().tmax()); }); @@ -151,7 +151,7 @@ fn main() { .length() - sphere.radius(); if_!(dist.cmplt(0.001), { - if_!(px.cmpeq(make_uint2(400, 400)).all(), { + if_!(px.cmpeq(Uint2::expr(400, 400)).all(), { debug_hit_t.write(2, *t); debug_hit_t.write(3, candidate.ray().tmax()); }); @@ -170,7 +170,7 @@ fn main() { hit.triangle_hit(), { let bary = hit.bary(); - let uvw = make_float3(1.0 - bary.x() - bary.y(), bary.x(), bary.y()); + let uvw = Float3::expr(1.0 - bary.x() - bary.y(), bary.x(), bary.y()); uvw }, else, @@ -184,19 +184,19 @@ fn main() { + ray.dir().unpack() * hit.committed_ray_t() - sphere.center()) .normalize(); - let light_dir = make_float3(1.0, 0.6, -0.2).normalize(); - let light = make_float3(1.0, 1.0, 1.0); - let ambient = make_float3(0.1, 0.1, 0.1); + let light_dir = Float3::expr(1.0, 0.6, -0.2).normalize(); + let light = Float3::expr(1.0, 1.0, 1.0); + let ambient = Float3::expr(0.1, 0.1, 0.1); let diffuse = light * normal.dot(light_dir).max(0.0); let color = ambient + diffuse; color }, else, - { make_float3(0.0, 0.0, 0.0) } + { Float3::expr(0.0, 0.0, 0.0) } ) } ); - img.write(px, make_float4(color.x(), color.y(), color.z(), 1.0)); + img.write(px, Float4::expr(color.x(), color.y(), color.z(), 1.0)); }); let event_loop = EventLoop::new(); let window = winit::window::WindowBuilder::new() diff --git a/luisa_compute/examples/raytracing.rs b/luisa_compute/examples/raytracing.rs index aca84d1..857decf 100644 --- a/luisa_compute/examples/raytracing.rs +++ b/luisa_compute/examples/raytracing.rs @@ -4,11 +4,11 @@ use image::Rgb; #[allow(unused_imports)] use luisa::prelude::*; use luisa_compute as luisa; +use winit::event::Event as WinitEvent; use winit::{ - event::{WindowEvent}, + event::WindowEvent, event_loop::{ControlFlow, EventLoop}, }; -use winit::event::Event as WinitEvent; fn main() { use luisa::*; init_logger(); @@ -46,20 +46,20 @@ fn main() { let rt_kernel = device.create_kernel::(&|| { let accel = accel.var(); let px = dispatch_id().xy(); - let xy = px.float() / make_float2(img_w as f32, img_h as f32); + let xy = px.float() / Float2::expr(img_w as f32, img_h as f32); let xy = 2.0 * xy - 1.0; - let o = make_float3(0.0, 0.0, -1.0); - let d = make_float3(xy.x(), xy.y(), 0.0) - o; + let o = Float3::expr(0.0, 0.0, -1.0); + let d = Float3::expr(xy.x(), xy.y(), 0.0) - o; let d = d.normalize(); let ray = rtx::RayExpr::new(o, 1e-3, d, 1e9); let hit = accel.trace_closest(ray); let img = img.view(0).var(); let color = select( hit.valid(), - make_float3(hit.u(), hit.v(), 1.0), - make_float3(0.0, 0.0, 0.0), + Float3::expr(hit.u(), hit.v(), 1.0), + Float3::expr(0.0, 0.0, 0.0), ); - img.write(px, make_float4(color.x(), color.y(), color.z(), 1.0)); + img.write(px, Float4::expr(color.x(), color.y(), color.z(), 1.0)); }); let event_loop = EventLoop::new(); let window = winit::window::WindowBuilder::new() diff --git a/luisa_compute/examples/sdf_renderer.rs b/luisa_compute/examples/sdf_renderer.rs index 7a706bb..10b0af9 100644 --- a/luisa_compute/examples/sdf_renderer.rs +++ b/luisa_compute/examples/sdf_renderer.rs @@ -37,8 +37,8 @@ fn main() { device.create_kernel::, Buffer)>( &|buf_x: BufferVar, spheres: BufferVar| { let tid = dispatch_id().x(); - let o = make_float3(0.0, 0.0, -2.0); - let d = make_float3(0.0, 0.0, 1.0); + let o = Float3::expr(0.0, 0.0, -2.0); + let d = Float3::expr(0.0, 0.0, 1.0); let sphere = spheres.read(0); let t = var!(f32); while_!(t.load().cmplt(10.0), { diff --git a/luisa_compute/examples/shadertoy.rs b/luisa_compute/examples/shadertoy.rs index 534927e..2756a3d 100644 --- a/luisa_compute/examples/shadertoy.rs +++ b/luisa_compute/examples/shadertoy.rs @@ -22,26 +22,26 @@ fn main() { }); let palette = device.create_callable::) -> Expr>(&|d| { - make_float3(0.2, 0.7, 0.9).lerp(make_float3(1.0, 0.0, 1.0), Float3Expr::splat(d)) + Float3::expr(0.2, 0.7, 0.9).lerp(Float3::expr(1.0, 0.0, 1.0), Float3Expr::splat(d)) }); let rotate = device.create_callable::, Expr) -> Expr>(&|mut p, a| { let c = a.cos(); let s = a.sin(); - make_float2(p.dot(make_float2(c, s)), p.dot(make_float2(-s, c))) + Float2::expr(p.dot(Float2::expr(c, s)), p.dot(Float2::expr(-s, c))) }); let map = device.create_callable::, Expr) -> Expr>(&|mut p, time| { for i in 0..8 { let t = time * 0.2; let r = rotate.call(p.xz(), t); - p = make_float3(r.x(), r.y(), p.y()).xzy(); + p = Float3::expr(r.x(), r.y(), p.y()).xzy(); let r = rotate.call(p.xy(), t * 1.89); - p = make_float3(r.x(), r.y(), p.z()); - p = make_float3(p.x().abs() - 0.5, p.y(), p.z().abs() - 0.5) + p = Float3::expr(r.x(), r.y(), p.z()); + p = Float3::expr(p.x().abs() - 0.5, p.y(), p.z().abs() - 0.5) } Float3Expr::splat(1.0).copysign(p).dot(p) * 0.2 }); - let rm = device.create_callable::, Expr, Expr)-> Expr>( + let rm = device.create_callable::, Expr, Expr) -> Expr>( &|ro, rd, time| { let t = var!(f32, 0.0); let col = var!(Float3); @@ -54,21 +54,21 @@ fn main() { *t.get_mut() += *d; }); let col = *col; - make_float4(col.x(), col.y(), col.z(), 1.0 / (100.0 * *d)) + Float4::expr(col.x(), col.y(), col.z(), 1.0 / (100.0 * *d)) }, ); - let clear_kernel = device.create_kernel::,)>(&|img| { + let clear_kernel = device.create_kernel::)>(&|img| { let coord = dispatch_id().xy(); - img.write(coord, make_float4(0.3, 0.4, 0.5, 1.0)); + img.write(coord, Float4::expr(0.3, 0.4, 0.5, 1.0)); }); let main_kernel = device.create_kernel::, f32)>(&|img, time| { let xy = dispatch_id().xy(); let resolution = dispatch_size().xy(); let uv = (xy.float() - resolution.float() * 0.5) / resolution.x().float(); - let r = rotate.call(make_float2(0.0, -50.0), time); - let ro = make_float3(r.x(), r.y(), 0.0).xzy(); + let r = rotate.call(Float2::expr(0.0, -50.0), time); + let ro = Float3::expr(r.x(), r.y(), 0.0).xzy(); let cf = (-ro).normalize(); - let cs = cf.cross(make_float3(0.0, 10.0, 0.0)).normalize(); + let cs = cf.cross(Float3::expr(0.0, 10.0, 0.0)).normalize(); let cu = cf.cross(cs).normalize(); let uuv = ro + cf * 3.0 + uv.x() * cs + uv.y() * cu; let rd = (uuv - ro).normalize(); @@ -77,6 +77,6 @@ fn main() { let alpha = col.w(); let old = img.read(xy).xyz(); let accum = color.lerp(old, Float3Expr::splat(alpha)); - img.write(xy, make_float4(accum.x(), accum.y(), accum.z(), 1.0)); + img.write(xy, Float4::expr(accum.x(), accum.y(), accum.z(), 1.0)); }); } diff --git a/luisa_compute/tests/autodiff.rs b/luisa_compute/tests/autodiff.rs index 9ed0a2b..480eecf 100644 --- a/luisa_compute/tests/autodiff.rs +++ b/luisa_compute/tests/autodiff.rs @@ -290,7 +290,7 @@ fn autodiff_vec3_reduce_add_manual() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.x() + v.y() + v.z() }); } @@ -301,7 +301,7 @@ fn autodiff_vec3_reduce_prod_manual() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.x() * v.y() * v.z() }); } @@ -311,7 +311,7 @@ fn autodiff_vec3_reduce_add() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.reduce_sum() }); } @@ -321,7 +321,7 @@ fn autodiff_vec3_reduce_mul() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.reduce_prod() }); } @@ -331,7 +331,7 @@ fn autodiff_vec3_dot() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.dot(v) }); } @@ -341,7 +341,7 @@ fn autodiff_vec3_length() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.length() }); } @@ -351,7 +351,7 @@ fn autodiff_vec3_length_squared() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.length_squared() }); } @@ -361,21 +361,21 @@ fn autodiff_vec3_normalize() { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.normalize().x() }); autodiff_helper(-10.0..10.0, 1024 * 1024, 3, |inputs| { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.normalize().y() }); autodiff_helper(-10.0..10.0, 1024 * 1024, 3, |inputs| { let x = inputs[0]; let y = inputs[1]; let z = inputs[2]; - let v = make_float3(x, y, z); + let v = Float3::expr(x, y, z); v.normalize().z() }); } @@ -386,11 +386,11 @@ fn autodiff_vec3_cross_x() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = def(make_float3(ax, ay, az)); + let a = def(Float3::expr(ax, ay, az)); let bx = inputs[3]; let by = inputs[4]; let bz = inputs[5]; - let b = def(make_float3(bx, by, bz)); + let b = def(Float3::expr(bx, by, bz)); let v = def(a.cross(*b)); *v.x() }); @@ -401,11 +401,11 @@ fn autodiff_vec3_cross_y() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = def(make_float3(ax, ay, az)); + let a = def(Float3::expr(ax, ay, az)); let bx = inputs[3]; let by = inputs[4]; let bz = inputs[5]; - let b = def(make_float3(bx, by, bz)); + let b = def(Float3::expr(bx, by, bz)); let v = def(a.cross(*b)); *v.x() }); @@ -417,11 +417,11 @@ fn autodiff_vec3_cross_z() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[3]; let by = inputs[4]; let bz = inputs[5]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let v = a.cross(b); v.z() }); @@ -432,11 +432,11 @@ fn autodiff_vec3_distance() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[3]; let by = inputs[4]; let bz = inputs[5]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); a.distance(b) }); } @@ -446,7 +446,7 @@ fn autodiff_vec3_replace() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let b = inputs[3]; let c = a.set_y(b); a.dot(c) @@ -458,19 +458,19 @@ fn autodiff_matmul() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[0 + 3]; let by = inputs[1 + 3]; let bz = inputs[2 + 3]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let cx = inputs[0 + 6]; let cy = inputs[1 + 6]; let cz = inputs[2 + 6]; - let c = make_float3(cx, cy, cz); + let c = Float3::expr(cx, cy, cz); let dx = inputs[0 + 9]; let dy = inputs[1 + 9]; let dz = inputs[2 + 9]; - let d = make_float3(dx, dy, dz); + let d = Float3::expr(dx, dy, dz); let m = Mat3Expr::new(a, b, c); let o = m * d; o.x() @@ -482,19 +482,19 @@ fn autodiff_matmul_transpose() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[0 + 3]; let by = inputs[1 + 3]; let bz = inputs[2 + 3]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let cx = inputs[0 + 6]; let cy = inputs[1 + 6]; let cz = inputs[2 + 6]; - let c = make_float3(cx, cy, cz); + let c = Float3::expr(cx, cy, cz); let dx = inputs[0 + 9]; let dy = inputs[1 + 9]; let dz = inputs[2 + 9]; - let d = make_float3(dx, dy, dz); + let d = Float3::expr(dx, dy, dz); let m = Mat3Expr::new(a, b, c); let o = m.transpose() * d; o.y() @@ -506,19 +506,19 @@ fn autodiff_matmul_2() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[0 + 3]; let by = inputs[1 + 3]; let bz = inputs[2 + 3]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let cx = inputs[0 + 6]; let cy = inputs[1 + 6]; let cz = inputs[2 + 6]; - let c = make_float3(cx, cy, cz); + let c = Float3::expr(cx, cy, cz); let dx = inputs[0 + 9]; let dy = inputs[1 + 9]; let dz = inputs[2 + 9]; - let d = make_float3(dx, dy, dz); + let d = Float3::expr(dx, dy, dz); let m = Mat3Expr::new(a, b, c); let o = m * m * d; o.z() @@ -530,19 +530,19 @@ fn autodiff_matmul_4() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[0 + 3]; let by = inputs[1 + 3]; let bz = inputs[2 + 3]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let cx = inputs[0 + 6]; let cy = inputs[1 + 6]; let cz = inputs[2 + 6]; - let c = make_float3(cx, cy, cz); + let c = Float3::expr(cx, cy, cz); let dx = inputs[0 + 9]; let dy = inputs[1 + 9]; let dz = inputs[2 + 9]; - let d = make_float3(dx, dy, dz); + let d = Float3::expr(dx, dy, dz); let m = Mat3Expr::new(a, b, c); let o = (m * m) * d; o.z() @@ -554,19 +554,19 @@ fn autodiff_matmul_5() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[0 + 3]; let by = inputs[1 + 3]; let bz = inputs[2 + 3]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let cx = inputs[0 + 6]; let cy = inputs[1 + 6]; let cz = inputs[2 + 6]; - let c = make_float3(cx, cy, cz); + let c = Float3::expr(cx, cy, cz); let dx = inputs[0 + 9]; let dy = inputs[1 + 9]; let dz = inputs[2 + 9]; - let d = make_float3(dx, dy, dz); + let d = Float3::expr(dx, dy, dz); let m = Mat3Expr::new(a, b, c); let o = m.comp_mul(m) * d; o.z() @@ -578,15 +578,15 @@ fn autodiff_mat_det() { let ax = inputs[0]; let ay = inputs[1]; let az = inputs[2]; - let a = make_float3(ax, ay, az); + let a = Float3::expr(ax, ay, az); let bx = inputs[0 + 3]; let by = inputs[1 + 3]; let bz = inputs[2 + 3]; - let b = make_float3(bx, by, bz); + let b = Float3::expr(bx, by, bz); let cx = inputs[0 + 6]; let cy = inputs[1 + 6]; let cz = inputs[2 + 6]; - let c = make_float3(cx, cy, cz); + let c = Float3::expr(cx, cy, cz); let m = Mat3Expr::new(a, b, c); m.determinant() }); @@ -598,7 +598,7 @@ fn autodiff_mat_det() { // let x = inputs[0]; // let y = inputs[1]; // let z = inputs[2]; -// let v = make_float3(x, y, z); +// let v = Float3::expr(x, y, z); // v.reduce_min() // }); // } @@ -610,7 +610,7 @@ fn autodiff_mat_det() { // let x = inputs[0]; // let y = inputs[1]; // let z = inputs[2]; -// let v = make_float3(x, y, z); +// let v = Float3::expr(x, y, z); // v.reduce_max() // }); // } @@ -990,7 +990,7 @@ fn autodiff_if_phi4() { autodiff(|| { requires_grad(x); requires_grad(y); - consts.store(make_float3(2.0, 3.0, 4.0)); + consts.store(Float3::expr(2.0, 3.0, 4.0)); let const_two = consts.x(); let const_three = consts.y(); let const_four = consts.z(); diff --git a/luisa_compute/tests/misc.rs b/luisa_compute/tests/misc.rs index 5d57835..cab4afb 100644 --- a/luisa_compute/tests/misc.rs +++ b/luisa_compute/tests/misc.rs @@ -91,7 +91,7 @@ fn callable() { v.store(v.load() + 1); }, ); - let add = device.create_callable::, Expr)->Expr>(&|a, b| a + b); + let add = device.create_callable::, Expr) -> Expr>(&|a, b| a + b); let x = device.create_buffer::(1024); let y = device.create_buffer::(1024); let z = device.create_buffer::(1024); @@ -698,7 +698,7 @@ fn byte_buffer() { let v1 = def(buf.read::(i1)); let v2 = def(buf.read::(i2)); let v3 = def(buf.read::(i3)); - *v0.get_mut() = make_float3(1.0, 2.0, 3.0); + *v0.get_mut() = Float3::expr(1.0, 2.0, 3.0); for_range(0u32..32u32, |i| { v1.a().write(i, i.float() * 2.0); }); @@ -715,7 +715,11 @@ fn byte_buffer() { ($t:ty, $offset:expr) => {{ let s = std::mem::size_of::<$t>(); let bytes = &data[$offset..$offset + s]; - let v = unsafe { std::mem::transmute_copy::<[u8; {std::mem::size_of::<$t>()}], $t>(bytes.try_into().unwrap()) }; + let v = unsafe { + std::mem::transmute_copy::<[u8; { std::mem::size_of::<$t>() }], $t>( + bytes.try_into().unwrap(), + ) + }; v }}; } @@ -723,7 +727,7 @@ fn byte_buffer() { let v1 = pop!(Big, i1); let v2 = pop!(i32, i2); let v3 = pop!(f32, i3); - assert_eq!(v0, Float3::new(1.0,2.0,3.0)); + assert_eq!(v0, Float3::new(1.0, 2.0, 3.0)); assert_eq!(v2, 1); assert_eq!(v3, 2.0); for i in 0..32 { @@ -759,7 +763,7 @@ fn bindless_byte_buffer() { let i2 = push!(i32, 0i32); let i3 = push!(f32, 1f32); device - .create_kernel::(&|out:ByteBufferVar| { + .create_kernel::(&|out: ByteBufferVar| { let heap = heap.var(); let buf = heap.byte_address_buffer(0); let i0 = i0 as u64; @@ -770,7 +774,7 @@ fn bindless_byte_buffer() { let v1 = def(buf.read::(i1)); let v2 = def(buf.read::(i2)); let v3 = def(buf.read::(i3)); - *v0.get_mut() = make_float3(1.0, 2.0, 3.0); + *v0.get_mut() = Float3::expr(1.0, 2.0, 3.0); for_range(0u32..32u32, |i| { v1.a().write(i, i.float() * 2.0); }); @@ -787,7 +791,11 @@ fn bindless_byte_buffer() { ($t:ty, $offset:expr) => {{ let s = std::mem::size_of::<$t>(); let bytes = &data[$offset..$offset + s]; - let v = unsafe { std::mem::transmute_copy::<[u8; {std::mem::size_of::<$t>()}], $t>(bytes.try_into().unwrap()) }; + let v = unsafe { + std::mem::transmute_copy::<[u8; { std::mem::size_of::<$t>() }], $t>( + bytes.try_into().unwrap(), + ) + }; v }}; } @@ -795,7 +803,7 @@ fn bindless_byte_buffer() { let v1 = pop!(Big, i1); let v2 = pop!(i32, i2); let v3 = pop!(f32, i3); - assert_eq!(v0, Float3::new(1.0,2.0,3.0)); + assert_eq!(v0, Float3::new(1.0, 2.0, 3.0)); assert_eq!(v2, 1); assert_eq!(v3, 2.0); for i in 0..32 {