I'm writing a compile-time math library using c++20, I already have floor/ceiling/abs/etc. but the method I am currently using to get the floor of a float is n >= 0.0f ? (float)(long long)n : (float)(long long)n - 1.0f; which is a pretty typical fast floor function. however for floats larger than long long max value this returns junk because I cast to a long long. I know using floorf works for large floats but it isn't constexpr (until c++23 which is still in preview). However I can't just copy what the stl is doing because it calls an intrinsic which itself isn't constexpr. Any information that could point me in the right direction would be much appreciated.
How can I get the floor of a large floating-point number at compile-time?
163 Views Asked by Zachary Peterson At
1
There are 1 best solutions below
Related Questions in C++
- How to immediately apply DISPLAYCONFIG_SCALING display scaling mode with SetDisplayConfig and DISPLAYCONFIG_PATH_TARGET_INFO
- Why can't I use templates members in its specialization?
- How to fix "Access violation executing location" when using GLFW and GLAD
- Dynamic array of structures in C++/ cannot fill a dynamic array of doubles in structure from dynamic array of structures
- How do I apply the interface concept with the base-class in design?
- File refuses to compile std::erase() even if using -std=g++23
- How can I do a successful map when the number of elements to be mapped is not consistent in Thrust C++
- Can std::bit_cast be applied to an empty object?
- Unexpected inter-thread happens-before relationships from relaxed memory ordering
- How i can move element of dynamic vector in argument of function push_back for dynamic vector
- Brick Breaker Ball Bounce
- Thread-safe lock-free min where both operands can change c++
- Watchdog Timer Reset on ESP32 using Webservers
- How to solve compiler error: no matching function for call to 'dmhFS::dmhFS()' in my case?
- Conda CMAKE CXX Compiler error while compiling Pytorch
Related Questions in FLOATING-POINT
- Imprecision in float integers in C
- printf floating-point output variations only with alpine docker on Windows
- Is it possible to represent -3/32 as a binary floating-point value using only 7 bits
- Pytorch sum problem (possibly floating point)
- Example of Code with and without strictfp Modifier
- Why does numpy's `2**np.array([64])` produces 0, whereas plain python's 2**64 gives the correct result?
- How does floating-point addition work in "np.finfo(np.float64).max + 1"?
- Problem caused by FP16 group quantization on vit-tiny
- How to format float to omit zeros at the end of the fraction
- TypeError: Cannot cast array data from dtype('O') to dtype('float64') according to the rule 'safe' again
- Why wont variables in the list print to 3 decimal places?
- How to print all the decimals of a float 128 to the console
- How to specify a float/decimal value for a column inside an insert in liquibase changelog?
- Why does gcc -O1 affects std::rint()?
- Sign of result of addition in floating point arithmetic
Related Questions in C++20
- Can std::bit_cast be applied to an empty object?
- Is there a way to negate constrains?
- Polymorphism using template and concepts
- Is there a way to write a concept to check if a type is a structural type
- unicode symbol breaks formatting in c++20
- Why is std::array<T,N>::size() not declared static?
- time_point extension to a struct holding another member
- How to create a string literal based on generic character type in c++20?
- Export and create package of c++20 modules
- How to avoid ambiguous overloads on inherited function calls using enable_if or concepts?
- Basic tests fail with msvc but work with gcc
- C++ static template class member variable: non-inline external definitions are not permitted in C++ header units
- Is the ordering of std::recursive_directory_iterator specified?
- What is the modern C++ way of handling multi-channel data using span?
- Understanding documentation for c++ concepts (weakly_incrementable)
Related Questions in FLOOR
- Flutter floor db cannot define return type
- How to fix the error in the color_post function in this code?
- Ceiling and Floor of a number for array in descending order (Java)
- SQL, random number
- How can I get the floor of a large floating-point number at compile-time?
- Flutter Floor Database. Failed to generate the floor database
- strftime coerces all time values to midnight if one entry doesn't have HH:MM
- How to select from a vector of fractions and respect the number of elements?
- save data aggregationly in floor database flutter
- How to implement a floor function that rounds according to integers in a specified array?
- PowerBI DAX: average per time interval
- Postgre floor changes values postgresql
- Why does math.floor() round up numbers after 15 decimal places in python?
- flutter floor floor_generator error: There are no entities added to the database annotation
- Error when generating results in cents (beecrowd - 1021)
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
As stated by @chtz and @IgorTandetnik floats large enough to be larger than long long max value can't store a fractional part so just return the input.
For floats:
For doubles:
Edit: Here is a templated version with concepts: