FiniteField[p,d]
gives a finite field with  elements.
 elements.
FiniteField[p,f]
gives the finite field  , where
, where  is an irreducible polynomial in
 is an irreducible polynomial in  .
.
FiniteField[p,…,rep]
uses field element representation rep, either "Polynomial" or "Exponential".
 
     
   FiniteField

FiniteField[p,d]
gives a finite field with  elements.
 elements.
FiniteField[p,f]
gives the finite field  , where
, where  is an irreducible polynomial in
 is an irreducible polynomial in  .
.
FiniteField[p,…,rep]
uses field element representation rep, either "Polynomial" or "Exponential".
Details
 
     
     
     
     
   - Finite fields are also known as Galois fields.
- Finite fields are used in algebraic computation, error-correcting codes, cryptography, combinatorics, algebraic geometry, number theory and finite geometry.
- A field  is an algebraic system with all four arithmetic operations +, -, * and ÷. A finite field is an algebraic system with all four arithmetic operations +, -, * and ÷. A finite field can have can have elements elements for some prime for some prime and positive integer and positive integer . .
- The  element element is the additive identity where is the additive identity where for all for all and the and the element element gives the multiplicative identity where gives the multiplicative identity where for all for all . .
- FiniteFieldElement[,k] or [k] can be used to get the  element element and is formatted as and is formatted as . . 
- FiniteFieldElement objects in the same field are automatically combined by arithmetic operations.
- Polynomial operations such as PolynomialGCD, Factor, Expand, PolynomialQuotientRemainder and Resultant can be used for polynomials with coefficients from a finite field. Together and Cancel can be used for rational functions with coefficients from a finite field.
- Linear algebra operations such as Det, Inverse, RowReduce, NullSpace, MatrixRank and LinearSolve can be used for matrices with entries from a finite field.
- Solve and Reduce can be used to solve systems of equations over finite fields.
- There are two different representations rep supported for FiniteField: "Polynomial" and "Exponential".
- The "Polynomial" representation is the analog of a Cartesian representation of complex numbers  , easy to add and subtract but slightly harder to multiply and divide. , easy to add and subtract but slightly harder to multiply and divide.
- Representation: It uses an irreducible polynomial  of degree d to identify the field with the quotient: of degree d to identify the field with the quotient:
 . .
- Each element  is represented as a polynomial is represented as a polynomial . Or you can think of it as a vector . Or you can think of it as a vector in the basis in the basis . .
- Enumeration: The elements are enumerated in reverse lexicographic order:
 , , ,…, ,…, ,…, ,…, 
- Operations: Let  and and ; then you have: ; then you have:
 and and 
- and  is reduced modulo is reduced modulo (PolynomialRemainder) to degree (PolynomialRemainder) to degree . . with with . . , and the multiplicative inverse , and the multiplicative inverse is computed using the extended polynomial GCD. Since is computed using the extended polynomial GCD. Since is irreducible, you have is irreducible, you have and hence from the extended polynomial GCD, you have and hence from the extended polynomial GCD, you have for some polynomials for some polynomials and and . By reducing modulo . By reducing modulo , you get , you get and hence you have and hence you have . .
- The "Exponential" representation is the analog of a polar representation of complex number  , easy to multiply and divide but slightly harder to add and subtract. , easy to multiply and divide but slightly harder to add and subtract.
- Representation: As in the "Polynomial" representation, it uses an irreducible polynomial  of degree d, but in this case of degree d, but in this case also needs to be primitive. Since also needs to be primitive. Since is primitive, the powers of is primitive, the powers of represent every element in represent every element in except except : :
- 
      
        
- This representation is also known as the cyclic group representation, since  is a cyclic group under multiplication. is a cyclic group under multiplication.
- Enumeration: The elements are enumerated using the power order:
 , , , , , …, , …, , …, , …, 
- Operations: Let  and and , then you have: , then you have:
![u *v=alpha^(TemplateBox[{{(, {i, +, j}, )}, {(, {q, -, 1}, )}}, Mod]) u *v=alpha^(TemplateBox[{{(, {i, +, j}, )}, {(, {q, -, 1}, )}}, Mod])](Files/FiniteField.en/74.png) and and 
- with the inversion  . For addition and subtraction, there is no simple rule that gives . For addition and subtraction, there is no simple rule that gives such that such that , and so that is stored in a lookup table that is linear in the field size , and so that is stored in a lookup table that is linear in the field size . This makes the operation fast at the cost of storing data. It also means that the "Exponential" representation is not suitable for large fields. . This makes the operation fast at the cost of storing data. It also means that the "Exponential" representation is not suitable for large fields.
- The practical difference between representations is:
- "Polynomial" takes no time to create, uses no extra memory, works for large fields but has slightly slower operations.
- "Exponential" takes some time to create, uses extra memory proportional to the size of the field, works for small fields but has slightly faster operations.
- Information[FiniteField[…], prop] gives the property prop of the finite field. The following properties can be specified:
- 
      
      "Characteristic" the characteristic p of the finite field "ExtensionDegree" the extension degree d of the finite field over  "FieldSize" the number of elements q=pd of the field "FieldIrreducible" the polynomial function f used to construct the field "ElementRepresentation" "Polynomial" or "Exponential" 
 
     Examples
open all close allBasic Examples (2)
Scope (13)
Representation and Properties (4)
Represent a finite field with characteristic  and extension degree
 and extension degree  :
:
Find the irreducible polynomial used to construct the field:
By default, the polynomial representation of field elements is used:
Find other properties of the field:
Field additive and multiplicative identity elements have indices  and
 and  :
:
Construct a finite field using a custom irreducible polynomial:
Verify that the polynomial is irreducible:
The field irreducible is equal to the specified polynomial modulo the field characteristic:
Construct a finite field that uses exponential representation of elements:
The polynomial used to represent the field is primitive:
Field additive and multiplicative identity elements have indices  and
 and  :
:
All nonzero elements of the field are powers of the element with index  :
:
Arithmetic (3)
Perform arithmetic operations in a finite field:
Rational powers work only with exponent denominators  and
 and  :
:
For some field elements, the square root may not exist:
Arithmetic operations treat integers as elements of the field:
Rational numbers need to be valid modulo the field characteristic:
 
        Use Element to decide which rational numbers can be identified with field elements:
For the purpose of comparison, rational numbers are identified with field elements:
Elements of different finite fields cannot be combined:
 
        Fields with same characteristic and field irreducible but different element representations are allowed:
Automorphisms and Embeddings (2)
Polynomials over Finite Fields (2)
Applications (8)
Implement an error-correcting code. The  Hamming code encodes a
 Hamming code encodes a  -bit message in an
-bit message in an  -bit sequence and is able to correct up to one error:
-bit sequence and is able to correct up to one error: 
Let  be a finite field with
 be a finite field with  elements using the exponential element representation, let
 elements using the exponential element representation, let  be the irreducible polynomial used to construct
 be the irreducible polynomial used to construct  , and let
, and let  be the generator of
 be the generator of  :
:
The encoded message is the coefficient list of  , where the coefficient list of
, where the coefficient list of  is the original message:
 is the original message:
Let  be the polynomial whose coefficient list is the received message:
 be the polynomial whose coefficient list is the received message:
If the received message contains no errors, then  , and hence
, and hence  :
:
If the received message contains one error in position  , then
, then  , and hence
, and hence  :
:
Check and correct the received message:
To decode the message, compute the coefficient list of  :
:
The decoded message is correct when the received message has no errors or one error:
Construct  orthogonal Latin squares of order
 orthogonal Latin squares of order  for any prime power
 for any prime power  . A Latin square of order
. A Latin square of order  is a
 is a  array such that each row and each column contains every element of a set of
 array such that each row and each column contains every element of a set of  elements exactly once. A pair of Latin squares is said to be orthogonal if the
 elements exactly once. A pair of Latin squares is said to be orthogonal if the  pairs formed by juxtaposing the two arrays are all distinct:
 pairs formed by juxtaposing the two arrays are all distinct:
Verify that all arrays are Latin squares:
Verify that all pairs of arrays are orthogonal:
A finite set  of integers is a Sidon set if the sums
 of integers is a Sidon set if the sums  for
 for  are all distinct. Construct a Sidon set of
 are all distinct. Construct a Sidon set of  integers in
 integers in  , for a prime power
, for a prime power  :
:
Verify that  is a Sidon set of length
 is a Sidon set of length  :
:
A de Bruijn sequence of order  for an alphabet with
 for an alphabet with  letters is a cyclic sequence
 letters is a cyclic sequence  of
 of  letters of the alphabet, such that every sequence of
 letters of the alphabet, such that every sequence of  letters appears exactly once as a subsequence of
 letters appears exactly once as a subsequence of  . Construct a de Bruijn sequence of order
. Construct a de Bruijn sequence of order  for an alphabet with
 for an alphabet with  letters, for a prime power
 letters, for a prime power  :
:
Verify that  is a de Bruijn sequence of order
 is a de Bruijn sequence of order  for an alphabet with
 for an alphabet with  letters:
 letters:
An  matrix
 matrix  is a Hadamard matrix if all entries of
 is a Hadamard matrix if all entries of  are
 are  or
 or  and
 and ![H.TemplateBox[{H}, Transpose]=n I_n H.TemplateBox[{H}, Transpose]=n I_n](Files/FiniteField.en/152.png) . Construct a Hadamard matrix of order
. Construct a Hadamard matrix of order  for any prime power
 for any prime power  with
 with ![TemplateBox[{{q, =, 3}, 4}, Mod] TemplateBox[{{q, =, 3}, 4}, Mod]](Files/FiniteField.en/155.png) :
:
Implement the Rijndael S-box step used in the Advanced Encryption Standard (AES) algorithm. The first part, called the Nyberg S-box, uses multiplicative inverse in  :
:
The second part involves an affine transformation over  :
:
The forward S-box is the composition of the two parts:
Compute the forward S-box table in the hexadecimal notation:
Define the inverse S-box transformation:
Compute the inverse S-box table in the hexadecimal notation:
Verify that the inverse S-box is the inverse of the forward S-box:
Implement a Diffie–Hellman public key cryptosystem with a 2049-bit prime:
Find a primitive element of the field  :
:
The first user chooses a private key  :
:
The public key consists of  ,
,  and
 and  :
:
To send a 2048-bit message  , the second user sends
, the second user sends  and
 and  :
:
The first user can recover  by computing
 by computing  :
:
Implement a digital signature scheme. Fix a prime  and find a primitive element
 and find a primitive element  of
 of  :
:
Pick a secret integer  and publish
 and publish  ,
,  and
 and  :
:
The signature for a message  is a pair
 is a pair  of positive integers less than
 of positive integers less than  such that
 such that  . Computing the signature requires the knowledge of the secret integer
. Computing the signature requires the knowledge of the secret integer  :
:
The signature can be verified using the publicly known information:
Properties & Relations (7)
A finite field with characteristic  and extension degree
 and extension degree  has
 has  elements:
 elements:
Elements of a finite field with characteristic  satisfy
 satisfy  :
:
Hence the mapping  is a field automorphism, known as FrobeniusAutomorphism:
 is a field automorphism, known as FrobeniusAutomorphism:
The field generator  is a root of the field irreducible:
 is a root of the field irreducible:
Use FrobeniusAutomorphism to find the remaining roots of  :
:
All elements of a finite field with  elements are roots of
 elements are roots of  :
:
Any irreducible polynomial of degree  over
 over  has
 has  roots in a field with
 roots in a field with  elements:
 elements:
Use IrreduciblePolynomialQ with Modulusp to verify irreducibility over  :
:
Use Factor with Extensionℱ to verify that f is a product of linear factors over ℱ:
Use FiniteField[p,1] to compute over the prime field  :
:
Compare with a result obtained using Mod:
Compare with a result obtained using the Modulus option:
Use ToFiniteField to convert integer coefficients to elements in the prime subfield of a finite field:
FromFiniteField converts the coefficients back to integers:
Convert the coefficients to finite field elements, with t used to represent the field generator:
Convert the finite field coefficients to polynomials in t, where t represents the field generator:
Related Guides
Text
Wolfram Research (2023), FiniteField, Wolfram Language function, https://reference.wolfram.com/language/ref/FiniteField.html (updated 2024).
CMS
Wolfram Language. 2023. "FiniteField." Wolfram Language & System Documentation Center. Wolfram Research. Last Modified 2024. https://reference.wolfram.com/language/ref/FiniteField.html.
APA
Wolfram Language. (2023). FiniteField. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/FiniteField.html
BibTeX
@misc{reference.wolfram_2025_finitefield, author="Wolfram Research", title="{FiniteField}", year="2024", howpublished="\url{https://reference.wolfram.com/language/ref/FiniteField.html}", note=[Accessed: 25-October-2025]}
BibLaTeX
@online{reference.wolfram_2025_finitefield, organization={Wolfram Research}, title={FiniteField}, year={2024}, url={https://reference.wolfram.com/language/ref/FiniteField.html}, note=[Accessed: 25-October-2025]}












