From ec4f6f66912dddd6a0e60708ca4633ba8e073702 Mon Sep 17 00:00:00 2001 From: Adrian Hurtado Date: Wed, 6 Mar 2024 14:41:40 -0500 Subject: [PATCH 1/6] Fixes problem with setting units to au or Bohr --- src/madness/chem/molecule.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/madness/chem/molecule.h b/src/madness/chem/molecule.h index 4a575273bb4..74dc7623caa 100644 --- a/src/madness/chem/molecule.h +++ b/src/madness/chem/molecule.h @@ -209,7 +209,7 @@ class Molecule { // } if (source_type()=="xyz") set_derived_value("units",std::string("angstrom")); - if (units()=="bohr" or units()=="au") set_derived_value("units","atomic"); + if (units()=="bohr" or units()=="au") set_derived_value("units",std::string("atomic")); } std::string source_type() const {return get("source_type");} From afa2c4a3e2b1bd0fa1fa60e409e7695ccf0765bb Mon Sep 17 00:00:00 2001 From: Jonathon Misiewicz Date: Thu, 21 Mar 2024 08:51:16 -0400 Subject: [PATCH 2/6] Update cmake.yml --- .github/workflows/cmake.yml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/.github/workflows/cmake.yml b/.github/workflows/cmake.yml index e02bb74d348..0f90454ef9d 100644 --- a/.github/workflows/cmake.yml +++ b/.github/workflows/cmake.yml @@ -40,7 +40,7 @@ jobs: -DMPIEXEC_PREFLAGS='--bind-to;none;--allow-run-as-root' -DBUILD_TESTING=ON -DMADNESS_ENABLE_CEREAL=ON - -DMADNESS_BUILD_MADWORLD_ONLY=${{ matrix.task_backend != 'Threads' }} + -DMADNESS_BUILD_MADWORLD_ONLY=${{ matrix.task_backend != 'Threads' || matrix.build_type == 'Debug' }} -DMADNESS_BUILD_LIBRARIES_ONLY=${{ matrix.build_type != 'Debug' }} steps: @@ -145,6 +145,7 @@ jobs: cmake -S $GITHUB_WORKSPACE/doc/tutorial -B test_install -DCMAKE_PREFIX_PATH=${{github.workspace}}/install cmake --build test_install test_install/test_runtime - if [ "X${{ matrix.task_backend }}" = "XThreads" ]; then # if built more than just MADWorld run the HF test + # if built more than just MADWorld run the HF test + if [ "X${{ matrix.task_backend }}" = "XThreads" && "X${{ matrix.build_type }}" != "XDebug" ]; then test_install/simple_hf fi From 82830fb8b622735d8237092941d11002d61de510 Mon Sep 17 00:00:00 2001 From: Jonathon Misiewicz Date: Wed, 27 Mar 2024 11:28:32 -0400 Subject: [PATCH 3/6] Update cmake.yml --- .github/workflows/cmake.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/cmake.yml b/.github/workflows/cmake.yml index 0f90454ef9d..e2122f7343d 100644 --- a/.github/workflows/cmake.yml +++ b/.github/workflows/cmake.yml @@ -40,7 +40,7 @@ jobs: -DMPIEXEC_PREFLAGS='--bind-to;none;--allow-run-as-root' -DBUILD_TESTING=ON -DMADNESS_ENABLE_CEREAL=ON - -DMADNESS_BUILD_MADWORLD_ONLY=${{ matrix.task_backend != 'Threads' || matrix.build_type == 'Debug' }} + -DMADNESS_BUILD_MADWORLD_ONLY=${{ matrix.task_backend != 'Threads' }} -DMADNESS_BUILD_LIBRARIES_ONLY=${{ matrix.build_type != 'Debug' }} steps: @@ -134,11 +134,13 @@ jobs: run: cmake --build . --target check-short-madness - name: Install + if: matrix.build_type != 'Debug' working-directory: ${{github.workspace}}/build shell: bash run: cmake --build . --target install - name: Test Install Tree + if: matrix.build_type != 'Debug' working-directory: ${{github.workspace}}/build shell: bash run: | @@ -146,6 +148,6 @@ jobs: cmake --build test_install test_install/test_runtime # if built more than just MADWorld run the HF test - if [ "X${{ matrix.task_backend }}" = "XThreads" && "X${{ matrix.build_type }}" != "XDebug" ]; then + if [ "X${{ matrix.task_backend }}" = "XThreads" ]; then test_install/simple_hf fi From 72281d92225c9fc0c27ec7dda1bb1c5ae81a2275 Mon Sep 17 00:00:00 2001 From: Jonathon Misiewicz Date: Wed, 13 Mar 2024 15:02:44 -0400 Subject: [PATCH 4/6] Misc. cleanup --- src/examples/dielectric.cc | 10 +++++----- src/examples/dielectric_external_field.cc | 16 ++++++++-------- src/examples/dirac-hatom.cc | 14 +++++++------- src/madness/mra/mraimpl.h | 5 +---- 4 files changed, 21 insertions(+), 24 deletions(-) diff --git a/src/examples/dielectric.cc b/src/examples/dielectric.cc index 20c1504f099..37415713586 100644 --- a/src/examples/dielectric.cc +++ b/src/examples/dielectric.cc @@ -256,11 +256,11 @@ int main(int argc, char **argv) { print("coords", atomic_coords); // Functors for mask related quantities - real_functor_3d volume_functor(new MolecularVolumeMask(sigma, atomic_radii, atomic_coords)); - real_functor_3d gradx_functor(new MolecularVolumeMaskGrad(sigma, atomic_radii, atomic_coords, 0)); - real_functor_3d grady_functor(new MolecularVolumeMaskGrad(sigma, atomic_radii, atomic_coords, 1)); - real_functor_3d gradz_functor(new MolecularVolumeMaskGrad(sigma, atomic_radii, atomic_coords, 2)); - real_functor_3d surface_functor(new MolecularSurface(sigma, atomic_radii, atomic_coords)); + auto volume_functor = std::make_shared(sigma, atomic_radii, atomic_coords); + auto gradx_functor = std::make_shared(sigma, atomic_radii, atomic_coords, 0); + auto grady_functor = std::make_shared(sigma, atomic_radii, atomic_coords, 1); + auto gradz_functor = std::make_shared(sigma, atomic_radii, atomic_coords, 2); + auto surface_functor = std::make_shared(sigma, atomic_radii, atomic_coords); // Make the actual functions TIME("make volume ", real_function_3d volume = real_factory_3d(world).functor(volume_functor)); diff --git a/src/examples/dielectric_external_field.cc b/src/examples/dielectric_external_field.cc index 178a399473e..63424d9072b 100644 --- a/src/examples/dielectric_external_field.cc +++ b/src/examples/dielectric_external_field.cc @@ -147,12 +147,12 @@ int main(int argc, char **argv) { FunctionDefaults<3>::set_bc(BC_FREE); // The Coulomb operator (this is just 1/r ... whereas the notes are -1/4pir) - real_convolution_3d op = CoulombOperator(world, sigma*0.001, thresh*0.1); + auto op = CoulombOperator(world, sigma*0.001, thresh*0.1); // Derivative operators - real_derivative_3d Dx = free_space_derivative(world, 0); - real_derivative_3d Dy = free_space_derivative(world, 1); - real_derivative_3d Dz = free_space_derivative(world, 2); + auto Dx = free_space_derivative(world, 0); + auto Dy = free_space_derivative(world, 1); + auto Dz = free_space_derivative(world, 2); // We will have one sphere of radius R centered at the origin vector atomic_radii(1,R-delta); @@ -169,9 +169,9 @@ int main(int argc, char **argv) { print(MolecularVolumeExponentialSwitchLogGrad(sigma,epsilon_1,epsilon_0, atomic_radii, atomic_coords,0).special_points()); // Log derivative of the dielectric function - real_function_3d logdx = real_factory_3d(world).functor(real_functor_3d(new MolecularVolumeExponentialSwitchLogGrad(sigma,epsilon_1,epsilon_0, atomic_radii, atomic_coords,0))); - real_function_3d logdy = real_factory_3d(world).functor(real_functor_3d(new MolecularVolumeExponentialSwitchLogGrad(sigma,epsilon_1,epsilon_0, atomic_radii, atomic_coords,1))); - real_function_3d logdz = real_factory_3d(world).functor(real_functor_3d(new MolecularVolumeExponentialSwitchLogGrad(sigma,epsilon_1,epsilon_0, atomic_radii, atomic_coords,2))); + std::vector logd(3); + for (int i = 0; i < 3; i++) + logd.emplace_back(real_factory_3d(world).functor(MolecularVolumeExponentialSwitchLogGrad(sigma,epsilon_1,epsilon_0, atomic_radii, atomic_coords,i))); //double area = 4*madness::constants::pi*R*R; //double simulation_volume = 8*L*L*L; @@ -186,7 +186,7 @@ int main(int argc, char **argv) { real_function_3d surface_charge, old_surface_charge(world); for (int iter=0; iter<20; iter++) { // Scale with 1/4pi AFTER applying operator to get one more digit of accuracy - surface_charge = (logdx*Dx(u) + logdy*Dy(u) + logdz*(-Ez+Dz(u))).truncate(); + surface_charge = (logd[0]*Dx(u) + logd[1]*Dy(u) + logd[2]*(-Ez+Dz(u))).truncate(); real_function_3d r = (u - op(surface_charge).scale(rfourpi)).truncate(thresh*0.032); surface_charge.scale(rfourpi); diff --git a/src/examples/dirac-hatom.cc b/src/examples/dirac-hatom.cc index 98a11b22f89..b1ea1b73219 100644 --- a/src/examples/dirac-hatom.cc +++ b/src/examples/dirac-hatom.cc @@ -961,12 +961,12 @@ struct ExactSpinor : public FunctionFunctorInterface { } void set_ansatz(const AnsatzBase& ansatz) { - compute_F = (ansatz.iansatz==3) ? true : false; + compute_F = (ansatz.iansatz == 3); cusp_a=ansatz.get_cusp_a(); - regularized= (ansatz.iansatz==0) ? false : true; + regularized= !(ansatz.iansatz == 0); } - int l_char_to_int(const char lc) const { + static int l_char_to_int(const char lc) { int ll=0; if (lc=='S') ll=0; else if (lc=='P') ll=1; @@ -1323,10 +1323,10 @@ void run(World& world, ansatzT ansatz, const int nuclear_charge, const commandli guess= schrodinger2dirac(wf,ansatz,nuclear_charge); } else { print("\nUsing exact spinor guess\n"); - for (int i=0; i void FunctionImpl::diff(const DerivativeBase* D, const implT* f, bool fence) { typedef std::pair argT; - typename dcT::const_iterator end = f->coeffs.end(); - for (typename dcT::const_iterator it=f->coeffs.begin(); it!=end; ++it) { - const keyT& key = it->first; - const nodeT& node = it->second; + for (const auto& [key, node]: f->coeffs) { if (node.has_coeff()) { Future left = D->find_neighbor(f, key,-1); argT center(key,node.coeff()); From 8127e3ed5354944bdfbd2bd76cb24bb70daa3681 Mon Sep 17 00:00:00 2001 From: Jonathon Misiewicz Date: Wed, 13 Mar 2024 15:49:21 -0400 Subject: [PATCH 5/6] Check remote compile --- src/examples/dielectric.cc | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/examples/dielectric.cc b/src/examples/dielectric.cc index 37415713586..1fbabc76086 100644 --- a/src/examples/dielectric.cc +++ b/src/examples/dielectric.cc @@ -256,11 +256,11 @@ int main(int argc, char **argv) { print("coords", atomic_coords); // Functors for mask related quantities - auto volume_functor = std::make_shared(sigma, atomic_radii, atomic_coords); - auto gradx_functor = std::make_shared(sigma, atomic_radii, atomic_coords, 0); - auto grady_functor = std::make_shared(sigma, atomic_radii, atomic_coords, 1); - auto gradz_functor = std::make_shared(sigma, atomic_radii, atomic_coords, 2); - auto surface_functor = std::make_shared(sigma, atomic_radii, atomic_coords); + auto volume_functor = MolecularVolumeMask(sigma, atomic_radii, atomic_coords); + auto gradx_functor = MolecularVolumeMaskGrad(sigma, atomic_radii, atomic_coords, 0); + auto grady_functor = MolecularVolumeMaskGrad(sigma, atomic_radii, atomic_coords, 1); + auto gradz_functor = MolecularVolumeMaskGrad(sigma, atomic_radii, atomic_coords, 2); + auto surface_functor = MolecularSurface(sigma, atomic_radii, atomic_coords); // Make the actual functions TIME("make volume ", real_function_3d volume = real_factory_3d(world).functor(volume_functor)); From 163895a8778ccf6b91eebbc00c5aa01436d27374 Mon Sep 17 00:00:00 2001 From: Adrian Hurtado Date: Wed, 6 Mar 2024 14:41:40 -0500 Subject: [PATCH 6/6] Fixes problem with setting units to au or Bohr --- src/madness/chem/molecule.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/madness/chem/molecule.h b/src/madness/chem/molecule.h index 4a575273bb4..74dc7623caa 100644 --- a/src/madness/chem/molecule.h +++ b/src/madness/chem/molecule.h @@ -209,7 +209,7 @@ class Molecule { // } if (source_type()=="xyz") set_derived_value("units",std::string("angstrom")); - if (units()=="bohr" or units()=="au") set_derived_value("units","atomic"); + if (units()=="bohr" or units()=="au") set_derived_value("units",std::string("atomic")); } std::string source_type() const {return get("source_type");}