diff --git a/luisa_compute/examples/path_tracer.rs b/luisa_compute/examples/path_tracer.rs index 8fdd0b0..357b4ce 100644 --- a/luisa_compute/examples/path_tracer.rs +++ b/luisa_compute/examples/path_tracer.rs @@ -250,9 +250,9 @@ fn main() { let path_tracer = Kernel::, Tex2d, Accel, Uint2)>::new_async( &device, &track!(|image: Tex2dVar, - seed_image: Tex2dVar, - accel: AccelVar, - resolution: Expr| { + seed_image: Tex2dVar, + accel: AccelVar, + resolution: Expr| { set_block_size([16u32, 16u32, 1u32]); let cbox_materials = ([ Float3::new(0.725f32, 0.710f32, 0.680f32), // floor diff --git a/luisa_compute/examples/path_tracer_cutout.rs b/luisa_compute/examples/path_tracer_cutout.rs index 4fee5d3..8c697b1 100644 --- a/luisa_compute/examples/path_tracer_cutout.rs +++ b/luisa_compute/examples/path_tracer_cutout.rs @@ -260,9 +260,9 @@ fn main() { let path_tracer = Kernel::, Tex2d, Accel, Uint2)>::new_async( &device, &track!(|image: Tex2dVar, - seed_image: Tex2dVar, - accel: AccelVar, - resolution: Expr| { + seed_image: Tex2dVar, + accel: AccelVar, + resolution: Expr| { set_block_size([16u32, 16u32, 1u32]); let cbox_materials = [ Float3::new(0.725f32, 0.710f32, 0.680f32), // floor diff --git a/luisa_compute/src/lang/types/vector/impls.rs b/luisa_compute/src/lang/types/vector/impls.rs index 8765d28..596127b 100644 --- a/luisa_compute/src/lang/types/vector/impls.rs +++ b/luisa_compute/src/lang/types/vector/impls.rs @@ -171,6 +171,24 @@ pub trait VectorExprProxy { })) } } +impl> VectorExprProxy2 { + #[tracked] + pub fn extend(self, z: impl AsExpr) -> Expr> + where + T: VectorAlign<3>, + { + Vec3::expr(self.x, self.y, z) + } +} +impl> VectorExprProxy3 { + #[tracked] + pub fn extend(self, w: impl AsExpr) -> Expr> + where + T: VectorAlign<4>, + { + Vec4::expr(self.x, self.y, self.z, w) + } +} impl SquareMatrix where f32: VectorAlign, diff --git a/luisa_compute/src/lib.rs b/luisa_compute/src/lib.rs index 061cf46..f87df30 100644 --- a/luisa_compute/src/lib.rs +++ b/luisa_compute/src/lib.rs @@ -41,7 +41,7 @@ pub mod prelude { pub use crate::runtime::api::StreamTag; pub use crate::runtime::{ Callable, Command, Device, DynCallable, Kernel, KernelBuildOptions, KernelDef, Scope, - Stream, + Stream, Swapchain, }; pub use crate::{cpu_dbg, if_, lc_assert, lc_unreachable, loop_, while_, Context}; diff --git a/luisa_compute/src/resource.rs b/luisa_compute/src/resource.rs index a228d50..9cfe65f 100644 --- a/luisa_compute/src/resource.rs +++ b/luisa_compute/src/resource.rs @@ -1,4 +1,5 @@ use std::cell::{Cell, RefCell}; +use std::fmt; use std::ops::RangeBounds; use std::process::abort; use std::sync::Arc; @@ -279,6 +280,33 @@ pub struct Buffer { pub(crate) len: usize, pub(crate) _marker: PhantomData, } +impl fmt::Debug for Buffer { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + struct DebugEllipsis; + impl fmt::Debug for DebugEllipsis { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + f.write_str("..") + } + } + + write!(f, "Buffer<{}>({})", std::any::type_name::(), self.len())?; + // if self.len() <= 16 || f.precision().is_some() { + // let count = f.precision().unwrap_or(16); + // if count >= self.len() { + // f.debug_list().entries(self.copy_to_vec().iter()).finish()?; + // } else { + // let values = self.view(0..count).copy_to_vec(); + // + // f.debug_list() + // .entries(values.iter()) + // .entry(&DebugEllipsis) + // .finish()?; + // } + // } + Ok(()) + } +} + pub(crate) struct BufferHandle { pub(crate) device: Device, pub(crate) handle: api::Buffer, @@ -406,7 +434,7 @@ impl Buffer { self.view(..).copy_from(data); } #[inline] - pub fn copy_from_async<'a>(&self, data: &[T]) -> Command<'_> { + pub fn copy_from_async<'a>(&self, data: &'a [T]) -> Command<'a> { self.view(..).copy_from_async(data) } #[inline] @@ -498,6 +526,12 @@ pub struct BufferHeap { pub(crate) inner: BindlessArray, pub(crate) _marker: PhantomData, } +impl fmt::Debug for BufferHeap { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + write!(f, "BufferHeap<{}>", std::any::type_name::(),) + } +} + pub struct BufferHeapVar { inner: BindlessArrayVar, _marker: PhantomData, @@ -849,7 +883,7 @@ unsafe impl Sync for BindlessArray {} pub use api::{PixelFormat, PixelStorage, Sampler, SamplerAddress, SamplerFilter}; use luisa_compute_ir::context::type_hash; use luisa_compute_ir::ir::{ - new_node, Binding, BindlessArrayBinding, BufferBinding, Func, Instruction, Node, TextureBinding, + Binding, BindlessArrayBinding, BufferBinding, Func, Instruction, Node, TextureBinding, }; pub(crate) struct TextureHandle { @@ -1060,6 +1094,17 @@ pub struct Tex2d { pub(crate) handle: Arc, pub(crate) marker: PhantomData, } +impl fmt::Debug for Tex2d { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + write!( + f, + "Tex2d<{}>({}, {})", + std::any::type_name::(), + self.width(), + self.height(), + ) + } +} // `T` is the read out type of the texture, which is not necessarily the same as // the storage type In fact, the texture can be stored in any format as long as @@ -1074,6 +1119,19 @@ pub struct Tex3d { pub(crate) handle: Arc, pub(crate) marker: PhantomData, } +impl fmt::Debug for Tex3d { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + write!( + f, + "Tex3d<{}>({}, {}, {})", + std::any::type_name::(), + self.width(), + self.height(), + self.depth(), + ) + } +} + #[derive(Clone, Copy)] pub struct Tex2dView<'a, T: IoTexel> { pub(crate) tex: &'a Tex2d, diff --git a/luisa_compute/src/rtx.rs b/luisa_compute/src/rtx.rs index 50d9295..4159fef 100644 --- a/luisa_compute/src/rtx.rs +++ b/luisa_compute/src/rtx.rs @@ -7,7 +7,7 @@ use crate::internal_prelude::*; use crate::runtime::*; use crate::{ResourceTracker, *}; use luisa_compute_ir::ir::{ - new_node, AccelBinding, Binding, Func, Instruction, IrBuilder, Node, NodeRef, Type, + AccelBinding, Binding, Func, Instruction, IrBuilder, Node, NodeRef, Type, }; use parking_lot::RwLock; use std::ops::Deref; diff --git a/luisa_compute/src/runtime.rs b/luisa_compute/src/runtime.rs index 2ad0783..30fa142 100644 --- a/luisa_compute/src/runtime.rs +++ b/luisa_compute/src/runtime.rs @@ -879,6 +879,7 @@ pub fn submit_default_stream_and_sync<'a, I: IntoIterator>>( }) } +#[must_use] pub struct Command<'a> { #[allow(dead_code)] pub(crate) inner: api::Command, diff --git a/luisa_compute_sys/LuisaCompute b/luisa_compute_sys/LuisaCompute index bcc49cd..fbb048b 160000 --- a/luisa_compute_sys/LuisaCompute +++ b/luisa_compute_sys/LuisaCompute @@ -1 +1 @@ -Subproject commit bcc49cdeb6004b62cd7cfc68010902e47682b5af +Subproject commit fbb048bd662bab74f373935af495f23e655cab48