-
Notifications
You must be signed in to change notification settings - Fork 25
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Loading status checks…
Merge branch 'main' into pyml
# Conflicts: # docs/algorithms/sidb_simulation.rst # libs/pybind11
Showing
12 changed files
with
938 additions
and
82 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
378 changes: 378 additions & 0 deletions
378
include/fiction/algorithms/simulation/sidb/assess_physical_population_stability.hpp
Large diffs are not rendered by default.
Oops, something went wrong.
64 changes: 64 additions & 0 deletions
64
include/fiction/algorithms/simulation/sidb/convert_potential_to_distance.hpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
// | ||
// Created by Jan Drewniok on 10.11.23. | ||
// | ||
|
||
#ifndef FICTION_CONVERT_POTENTIAL_TO_DISTANCE_HPP | ||
#define FICTION_CONVERT_POTENTIAL_TO_DISTANCE_HPP | ||
|
||
#include "fiction/algorithms/simulation/sidb/sidb_simulation_parameters.hpp" | ||
#include "fiction/technology/physical_constants.hpp" | ||
|
||
#include <cmath> | ||
#include <cstdint> | ||
#include <limits> | ||
#include <vector> | ||
|
||
namespace fiction | ||
{ | ||
|
||
/** | ||
* The electrostatic potential on hydrogen-passivated silicon is typically modeled using a screened Coulomb potential. | ||
* This electrostatic potential is commonly employed to determine the electrostatic potential for a given distance | ||
* (between SiDB and point under consideration) and given physical parameters. However, the function provided here | ||
* serves the inverse purpose by calculating the distance for a given potential and given physical parameters. | ||
* | ||
* @note Runtime depends exponentially on the provided precision. | ||
* | ||
* @param params The physical parameters for a given hydrogen-passivated silicon surface. | ||
* @param potential The electrostatic potential (unit: V) to be converted to a distance. | ||
* @param precision The precision level for the conversion, specifying the number of decimal places. | ||
* @return The distance (unit: nm) corresponding to the given electrostatic potential. | ||
*/ | ||
[[nodiscard]] inline double | ||
convert_potential_to_distance(const double potential, | ||
const sidb_simulation_parameters& params = sidb_simulation_parameters{}, | ||
const uint64_t precision = 2) noexcept | ||
{ | ||
// function to calculate the electrostatic potential for a given distance and given physical parameters on the H-Si | ||
// surface | ||
const auto calculate_potential_for_given_distance = [¶ms](const double distance) noexcept | ||
{ | ||
return params.k() * params.epsilon_r / params.epsilon_r / (distance * 1e-9) * | ||
std::exp(-distance / params.lambda_tf) * physical_constants::ELEMENTARY_CHARGE; | ||
}; | ||
|
||
// calculate the step size based on the precision | ||
const double step_size = std::pow(10, -static_cast<double>(precision)); | ||
|
||
// initialize distance and potential for the initial step | ||
double distance = step_size; | ||
double potential_for_given_distance = calculate_potential_for_given_distance(distance); | ||
|
||
// as long as the electrostatic potential is still larger than the given potential, the distance is increased | ||
while (potential_for_given_distance > potential) | ||
{ | ||
distance += step_size; | ||
potential_for_given_distance = calculate_potential_for_given_distance(distance); | ||
} | ||
|
||
return distance; | ||
} | ||
|
||
} // namespace fiction | ||
|
||
#endif // FICTION_CONVERT_POTENTIAL_TO_DISTANCE_HPP |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Submodule Catch2
updated
31 files
Submodule parallel-hashmap
updated
2 files
+70 −38 | parallel_hashmap/phmap.h | |
+103 −0 | parallel_hashmap/phmap_base.h |
253 changes: 253 additions & 0 deletions
253
test/algorithms/simulation/sidb/assess_physical_population_stability.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,253 @@ | ||
// | ||
// Created by Jan Drewniok on 02.11.23. | ||
// | ||
|
||
#include <catch2/catch_template_test_macros.hpp> | ||
#include <catch2/matchers/catch_matchers_floating_point.hpp> | ||
|
||
#include <fiction/algorithms/simulation/sidb/assess_physical_population_stability.hpp> | ||
#include <fiction/algorithms/simulation/sidb/sidb_simulation_parameters.hpp> | ||
#include <fiction/layouts/cell_level_layout.hpp> | ||
#include <fiction/technology/cell_technologies.hpp> | ||
#include <fiction/types.hpp> | ||
|
||
using namespace fiction; | ||
|
||
using layout = sidb_cell_clk_lyt_siqad; | ||
|
||
TEST_CASE("Single SiDB", "[assess-physical-population-stability]") | ||
{ | ||
layout lyt{}; | ||
lyt.assign_cell_type({1, 1, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
SECTION("Precision of distance_corresponding_to_potential is two") | ||
{ | ||
const auto params = assess_physical_population_stability_params{sidb_simulation_parameters{2, -0.29}, 2}; | ||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 1); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{1, 1, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEGATIVE_TO_NEUTRAL); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition == 0.29); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(0.77, 1e-5)); | ||
} | ||
|
||
SECTION("Precision of distance_corresponding_to_potential is three") | ||
{ | ||
const auto params = assess_physical_population_stability_params{sidb_simulation_parameters{2, -0.29}, 3}; | ||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 1); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{1, 1, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEGATIVE_TO_NEUTRAL); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition == 0.29); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(0.762, 1e-5)); | ||
} | ||
} | ||
|
||
TEST_CASE("Three SiDBs with positive charge states", "[assess-physical-population-stability]") | ||
{ | ||
layout lyt{}; | ||
const auto params = assess_physical_population_stability_params{}; | ||
lyt.assign_cell_type({1, 1, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({1, 1, 1}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({2, 1, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 3); | ||
|
||
SECTION("Check correct energy order") | ||
{ | ||
CHECK(result[0].system_energy < result[1].system_energy); | ||
CHECK(result[1].system_energy < result[2].system_energy); | ||
} | ||
|
||
SECTION("Ground state") | ||
{ | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{2, 1, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEGATIVE_TO_NEUTRAL); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.43); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(0.56, 1e-5)); | ||
} | ||
SECTION("1st excited state") | ||
{ | ||
const auto& population_stability_detail = result[1]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{2, 1, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEGATIVE_TO_NEUTRAL); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.23); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(0.94, 1e-5)); | ||
} | ||
|
||
SECTION("2nd excited state") | ||
{ | ||
const auto& population_stability_detail = result[2]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{1, 1, 1}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.21); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(1.01, 1e-5)); | ||
} | ||
} | ||
|
||
TEST_CASE("Bestagon AND gate", "[assess-physical-population-stability]") | ||
{ | ||
layout lyt{}; | ||
const auto params = assess_physical_population_stability_params{}; | ||
lyt.assign_cell_type({36, 1, 0}, sidb_technology::cell_type::INPUT); | ||
lyt.assign_cell_type({2, 1, 0}, sidb_technology::cell_type::INPUT); | ||
|
||
lyt.assign_cell_type({38, 0, 0}, sidb_technology::cell_type::INPUT); | ||
lyt.assign_cell_type({0, 0, 0}, sidb_technology::cell_type::INPUT); | ||
|
||
lyt.assign_cell_type({23, 9, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({18, 11, 1}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({18, 9, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({19, 8, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({20, 14, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({19, 13, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({26, 16, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({24, 15, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({32, 2, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({30, 3, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({26, 4, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({24, 5, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({12, 4, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({14, 5, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({6, 2, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({8, 3, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({32, 18, 0}, sidb_technology::cell_type::OUTPUT); | ||
lyt.assign_cell_type({30, 17, 0}, sidb_technology::cell_type::OUTPUT); | ||
|
||
lyt.assign_cell_type({36, 19, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
SECTION("no input specified") | ||
{ | ||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 8); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{2, 1, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.021); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(4.79, 1e-5)); | ||
} | ||
|
||
SECTION("input 00") | ||
{ | ||
lyt.assign_cell_type({36, 1, 0}, sidb_technology::cell_type::EMPTY); | ||
lyt.assign_cell_type({2, 1, 0}, sidb_technology::cell_type::EMPTY); | ||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 2); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{14, 5, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.026); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(4.32, 1e-5)); | ||
} | ||
|
||
SECTION("input 01") | ||
{ | ||
lyt.assign_cell_type({36, 1, 0}, sidb_technology::cell_type::EMPTY); | ||
lyt.assign_cell_type({0, 0, 0}, sidb_technology::cell_type::EMPTY); | ||
|
||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 4); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{32, 18, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.041); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(3.3, 1e-5)); | ||
} | ||
|
||
SECTION("input 10") | ||
{ | ||
lyt.assign_cell_type({38, 0, 0}, sidb_technology::cell_type::EMPTY); | ||
lyt.assign_cell_type({0, 0, 0}, sidb_technology::cell_type::EMPTY); | ||
|
||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 8); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{19, 8, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.02); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(4.87, 1e-5)); | ||
} | ||
|
||
SECTION("input 11") | ||
{ | ||
lyt.assign_cell_type({36, 1, 0}, sidb_technology::cell_type::EMPTY); | ||
lyt.assign_cell_type({2, 1, 0}, sidb_technology::cell_type::EMPTY); | ||
|
||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 2); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{14, 5, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.026); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(4.32, 1e-5)); | ||
} | ||
} | ||
|
||
TEST_CASE("Bestagon CROSSING gate input 11", "[assess-physical-population-stability]") | ||
{ | ||
layout lyt{}; | ||
const auto params = assess_physical_population_stability_params{}; | ||
lyt.assign_cell_type({36, 1, 0}, sidb_technology::cell_type::INPUT); | ||
lyt.assign_cell_type({2, 1, 0}, sidb_technology::cell_type::INPUT); | ||
|
||
lyt.assign_cell_type({6, 2, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({20, 12, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({8, 3, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({14, 5, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({14, 11, 1}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({12, 4, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({14, 15, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({26, 4, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({14, 9, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({24, 15, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({12, 16, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({18, 9, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({26, 16, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({24, 13, 1}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({24, 5, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({30, 3, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({16, 13, 1}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({32, 2, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({20, 8, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
lyt.assign_cell_type({30, 17, 0}, sidb_technology::cell_type::OUTPUT); | ||
lyt.assign_cell_type({6, 18, 0}, sidb_technology::cell_type::OUTPUT); | ||
|
||
lyt.assign_cell_type({32, 18, 0}, sidb_technology::cell_type::OUTPUT); | ||
lyt.assign_cell_type({8, 17, 0}, sidb_technology::cell_type::OUTPUT); | ||
|
||
lyt.assign_cell_type({2, 19, 0}, sidb_technology::cell_type::NORMAL); | ||
lyt.assign_cell_type({36, 19, 0}, sidb_technology::cell_type::NORMAL); | ||
|
||
CHECK(lyt.num_cells() == 27); | ||
|
||
const auto result = assess_physical_population_stability(lyt, params); | ||
REQUIRE(result.size() == 20); | ||
const auto& population_stability_detail = result[0]; | ||
CHECK(population_stability_detail.critical_cell == siqad::coord_t{14, 9, 0}); | ||
CHECK(population_stability_detail.transition_from_to == transition_type::NEUTRAL_TO_NEGATIVE); | ||
CHECK(population_stability_detail.minimum_potential_difference_to_transition < 0.01); | ||
REQUIRE_THAT(population_stability_detail.distance_corresponding_to_potential, | ||
Catch::Matchers::WithinAbs(6.88, 1e-5)); | ||
} |
78 changes: 78 additions & 0 deletions
78
test/algorithms/simulation/sidb/convert_potential_to_distance.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
// | ||
// Created by Jan Drewniok on 10.11.23. | ||
// | ||
|
||
#include <catch2/catch_template_test_macros.hpp> | ||
#include <catch2/matchers/catch_matchers_floating_point.hpp> | ||
|
||
#include <fiction/algorithms/simulation/sidb/convert_potential_to_distance.hpp> | ||
#include <fiction/algorithms/simulation/sidb/sidb_simulation_parameters.hpp> | ||
|
||
#include <limits> | ||
|
||
using namespace fiction; | ||
|
||
TEST_CASE("Conversion of potential to distance", "[convert-potential-to-distance]") | ||
{ | ||
auto params = sidb_simulation_parameters{}; | ||
|
||
SECTION("Valid conversion with default parameters") | ||
{ | ||
uint64_t const precision = 1; | ||
const double potential_value = 5.0; | ||
const double expected_distance = 0.1; | ||
REQUIRE_THAT(convert_potential_to_distance(potential_value, params, precision), | ||
Catch::Matchers::WithinAbs(expected_distance, 1e-5)); | ||
} | ||
|
||
SECTION("Valid conversion with custom parameters, precision is 1") | ||
{ | ||
params.epsilon_r = 2.0; | ||
params.lambda_tf = 1.0; | ||
const uint64_t precision = 1; | ||
const double potential_value = 0.01; | ||
const double expected_distance = 3.2; | ||
REQUIRE_THAT(convert_potential_to_distance(potential_value, params, precision), | ||
Catch::Matchers::WithinAbs(expected_distance, 1e-5)); | ||
} | ||
|
||
SECTION("Valid conversion with custom parameters, precision is 2") | ||
{ | ||
params.epsilon_r = 2.0; | ||
params.lambda_tf = 1.0; | ||
const uint64_t precision = 2; | ||
const double potential_value = 0.01; | ||
const double expected_distance = 3.14; | ||
REQUIRE_THAT(convert_potential_to_distance(potential_value, params, precision), | ||
Catch::Matchers::WithinAbs(expected_distance, 1e-5)); | ||
} | ||
|
||
SECTION("Valid conversion with custom parameters, precision is 3") | ||
{ | ||
params.epsilon_r = 2.0; | ||
params.lambda_tf = 1.0; | ||
const uint64_t precision = 3; | ||
const double potential_value = 0.01; | ||
const double expected_distance = 3.135; | ||
REQUIRE_THAT(convert_potential_to_distance(potential_value, params, precision), | ||
Catch::Matchers::WithinAbs(expected_distance, 1e-5)); | ||
} | ||
|
||
SECTION("Valid conversion with custom parameters, precision is 0") | ||
{ | ||
const uint64_t precision = 0; | ||
const double potential_value = 0.03; | ||
const double expected_distance = 4; | ||
REQUIRE_THAT(convert_potential_to_distance(potential_value, params, precision), | ||
Catch::Matchers::WithinAbs(expected_distance, 1e-5)); | ||
} | ||
|
||
SECTION("Conversion with infinite potential") | ||
{ | ||
const uint64_t precision = 3; | ||
const double potential_value = std::numeric_limits<double>::infinity(); | ||
const double expected_distance = 0.001; | ||
REQUIRE_THAT(convert_potential_to_distance(potential_value, params, precision), | ||
Catch::Matchers::WithinAbs(expected_distance, 1e-5)); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters