From ace49eea2e7eb39357cff564f0bc45102505c692 Mon Sep 17 00:00:00 2001 From: Karl Pierce Date: Tue, 3 Sep 2024 16:13:37 -0400 Subject: [PATCH 1/8] [NDTensors] Scalar diag calls `expose` to skip scalar indexing (#1517) --- NDTensors/src/diag/diagtensor.jl | 3 ++- NDTensors/test/test_diag.jl | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/NDTensors/src/diag/diagtensor.jl b/NDTensors/src/diag/diagtensor.jl index af0c294a0a..852fefa466 100644 --- a/NDTensors/src/diag/diagtensor.jl +++ b/NDTensors/src/diag/diagtensor.jl @@ -82,7 +82,8 @@ setdiag(T::UniformDiagTensor, val) = tensor(Diag(val), inds(T)) end end @propagate_inbounds getindex(T::DiagTensor{<:Number,1}, ind::Int) = storage(T)[ind] -@propagate_inbounds getindex(T::DiagTensor{<:Number,0}) = storage(T)[1] +using NDTensors.Expose: expose +@propagate_inbounds getindex(T::DiagTensor{<:Number,0}) = getindex(expose(storage(T))) # Set diagonal elements # Throw error for off-diagonal diff --git a/NDTensors/test/test_diag.jl b/NDTensors/test/test_diag.jl index 997ca497dd..cb8adc367a 100644 --- a/NDTensors/test/test_diag.jl +++ b/NDTensors/test/test_diag.jl @@ -63,7 +63,7 @@ using .NDTensorsTestUtils: devices_list, is_supported_eltype @test x == dev(diagm(0 => vr)) @test x == D end - + @test sqrt(contract(D, (-1, -2), conj(D), (-1, -2))[]) ≈ norm(D) # This if statement corresponds to the reported bug: # https://github.com/JuliaGPU/Metal.jl/issues/364 if !(dev == NDTensors.mtl && elt === ComplexF32) From fa697c99744c3739b3707c571a2c3f2881fe9811 Mon Sep 17 00:00:00 2001 From: Matt Fishman Date: Tue, 3 Sep 2024 16:14:24 -0400 Subject: [PATCH 2/8] [NDTensors] Bump to v0.3.40 [no ci] --- NDTensors/Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/NDTensors/Project.toml b/NDTensors/Project.toml index 66be11c53d..77373b407e 100644 --- a/NDTensors/Project.toml +++ b/NDTensors/Project.toml @@ -1,7 +1,7 @@ name = "NDTensors" uuid = "23ae76d9-e61a-49c4-8f12-3f1a16adf9cf" authors = ["Matthew Fishman "] -version = "0.3.39" +version = "0.3.40" [deps] Accessors = "7d9f7c33-5ae7-4f3b-8dc6-eff91059b697" From cf518973152960c83b0aaa743929af15ef7993e0 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Tue, 3 Sep 2024 16:18:41 -0400 Subject: [PATCH 3/8] CompatHelper: bump compat for AMDGPU in [weakdeps] to 1 for package NDTensors, (keep existing compat) (#1522) Co-authored-by: CompatHelper Julia --- NDTensors/Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/NDTensors/Project.toml b/NDTensors/Project.toml index 77373b407e..46208bce42 100644 --- a/NDTensors/Project.toml +++ b/NDTensors/Project.toml @@ -54,7 +54,7 @@ NDTensorsTBLISExt = "TBLIS" NDTensorscuTENSORExt = "cuTENSOR" [compat] -AMDGPU = "0.9" +AMDGPU = "0.9, 1" Accessors = "0.1.33" Adapt = "3.7, 4" ArrayLayouts = "1.4" From b7d31b0786bc36233931002077dede7b055e612c Mon Sep 17 00:00:00 2001 From: Matt Fishman Date: Tue, 3 Sep 2024 16:19:10 -0400 Subject: [PATCH 4/8] [NDTensors] Bump to v0.3.41 [no ci] --- NDTensors/Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/NDTensors/Project.toml b/NDTensors/Project.toml index 46208bce42..4efc49919b 100644 --- a/NDTensors/Project.toml +++ b/NDTensors/Project.toml @@ -1,7 +1,7 @@ name = "NDTensors" uuid = "23ae76d9-e61a-49c4-8f12-3f1a16adf9cf" authors = ["Matthew Fishman "] -version = "0.3.40" +version = "0.3.41" [deps] Accessors = "7d9f7c33-5ae7-4f3b-8dc6-eff91059b697" From c2816cde597262a6393ff6ede8e85282ce037764 Mon Sep 17 00:00:00 2001 From: NuclearPowerNerd <58567518+NuclearPowerNerd@users.noreply.github.com> Date: Tue, 3 Sep 2024 16:20:27 -0400 Subject: [PATCH 5/8] [DOCS] Fix typo in `error_contract` docstring (#1520) --- src/lib/ITensorMPS/src/mpo.jl | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/lib/ITensorMPS/src/mpo.jl b/src/lib/ITensorMPS/src/mpo.jl index cd4b076fc8..647ca1bad6 100644 --- a/src/lib/ITensorMPS/src/mpo.jl +++ b/src/lib/ITensorMPS/src/mpo.jl @@ -561,7 +561,7 @@ end """ error_contract(y::MPS, A::MPO, x::MPS; make_inds_match::Bool = true) - error_contract(y::MPS, x::MPS, x::MPO; + error_contract(y::MPS, x::MPS, A::MPO; make_inds_match::Bool = true) Compute the distance between A|x> and an approximation MPS y: From 63e7e737e05e117cd3e43dd49ff93ab4af1cba04 Mon Sep 17 00:00:00 2001 From: Matt Fishman Date: Tue, 3 Sep 2024 16:20:52 -0400 Subject: [PATCH 6/8] [ITensors] Bump to v0.6.17 [no ci] --- Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Project.toml b/Project.toml index 4710d75ddf..02b13bdf91 100644 --- a/Project.toml +++ b/Project.toml @@ -1,7 +1,7 @@ name = "ITensors" uuid = "9136182c-28ba-11e9-034c-db9fb085ebd5" authors = ["Matthew Fishman ", "Miles Stoudenmire "] -version = "0.6.16" +version = "0.6.17" [deps] Adapt = "79e6a3ab-5dfb-504d-930d-738a2a938a0e" From 995b6dce277b9304254c3ba7e0585b5e459651d4 Mon Sep 17 00:00:00 2001 From: Karl Pierce Date: Tue, 3 Sep 2024 20:25:50 -0400 Subject: [PATCH 7/8] [NDTensors] Use TensorOperations.jl v5 in tests (#1483) --- .../src/lib/TensorAlgebra/test/test_basics.jl | 141 +++++++++--------- .../test/NDTensorsTestUtils/device_list.jl | 3 - 2 files changed, 68 insertions(+), 76 deletions(-) diff --git a/NDTensors/src/lib/TensorAlgebra/test/test_basics.jl b/NDTensors/src/lib/TensorAlgebra/test/test_basics.jl index bafabdf0b9..95576a8bf5 100644 --- a/NDTensors/src/lib/TensorAlgebra/test/test_basics.jl +++ b/NDTensors/src/lib/TensorAlgebra/test/test_basics.jl @@ -122,83 +122,78 @@ end @test eltype(a_split) === elt @test a_split ≈ reshape(a, (2, 3, 20)) end - ## Right now TensorOperations version is downgraded when using cuTENSOR to `v0.7` we - ## are waiting for TensorOperations to support the breaking changes in cuTENSOR 2.x - if !("cutensor" ∈ ARGS) - using TensorOperations: TensorOperations - @testset "contract (eltype1=$elt1, eltype2=$elt2)" for elt1 in elts, elt2 in elts - dims = (2, 3, 4, 5, 6, 7, 8, 9, 10) - labels = (:a, :b, :c, :d, :e, :f, :g, :h, :i) - for (d1s, d2s, d_dests) in ( - ((1, 2), (1, 2), ()), - ((1, 2), (2, 1), ()), - ((1, 2), (2, 1, 3), (3,)), - ((1, 2, 3), (2, 1), (3,)), - ((1, 2), (2, 3), (1, 3)), - ((1, 2), (2, 3), (3, 1)), - ((2, 1), (2, 3), (3, 1)), - ((1, 2, 3), (2, 3, 4), (1, 4)), - ((1, 2, 3), (2, 3, 4), (4, 1)), - ((3, 2, 1), (4, 2, 3), (4, 1)), - ((1, 2, 3), (3, 4), (1, 2, 4)), - ((1, 2, 3), (3, 4), (4, 1, 2)), - ((1, 2, 3), (3, 4), (2, 4, 1)), - ((3, 1, 2), (3, 4), (2, 4, 1)), - ((3, 2, 1), (4, 3), (2, 4, 1)), - ((1, 2, 3, 4, 5, 6), (4, 5, 6, 7, 8, 9), (1, 2, 3, 7, 8, 9)), - ((2, 4, 5, 1, 6, 3), (6, 4, 9, 8, 5, 7), (1, 7, 2, 8, 3, 9)), - ) - a1 = randn(elt1, map(i -> dims[i], d1s)) - labels1 = map(i -> labels[i], d1s) - a2 = randn(elt2, map(i -> dims[i], d2s)) - labels2 = map(i -> labels[i], d2s) - labels_dest = map(i -> labels[i], d_dests) + using TensorOperations: TensorOperations + @testset "contract (eltype1=$elt1, eltype2=$elt2)" for elt1 in elts, elt2 in elts + dims = (2, 3, 4, 5, 6, 7, 8, 9, 10) + labels = (:a, :b, :c, :d, :e, :f, :g, :h, :i) + for (d1s, d2s, d_dests) in ( + ((1, 2), (1, 2), ()), + ((1, 2), (2, 1), ()), + ((1, 2), (2, 1, 3), (3,)), + ((1, 2, 3), (2, 1), (3,)), + ((1, 2), (2, 3), (1, 3)), + ((1, 2), (2, 3), (3, 1)), + ((2, 1), (2, 3), (3, 1)), + ((1, 2, 3), (2, 3, 4), (1, 4)), + ((1, 2, 3), (2, 3, 4), (4, 1)), + ((3, 2, 1), (4, 2, 3), (4, 1)), + ((1, 2, 3), (3, 4), (1, 2, 4)), + ((1, 2, 3), (3, 4), (4, 1, 2)), + ((1, 2, 3), (3, 4), (2, 4, 1)), + ((3, 1, 2), (3, 4), (2, 4, 1)), + ((3, 2, 1), (4, 3), (2, 4, 1)), + ((1, 2, 3, 4, 5, 6), (4, 5, 6, 7, 8, 9), (1, 2, 3, 7, 8, 9)), + ((2, 4, 5, 1, 6, 3), (6, 4, 9, 8, 5, 7), (1, 7, 2, 8, 3, 9)), + ) + a1 = randn(elt1, map(i -> dims[i], d1s)) + labels1 = map(i -> labels[i], d1s) + a2 = randn(elt2, map(i -> dims[i], d2s)) + labels2 = map(i -> labels[i], d2s) + labels_dest = map(i -> labels[i], d_dests) - # Don't specify destination labels - a_dest, labels_dest′ = TensorAlgebra.contract(a1, labels1, a2, labels2) - a_dest_tensoroperations = TensorOperations.tensorcontract( - labels_dest′, a1, labels1, a2, labels2 - ) - @test a_dest ≈ a_dest_tensoroperations + # Don't specify destination labels + a_dest, labels_dest′ = TensorAlgebra.contract(a1, labels1, a2, labels2) + a_dest_tensoroperations = TensorOperations.tensorcontract( + labels_dest′, a1, labels1, a2, labels2 + ) + @test a_dest ≈ a_dest_tensoroperations - # Specify destination labels - a_dest = TensorAlgebra.contract(labels_dest, a1, labels1, a2, labels2) - a_dest_tensoroperations = TensorOperations.tensorcontract( - labels_dest, a1, labels1, a2, labels2 - ) - @test a_dest ≈ a_dest_tensoroperations + # Specify destination labels + a_dest = TensorAlgebra.contract(labels_dest, a1, labels1, a2, labels2) + a_dest_tensoroperations = TensorOperations.tensorcontract( + labels_dest, a1, labels1, a2, labels2 + ) + @test a_dest ≈ a_dest_tensoroperations - # Specify α and β - elt_dest = promote_type(elt1, elt2) - # TODO: Using random `α`, `β` causing - # random test failures, investigate why. - α = elt_dest(1.2) # randn(elt_dest) - β = elt_dest(2.4) # randn(elt_dest) - a_dest_init = randn(elt_dest, map(i -> dims[i], d_dests)) - a_dest = copy(a_dest_init) - TensorAlgebra.contract!(a_dest, labels_dest, a1, labels1, a2, labels2, α, β) - a_dest_tensoroperations = TensorOperations.tensorcontract( - labels_dest, a1, labels1, a2, labels2 - ) - ## Here we loosened the tolerance because of some floating point roundoff issue. - ## with Float32 numbers - @test a_dest ≈ α * a_dest_tensoroperations + β * a_dest_init rtol = - 50 * default_rtol(elt_dest) - end + # Specify α and β + elt_dest = promote_type(elt1, elt2) + # TODO: Using random `α`, `β` causing + # random test failures, investigate why. + α = elt_dest(1.2) # randn(elt_dest) + β = elt_dest(2.4) # randn(elt_dest) + a_dest_init = randn(elt_dest, map(i -> dims[i], d_dests)) + a_dest = copy(a_dest_init) + TensorAlgebra.contract!(a_dest, labels_dest, a1, labels1, a2, labels2, α, β) + a_dest_tensoroperations = TensorOperations.tensorcontract( + labels_dest, a1, labels1, a2, labels2 + ) + ## Here we loosened the tolerance because of some floating point roundoff issue. + ## with Float32 numbers + @test a_dest ≈ α * a_dest_tensoroperations + β * a_dest_init rtol = + 50 * default_rtol(elt_dest) end end - @testset "qr (eltype=$elt)" for elt in elts - a = randn(elt, 5, 4, 3, 2) - labels_a = (:a, :b, :c, :d) - labels_q = (:b, :a) - labels_r = (:d, :c) - q, r = qr(a, labels_a, labels_q, labels_r) - label_qr = :qr - a′ = TensorAlgebra.contract( - labels_a, q, (labels_q..., label_qr), r, (label_qr, labels_r...) - ) - @test a ≈ a′ - end end - +@testset "qr (eltype=$elt)" for elt in elts + a = randn(elt, 5, 4, 3, 2) + labels_a = (:a, :b, :c, :d) + labels_q = (:b, :a) + labels_r = (:d, :c) + q, r = qr(a, labels_a, labels_q, labels_r) + label_qr = :qr + a′ = TensorAlgebra.contract( + labels_a, q, (labels_q..., label_qr), r, (label_qr, labels_r...) + ) + @test a ≈ a′ +end end diff --git a/NDTensors/test/NDTensorsTestUtils/device_list.jl b/NDTensors/test/NDTensorsTestUtils/device_list.jl index 56c44d5fc4..1220ec42a9 100644 --- a/NDTensors/test/NDTensorsTestUtils/device_list.jl +++ b/NDTensors/test/NDTensorsTestUtils/device_list.jl @@ -17,9 +17,6 @@ if "metal" in ARGS || "all" in ARGS using Metal end if "cutensor" in ARGS || "all" in ARGS - if in("TensorOperations", map(v -> v.name, values(Pkg.dependencies()))) - Pkg.rm("TensorOperations") - end Pkg.add("cuTENSOR") using CUDA, cuTENSOR end From 988e2165360f75e3851be169c539c6abde61bc8e Mon Sep 17 00:00:00 2001 From: Matt Fishman Date: Tue, 3 Sep 2024 20:27:03 -0400 Subject: [PATCH 8/8] [NDTensors] Bump to v0.3.42 [no ci] --- NDTensors/Project.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/NDTensors/Project.toml b/NDTensors/Project.toml index 4efc49919b..79b140cee6 100644 --- a/NDTensors/Project.toml +++ b/NDTensors/Project.toml @@ -1,7 +1,7 @@ name = "NDTensors" uuid = "23ae76d9-e61a-49c4-8f12-3f1a16adf9cf" authors = ["Matthew Fishman "] -version = "0.3.41" +version = "0.3.42" [deps] Accessors = "7d9f7c33-5ae7-4f3b-8dc6-eff91059b697"