From f11d997b15ca279337e8c90854d1c82ec09506c0 Mon Sep 17 00:00:00 2001 From: will_cr Date: Wed, 22 May 2024 12:34:46 +0200 Subject: [PATCH 01/12] update find_local neighbors --- .../Bond_Associated_Correspondence.jl | 24 +++++++++---------- .../bond_deformation_gradient.jl | 2 +- .../Pre_calculation/bond_shape_tensor.jl | 2 +- .../ut_Bond_Associated_Correspondence.jl | 6 ++--- 4 files changed, 16 insertions(+), 18 deletions(-) diff --git a/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl b/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl index 918318f6f..1dc3e764e 100644 --- a/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl +++ b/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl @@ -20,15 +20,14 @@ function init_material_model(datamanager::Module, nodes::Union{SubArray,Vector{I bond_horizon = material_parameter["Bond Horizon"] weighted_volume = datamanager.create_constant_bond_field("Bond Weighted Volume", Float64, 1) - try - for iID in nodes - for (jID, nID) in enumerate(nlist) - find_local_neighbors(coordinates[nID, :], coordinates[nlist, :], nlist, bond_horizon) + + for iID in nodes + for nID in nlist[iID] + if length(find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon)) + @error "Bond horizon is to small. No neighbors were found." end + end - catch - @error "Bond horizon is to small. Now neighbors were found." - return nothing end end @@ -66,12 +65,12 @@ https://link.springer.com/article/10.1007/s10409-021-01055-5 -function find_local_neighbors(neighbor_coordinate::Union{Vector{Float64},Vector{Int64}}, coordinates::Union{Matrix{Float64},Matrix{Int64}}, nlist::Union{Vector{Int64},SubArray{Int64}}, bond_horizon::Union{Float64,Int64}) +function find_local_neighbors(nID::Int64, coordinates::Union{Matrix{Float64},Matrix{Int64}}, nlist::Union{Vector{Int64},SubArray{Int64}}, bond_horizon::Union{Float64,Int64}) # excludes right now iID node in the coordinates list. Because it is an abritrary sublist it should be fine. # saving faster than recalculation? - balltree = BallTree(transpose(coordinates)) - - return nlist[inrange(balltree, neighbor_coordinate, bond_horizon, true)] + nlist_without_neighbor = view(nlist[nlist.!=nID], :) + balltree = BallTree(transpose(coordinates[nlist_without_neighbor, :])) + return nlist_without_neighbor[inrange(balltree, coordinates[nID, :], bond_horizon, true)] end @@ -161,8 +160,7 @@ function compute_bond_associated_weighted_volume(nodes::Union{SubArray,Vector{In neighborhood_volume = sum(volume[nlist[iID]] .* bond_damage[iID] .* omega[iID]) for (jID, nID) in enumerate(nlist[iID]) - nlist_without_neighbor = view(nlist[iID][nlist[iID].!=nID], :) - local_nlist = find_local_neighbors(coordinates[nID, :], coordinates[nlist_without_neighbor, :], nlist_without_neighbor, bond_horizon) + local_nlist = find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon) sub_bond_list = [findfirst(x -> x == elem, nlist[iID]) for elem in local_nlist] weighted_volume[iID][jID] = sum(volume[local_nlist] .* bond_damage[iID][sub_bond_list] .* omega[iID][sub_bond_list] / neighborhood_volume) end diff --git a/src/Physics/Pre_calculation/bond_deformation_gradient.jl b/src/Physics/Pre_calculation/bond_deformation_gradient.jl index 25a5e0137..74f5462c4 100644 --- a/src/Physics/Pre_calculation/bond_deformation_gradient.jl +++ b/src/Physics/Pre_calculation/bond_deformation_gradient.jl @@ -46,7 +46,7 @@ function compute(datamanager::Module, nodes::Union{SubArray,Vector{Int64}}) bond_horizon = horizon[iID] end for (jID, nID) in enumerate(nlist[iID]) - neighbor_nlist = find_local_neighbors(neighbor_coordinate[nID], coordinates[nlist[nlist.!=nID], :], nlist[iID], bond_horizon) + neighbor_nlist = find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon) indices = vcat(1:jID-1, jID+1:length(nlist[iID])) deformation_gradient[iID][jID, :, :] = Geometry.bond_associated_deformation_gradient(dof, volume[neighbor_nlist], omega[neighbor_nlist], bond_damage[iID][indices], undeformed_bond[iID][indices], deformed_bond[iID][indices], bond_deformation_gradient[iID][jID, :, :]) diff --git a/src/Physics/Pre_calculation/bond_shape_tensor.jl b/src/Physics/Pre_calculation/bond_shape_tensor.jl index 82804434a..d61884189 100644 --- a/src/Physics/Pre_calculation/bond_shape_tensor.jl +++ b/src/Physics/Pre_calculation/bond_shape_tensor.jl @@ -43,7 +43,7 @@ function compute(datamanager::Module, nodes::Union{SubArray,Vector{Int64}}) bond_horizon = horizon[iID] end for (jID, nID) in enumerate(nlist[iID]) - neighbor_nlist = find_local_neighbors(neighbor_coordinate[nID], coordinates[nlist[nlist.!=nID], :], nlist[iID], bond_horizon) + neighbor_nlist = find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon) indices = vcat(1:jID-1, jID+1:length(nlist[iID])) shape_tensor[iID][jID, :, :], inverse_shape_tensor[iID][jID, :, :] = Geometry.bond_associated_shape_tensor(dof, volume[neighbor_nlist], omega[neighbor_nlist], bond_damage[iID][indices], undeformed_bond[iID][indices], bond_shape_tensor[iID][jID, :, :], inverse_bond_shape_tensor[iID][jID, :, :]) end diff --git a/test/unit_tests/Physics/Material/Material_Models/ut_Bond_Associated_Correspondence.jl b/test/unit_tests/Physics/Material/Material_Models/ut_Bond_Associated_Correspondence.jl index ab3618dd4..16ddc4e14 100644 --- a/test/unit_tests/Physics/Material/Material_Models/ut_Bond_Associated_Correspondence.jl +++ b/test/unit_tests/Physics/Material/Material_Models/ut_Bond_Associated_Correspondence.jl @@ -23,10 +23,10 @@ using Test bond_horizon::Float64 = 1 - @test Bond_Associated_Correspondence.find_local_neighbors(coordinates[5, :], coordinates[nlist[nlist.!=5], :], nlist[nlist.!=5], bond_horizon) == [] + @test Bond_Associated_Correspondence.find_local_neighbors(5, coordinates, nlist, bond_horizon) == [] bond_horizon = 2.6 - @test Bond_Associated_Correspondence.find_local_neighbors(coordinates[5, :], coordinates[nlist[nlist.!=5], :], nlist[nlist.!=5], bond_horizon) == [2, 3, 4] - @test Bond_Associated_Correspondence.find_local_neighbors(coordinates[2, :], coordinates[nlist[nlist.!=2], :], nlist[nlist.!=2], bond_horizon) == [3, 4, 5] + @test Bond_Associated_Correspondence.find_local_neighbors(5, coordinates, nlist, bond_horizon) == [2, 3, 4] + @test Bond_Associated_Correspondence.find_local_neighbors(2, coordinates, nlist, bond_horizon) == [3, 4, 5] end @testset "ut_compute_bond_associated_weighted_volume" begin From c69bf0bad93770d2ffafcc5743b9ef5e117665a7 Mon Sep 17 00:00:00 2001 From: will_cr Date: Wed, 22 May 2024 14:59:00 +0200 Subject: [PATCH 02/12] minor improvements --- src/Physics/Material/Material_Factory.jl | 3 +-- .../Material/Material_Models/Bond_Associated_Correspondence.jl | 3 ++- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/Physics/Material/Material_Factory.jl b/src/Physics/Material/Material_Factory.jl index dd91c0098..d3a0d21d7 100644 --- a/src/Physics/Material/Material_Factory.jl +++ b/src/Physics/Material/Material_Factory.jl @@ -72,8 +72,7 @@ function init_material_model(datamanager::Module, nodes::Union{SubArray,Vector{I if occursin("Correspondence", model_param["Material Model"]) datamanager.set_model_module("Correspondence", Correspondence) - datamanager = Correspondence.init_material_model(datamanager, nodes, model_param) - return datamanager + return Correspondence.init_material_model(datamanager, nodes, model_param) end material_models = split(model_param["Material Model"], "+") diff --git a/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl b/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl index 1dc3e764e..2fd675849 100644 --- a/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl +++ b/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl @@ -25,6 +25,7 @@ function init_material_model(datamanager::Module, nodes::Union{SubArray,Vector{I for nID in nlist[iID] if length(find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon)) @error "Bond horizon is to small. No neighbors were found." + return nothing end end @@ -65,7 +66,7 @@ https://link.springer.com/article/10.1007/s10409-021-01055-5 -function find_local_neighbors(nID::Int64, coordinates::Union{Matrix{Float64},Matrix{Int64}}, nlist::Union{Vector{Int64},SubArray{Int64}}, bond_horizon::Union{Float64,Int64}) +function find_local_neighbors(nID::Int64, coordinates::Union{SubArray,Matrix{Float64},Matrix{Int64}}, nlist::Union{Vector{Int64},SubArray{Int64}}, bond_horizon::Union{Float64,Int64}) # excludes right now iID node in the coordinates list. Because it is an abritrary sublist it should be fine. # saving faster than recalculation? nlist_without_neighbor = view(nlist[nlist.!=nID], :) From 097e986f10a2e9d385cfa83ae905aaae9bdf5d1b Mon Sep 17 00:00:00 2001 From: will_cr Date: Wed, 22 May 2024 15:36:40 +0200 Subject: [PATCH 03/12] template update --- src/Support/Parameters/parameter_handling.jl | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Support/Parameters/parameter_handling.jl b/src/Support/Parameters/parameter_handling.jl index b1f2b28e1..8fdd9265b 100644 --- a/src/Support/Parameters/parameter_handling.jl +++ b/src/Support/Parameters/parameter_handling.jl @@ -116,6 +116,7 @@ global expected_structure = Dict( "Any" => [Dict{Any,Any}( "Material Model" => [String, true], "Symmetry" => [String, false], + "Bond Associated" => [Bool, false], "Poisson's Ratio" => [Union{Float64,Int64}, false], "Young's Modulus" => [Union{Float64,Int64}, false], "Bulk Modulus" => [Union{Float64,Int64}, false], From 0734bc83caf7c13fd871f4ddf85530bfbb003dfe Mon Sep 17 00:00:00 2001 From: will_cr Date: Wed, 22 May 2024 15:36:57 +0200 Subject: [PATCH 04/12] minor fix --- .../Material_Models/Bond_Associated_Correspondence.jl | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl b/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl index 2fd675849..c4cb39cef 100644 --- a/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl +++ b/src/Physics/Material/Material_Models/Bond_Associated_Correspondence.jl @@ -20,16 +20,16 @@ function init_material_model(datamanager::Module, nodes::Union{SubArray,Vector{I bond_horizon = material_parameter["Bond Horizon"] weighted_volume = datamanager.create_constant_bond_field("Bond Weighted Volume", Float64, 1) - for iID in nodes for nID in nlist[iID] - if length(find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon)) + if length(find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon)) == 0 @error "Bond horizon is to small. No neighbors were found." return nothing end end end + return datamanager end function compute_stress_integral(nodes::Union{SubArray,Vector{Int64}}, nlist::SubArray, omega::SubArray, bond_damage::SubArray, volume::SubArray, weighted_volume::SubArray, bond_geometry::SubArray, bond_length::SubArray, bond_stresses::SubArray, stress_integral::SubArray) From d8c1b577fec3566e2fe04147a065a070abd181aa Mon Sep 17 00:00:00 2001 From: will_cr Date: Wed, 22 May 2024 15:37:10 +0200 Subject: [PATCH 05/12] minor optimization --- src/Physics/Material/Material_Models/Correspondence.jl | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/Physics/Material/Material_Models/Correspondence.jl b/src/Physics/Material/Material_Models/Correspondence.jl index beebf9026..2d2c002b5 100644 --- a/src/Physics/Material/Material_Models/Correspondence.jl +++ b/src/Physics/Material/Material_Models/Correspondence.jl @@ -65,8 +65,7 @@ function init_material_model(datamanager::Module, nodes::Union{SubArray,Vector{I end if haskey(material_parameter, "Bond Associated") && material_parameter["Bond Associated"] - datamanager = Bond_Associated_Correspondence.init_material_model(datamanager, nodes, material_parameter) - return datamanager + return Bond_Associated_Correspondence.init_material_model(datamanager, nodes, material_parameter) end material_parameter["Bond Associated"] = false return datamanager From 2963a6248738765d598fb3c7e4edf9fddc5fd109 Mon Sep 17 00:00:00 2001 From: will_cr Date: Thu, 23 May 2024 11:04:04 +0200 Subject: [PATCH 06/12] improve code --- .../Pre_calculation/Pre_Calculation_Factory.jl | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/src/Physics/Pre_calculation/Pre_Calculation_Factory.jl b/src/Physics/Pre_calculation/Pre_Calculation_Factory.jl index 692b0afe8..6f1f975c6 100644 --- a/src/Physics/Pre_calculation/Pre_Calculation_Factory.jl +++ b/src/Physics/Pre_calculation/Pre_Calculation_Factory.jl @@ -69,20 +69,24 @@ function init_pre_calculation(datamanager::Module, options::Dict) datamanager.create_bond_field("Deformed Bond Geometry", Float64, dof) datamanager.create_bond_field("Deformed Bond Length", Float64, 1) end + + if options["Deformation Gradient"] + datamanager.create_constant_node_field("Deformation Gradient", Float64, "Matrix", dof) + options["Shape Tensor"] = true + end + + if options["Bond Associated Deformation Gradient"] + datamanager.create_constant_bond_field("Bond Associated Deformation Gradient", Float64, "Matrix", dof) + options["Bond Associated Shape Tensor"] = true + end if options["Shape Tensor"] datamanager.create_constant_node_field("Shape Tensor", Float64, "Matrix", dof) datamanager.create_constant_node_field("Inverse Shape Tensor", Float64, "Matrix", dof) end - if options["Deformation Gradient"] - datamanager.create_constant_node_field("Deformation Gradient", Float64, "Matrix", dof) - end if options["Bond Associated Shape Tensor"] datamanager.create_constant_bond_field("Bond Associated Shape Tensor", Float64, "Matrix", dof) datamanager.create_constant_bond_field("Inverse Bond Associated Shape Tensor", Float64, "Matrix", dof) end - if options["Bond Associated Deformation Gradient"] - datamanager.create_constant_bond_field("Bond Associated Deformation Gradient", Float64, "Matrix", dof) - end return datamanager end From cdb1b129c1e37f3aa30bd911b9a9ac6639340ff6 Mon Sep 17 00:00:00 2001 From: will_cr Date: Thu, 23 May 2024 15:36:51 +0200 Subject: [PATCH 07/12] code cleaning --- src/IO/mesh_data.jl | 2 +- src/Support/geometry.jl | 10 +++++----- test/unit_tests/Core/Solver/ut_Verlet.jl | 2 +- test/unit_tests/IO/ut_mesh_data.jl | 2 +- test/unit_tests/Support/ut_geometry.jl | 14 +++++++------- 5 files changed, 15 insertions(+), 15 deletions(-) diff --git a/src/IO/mesh_data.jl b/src/IO/mesh_data.jl index 50224268a..af8acc343 100644 --- a/src/IO/mesh_data.jl +++ b/src/IO/mesh_data.jl @@ -283,7 +283,7 @@ function get_bond_geometry(datamanager::Module) coor = datamanager.get_field("Coordinates") undeformed_bond = datamanager.create_constant_bond_field("Bond Geometry", Float64, dof) undeformed_bond_length = datamanager.create_constant_bond_field("Bond Length", Float64, 1) - undeformed_bond, undeformed_bond_length = Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) + undeformed_bond, undeformed_bond_length = Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) return datamanager end diff --git a/src/Support/geometry.jl b/src/Support/geometry.jl index 53861c930..9a1320df0 100644 --- a/src/Support/geometry.jl +++ b/src/Support/geometry.jl @@ -9,13 +9,12 @@ export bond_geometry export shape_tensor """ - bond_geometry(nodes::Union{SubArray,Vector{Int64}}, dof::Int64, nlist, coor, undeformed_bond, undeformed_bond_length) + bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist, coor, undeformed_bond, undeformed_bond_length) Calculate bond geometries between nodes based on their coordinates. # Arguments - `nodes::Union{SubArray,Vector{Int64}}`: A vector of integers representing node IDs. - - `dof::Int64`: An integer representing the degrees of freedom. - `nlist`: A data structure (e.g., a list or array) representing neighboring node IDs for each node. - `coor`: A matrix representing the coordinates of each node. - `undeformed_bond`: A preallocated array or data structure to store bond geometries. @@ -39,7 +38,7 @@ Calculate bond geometries between nodes based on their coordinates. undeformed_bond(nodes, dof, nlist, coor, undeformed_bond) """ -function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, dof::Int64, nlist, coor, undeformed_bond, undeformed_bond_length) +function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist::SubArray, coor::SubArray, undeformed_bond, undeformed_bond_length) for iID in nodes @@ -49,6 +48,7 @@ function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, dof::Int64, nlist, # Check for identical point coordinates if any(distances .== 0) + println() @error "Identical point coordinates with no distance $iID" return nothing end @@ -127,7 +127,7 @@ end function bond_associated_shape_tensor(dof::Int64, volume, omega, bond_damage, undeformed_bond, shape_tensor, inverse_shape_tensor) - + # bond geometries -> zwischen nachbar und seinen nachbarn shape_tensor[:, :] = calculate_shape_tensor(shape_tensor[:, :], dof, volume, omega, bond_damage, undeformed_bond) try inverse_shape_tensor[:, :] = inv(shape_tensor[:, :]) @@ -143,7 +143,7 @@ end function bond_associated_deformation_gradient(dof::Int64, volume, omega, bond_damage, undeformed_bond, deformed_bond, deformation_gradient) - + # bond deformation -> zwischen nachbar und seinen nachbarn return calculate_deformation_gradient(deformation_gradient, dof, bond_damage, deformed_bond, undeformed_bond, volume, omega) end diff --git a/test/unit_tests/Core/Solver/ut_Verlet.jl b/test/unit_tests/Core/Solver/ut_Verlet.jl index e2700f766..205fc4a2d 100644 --- a/test/unit_tests/Core/Solver/ut_Verlet.jl +++ b/test/unit_tests/Core/Solver/ut_Verlet.jl @@ -87,7 +87,7 @@ volume = [0.5, 0.5, 0.5, 0.5, 0.5] density = [1e-6, 1e-6, 3e-6, 3e-6, 1e-6] horizon = [3.1, 3.1, 3.1, 3.1, 3.1] -undeformed_bond = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) +undeformed_bond = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) blocks = [1, 1, 2, 2, 1] blocks = test_Data_manager.set_block_list(blocks) diff --git a/test/unit_tests/IO/ut_mesh_data.jl b/test/unit_tests/IO/ut_mesh_data.jl index a11940983..c89e13347 100644 --- a/test/unit_tests/IO/ut_mesh_data.jl +++ b/test/unit_tests/IO/ut_mesh_data.jl @@ -482,7 +482,7 @@ end coor = test_Data_manager.get_field("Coordinates") undeformed_bond = test_Data_manager.create_constant_bond_field("Bond Geometry", Float64, dof) undeformed_bond_length = test_Data_manager.create_constant_bond_field("Bond Length", Float64, 1) - undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) + undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) @test undeformed_bond[1][1, 1] == 1 @test undeformed_bond[1][1, 2] == 0 diff --git a/test/unit_tests/Support/ut_geometry.jl b/test/unit_tests/Support/ut_geometry.jl index 476288bb5..d9efb33de 100644 --- a/test/unit_tests/Support/ut_geometry.jl +++ b/test/unit_tests/Support/ut_geometry.jl @@ -34,7 +34,7 @@ using Test coor[4, 1] = 0 coor[4, 2] = 1 - undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) + undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) @test undeformed_bond[1][1, 1] == 0.5 @test undeformed_bond[1][1, 2] == 0.5 @@ -60,7 +60,7 @@ using Test @test undeformed_bond[4][1, 1] == 0.5 @test undeformed_bond[4][1, 2] == -0.5 @test undeformed_bond_length[4][1] / sqrt(1.25) - 1 < 1e-8 - undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) + undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) # test if a sum exists or not @test undeformed_bond[1][1, 1] == 0.5 @test undeformed_bond[1][1, 2] == 0.5 @@ -95,7 +95,7 @@ using Test undeformed_bond[3][:, :] .= 0 undeformed_bond[4][:, :] .= 0 - undeformed_bond = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) + undeformed_bond = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) @test isnothing(undeformed_bond) end @testset "ut_shape_tensor_and_deformation_gradient" begin @@ -146,7 +146,7 @@ end coor[4, 1] = 1 coor[4, 2] = 0.5 - undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, coor, undeformed_bond, undeformed_bond_length) + undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) shape_tensor, inverse_shape_tensor = PeriLab.IO.Geometry.shape_tensor(view(nodes, eachindex(nodes)), dof, nlist, volume, omega, bond_damage, undeformed_bond, shape_tensor, inverse_shape_tensor) deformed_coor = copy(coor) @@ -163,7 +163,7 @@ end deformed_coor[2, 1] = 0.25 deformed_coor[4, 1] = 0.25 - deformed_bond, deformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, deformed_coor, deformed_bond, deformed_bond_length) + deformed_bond, deformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, deformed_coor, deformed_bond, deformed_bond_length) deformation_gradient = PeriLab.IO.Geometry.deformation_gradient(view(nodes, eachindex(nodes)), dof, nlist, volume, omega, bond_damage, deformed_bond, undeformed_bond, inverse_shape_tensor, deformation_gradient) for i in 1:nnodes @@ -179,7 +179,7 @@ end deformed_coor[3, 2] = 1.5 deformed_coor[4, 2] = 1.5 - deformed_bond, deformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, deformed_coor, deformed_bond, deformed_bond_length) + deformed_bond, deformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, deformed_coor, deformed_bond, deformed_bond_length) deformation_gradient = PeriLab.IO.Geometry.deformation_gradient(view(nodes, eachindex(nodes)), dof, nlist, volume, omega, bond_damage, deformed_bond, undeformed_bond, inverse_shape_tensor, deformation_gradient) for i in 1:nnodes for j in nn[i] @@ -199,7 +199,7 @@ end deformed_coor[4, 1] = 1.5 deformed_coor[4, 2] = 0.5 - deformed_bond, deformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), dof, nlist, deformed_coor, deformed_bond, deformed_bond_length) + deformed_bond, deformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, deformed_coor, deformed_bond, deformed_bond_length) deformation_gradient = PeriLab.IO.Geometry.deformation_gradient(view(nodes, eachindex(nodes)), dof, nlist, volume, omega, bond_damage, deformed_bond, undeformed_bond, inverse_shape_tensor, deformation_gradient) for i in 1:nnodes for j in nn[i] From 59c81cb5b43b85692a53888a1aaaa60aef7b1524 Mon Sep 17 00:00:00 2001 From: will_cr Date: Thu, 23 May 2024 16:38:00 +0200 Subject: [PATCH 08/12] bond geometry update --- src/Support/geometry.jl | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/Support/geometry.jl b/src/Support/geometry.jl index 9a1320df0..b5d825ccf 100644 --- a/src/Support/geometry.jl +++ b/src/Support/geometry.jl @@ -53,13 +53,25 @@ function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist::SubArray, co return nothing end - undeformed_bond[iID] .= bond_vectors - undeformed_bond_length[iID] .= distances + undeformed_bond[iID], undeformed_bond_length[iID] = calculate_bond_length(iID, coor, nlist[iID]) end return undeformed_bond, undeformed_bond_length end +function calculate_bond_length(iID::Int64, coor::SubArray, nlist::Vector{Int64}) + + bond_vectors = coor[nlist, :] .- coor[iID, :]' + distances = sqrt.(sum(bond_vectors .^ 2, dims=2))[:] + + # Check for identical point coordinates + if any(distances .== 0) + println() + @error "Identical point coordinates with no distance $iID" + return nothing + end + return bond_vectors, distances +end """ shape_tensor(nodes::Union{SubArray, Vector{Int64}}, dof::Int64, nlist, volume, omega, bond_damage, undeformed_bond, shape_tensor, inverse_shape_tensor) From f716a5aac57443a71f6d3003a16f48a54a667801 Mon Sep 17 00:00:00 2001 From: will_cr Date: Thu, 23 May 2024 16:38:20 +0200 Subject: [PATCH 09/12] calculate_bond_length test --- test/unit_tests/Support/ut_geometry.jl | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/test/unit_tests/Support/ut_geometry.jl b/test/unit_tests/Support/ut_geometry.jl index d9efb33de..817a46e8f 100644 --- a/test/unit_tests/Support/ut_geometry.jl +++ b/test/unit_tests/Support/ut_geometry.jl @@ -3,9 +3,9 @@ # SPDX-License-Identifier: BSD-3-Clause using Test -#include("../../../src/PeriLab.jl") -#using .PeriLab - +include("../../../src/PeriLab.jl") +using .PeriLab +calculate_bond_length @testset "ut_undeformed_bond" begin nnodes = 4 dof = 2 @@ -34,6 +34,14 @@ using Test coor[4, 1] = 0 coor[4, 2] = 1 + u_bond, u_bond_length = PeriLab.IO.Geometry.calculate_bond_length(1, coor, nlist[1]) + @test u_bond[1, 1] == 0.5 + @test u_bond[1, 2] == 0.5 + @test isapprox(u_bond_length[1], sqrt(0.5)) + @test u_bond[2, 1] == 1 + @test u_bond[2, 2] == 0 + @test u_bond_length[2] == 1 + undeformed_bond, undeformed_bond_length = PeriLab.IO.Geometry.bond_geometry(Vector(1:nnodes), nlist, coor, undeformed_bond, undeformed_bond_length) @test undeformed_bond[1][1, 1] == 0.5 From 0f588f55b580d5d24dee867fb2e14bc0fd9e884e Mon Sep 17 00:00:00 2001 From: will_cr Date: Fri, 24 May 2024 08:23:18 +0200 Subject: [PATCH 10/12] test fix --- src/Support/geometry.jl | 21 ++++----------------- 1 file changed, 4 insertions(+), 17 deletions(-) diff --git a/src/Support/geometry.jl b/src/Support/geometry.jl index b5d825ccf..e453a6e4c 100644 --- a/src/Support/geometry.jl +++ b/src/Support/geometry.jl @@ -38,38 +38,25 @@ Calculate bond geometries between nodes based on their coordinates. undeformed_bond(nodes, dof, nlist, coor, undeformed_bond) """ -function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist::SubArray, coor::SubArray, undeformed_bond, undeformed_bond_length) +function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist::SubArray, coor::Union{SubArray,Matrix{Float64},Matrix{Int64}}, undeformed_bond, undeformed_bond_length) for iID in nodes - - # Calculate bond vector and distance - bond_vectors = coor[nlist[iID], :] .- coor[iID, :]' - distances = sqrt.(sum(bond_vectors .^ 2, dims=2)) - - # Check for identical point coordinates - if any(distances .== 0) + undeformed_bond[iID], undeformed_bond_length[iID] = calculate_bond_length(iID, coor, nlist[iID]) + if any(undeformed_bond_length[iID] .== 0) println() @error "Identical point coordinates with no distance $iID" return nothing end - - undeformed_bond[iID], undeformed_bond_length[iID] = calculate_bond_length(iID, coor, nlist[iID]) - end return undeformed_bond, undeformed_bond_length end -function calculate_bond_length(iID::Int64, coor::SubArray, nlist::Vector{Int64}) +function calculate_bond_length(iID::Int64, coor::Union{SubArray,Matrix{Float64},Matrix{Int64}}, nlist::Vector{Int64}) bond_vectors = coor[nlist, :] .- coor[iID, :]' distances = sqrt.(sum(bond_vectors .^ 2, dims=2))[:] # Check for identical point coordinates - if any(distances .== 0) - println() - @error "Identical point coordinates with no distance $iID" - return nothing - end return bond_vectors, distances end """ From d230bbc9d98c81e231a16cab688882a595524705 Mon Sep 17 00:00:00 2001 From: will_cr Date: Fri, 24 May 2024 08:45:43 +0200 Subject: [PATCH 11/12] test fix --- src/Physics/Pre_calculation/bond_shape_tensor.jl | 12 ++++++++++-- test/unit_tests/Physics/ut_Physics_Factory.jl | 11 ++++++----- test/unit_tests/Support/ut_geometry.jl | 4 ++-- 3 files changed, 18 insertions(+), 9 deletions(-) diff --git a/src/Physics/Pre_calculation/bond_shape_tensor.jl b/src/Physics/Pre_calculation/bond_shape_tensor.jl index d61884189..a7d97f314 100644 --- a/src/Physics/Pre_calculation/bond_shape_tensor.jl +++ b/src/Physics/Pre_calculation/bond_shape_tensor.jl @@ -4,6 +4,7 @@ module Bond_Shape_Tensor include("../Material/Material_Models/Bond_Associated_Correspondence.jl") + using .Bond_Associated_Correspondence: find_local_neighbors export compute @@ -26,7 +27,7 @@ function compute(datamanager::Module, nodes::Union{SubArray,Vector{Int64}}) volume = datamanager.get_field("Volume") omega = datamanager.get_field("Influence Function") bond_damage = datamanager.get_bond_damage("NP1") - undeformed_bond = datamanager.get_field("Bond Geometry") + coordinates = datamanager.get_field("Coordinates") bond_shape_tensor = datamanager.get_field("Bond Associated Shape Tensor") inverse_bond_shape_tensor = datamanager.get_field("Inverse Bond Associated Shape Tensor") @@ -42,10 +43,17 @@ function compute(datamanager::Module, nodes::Union{SubArray,Vector{Int64}}) if isnothing(bond_horizon) bond_horizon = horizon[iID] end + #bond damage for (jID, nID) in enumerate(nlist[iID]) + neighbor_nlist = find_local_neighbors(nID, coordinates, nlist[iID], bond_horizon) + undeformed_bond, distances = Geometry.calculate_bond_length(coor[nID, :], neighbor_nlist) + # TODO Bond damage is not correct and must be adapted + # indices are not needed for that indices = vcat(1:jID-1, jID+1:length(nlist[iID])) - shape_tensor[iID][jID, :, :], inverse_shape_tensor[iID][jID, :, :] = Geometry.bond_associated_shape_tensor(dof, volume[neighbor_nlist], omega[neighbor_nlist], bond_damage[iID][indices], undeformed_bond[iID][indices], bond_shape_tensor[iID][jID, :, :], inverse_bond_shape_tensor[iID][jID, :, :]) + + + shape_tensor[iID][jID, :, :], inverse_shape_tensor[iID][jID, :, :] = Geometry.bond_associated_shape_tensor(dof, volume[neighbor_nlist], omega[neighbor_nlist], bond_damage[iID][indices], undeformed_bond, bond_shape_tensor[iID][jID, :, :], inverse_bond_shape_tensor[iID][jID, :, :]) end end diff --git a/test/unit_tests/Physics/ut_Physics_Factory.jl b/test/unit_tests/Physics/ut_Physics_Factory.jl index fd6ae431a..b554b77c5 100644 --- a/test/unit_tests/Physics/ut_Physics_Factory.jl +++ b/test/unit_tests/Physics/ut_Physics_Factory.jl @@ -3,8 +3,8 @@ # SPDX-License-Identifier: BSD-3-Clause include("../../../src/Physics/Physics_Factory.jl") -# include("../../../src/Core/data_manager.jl") -# include("../../../src/Support/Parameters/parameter_handling.jl") +#include("../../../src/PeriLab.jl") +#using .PeriLab using Test import .Physics @testset "ut_get_block_model_definition" begin @@ -80,8 +80,8 @@ end test_Data_manager = Physics.init_pre_calculation(test_Data_manager, options) @test "Deformed Bond GeometryN" in test_Data_manager.get_all_field_keys() @test "Deformed Bond GeometryNP1" in test_Data_manager.get_all_field_keys() - @test !("Shape Tensor" in test_Data_manager.get_all_field_keys()) - @test !("Inverse Shape Tensor" in test_Data_manager.get_all_field_keys()) + @test "Shape Tensor" in test_Data_manager.get_all_field_keys() + @test "Inverse Shape Tensor" in test_Data_manager.get_all_field_keys() @test "Deformation Gradient" in test_Data_manager.get_all_field_keys() @test !("Bond Associated Shape Tensor" in test_Data_manager.get_all_field_keys()) @test !("Bond Associated Deformation Gradient" in test_Data_manager.get_all_field_keys()) @@ -97,7 +97,7 @@ end @test "Bond Associated Shape Tensor" in test_Data_manager.get_all_field_keys() @test !("Bond Associated Deformation Gradient" in test_Data_manager.get_all_field_keys()) - options = Dict("Deformed Bond Geometry" => true, "Shape Tensor" => true, "Deformation Gradient" => true, "Bond Associated Shape Tensor" => true, "Bond Associated Deformation Gradient" => true) + options = Dict("Deformed Bond Geometry" => true, "Shape Tensor" => false, "Deformation Gradient" => true, "Bond Associated Shape Tensor" => false, "Bond Associated Deformation Gradient" => true) test_Data_manager = Physics.init_pre_calculation(test_Data_manager, options) @test "Deformed Bond GeometryN" in test_Data_manager.get_all_field_keys() @@ -106,4 +106,5 @@ end @test "Deformation Gradient" in test_Data_manager.get_all_field_keys() @test "Bond Associated Shape Tensor" in test_Data_manager.get_all_field_keys() @test "Bond Associated Deformation Gradient" in test_Data_manager.get_all_field_keys() + end \ No newline at end of file diff --git a/test/unit_tests/Support/ut_geometry.jl b/test/unit_tests/Support/ut_geometry.jl index 817a46e8f..5765a4e6f 100644 --- a/test/unit_tests/Support/ut_geometry.jl +++ b/test/unit_tests/Support/ut_geometry.jl @@ -3,8 +3,8 @@ # SPDX-License-Identifier: BSD-3-Clause using Test -include("../../../src/PeriLab.jl") -using .PeriLab +#include("../../../src/PeriLab.jl") +#using .PeriLab calculate_bond_length @testset "ut_undeformed_bond" begin nnodes = 4 From 491dace917f741ab420722d79636879f2ecff7ac Mon Sep 17 00:00:00 2001 From: will_cr Date: Fri, 24 May 2024 09:02:49 +0200 Subject: [PATCH 12/12] test fix --- src/Physics/Pre_calculation/bond_deformation.jl | 3 +-- src/Support/geometry.jl | 2 +- test/unit_tests/Support/ut_geometry.jl | 1 - 3 files changed, 2 insertions(+), 4 deletions(-) diff --git a/src/Physics/Pre_calculation/bond_deformation.jl b/src/Physics/Pre_calculation/bond_deformation.jl index 751624fcd..a9c314fdf 100644 --- a/src/Physics/Pre_calculation/bond_deformation.jl +++ b/src/Physics/Pre_calculation/bond_deformation.jl @@ -20,12 +20,11 @@ Compute the bond deformation. - `datamanager`: Datamanager. """ function compute(datamanager::Module, nodes::Union{SubArray,Vector{Int64}}, time::Float64) - dof = datamanager.get_dof() nlist = datamanager.get_nlist() deformed_coor = datamanager.get_field("Deformed Coordinates", "NP1") deformed_bond = datamanager.get_field("Deformed Bond Geometry", "NP1") deformed_bond_length = datamanager.get_field("Deformed Bond Length", "NP1") - deformed_bond, deformed_bond_length = Geometry.bond_geometry(nodes, dof, nlist, deformed_coor, deformed_bond, deformed_bond_length) + deformed_bond, deformed_bond_length = Geometry.bond_geometry(nodes, nlist, deformed_coor, deformed_bond, deformed_bond_length) return datamanager end diff --git a/src/Support/geometry.jl b/src/Support/geometry.jl index e453a6e4c..53ea4febe 100644 --- a/src/Support/geometry.jl +++ b/src/Support/geometry.jl @@ -38,7 +38,7 @@ Calculate bond geometries between nodes based on their coordinates. undeformed_bond(nodes, dof, nlist, coor, undeformed_bond) """ -function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist::SubArray, coor::Union{SubArray,Matrix{Float64},Matrix{Int64}}, undeformed_bond, undeformed_bond_length) +function bond_geometry(nodes::Union{SubArray,Vector{Int64}}, nlist::Union{SubArray,Vector{Int64}}, coor::Union{SubArray,Matrix{Float64},Matrix{Int64}}, undeformed_bond, undeformed_bond_length) for iID in nodes undeformed_bond[iID], undeformed_bond_length[iID] = calculate_bond_length(iID, coor, nlist[iID]) diff --git a/test/unit_tests/Support/ut_geometry.jl b/test/unit_tests/Support/ut_geometry.jl index 5765a4e6f..46c692819 100644 --- a/test/unit_tests/Support/ut_geometry.jl +++ b/test/unit_tests/Support/ut_geometry.jl @@ -5,7 +5,6 @@ using Test #include("../../../src/PeriLab.jl") #using .PeriLab -calculate_bond_length @testset "ut_undeformed_bond" begin nnodes = 4 dof = 2