
In mathematics, the floor function is the function that takes as input a real number x, and gives as output the greatest integer less than or equal to x, denoted ⌊x⌋ or floor(x). Similarly, the ceiling function maps x to the least integer greater than or equal to x, denoted ⌈x⌉ or ceil(x).
For example, for floor: ⌊2.4⌋ = 2, ⌊−2.4⌋ = −3, and for ceiling: ⌈2.4⌉ = 3, and ⌈−2.4⌉ = −2.
The floor of x is also called the integral part, integer part, greatest integer, or entier of x, and was historically denoted [x] (among other notations). However, the same term, integer part, is also used for truncation towards zero, which differs from the floor function for negative numbers.
For an integer n, ⌊n⌋ = ⌈n⌉ = n.
Although floor(x + 1) and ceil(x) produce graphs that appear exactly alike, they are not the same when the value of x is an exact integer. For example, when x = 2.0001, ⌊2.0001 + 1⌋ = ⌈2.0001⌉ = 3. However, if x = 2, then ⌊2 + 1⌋ = 3, while ⌈2⌉ = 2.
x | Floor ⌊x⌋ | Ceiling ⌈x⌉ | Fractional part {x} |
---|---|---|---|
2 | 2 | 2 | 0 |
2.0001 | 2 | 3 | 0.0001 |
2.4 | 2 | 3 | 0.4 |
2.9 | 2 | 3 | 0.9 |
2.999 | 2 | 3 | 0.999 |
−2.7 | −3 | −2 | 0.3 |
−2 | −2 | −2 | 0 |
Notation
The integral part or integer part of a number (partie entière in the original) was first defined in 1798 by Adrien-Marie Legendre in his proof of the Legendre's formula.
Carl Friedrich Gauss introduced the square bracket notation [x] in his third proof of quadratic reciprocity (1808). This remained the standard in mathematics until Kenneth E. Iverson introduced, in his 1962 book A Programming Language, the names "floor" and "ceiling" and the corresponding notations ⌊x⌋ and ⌈x⌉. (Iverson used square brackets for a different purpose, the Iverson bracket notation.) Both notations are now used in mathematics, although Iverson's notation will be followed in this article.
In some sources, boldface or double brackets ⟦x⟧ are used for floor, and reversed brackets ⟧x⟦ or ]x[ for ceiling.
The fractional part is the sawtooth function, denoted by {x} for real x and defined by the formula
- {x} = x − ⌊x⌋
For all x,
- 0 ≤ {x} < 1.
These characters are provided in Unicode:
- U+2308 ⌈ LEFT CEILING (⌈, ⌈)
- U+2309 ⌉ RIGHT CEILING (⌉, ⌉)
- U+230A ⌊ LEFT FLOOR (⌊, ⌊)
- U+230B ⌋ RIGHT FLOOR (⌋, ⌋)
In the LaTeX typesetting system, these symbols can be specified with the \lceil, \rceil, \lfloor,
and \rfloor
commands in math mode. LaTeX has supported UTF-8 since 2018, so the Unicode characters can now be used directly. Larger versions are\left\lceil, \right\rceil, \left\lfloor,
and \right\rfloor
.
Definition and properties
Given real numbers x and y, integers m and n and the set of integers , floor and ceiling may be defined by the equations
Since there is exactly one integer in a half-open interval of length one, for any real number x, there are unique integers m and n satisfying the equation
where and
may also be taken as the definition of floor and ceiling.
Equivalences
These formulas can be used to simplify expressions involving floors and ceilings.
In the language of order theory, the floor function is a residuated mapping, that is, part of a Galois connection: it is the upper adjoint of the function that embeds the integers into the reals.
These formulas show how adding an integer n to the arguments affects the functions:
The above are never true if n is not an integer; however, for every x and y, the following inequalities hold:
Monotonicity
Both floor and ceiling functions are monotonically non-decreasing functions:
Relations among the functions
It is clear from the definitions that
with equality if and only if x is an integer, i.e.
In fact, for integers n, both floor and ceiling functions are the identity:
Negating the argument switches floor and ceiling and changes the sign:
and:
Negating the argument complements the fractional part:
The floor, ceiling, and fractional part functions are idempotent:
The result of nested floor or ceiling functions is the innermost function:
due to the identity property for integers.
Quotients
If m and n are integers and n ≠ 0,
If n is positive
If m is positive
For m = 2 these imply
More generally, for positive m (See Hermite's identity)
The following can be used to convert floors to ceilings and vice versa (with m being positive)
For all m and n strictly positive integers:
which, for positive and coprime m and n, reduces to
and similarly for the ceiling and fractional part functions (still for positive and coprime m and n),
Since the right-hand side of the general case is symmetrical in m and n, this implies that
More generally, if m and n are positive,
This is sometimes called a reciprocity law.
Division by positive integers gives rise to an interesting and sometimes useful property. Assuming ,
Similarly,
Indeed,
keeping in mind that The second equivalence involving the ceiling function can be proved similarly.
Nested divisions
For positive integer n, and arbitrary real numbers m,x:
Continuity and series expansions
None of the functions discussed in this article are continuous, but all are piecewise linear: the functions ,
, and
have discontinuities at the integers.
is upper semi-continuous and
and
are lower semi-continuous.
Since none of the functions discussed in this article are continuous, none of them have a power series expansion. Since floor and ceiling are not periodic, they do not have uniformly convergent Fourier series expansions. The fractional part function has Fourier series expansion for x not an integer.
At points of discontinuity, a Fourier series converges to a value that is the average of its limits on the left and the right, unlike the floor, ceiling and fractional part functions: for y fixed and x a multiple of y the Fourier series given converges to y/2, rather than to x mod y = 0. At points of continuity the series converges to the true value.
Using the formula gives
for x not an integer.
Applications
Mod operator
For an integer x and a positive integer y, the modulo operation, denoted by x mod y, gives the value of the remainder when x is divided by y. This definition can be extended to real x and y, y ≠ 0, by the formula
Then it follows from the definition of floor function that this extended operation satisfies many natural properties. Notably, x mod y is always between 0 and y, i.e.,
if y is positive,
and if y is negative,
Quadratic reciprocity
Gauss's third proof of quadratic reciprocity, as modified by Eisenstein, has two basic steps.
Let p and q be distinct positive odd prime numbers, and let
First, Gauss's lemma is used to show that the Legendre symbols are given by
The second step is to use a geometric argument to show that
Combining these formulas gives quadratic reciprocity in the form
There are formulas that use floor to express the quadratic character of small numbers mod odd primes p:
Rounding
For an arbitrary real number , rounding
to the nearest integer with tie breaking towards positive infinity is given by
; rounding towards negative infinity is given as
.
If tie-breaking is away from 0, then the rounding function is (see sign function), and rounding towards even can be expressed with the more cumbersome
, which is the above expression for rounding towards positive infinity
minus an integrality indicator for
.
Rounding a real number to the nearest integer value forms a very basic type of quantizer – a uniform one. A typical (mid-tread) uniform quantizer with a quantization step size equal to some value
can be expressed as
,
Number of digits
The number of digits in base b of a positive integer k is
Number of strings without repeated characters
The number of possible strings of arbitrary length that doesn't use any character twice is given by[better source needed]
where:
- n > 0 is the number of letters in the alphabet (e.g., 26 in English)
- the falling factorial
denotes the number of strings of length k that don't use any character twice.
- n! denotes the factorial of n
- e = 2.718... is Euler's number
For n = 26, this comes out to 1096259850353149530222034277.
Factors of factorials
Let n be a positive integer and p a positive prime number. The exponent of the highest power of p that divides n! is given by a version of Legendre's formula
where is the way of writing n in base p. This is a finite sum, since the floors are zero when pk > n.
Beatty sequence
The Beatty sequence shows how every positive irrational number gives rise to a partition of the natural numbers into two sequences via the floor function.
Euler's constant (γ)
There are formulas for Euler's constant γ = 0.57721 56649 ... that involve the floor and ceiling, e.g.
and
Riemann zeta function (ζ)
The fractional part function also shows up in integral representations of the Riemann zeta function. It is straightforward to prove (using integration by parts) that if is any function with a continuous derivative in the closed interval [a, b],
Letting for real part of s greater than 1 and letting a and b be integers, and letting b approach infinity gives
This formula is valid for all s with real part greater than −1, (except s = 1, where there is a pole) and combined with the Fourier expansion for {x} can be used to extend the zeta function to the entire complex plane and to prove its functional equation.
For s = σ + it in the critical strip 0 < σ < 1,
In 1947 van der Pol used this representation to construct an analogue computer for finding roots of the zeta function.
Formulas for prime numbers
The floor function appears in several formulas characterizing prime numbers. For example, since is equal to 1 if m divides n, and to 0 otherwise, it follows that a positive integer n is a prime if and only if
One may also give formulas for producing the prime numbers. For example, let pn be the n-th prime, and for any integer r > 1, define the real number α by the sum
Then
A similar result is that there is a number θ = 1.3064... (Mills' constant) with the property that
are all prime.
There is also a number ω = 1.9287800... with the property that
are all prime.
Let π(x) be the number of primes less than or equal to x. It is a straightforward deduction from Wilson's theorem that
Also, if n ≥ 2,
None of the formulas in this section are of any practical use.
Solved problems
Ramanujan submitted these problems to the Journal of the Indian Mathematical Society.
If n is a positive integer, prove that
Some generalizations to the above floor function identities have been proven.
Unsolved problem
The study of Waring's problem has led to an unsolved problem:
Are there any positive integers k ≥ 6 such that
Mahler has proved there can only be a finite number of such k; none are known.
Computer implementations
In most programming languages, the simplest method to convert a floating point number to an integer does not do floor or ceiling, but truncation. The reason for this is historical, as the first machines used ones' complement and truncation was simpler to implement (floor is simpler in two's complement). FORTRAN was defined to require this behavior and thus almost all processors implement conversion this way. Some consider this to be an unfortunate historical design decision that has led to bugs handling negative offsets and graphics on the negative side of the origin.[citation needed]
An arithmetic right-shift of a signed integer by
is the same as
. Division by a power of 2 is often written as a right-shift, not for optimization as might be assumed, but because the floor of negative results is required. Assuming such shifts are "premature optimization" and replacing them with division can break software.[citation needed]
Many programming languages (including C, C++,C#,Java,Julia,PHP,R, and Python) provide standard functions for floor and ceiling, usually called floor
and ceil
, or less commonly ceiling
. The language APL uses ⌊x
for floor. The J Programming Language, a follow-on to APL that is designed to use standard keyboard symbols, uses <.
for floor and >.
for ceiling.ALGOL usesentier
for floor.
In Microsoft Excel the function INT
rounds down rather than toward zero, while FLOOR
rounds toward zero, the opposite of what "int" and "floor" do in other languages. Since 2010 FLOOR
has been changed to error if the number is negative. The OpenDocument file format, as used by OpenOffice.org, Libreoffice and others, INT
and FLOOR
both do floor, and FLOOR
has a third argument to reproduce Excel's earlier behavior.
See also
- Bracket (mathematics)
- Integer-valued function
- Step function
- Modulo operation
Citations
- Graham, Knuth, & Patashnik, Ch. 3.1
- 1) Luke Heaton, A Brief History of Mathematical Thought, 2015, ISBN 1472117158 (n.p.)
2) Albert A. Blank et al., Calculus: Differential Calculus, 1968, p. 259
3) John W. Warris, Horst Stocker, Handbook of mathematics and computational science, 1998, ISBN 0387947469, p. 151 - Lemmermeyer, pp. 10, 23.
- e.g. Cassels, Hardy & Wright, and Ribenboim use Gauss's notation. Graham, Knuth & Patashnik, and Crandall & Pomerance use Iverson's.
- Iverson, p. 12.
- Higham, p. 25.
- Mathwords: Floor Function.
- Mathwords: Ceiling Function
- Graham, Knuth, & Patashnik, p. 70.
- "LaTeX News, Issue 28" (PDF; 379 KB). The LaTeX Project. April 2018. Retrieved 27 July 2024.
- Graham, Knuth, & Patashink, Ch. 3
- Graham, Knuth, & Patashnik, p. 73
- Graham, Knuth, & Patashnik, p. 85
- Graham, Knuth, & Patashnik, p. 85 and Ex. 3.15
- Graham, Knuth, & Patashnik, Ex. 3.12
- Graham, Knuth, & Patashnik, p. 94.
- Graham, Knuth, & Patashnik, p. 94
- Graham, Knuth, & Patashnik, p. 71, apply theorem 3.10 with x/m as input and the division by n as function
- Titchmarsh, p. 15, Eq. 2.1.7
- Lemmermeyer, § 1.4, Ex. 1.32–1.33
- Hardy & Wright, §§ 6.11–6.13
- Lemmermeyer, p. 25
- OEIS sequence A000522 (Total number of arrangements of a set with n elements: a(n) = Sum_{k=0..n} n!/k!.) (See Formulas.)
- Hardy & Wright, Th. 416
- Graham, Knuth, & Patashnik, pp. 77–78
- These formulas are from the Wikipedia article Euler's constant, which has many more.
- Titchmarsh, p. 13
- Titchmarsh, pp.14–15
- Crandall & Pomerance, p. 391
- Crandall & Pomerance, Ex. 1.3, p. 46. The infinite upper limit of the sum can be replaced with n. An equivalent condition is n > 1 is prime if and only if
.
- Hardy & Wright, § 22.3
- Ribenboim, p. 186
- Ribenboim, p. 181
- Crandall & Pomerance, Ex. 1.4, p. 46
- Ribenboim, p. 180 says that "Despite the nil practical value of the formulas ... [they] may have some relevance to logicians who wish to understand clearly how various parts of arithmetic may be deduced from different axiomatzations ... "
- Hardy & Wright, pp. 344—345 "Any one of these formulas (or any similar one) would attain a different status if the exact value of the number α ... could be expressed independently of the primes. There seems no likelihood of this, but it cannot be ruled out as entirely impossible."
- Ramanujan, Question 723, Papers p. 332
- Somu, Sai Teja; Kukla, Andrzej (2022). "On some generalizations to floor function identities of Ramanujan" (PDF). Integers. 22. arXiv:2109.03680.
- Hardy & Wright, p. 337
- Mahler, Kurt (1957). "On the fractional parts of the powers of a rational number II". Mathematika. 4 (2): 122–124. doi:10.1112/S0025579300001170.
- "C++ reference of
floor
function". Retrieved 5 December 2010. - "C++ reference of
ceil
function". Retrieved 5 December 2010. - dotnet-bot. "Math.Floor Method (System)". docs.microsoft.com. Retrieved 28 November 2019.
- dotnet-bot. "Math.Ceiling Method (System)". docs.microsoft.com. Retrieved 28 November 2019.
- "Math (Java SE 9 & JDK 9 )". docs.oracle.com. Retrieved 20 November 2018.
- "Math (Java SE 9 & JDK 9 )". docs.oracle.com. Retrieved 20 November 2018.
- "Math (Julia v1.10)". docs.julialang.org/en/v1/. Retrieved 4 September 2024.
- "PHP manual for
ceil
function". Retrieved 18 July 2013. - "PHP manual for
floor
function". Retrieved 18 July 2013. - "R: Rounding of Numbers".
- "Python manual for
math
module". Retrieved 18 July 2013. - Sullivan, p. 86.
- "Vocabulary". J Language. Retrieved 6 September 2011.
- "INT function". Retrieved 29 October 2021.
- "FLOOR function". Retrieved 29 October 2021.
- "Documentation/How Tos/Calc: INT function". Retrieved 29 October 2021.
- "Documentation/How Tos/Calc: FLOOR function". Retrieved 29 October 2021.
References
- J.W.S. Cassels (1957), An introduction to Diophantine approximation, Cambridge Tracts in Mathematics and Mathematical Physics, vol. 45, Cambridge University Press
- Crandall, Richard; Pomerance, Carl (2001), Prime Numbers: A Computational Perspective, New York: Springer, ISBN 0-387-94777-9
- Graham, Ronald L.; Knuth, Donald E.; Patashnik, Oren (1994), Concrete Mathematics, Reading Ma.: Addison-Wesley, ISBN 0-201-55802-5
- Hardy, G. H.; Wright, E. M. (1980), An Introduction to the Theory of Numbers (Fifth edition), Oxford: Oxford University Press, ISBN 978-0-19-853171-5
- Nicholas J. Higham, Handbook of writing for the mathematical sciences, SIAM. ISBN 0-89871-420-6, p. 25
- ISO/IEC. ISO/IEC 9899::1999(E): Programming languages — C (2nd ed), 1999; Section 6.3.1.4, p. 43.
- Iverson, Kenneth E. (1962), A Programming Language, Wiley
- Lemmermeyer, Franz (2000), Reciprocity Laws: from Euler to Eisenstein, Berlin: Springer, ISBN 3-540-66957-4
- Ramanujan, Srinivasa (2000), Collected Papers, Providence RI: AMS / Chelsea, ISBN 978-0-8218-2076-6
- Ribenboim, Paulo (1996), The New Book of Prime Number Records, New York: Springer, ISBN 0-387-94457-5
- Michael Sullivan. Precalculus, 8th edition, p. 86
- Titchmarsh, Edward Charles; Heath-Brown, David Rodney ("Roger") (1986), The Theory of the Riemann Zeta-function (2nd ed.), Oxford: Oxford U. P., ISBN 0-19-853369-1
External links
- "Floor function", Encyclopedia of Mathematics, EMS Press, 2001 [1994]
- Štefan Porubský, "Integer rounding functions", Interactive Information Portal for Algorithmic Mathematics, Institute of Computer Science of the Czech Academy of Sciences, Prague, Czech Republic, retrieved 24 October 2008
- Weisstein, Eric W. "Floor Function". MathWorld.
- Weisstein, Eric W. "Ceiling Function". MathWorld.
In mathematics the floor function is the function that takes as input a real number x and gives as output the greatest integer less than or equal to x denoted x or floor x Similarly the ceiling function maps x to the least integer greater than or equal to x denoted x or ceil x Floor and ceiling functionsFloor functionCeiling function For example for floor 2 4 2 2 4 3 and for ceiling 2 4 3 and 2 4 2 The floor of x is also called the integral part integer part greatest integer or entier of x and was historically denoted x among other notations However the same term integer part is also used for truncation towards zero which differs from the floor function for negative numbers For an integer n n n n Although floor x 1 and ceil x produce graphs that appear exactly alike they are not the same when the value of x is an exact integer For example when x 2 0001 2 0001 1 2 0001 3 However if x 2 then 2 1 3 while 2 2 Examples x Floor x Ceiling x Fractional part x 2 2 2 02 0001 2 3 0 00012 4 2 3 0 42 9 2 3 0 92 999 2 3 0 999 2 7 3 2 0 3 2 2 2 0NotationThe integral part or integer part of a number partie entiere in the original was first defined in 1798 by Adrien Marie Legendre in his proof of the Legendre s formula Carl Friedrich Gauss introduced the square bracket notation x in his third proof of quadratic reciprocity 1808 This remained the standard in mathematics until Kenneth E Iverson introduced in his 1962 book A Programming Language the names floor and ceiling and the corresponding notations x and x Iverson used square brackets for a different purpose the Iverson bracket notation Both notations are now used in mathematics although Iverson s notation will be followed in this article In some sources boldface or double brackets x are used for floor and reversed brackets x or x for ceiling The fractional part is the sawtooth function denoted by x for real x and defined by the formula x x x For all x 0 x lt 1 These characters are provided in Unicode U 2308 LEFT CEILING amp lceil amp LeftCeiling U 2309 RIGHT CEILING amp rceil amp RightCeiling U 230A LEFT FLOOR amp LeftFloor amp lfloor U 230B RIGHT FLOOR amp rfloor amp RightFloor In the LaTeX typesetting system these symbols can be specified with the link rel mw deduplicated inline style href mw data TemplateStyles r886049734 span class monospaced lceil rceil lfloor span and link rel mw deduplicated inline style href mw data TemplateStyles r886049734 span class monospaced rfloor span commands in math mode LaTeX has supported UTF 8 since 2018 so the Unicode characters can now be used directly Larger versions are link rel mw deduplicated inline style href mw data TemplateStyles r886049734 span class monospaced left lceil right rceil left lfloor span and link rel mw deduplicated inline style href mw data TemplateStyles r886049734 span class monospaced right rfloor span Definition and propertiesGiven real numbers x and y integers m and n and the set of integers Z displaystyle mathbb Z floor and ceiling may be defined by the equations x max m Z m x displaystyle lfloor x rfloor max m in mathbb Z mid m leq x x min n Z n x displaystyle lceil x rceil min n in mathbb Z mid n geq x Since there is exactly one integer in a half open interval of length one for any real number x there are unique integers m and n satisfying the equation x 1 lt m x n lt x 1 displaystyle x 1 lt m leq x leq n lt x 1 where x m displaystyle lfloor x rfloor m and x n displaystyle lceil x rceil n may also be taken as the definition of floor and ceiling Equivalences These formulas can be used to simplify expressions involving floors and ceilings x m if and only if m x lt m 1 x n if and only if n 1 lt x n x m if and only if x 1 lt m x x n if and only if x n lt x 1 displaystyle begin alignedat 3 lfloor x rfloor amp m amp amp mbox if and only if amp m amp leq x lt m 1 lceil x rceil amp n amp amp mbox if and only if amp n 1 amp lt x leq n lfloor x rfloor amp m amp amp mbox if and only if amp x 1 amp lt m leq x lceil x rceil amp n amp amp mbox if and only if amp x amp leq n lt x 1 end alignedat In the language of order theory the floor function is a residuated mapping that is part of a Galois connection it is the upper adjoint of the function that embeds the integers into the reals x lt n if and only if x lt n n lt x if and only if n lt x x n if and only if x n n x if and only if n x displaystyle begin aligned x lt n amp mbox if and only if amp lfloor x rfloor amp lt n n lt x amp mbox if and only if amp n amp lt lceil x rceil x leq n amp mbox if and only if amp lceil x rceil amp leq n n leq x amp mbox if and only if amp n amp leq lfloor x rfloor end aligned These formulas show how adding an integer n to the arguments affects the functions x n x n x n x n x n x displaystyle begin aligned lfloor x n rfloor amp lfloor x rfloor n lceil x n rceil amp lceil x rceil n x n amp x end aligned The above are never true if n is not an integer however for every x and y the following inequalities hold x y x y x y 1 x y 1 x y x y displaystyle begin aligned lfloor x rfloor lfloor y rfloor amp leq lfloor x y rfloor leq lfloor x rfloor lfloor y rfloor 1 3mu lceil x rceil lceil y rceil 1 amp leq lceil x y rceil leq lceil x rceil lceil y rceil end aligned Monotonicity Both floor and ceiling functions are monotonically non decreasing functions x1 x2 x1 x2 x1 x2 x1 x2 displaystyle begin aligned x 1 leq x 2 amp Rightarrow lfloor x 1 rfloor leq lfloor x 2 rfloor x 1 leq x 2 amp Rightarrow lceil x 1 rceil leq lceil x 2 rceil end aligned Relations among the functions It is clear from the definitions that x x displaystyle lfloor x rfloor leq lceil x rceil with equality if and only if x is an integer i e x x 0 if x Z1 if x Z displaystyle lceil x rceil lfloor x rfloor begin cases 0 amp mbox if x in mathbb Z 1 amp mbox if x not in mathbb Z end cases In fact for integers n both floor and ceiling functions are the identity n n n displaystyle lfloor n rfloor lceil n rceil n Negating the argument switches floor and ceiling and changes the sign x x 0 x x x x displaystyle begin aligned lfloor x rfloor lceil x rceil amp 0 lfloor x rfloor amp lceil x rceil lceil x rceil amp lfloor x rfloor end aligned and x x 0if x Z 1if x Z displaystyle lfloor x rfloor lfloor x rfloor begin cases 0 amp text if x in mathbb Z 1 amp text if x not in mathbb Z end cases x x 0if x Z1if x Z displaystyle lceil x rceil lceil x rceil begin cases 0 amp text if x in mathbb Z 1 amp text if x not in mathbb Z end cases Negating the argument complements the fractional part x x 0if x Z1if x Z displaystyle x x begin cases 0 amp text if x in mathbb Z 1 amp text if x not in mathbb Z end cases The floor ceiling and fractional part functions are idempotent x x x x x x displaystyle begin aligned big lfloor lfloor x rfloor big rfloor amp lfloor x rfloor big lceil lceil x rceil big rceil amp lceil x rceil big x big amp x end aligned The result of nested floor or ceiling functions is the innermost function x x x x displaystyle begin aligned big lfloor lceil x rceil big rfloor amp lceil x rceil big lceil lfloor x rfloor big rceil amp lfloor x rfloor end aligned due to the identity property for integers Quotients If m and n are integers and n 0 0 mn 1 1 n displaystyle 0 leq left frac m n right leq 1 frac 1 n If n is positive x mn x mn displaystyle left lfloor frac x m n right rfloor left lfloor frac lfloor x rfloor m n right rfloor x mn x mn displaystyle left lceil frac x m n right rceil left lceil frac lceil x rceil m n right rceil If m is positive n n1m n 1m n m 1m displaystyle n left lceil frac n vphantom 1 m right rceil left lceil frac n 1 m right rceil dots left lceil frac n m 1 m right rceil n n1m n 1m n m 1m displaystyle n left lfloor frac n vphantom 1 m right rfloor left lfloor frac n 1 m right rfloor dots left lfloor frac n m 1 m right rfloor For m 2 these imply n n12 n12 displaystyle n left lfloor frac n vphantom 1 2 right rfloor left lceil frac n vphantom 1 2 right rceil More generally for positive m See Hermite s identity mx x x 1m x m 1m displaystyle lceil mx rceil left lceil x right rceil left lceil x frac 1 m right rceil dots left lceil x frac m 1 m right rceil mx x x 1m x m 1m displaystyle lfloor mx rfloor left lfloor x right rfloor left lfloor x frac 1 m right rfloor dots left lfloor x frac m 1 m right rfloor The following can be used to convert floors to ceilings and vice versa with m being positive n1m n m 1m n 1m 1 displaystyle left lceil frac n vphantom 1 m right rceil left lfloor frac n m 1 m right rfloor left lfloor frac n 1 m right rfloor 1 n1m n m 1m n 1m 1 displaystyle left lfloor frac n vphantom 1 m right rfloor left lceil frac n m 1 m right rceil left lceil frac n 1 m right rceil 1 For all m and n strictly positive integers k 1n 1 kmn m 1 n 1 gcd m n 12 displaystyle sum k 1 n 1 left lfloor frac km n right rfloor frac m 1 n 1 gcd m n 1 2 which for positive and coprime m and n reduces to k 1n 1 kmn 12 m 1 n 1 displaystyle sum k 1 n 1 left lfloor frac km n right rfloor tfrac 1 2 m 1 n 1 and similarly for the ceiling and fractional part functions still for positive and coprime m and n k 1n 1 kmn 12 m 1 n 1 displaystyle sum k 1 n 1 left lceil frac km n right rceil tfrac 1 2 m 1 n 1 k 1n 1 kmn 12 n 1 displaystyle sum k 1 n 1 left frac km n right tfrac 1 2 n 1 Since the right hand side of the general case is symmetrical in m and n this implies that m1n 2mn n 1 mn n1m 2nm m 1 nm displaystyle left lfloor frac m vphantom 1 n right rfloor left lfloor frac 2m n right rfloor dots left lfloor frac n 1 m n right rfloor left lfloor frac n vphantom 1 m right rfloor left lfloor frac 2n m right rfloor dots left lfloor frac m 1 n m right rfloor More generally if m and n are positive x1n m xn 2m xn n 1 m xn x1m n xm 2n xm m 1 n xm displaystyle begin aligned amp left lfloor frac x vphantom 1 n right rfloor left lfloor frac m x n right rfloor left lfloor frac 2m x n right rfloor dots left lfloor frac n 1 m x n right rfloor 5mu amp left lfloor frac x vphantom 1 m right rfloor left lfloor frac n x m right rfloor left lfloor frac 2n x m right rfloor cdots left lfloor frac m 1 n x m right rfloor end aligned This is sometimes called a reciprocity law Division by positive integers gives rise to an interesting and sometimes useful property Assuming m n gt 0 displaystyle m n gt 0 m xn n xm n x m displaystyle m leq left lfloor frac x n right rfloor iff n leq left lfloor frac x m right rfloor iff n leq frac lfloor x rfloor m Similarly m xn n xm n x m displaystyle m geq left lceil frac x n right rceil iff n geq left lceil frac x m right rceil iff n geq frac lceil x rceil m Indeed m xn m xn n xm n xm m xn displaystyle m leq left lfloor frac x n right rfloor implies m leq frac x n implies n leq frac x m implies n leq left lfloor frac x m right rfloor implies ldots implies m leq left lfloor frac x n right rfloor keeping in mind that x n x n textstyle lfloor x n rfloor bigl lfloor lfloor x rfloor n bigr rfloor The second equivalence involving the ceiling function can be proved similarly Nested divisions For positive integer n and arbitrary real numbers m x x m n xmn displaystyle left lfloor frac lfloor x m rfloor n right rfloor left lfloor frac x mn right rfloor x m n xmn displaystyle left lceil frac lceil x m rceil n right rceil left lceil frac x mn right rceil Continuity and series expansions None of the functions discussed in this article are continuous but all are piecewise linear the functions x displaystyle lfloor x rfloor x displaystyle lceil x rceil and x displaystyle x have discontinuities at the integers x displaystyle lfloor x rfloor is upper semi continuous and x displaystyle lceil x rceil and x displaystyle x are lower semi continuous Since none of the functions discussed in this article are continuous none of them have a power series expansion Since floor and ceiling are not periodic they do not have uniformly convergent Fourier series expansions The fractional part function has Fourier series expansion x 12 1p k 1 sin 2pkx k displaystyle x frac 1 2 frac 1 pi sum k 1 infty frac sin 2 pi kx k for x not an integer At points of discontinuity a Fourier series converges to a value that is the average of its limits on the left and the right unlike the floor ceiling and fractional part functions for y fixed and x a multiple of y the Fourier series given converges to y 2 rather than to x mod y 0 At points of continuity the series converges to the true value Using the formula x x x displaystyle lfloor x rfloor x x gives x x 12 1p k 1 sin 2pkx k displaystyle lfloor x rfloor x frac 1 2 frac 1 pi sum k 1 infty frac sin 2 pi kx k for x not an integer ApplicationsMod operator For an integer x and a positive integer y the modulo operation denoted by x mod y gives the value of the remainder when x is divided by y This definition can be extended to real x and y y 0 by the formula xmody x y xy displaystyle x bmod y x y left lfloor frac x y right rfloor Then it follows from the definition of floor function that this extended operation satisfies many natural properties Notably x mod y is always between 0 and y i e if y is positive 0 xmody lt y displaystyle 0 leq x bmod y lt y and if y is negative 0 xmody gt y displaystyle 0 geq x bmod y gt y Quadratic reciprocity Gauss s third proof of quadratic reciprocity as modified by Eisenstein has two basic steps Let p and q be distinct positive odd prime numbers and let m 12 p 1 displaystyle m tfrac 1 2 p 1 n 12 q 1 displaystyle n tfrac 1 2 q 1 First Gauss s lemma is used to show that the Legendre symbols are given by qp 1 qp 2qp mqp pq 1 pq 2pq npq displaystyle begin aligned left frac q p right amp 1 left lfloor frac q p right rfloor left lfloor frac 2q p right rfloor dots left lfloor frac mq p right rfloor 5mu left frac p q right amp 1 left lfloor frac p q right rfloor left lfloor frac 2p q right rfloor dots left lfloor frac np q right rfloor end aligned The second step is to use a geometric argument to show that qp 2qp mqp pq 2pq npq mn displaystyle left lfloor frac q p right rfloor left lfloor frac 2q p right rfloor dots left lfloor frac mq p right rfloor left lfloor frac p q right rfloor left lfloor frac 2p q right rfloor dots left lfloor frac np q right rfloor mn Combining these formulas gives quadratic reciprocity in the form pq qp 1 mn 1 p 12q 12 displaystyle left frac p q right left frac q p right 1 mn 1 frac p 1 2 frac q 1 2 There are formulas that use floor to express the quadratic character of small numbers mod odd primes p 2p 1 p 14 3p 1 p 16 displaystyle begin aligned left frac 2 p right amp 1 left lfloor frac p 1 4 right rfloor 5mu left frac 3 p right amp 1 left lfloor frac p 1 6 right rfloor end aligned Rounding For an arbitrary real number x displaystyle x rounding x displaystyle x to the nearest integer with tie breaking towards positive infinity is given by rpi x x 12 12 2x displaystyle text rpi x left lfloor x tfrac 1 2 right rfloor left lceil tfrac 1 2 lfloor 2x rfloor right rceil rounding towards negative infinity is given as rni x x 12 12 2x displaystyle text rni x left lceil x tfrac 1 2 right rceil left lfloor tfrac 1 2 lceil 2x rceil right rfloor If tie breaking is away from 0 then the rounding function is ri x sgn x x 12 displaystyle text ri x operatorname sgn x left lfloor x tfrac 1 2 right rfloor see sign function and rounding towards even can be expressed with the more cumbersome x x 12 14 2x 1 14 2x 1 1 displaystyle lfloor x rceil left lfloor x tfrac 1 2 right rfloor bigl lceil tfrac 1 4 2x 1 bigr rceil bigl lfloor tfrac 1 4 2x 1 bigr rfloor 1 which is the above expression for rounding towards positive infinity rpi x displaystyle text rpi x minus an integrality indicator for 14 2x 1 displaystyle tfrac 1 4 2x 1 Rounding a real number x displaystyle x to the nearest integer value forms a very basic type of quantizer a uniform one A typical mid tread uniform quantizer with a quantization step size equal to some value D displaystyle Delta can be expressed as Q x D xD 12 displaystyle Q x Delta cdot left lfloor frac x Delta frac 1 2 right rfloor Number of digits The number of digits in base b of a positive integer k is logb k 1 logb k 1 displaystyle lfloor log b k rfloor 1 lceil log b k 1 rceil Number of strings without repeated characters The number of possible strings of arbitrary length that doesn t use any character twice is given by better source needed n 0 n n en displaystyle n 0 cdots n n lfloor en rfloor where n gt 0 is the number of letters in the alphabet e g 26 in English the falling factorial n k n n 1 n k 1 displaystyle n k n n 1 cdots n k 1 denotes the number of strings of length k that don t use any character twice n denotes the factorial of n e 2 718 is Euler s number For n 26 this comes out to 1096259850353149530222034277 Factors of factorials Let n be a positive integer and p a positive prime number The exponent of the highest power of p that divides n is given by a version of Legendre s formula np np2 np3 n kakp 1 displaystyle left lfloor frac n p right rfloor left lfloor frac n p 2 right rfloor left lfloor frac n p 3 right rfloor dots frac n sum k a k p 1 where n kakpk textstyle n sum k a k p k is the way of writing n in base p This is a finite sum since the floors are zero when pk gt n Beatty sequence The Beatty sequence shows how every positive irrational number gives rise to a partition of the natural numbers into two sequences via the floor function Euler s constant g There are formulas for Euler s constant g 0 57721 56649 that involve the floor and ceiling e g g 1 1 x 1x dx displaystyle gamma int 1 infty left 1 over lfloor x rfloor 1 over x right dx g limn 1n k 1n nk nk displaystyle gamma lim n to infty frac 1 n sum k 1 n left left lceil frac n k right rceil frac n k right and g k 2 1 k log2 k k 12 13 2 14 15 16 17 3 18 115 displaystyle gamma sum k 2 infty 1 k frac left lfloor log 2 k right rfloor k tfrac 1 2 tfrac 1 3 2 left tfrac 1 4 tfrac 1 5 tfrac 1 6 tfrac 1 7 right 3 left tfrac 1 8 cdots tfrac 1 15 right cdots Riemann zeta function z The fractional part function also shows up in integral representations of the Riemann zeta function It is straightforward to prove using integration by parts that if f x displaystyle varphi x is any function with a continuous derivative in the closed interval a b a lt n bf n abf x dx ab x 12 f x dx a 12 f a b 12 f b displaystyle sum a lt n leq b varphi n int a b varphi x dx int a b left x tfrac 1 2 right varphi x dx left a tfrac 1 2 right varphi a left b tfrac 1 2 right varphi b Letting f n n s displaystyle varphi n n s for real part of s greater than 1 and letting a and b be integers and letting b approach infinity gives z s s 1 12 x xs 1dx 1s 1 12 displaystyle zeta s s int 1 infty frac frac 1 2 x x s 1 dx frac 1 s 1 frac 1 2 This formula is valid for all s with real part greater than 1 except s 1 where there is a pole and combined with the Fourier expansion for x can be used to extend the zeta function to the entire complex plane and to prove its functional equation For s s it in the critical strip 0 lt s lt 1 z s s e sw ew ew e itwdw displaystyle zeta s s int infty infty e sigma omega lfloor e omega rfloor e omega e it omega d omega In 1947 van der Pol used this representation to construct an analogue computer for finding roots of the zeta function Formulas for prime numbers The floor function appears in several formulas characterizing prime numbers For example since nm n 1m textstyle bigl lfloor frac n m bigr rfloor bigl lfloor frac n 1 m bigr rfloor is equal to 1 if m divides n and to 0 otherwise it follows that a positive integer n is a prime if and only if m 1 nm n 1m 2 displaystyle sum m 1 infty left biggl lfloor frac n m biggr rfloor biggl lfloor frac n 1 m biggr rfloor right 2 One may also give formulas for producing the prime numbers For example let pn be the n th prime and for any integer r gt 1 define the real number a by the sum a m 1 pmr m2 displaystyle alpha sum m 1 infty p m r m 2 Then pn rn2a r2n 1 r n 1 2a displaystyle p n left lfloor r n 2 alpha right rfloor r 2n 1 left lfloor r n 1 2 alpha right rfloor A similar result is that there is a number 8 1 3064 Mills constant with the property that 83 89 827 displaystyle left lfloor theta 3 right rfloor left lfloor theta 9 right rfloor left lfloor theta 27 right rfloor dots are all prime There is also a number w 1 9287800 with the property that 2w 22w 222w displaystyle left lfloor 2 omega right rfloor left lfloor 2 2 omega right rfloor left lfloor 2 2 2 omega right rfloor dots are all prime Let p x be the number of primes less than or equal to x It is a straightforward deduction from Wilson s theorem that p n j 2n j 1 1j j 1 j displaystyle pi n sum j 2 n Biggl lfloor frac j 1 1 j left lfloor frac j 1 j right rfloor Biggr rfloor Also if n 2 p n j 2n 1 k 2j jk kj displaystyle pi n sum j 2 n Biggl lfloor 1 bigg sum k 2 j left lfloor left lfloor frac j k right rfloor frac k j right rfloor Biggr rfloor None of the formulas in this section are of any practical use Solved problems Ramanujan submitted these problems to the Journal of the Indian Mathematical Society If n is a positive integer prove that n3 n 26 n 46 n2 n 36 displaystyle left lfloor tfrac n 3 right rfloor left lfloor tfrac n 2 6 right rfloor left lfloor tfrac n 4 6 right rfloor left lfloor tfrac n 2 right rfloor left lfloor tfrac n 3 6 right rfloor 12 n 12 12 n 14 displaystyle left lfloor tfrac 1 2 sqrt n tfrac 1 2 right rfloor left lfloor tfrac 1 2 sqrt n tfrac 1 4 right rfloor n n 1 4n 2 displaystyle left lfloor sqrt n sqrt n 1 right rfloor left lfloor sqrt 4n 2 right rfloor Some generalizations to the above floor function identities have been proven Unsolved problem The study of Waring s problem has led to an unsolved problem Are there any positive integers k 6 such that 3k 2k 32 k gt 2k 32 k 2 displaystyle 3 k 2 k Bigl lfloor bigl tfrac 3 2 bigr k Bigr rfloor gt 2 k Bigl lfloor bigl tfrac 3 2 bigr k Bigr rfloor 2 Mahler has proved there can only be a finite number of such k none are known Computer implementationsInt function from floating point conversion in C In most programming languages the simplest method to convert a floating point number to an integer does not do floor or ceiling but truncation The reason for this is historical as the first machines used ones complement and truncation was simpler to implement floor is simpler in two s complement FORTRAN was defined to require this behavior and thus almost all processors implement conversion this way Some consider this to be an unfortunate historical design decision that has led to bugs handling negative offsets and graphics on the negative side of the origin citation needed An arithmetic right shift of a signed integer x displaystyle x by n displaystyle n is the same as x 2n displaystyle left lfloor x 2 n right rfloor Division by a power of 2 is often written as a right shift not for optimization as might be assumed but because the floor of negative results is required Assuming such shifts are premature optimization and replacing them with division can break software citation needed Many programming languages including C C C Java Julia PHP R and Python provide standard functions for floor and ceiling usually called floor and ceil or less commonly ceiling The language APL uses x for floor The J Programming Language a follow on to APL that is designed to use standard keyboard symbols uses lt for floor and gt for ceiling ALGOL usesentier for floor In Microsoft Excel the function INT rounds down rather than toward zero while FLOOR rounds toward zero the opposite of what int and floor do in other languages Since 2010 FLOOR has been changed to error if the number is negative The OpenDocument file format as used by OpenOffice org Libreoffice and others INT and FLOOR both do floor and FLOOR has a third argument to reproduce Excel s earlier behavior See alsoBracket mathematics Integer valued function Step function Modulo operationCitationsGraham Knuth amp Patashnik Ch 3 1 1 Luke Heaton A Brief History of Mathematical Thought 2015 ISBN 1472117158 n p 2 Albert A Blank et al Calculus Differential Calculus 1968 p 259 3 John W Warris Horst Stocker Handbook of mathematics and computational science 1998 ISBN 0387947469 p 151 Lemmermeyer pp 10 23 e g Cassels Hardy amp Wright and Ribenboim use Gauss s notation Graham Knuth amp Patashnik and Crandall amp Pomerance use Iverson s Iverson p 12 Higham p 25 Mathwords Floor Function Mathwords Ceiling Function Graham Knuth amp Patashnik p 70 LaTeX News Issue 28 PDF 379 KB The LaTeX Project April 2018 Retrieved 27 July 2024 Graham Knuth amp Patashink Ch 3 Graham Knuth amp Patashnik p 73 Graham Knuth amp Patashnik p 85 Graham Knuth amp Patashnik p 85 and Ex 3 15 Graham Knuth amp Patashnik Ex 3 12 Graham Knuth amp Patashnik p 94 Graham Knuth amp Patashnik p 94 Graham Knuth amp Patashnik p 71 apply theorem 3 10 with x m as input and the division by n as function Titchmarsh p 15 Eq 2 1 7 Lemmermeyer 1 4 Ex 1 32 1 33 Hardy amp Wright 6 11 6 13 Lemmermeyer p 25 OEIS sequence A000522 Total number of arrangements of a set with n elements a n Sum k 0 n n k See Formulas Hardy amp Wright Th 416 Graham Knuth amp Patashnik pp 77 78 These formulas are from the Wikipedia article Euler s constant which has many more Titchmarsh p 13 Titchmarsh pp 14 15 Crandall amp Pomerance p 391 Crandall amp Pomerance Ex 1 3 p 46 The infinite upper limit of the sum can be replaced with n An equivalent condition is n gt 1 is prime if and only if m 1 n nm n 1m 1 textstyle sum m 1 lfloor sqrt n rfloor bigl bigl lfloor frac n m bigr rfloor bigl lfloor frac n 1 m bigr rfloor bigr 1 Hardy amp Wright 22 3 Ribenboim p 186 Ribenboim p 181 Crandall amp Pomerance Ex 1 4 p 46 Ribenboim p 180 says that Despite the nil practical value of the formulas they may have some relevance to logicians who wish to understand clearly how various parts of arithmetic may be deduced from different axiomatzations Hardy amp Wright pp 344 345 Any one of these formulas or any similar one would attain a different status if the exact value of the number a could be expressed independently of the primes There seems no likelihood of this but it cannot be ruled out as entirely impossible Ramanujan Question 723 Papers p 332 Somu Sai Teja Kukla Andrzej 2022 On some generalizations to floor function identities of Ramanujan PDF Integers 22 arXiv 2109 03680 Hardy amp Wright p 337 Mahler Kurt 1957 On the fractional parts of the powers of a rational number II Mathematika 4 2 122 124 doi 10 1112 S0025579300001170 C reference of floor function Retrieved 5 December 2010 C reference of ceil function Retrieved 5 December 2010 dotnet bot Math Floor Method System docs microsoft com Retrieved 28 November 2019 dotnet bot Math Ceiling Method System docs microsoft com Retrieved 28 November 2019 Math Java SE 9 amp JDK 9 docs oracle com Retrieved 20 November 2018 Math Java SE 9 amp JDK 9 docs oracle com Retrieved 20 November 2018 Math Julia v1 10 docs julialang org en v1 Retrieved 4 September 2024 PHP manual for ceil function Retrieved 18 July 2013 PHP manual for floor function Retrieved 18 July 2013 R Rounding of Numbers Python manual for math module Retrieved 18 July 2013 Sullivan p 86 Vocabulary J Language Retrieved 6 September 2011 INT function Retrieved 29 October 2021 FLOOR function Retrieved 29 October 2021 Documentation How Tos Calc INT function Retrieved 29 October 2021 Documentation How Tos Calc FLOOR function Retrieved 29 October 2021 ReferencesJ W S Cassels 1957 An introduction to Diophantine approximation Cambridge Tracts in Mathematics and Mathematical Physics vol 45 Cambridge University Press Crandall Richard Pomerance Carl 2001 Prime Numbers A Computational Perspective New York Springer ISBN 0 387 94777 9 Graham Ronald L Knuth Donald E Patashnik Oren 1994 Concrete Mathematics Reading Ma Addison Wesley ISBN 0 201 55802 5 Hardy G H Wright E M 1980 An Introduction to the Theory of Numbers Fifth edition Oxford Oxford University Press ISBN 978 0 19 853171 5 Nicholas J Higham Handbook of writing for the mathematical sciences SIAM ISBN 0 89871 420 6 p 25 ISO IEC ISO IEC 9899 1999 E Programming languages C 2nd ed 1999 Section 6 3 1 4 p 43 Iverson Kenneth E 1962 A Programming Language Wiley Lemmermeyer Franz 2000 Reciprocity Laws from Euler to Eisenstein Berlin Springer ISBN 3 540 66957 4 Ramanujan Srinivasa 2000 Collected Papers Providence RI AMS Chelsea ISBN 978 0 8218 2076 6 Ribenboim Paulo 1996 The New Book of Prime Number Records New York Springer ISBN 0 387 94457 5 Michael Sullivan Precalculus 8th edition p 86 Titchmarsh Edward Charles Heath Brown David Rodney Roger 1986 The Theory of the Riemann Zeta function 2nd ed Oxford Oxford U P ISBN 0 19 853369 1External linksWikimedia Commons has media related to Floor and ceiling functions Floor function Encyclopedia of Mathematics EMS Press 2001 1994 Stefan Porubsky Integer rounding functions Interactive Information Portal for Algorithmic Mathematics Institute of Computer Science of the Czech Academy of Sciences Prague Czech Republic retrieved 24 October 2008 Weisstein Eric W Floor Function MathWorld Weisstein Eric W Ceiling Function MathWorld