spla
Loading...
Searching...
No Matches
common.hpp
Go to the documentation of this file.
1/**********************************************************************************/
2/* This file is part of spla project */
3/* https://github.com/JetBrains-Research/spla */
4/**********************************************************************************/
5/* MIT License */
6/* */
7/* Copyright (c) 2023 SparseLinearAlgebra */
8/* */
9/* Permission is hereby granted, free of charge, to any person obtaining a copy */
10/* of this software and associated documentation files (the "Software"), to deal */
11/* in the Software without restriction, including without limitation the rights */
12/* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell */
13/* copies of the Software, and to permit persons to whom the Software is */
14/* furnished to do so, subject to the following conditions: */
15/* */
16/* The above copyright notice and this permission notice shall be included in all */
17/* copies or substantial portions of the Software. */
18/* */
19/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
20/* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
21/* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
22/* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
23/* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
24/* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
25/* SOFTWARE. */
26/**********************************************************************************/
27
28#ifndef SPLA_COMMON_HPP
29#define SPLA_COMMON_HPP
30
31#include <spla/config.hpp>
32
33#include <cmath>
34
35namespace spla {
36
37 static inline uint clamp(uint x, uint left, uint right) {
38 return std::min(std::max(x, left), right);
39 }
40
41 static inline uint div_up(uint what, uint by) {
42 return what / by + (what % by ? 1 : 0);
43 }
44
45 static inline uint div_up_clamp(uint what, uint by, uint left, uint right) {
46 return clamp(div_up(what, by), left, right);
47 }
48
49 static inline uint align(uint what, uint alignment) {
50 return what + (what % alignment ? alignment - (what % alignment) : 0);
51 }
52
53 static inline std::size_t aligns(std::size_t what, std::size_t alignment) {
54 return what + (what % alignment ? alignment - (what % alignment) : 0);
55 }
56
57 static inline uint ceil_to_pow2(uint n) {
58 uint r = 1;
59 while (r < n) r *= 2u;
60 return r;
61 }
62
63 static inline uint floor_to_pow2(uint n) {
64 uint r = 1;
65 while (r <= n) {
66 r *= 2;
67 }
68 return r / 2;
69 }
70
71}// namespace spla
72
73#endif//SPLA_COMMON_HPP
std::uint32_t uint
Library index and size type.
Definition config.hpp:56
Definition algorithm.hpp:37