decomposeFloat.cpp 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. // ArduinoJson - https://arduinojson.org
  2. // Copyright © 2014-2024, Benoit BLANCHON
  3. // MIT License
  4. #include <ArduinoJson/Numbers/FloatParts.hpp>
  5. #include <catch.hpp>
  6. using namespace ArduinoJson::detail;
  7. TEST_CASE("decomposeFloat()") {
  8. SECTION("1.7976931348623157E+308") {
  9. auto parts = decomposeFloat(1.7976931348623157E+308, 9);
  10. REQUIRE(parts.integral == 1);
  11. REQUIRE(parts.decimal == 797693135);
  12. REQUIRE(parts.decimalPlaces == 9);
  13. REQUIRE(parts.exponent == 308);
  14. }
  15. SECTION("4.94065645841247e-324") {
  16. auto parts = decomposeFloat(4.94065645841247e-324, 9);
  17. REQUIRE(parts.integral == 4);
  18. REQUIRE(parts.decimal == 940656458);
  19. REQUIRE(parts.decimalPlaces == 9);
  20. REQUIRE(parts.exponent == -324);
  21. }
  22. SECTION("3.4E+38") {
  23. auto parts = decomposeFloat(3.4E+38f, 6);
  24. REQUIRE(parts.integral == 3);
  25. REQUIRE(parts.decimal == 4);
  26. REQUIRE(parts.decimalPlaces == 1);
  27. REQUIRE(parts.exponent == 38);
  28. }
  29. SECTION("1.17549435e−38") {
  30. auto parts = decomposeFloat(1.17549435e-38f, 6);
  31. REQUIRE(parts.integral == 1);
  32. REQUIRE(parts.decimal == 175494);
  33. REQUIRE(parts.decimalPlaces == 6);
  34. REQUIRE(parts.exponent == -38);
  35. }
  36. }