Menu
Home Explore People Places Arts History Plants & Animals Science Life & Culture Technology
On this page
Floor and ceiling functions
Mathematical functions rounding a number to the two closest integers

In mathematics, the floor function maps a real number x to the greatest integer less than or equal to x, denoted ⌊x⌋, while the ceiling function returns the least integer greater than or equal to x, denoted ⌈x⌉. For example, ⌊2.4⌋ = 2 and ⌈2.4⌉ = 3, whereas for negative values, ⌊−2.4⌋ = −3 and ⌈−2.4⌉ = −2. The floor, also called the integral or greatest integer part, differs from truncation toward zero for negative numbers. For integers n, floor(n) = ceil(n) = n. Although floor(x+1) and ceil(x) appear similar, they differ at integer values of x. See more in the fractional part of a number.

Related Image Collections Add Image
We don't have any YouTube videos related to Floor and ceiling functions yet.
We don't have any PDF documents related to Floor and ceiling functions yet.
We don't have any Books related to Floor and ceiling functions yet.
We don't have any archived web articles related to Floor and ceiling functions yet.

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).3 This remained the standard4 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⌉.56 (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.78

The fractional part is the sawtooth function, denoted by {x} for real x and defined by the formula

{x} = x − ⌊x9

For all x,

0 ≤ {x} < 1.

These characters are provided in Unicode:

  • U+2308 ⌈ LEFT CEILING (&lceil;, &LeftCeiling;)
  • U+2309 ⌉ RIGHT CEILING (&rceil;, &RightCeiling;)
  • U+230A ⌊ LEFT FLOOR (&LeftFloor;, &lfloor;)
  • U+230B ⌋ RIGHT FLOOR (&rfloor;, &RightFloor;)

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.10 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 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 < m ≤ x ≤ n < x + 1. {\displaystyle x-1<m\leq x\leq n<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.11

⌊ x ⌋ = m      if and only if  m ≤ x < m + 1 , ⌈ x ⌉ = n  if and only if      n − 1 < x ≤ n , ⌊ x ⌋ = m  if and only if  x − 1 < m ≤ x , ⌈ x ⌉ = n  if and only if  x ≤ n < x + 1. {\displaystyle {\begin{alignedat}{3}\lfloor x\rfloor &=m\ \ &&{\mbox{ if and only if }}&m&\leq x<m+1,\\\lceil x\rceil &=n&&{\mbox{ if and only if }}&\ \ n-1&<x\leq n,\\\lfloor x\rfloor &=m&&{\mbox{ if and only if }}&x-1&<m\leq x,\\\lceil x\rceil &=n&&{\mbox{ if and only if }}&x&\leq n<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 < n  if and only if  ⌊ x ⌋ < n , n < x  if and only if  n < ⌈ x ⌉ , x ≤ n  if and only if  ⌈ x ⌉ ≤ n , n ≤ x  if and only if  n ≤ ⌊ x ⌋ . {\displaystyle {\begin{aligned}x<n&\;\;{\mbox{ if and only if }}&\lfloor x\rfloor &<n,\\n<x&\;\;{\mbox{ if and only if }}&n&<\lceil x\rceil ,\\x\leq n&\;\;{\mbox{ if and only if }}&\lceil x\rceil &\leq n,\\n\leq x&\;\;{\mbox{ if and only if }}&n&\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 &=\lfloor x\rfloor +n,\\\lceil x+n\rceil &=\lceil x\rceil +n,\\\{x+n\}&=\{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 &\leq \lfloor x+y\rfloor \leq \lfloor x\rfloor +\lfloor y\rfloor +1,\\[3mu]\lceil x\rceil +\lceil y\rceil -1&\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:

x 1 ≤ x 2 ⇒ ⌊ x 1 ⌋ ≤ ⌊ x 2 ⌋ , x 1 ≤ x 2 ⇒ ⌈ x 1 ⌉ ≤ ⌈ x 2 ⌉ . {\displaystyle {\begin{aligned}x_{1}\leq x_{2}&\Rightarrow \lfloor x_{1}\rfloor \leq \lfloor x_{2}\rfloor ,\\x_{1}\leq x_{2}&\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 ∈ Z 1  if  x ∉ Z {\displaystyle \lceil x\rceil -\lfloor x\rfloor ={\begin{cases}0&{\mbox{ if }}x\in \mathbb {Z} \\1&{\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 &=0\\-\lfloor x\rfloor &=\lceil -x\rceil \\-\lceil x\rceil &=\lfloor -x\rfloor \end{aligned}}}

and:

⌊ x ⌋ + ⌊ − x ⌋ = { 0 if  x ∈ Z − 1 if  x ∉ Z , {\displaystyle \lfloor x\rfloor +\lfloor -x\rfloor ={\begin{cases}0&{\text{if }}x\in \mathbb {Z} \\-1&{\text{if }}x\not \in \mathbb {Z} ,\end{cases}}} ⌈ x ⌉ + ⌈ − x ⌉ = { 0 if  x ∈ Z 1 if  x ∉ Z . {\displaystyle \lceil x\rceil +\lceil -x\rceil ={\begin{cases}0&{\text{if }}x\in \mathbb {Z} \\1&{\text{if }}x\not \in \mathbb {Z} .\end{cases}}}

Negating the argument complements the fractional part:

{ x } + { − x } = { 0 if  x ∈ Z 1 if  x ∉ Z . {\displaystyle \{x\}+\{-x\}={\begin{cases}0&{\text{if }}x\in \mathbb {Z} \\1&{\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 }&=\lfloor x\rfloor ,\\{\big \lceil }\lceil x\rceil {\big \rceil }&=\lceil x\rceil ,\\{\big \{}\{x\}{\big \}}&=\{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 }&=\lceil x\rceil ,\\{\big \lceil }\lfloor x\rfloor {\big \rceil }&=\lfloor x\rfloor \end{aligned}}}

due to the identity property for integers.

Quotients

If m and n are integers and n ≠ 0,

0 ≤ { m n } ≤ 1 − 1 | n | . {\displaystyle 0\leq \left\{{\frac {m}{n}}\right\}\leq 1-{\frac {1}{|n|}}.}

If n is positive12

⌊ x + m n ⌋ = ⌊ ⌊ x ⌋ + m n ⌋ , {\displaystyle \left\lfloor {\frac {x+m}{n}}\right\rfloor =\left\lfloor {\frac {\lfloor x\rfloor +m}{n}}\right\rfloor ,} ⌈ x + m n ⌉ = ⌈ ⌈ x ⌉ + m n ⌉ . {\displaystyle \left\lceil {\frac {x+m}{n}}\right\rceil =\left\lceil {\frac {\lceil x\rceil +m}{n}}\right\rceil .}

If m is positive13

n = ⌈ n 1 m ⌉ + ⌈ n − 1 m ⌉ + ⋯ + ⌈ n − m + 1 m ⌉ , {\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 = ⌊ n 1 m ⌋ + ⌊ n + 1 m ⌋ + ⋯ + ⌊ n + m − 1 m ⌋ . {\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 = ⌊ n 1 2 ⌋ + ⌈ n 1 2 ⌉ . {\displaystyle n=\left\lfloor {\frac {n{\vphantom {1}}}{2}}\right\rfloor +\left\lceil {\frac {n{\vphantom {1}}}{2}}\right\rceil .}

More generally,14 for positive m (See Hermite's identity)

⌈ m x ⌉ = ⌈ x ⌉ + ⌈ x − 1 m ⌉ + ⋯ + ⌈ x − m − 1 m ⌉ , {\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 ,} ⌊ m x ⌋ = ⌊ x ⌋ + ⌊ x + 1 m ⌋ + ⋯ + ⌊ x + m − 1 m ⌋ . {\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)15

⌈ n 1 m ⌉ = ⌊ n + m − 1 m ⌋ = ⌊ n − 1 m ⌋ + 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,} ⌊ n 1 m ⌋ = ⌈ n − m + 1 m ⌉ = ⌈ n + 1 m ⌉ − 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:16

∑ k = 1 n − 1 ⌊ k m n ⌋ = ( m − 1 ) ( n − 1 ) + gcd ( m , n ) − 1 2 , {\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 = 1 n − 1 ⌊ k m n ⌋ = 1 2 ( 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 = 1 n − 1 ⌈ k m n ⌉ = 1 2 ( 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 = 1 n − 1 { k m n } = 1 2 ( 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

⌊ m 1 n ⌋ + ⌊ 2 m n ⌋ + ⋯ + ⌊ ( n − 1 ) m n ⌋ = ⌊ n 1 m ⌋ + ⌊ 2 n m ⌋ + ⋯ + ⌊ ( m − 1 ) n m ⌋ . {\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,

⌊ x 1 n ⌋ + ⌊ m + x n ⌋ + ⌊ 2 m + x n ⌋ + ⋯ + ⌊ ( n − 1 ) m + x n ⌋ = ⌊ x 1 m ⌋ + ⌊ n + x m ⌋ + ⌊ 2 n + x m ⌋ + ⋯ + ⌊ ( m − 1 ) n + x m ⌋ . {\displaystyle {\begin{aligned}&\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]=&\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.17

Division by positive integers gives rise to an interesting and sometimes useful property. Assuming m , n > 0 {\displaystyle m,n>0} ,

m ≤ ⌊ x n ⌋ ⟺ n ≤ ⌊ x m ⌋ ⟺ 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 ≥ ⌈ x n ⌉ ⟺ n ≥ ⌈ x m ⌉ ⟺ 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 ≤ ⌊ x n ⌋ ⟹ m ≤ x n ⟹ n ≤ x m ⟹ n ≤ ⌊ x m ⌋ ⟹ … ⟹ m ≤ ⌊ x n ⌋ , {\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:18

⌊ ⌊ x / m ⌋ n ⌋ = ⌊ x m n ⌋ {\displaystyle \left\lfloor {\frac {\lfloor x/m\rfloor }{n}}\right\rfloor =\left\lfloor {\frac {x}{mn}}\right\rfloor } ⌈ ⌈ x / m ⌉ n ⌉ = ⌈ x m n ⌉ . {\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 expansion19 { x } = 1 2 − 1 π ∑ k = 1 ∞ sin ⁡ ( 2 π k x ) 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 − 1 2 + 1 π ∑ k = 1 ∞ sin ⁡ ( 2 π k x ) 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.

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

x mod y = x − y ⌊ x y ⌋ . {\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 ≤ x mod y < y , {\displaystyle 0\leq x{\bmod {y}}<y,}

and if y is negative,

0 ≥ x mod y > y . {\displaystyle 0\geq x{\bmod {y}}>y.}

Quadratic reciprocity

Gauss's third proof of quadratic reciprocity, as modified by Eisenstein, has two basic steps.2021

Let p and q be distinct positive odd prime numbers, and let m = 1 2 ( p − 1 ) , {\displaystyle m={\tfrac {1}{2}}(p-1),} n = 1 2 ( q − 1 ) . {\displaystyle n={\tfrac {1}{2}}(q-1).}

First, Gauss's lemma is used to show that the Legendre symbols are given by

( q p ) = ( − 1 ) ⌊ q p ⌋ + ⌊ 2 q p ⌋ + ⋯ + ⌊ m q p ⌋ , ( p q ) = ( − 1 ) ⌊ p q ⌋ + ⌊ 2 p q ⌋ + ⋯ + ⌊ n p q ⌋ . {\displaystyle {\begin{aligned}\left({\frac {q}{p}}\right)&=(-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)&=(-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

⌊ q p ⌋ + ⌊ 2 q p ⌋ + ⋯ + ⌊ m q p ⌋ + ⌊ p q ⌋ + ⌊ 2 p q ⌋ + ⋯ + ⌊ n p q ⌋ = m n . {\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

( p q ) ( q p ) = ( − 1 ) m n = ( − 1 ) p − 1 2 q − 1 2 . {\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:22

( 2 p ) = ( − 1 ) ⌊ p + 1 4 ⌋ , ( 3 p ) = ( − 1 ) ⌊ p + 1 6 ⌋ . {\displaystyle {\begin{aligned}\left({\frac {2}{p}}\right)&=(-1)^{\left\lfloor {\frac {p+1}{4}}\right\rfloor },\\[5mu]\left({\frac {3}{p}}\right)&=(-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 + 1 2 ⌋ = ⌈ 1 2 ⌊ 2 x ⌋ ⌉ {\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 − 1 2 ⌉ = ⌊ 1 2 ⌈ 2 x ⌉ ⌋ {\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 | + 1 2 ⌋ {\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 + 1 2 ⌋ + ⌈ 1 4 ( 2 x − 1 ) ⌉ − ⌊ 1 4 ( 2 x − 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 1 4 ( 2 x − 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 Δ {\displaystyle \Delta } can be expressed as

Q ( x ) = Δ ⋅ ⌊ x Δ + 1 2 ⌋ {\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

⌊ log b ⁡ k ⌋ + 1 = ⌈ log b ⁡ ( 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 by23[better source needed]

( n ) 0 + ⋯ + ( n ) n = ⌊ e n ! ⌋ {\displaystyle (n)_{0}+\cdots +(n)_{n}=\lfloor en!\rfloor }

where:

  • n > 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 formula24

⌊ n p ⌋ + ⌊ n p 2 ⌋ + ⌊ n p 3 ⌋ + ⋯ = n − ∑ k a k p − 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 = ∑ k a k p k {\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 > 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.25

Euler's constant (γ)

There are formulas for Euler's constant γ = 0.57721 56649 ... that involve the floor and ceiling, e.g.26

γ = ∫ 1 ∞ ( 1 ⌊ x ⌋ − 1 x ) d x , {\displaystyle \gamma =\int _{1}^{\infty }\left({1 \over \lfloor x\rfloor }-{1 \over x}\right)\,dx,} γ = lim n → ∞ 1 n ∑ k = 1 n ( ⌈ n k ⌉ − n k ) , {\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

γ = ∑ k = 2 ∞ ( − 1 ) k ⌊ log 2 ⁡ k ⌋ k = 1 2 − 1 3 + 2 ( 1 4 − 1 5 + 1 6 − 1 7 ) + 3 ( 1 8 − ⋯ − 1 15 ) + ⋯ {\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 (ζ)

The fractional part function also shows up in integral representations of the Riemann zeta function. It is straightforward to prove (using integration by parts)27 that if φ ( x ) {\displaystyle \varphi (x)} is any function with a continuous derivative in the closed interval [a, b],

∑ a < n ≤ b φ ( n ) = ∫ a b φ ( x ) d x + ∫ a b ( { x } − 1 2 ) φ ′ ( x ) d x + ( { a } − 1 2 ) φ ( a ) − ( { b } − 1 2 ) φ ( b ) . {\displaystyle \sum _{a<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 φ ( 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

ζ ( s ) = s ∫ 1 ∞ 1 2 − { x } x s + 1 d x + 1 s − 1 + 1 2 . {\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.28

For s = σ + it in the critical strip 0 < σ < 1,

ζ ( s ) = s ∫ − ∞ ∞ e − σ ω ( ⌊ e ω ⌋ − e ω ) e − i t ω d ω . {\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.29

Formulas for prime numbers

The floor function appears in several formulas characterizing prime numbers. For example, since ⌊ n m ⌋ − ⌊ n − 1 m ⌋ {\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 if30

∑ m = 1 ∞ ( ⌊ n m ⌋ − ⌊ n − 1 m ⌋ ) = 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 > 1, define the real number α by the sum

α = ∑ m = 1 ∞ p m r − m 2 . {\displaystyle \alpha =\sum _{m=1}^{\infty }p_{m}r^{-m^{2}}.}

Then31

p n = ⌊ r n 2 α ⌋ − r 2 n − 1 ⌊ r ( n − 1 ) 2 α ⌋ . {\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 θ = 1.3064... (Mills' constant) with the property that

⌊ θ 3 ⌋ , ⌊ θ 9 ⌋ , ⌊ θ 27 ⌋ , … {\displaystyle \left\lfloor \theta ^{3}\right\rfloor ,\left\lfloor \theta ^{9}\right\rfloor ,\left\lfloor \theta ^{27}\right\rfloor ,\dots }

are all prime.32

There is also a number ω = 1.9287800... with the property that

⌊ 2 ω ⌋ , ⌊ 2 2 ω ⌋ , ⌊ 2 2 2 ω ⌋ , … {\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.33

Let π(x) be the number of primes less than or equal to x. It is a straightforward deduction from Wilson's theorem that34

π ( n ) = ∑ j = 2 n ⌊ ( j − 1 ) ! + 1 j − ⌊ ( 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,35

π ( n ) = ∑ j = 2 n ⌊ 1 /   ∑ k = 2 j ⌊ ⌊ j k ⌋ k j ⌋ ⌋ . {\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.3637

Solved problems

Ramanujan submitted these problems to the Journal of the Indian Mathematical Society.38

If n is a positive integer, prove that

  1. ⌊ n 3 ⌋ + ⌊ n + 2 6 ⌋ + ⌊ n + 4 6 ⌋ = ⌊ n 2 ⌋ + ⌊ n + 3 6 ⌋ , {\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 ,}
  2. ⌊ 1 2 + n + 1 2 ⌋ = ⌊ 1 2 + n + 1 4 ⌋ , {\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 ,}
  3. ⌊ n + n + 1 ⌋ = ⌊ 4 n + 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.39

Unsolved problem

The study of Waring's problem has led to an unsolved problem:

Are there any positive integers k ≥ 6 such that40

3 k − 2 k ⌊ ( 3 2 ) k ⌋ > 2 k − ⌊ ( 3 2 ) k ⌋ − 2   ? {\displaystyle 3^{k}-2^{k}{\Bigl \lfloor }{\bigl (}{\tfrac {3}{2}}{\bigr )}^{k}{\Bigr \rfloor }>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.41

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.

An arithmetic right-shift of a signed integer x {\displaystyle x} by n {\displaystyle n} is the same as ⌊ x / 2 n ⌋ {\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.

Many programming languages (including C, C++,4243 C#,4445 Java,4647 Julia,48 PHP,4950 R,51 and Python52) provide standard functions for floor and ceiling, usually called floor and ceil, or less commonly ceiling.53 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.54 ALGOL usesentier for floor.

In Microsoft Excel the function INT rounds down rather than toward zero,55 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.56 The OpenDocument file format, as used by OpenOffice.org, Libreoffice and others, INT57 and FLOOR both do floor, and FLOOR has a third argument to reproduce Excel's earlier behavior.58

See also

Citations

  • 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
Wikimedia Commons has media related to Floor and ceiling functions.

References

  1. Graham, Knuth, & Patashnik, Ch. 3.1

  2. 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 /wiki/ISBN_(identifier)

  3. Lemmermeyer, pp. 10, 23.

  4. e.g. Cassels, Hardy & Wright, and Ribenboim use Gauss's notation. Graham, Knuth & Patashnik, and Crandall & Pomerance use Iverson's.

  5. Iverson, p. 12.

  6. Higham, p. 25.

  7. Mathwords: Floor Function. http://www.mathwords.com/f/floor_function.htm

  8. Mathwords: Ceiling Function http://www.mathwords.com/c/ceiling_function.htm

  9. Graham, Knuth, & Patashnik, p. 70.

  10. "LaTeX News, Issue 28" (PDF; 379 KB). The LaTeX Project. April 2018. Retrieved 27 July 2024. https://www.latex-project.org/news/latex2e-news/ltnews28.pdf

  11. Graham, Knuth, & Patashink, Ch. 3

  12. Graham, Knuth, & Patashnik, p. 73

  13. Graham, Knuth, & Patashnik, p. 85

  14. Graham, Knuth, & Patashnik, p. 85 and Ex. 3.15

  15. Graham, Knuth, & Patashnik, Ex. 3.12

  16. Graham, Knuth, & Patashnik, p. 94.

  17. Graham, Knuth, & Patashnik, p. 94

  18. Graham, Knuth, & Patashnik, p. 71, apply theorem 3.10 with x/m as input and the division by n as function

  19. Titchmarsh, p. 15, Eq. 2.1.7

  20. Lemmermeyer, § 1.4, Ex. 1.32–1.33

  21. Hardy & Wright, §§ 6.11–6.13

  22. Lemmermeyer, p. 25

  23. OEIS sequence A000522 (Total number of arrangements of a set with n elements: a(n) = Sum_{k=0..n} n!/k!.) (See Formulas.) https://oeis.org/A000522

  24. Hardy & Wright, Th. 416

  25. Graham, Knuth, & Patashnik, pp. 77–78

  26. These formulas are from the Wikipedia article Euler's constant, which has many more. /wiki/Euler%E2%80%93Mascheroni_constant

  27. Titchmarsh, p. 13

  28. Titchmarsh, pp.14–15

  29. Crandall & Pomerance, p. 391

  30. 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 ∑ m = 1 ⌊ n ⌋ ( ⌊ n m ⌋ − ⌊ n − 1 m ⌋ ) = 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} .

  31. Hardy & Wright, § 22.3

  32. Ribenboim, p. 186

  33. Ribenboim, p. 186

  34. Ribenboim, p. 181

  35. Crandall & Pomerance, Ex. 1.4, p. 46

  36. 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 ... "

  37. 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."

  38. Ramanujan, Question 723, Papers p. 332

  39. Somu, Sai Teja; Kukla, Andrzej (2022). "On some generalizations to floor function identities of Ramanujan" (PDF). Integers. 22. arXiv:2109.03680. http://math.colgate.edu/~integers/w33/w33.pdf

  40. Hardy & Wright, p. 337

  41. Mahler, Kurt (1957). "On the fractional parts of the powers of a rational number II". Mathematika. 4 (2): 122–124. doi:10.1112/S0025579300001170. /wiki/Kurt_Mahler

  42. "C++ reference of floor function". Retrieved 5 December 2010. http://en.cppreference.com/w/cpp/numeric/math/floor

  43. "C++ reference of ceil function". Retrieved 5 December 2010. http://en.cppreference.com/w/cpp/numeric/math/ceil

  44. dotnet-bot. "Math.Floor Method (System)". docs.microsoft.com. Retrieved 28 November 2019. https://docs.microsoft.com/en-us/dotnet/api/system.math.floor

  45. dotnet-bot. "Math.Ceiling Method (System)". docs.microsoft.com. Retrieved 28 November 2019. https://docs.microsoft.com/en-us/dotnet/api/system.math.ceiling

  46. "Math (Java SE 9 & JDK 9 )". docs.oracle.com. Retrieved 20 November 2018. https://docs.oracle.com/javase/9/docs/api/java/lang/Math.html#floor-double-

  47. "Math (Java SE 9 & JDK 9 )". docs.oracle.com. Retrieved 20 November 2018. https://docs.oracle.com/javase/9/docs/api/java/lang/Math.html#ceil-double-

  48. "Math (Julia v1.10)". docs.julialang.org/en/v1/. Retrieved 4 September 2024. https://docs.julialang.org/en/v1/base/math/

  49. "PHP manual for ceil function". Retrieved 18 July 2013. http://php.net/manual/function.ceil.php

  50. "PHP manual for floor function". Retrieved 18 July 2013. http://php.net/manual/function.floor.php

  51. "R: Rounding of Numbers". https://stat.ethz.ch/R-manual/R-devel/library/base/html/Round.html

  52. "Python manual for math module". Retrieved 18 July 2013. https://docs.python.org/2/library/math.html

  53. Sullivan, p. 86.

  54. "Vocabulary". J Language. Retrieved 6 September 2011. http://www.jsoftware.com/help/dictionary/vocabul.htm

  55. "INT function". Retrieved 29 October 2021. https://support.microsoft.com/en-us/office/int-function-a6c4af9e-356d-4369-ab6a-cb1fd9d343ef

  56. "FLOOR function". Retrieved 29 October 2021. https://support.microsoft.com/en-us/office/floor-function-14bb497c-24f2-4e04-b327-b0b4de5a8886

  57. "Documentation/How Tos/Calc: INT function". Retrieved 29 October 2021. https://wiki.openoffice.org/wiki/Documentation/How_Tos/Calc:_INT_function

  58. "Documentation/How Tos/Calc: FLOOR function". Retrieved 29 October 2021. https://wiki.openoffice.org/wiki/Documentation/How_Tos/Calc:_FLOOR_function