Products
  • Wolfram|One

    The definitive Wolfram Language and notebook experience

  • Mathematica

    The original technical computing environment

  • Notebook Assistant + LLM Kit

    All-in-one AI assistance for your Wolfram experience

  • Compute Services
  • System Modeler
  • Finance Platform
  • Wolfram|Alpha Notebook Edition
  • Application Server
  • Enterprise Private Cloud
  • Wolfram Engine
  • Wolfram Player
  • Wolfram Cloud App
  • Wolfram Player App

More mobile apps

Core Technologies of Wolfram Products

  • Wolfram Language
  • Computable Data
  • Wolfram Notebooks
  • AI & Linguistic Understanding

Deployment Options

  • Wolfram Cloud
  • wolframscript
  • Wolfram Engine Community Edition
  • Wolfram LLM API
  • WSTPServer
  • Wolfram|Alpha APIs

From the Community

  • Function Repository
  • Community Paclet Repository
  • Example Repository
  • Neural Net Repository
  • Prompt Repository
  • Wolfram Demonstrations
  • Data Repository
  • Group & Organizational Licensing
  • All Products
Consulting & Solutions

We deliver solutions for the AI era—combining symbolic computation, data-driven insights and deep technical expertise

  • Data & Computational Intelligence
  • Model-Based Design
  • Algorithm Development
  • Wolfram|Alpha for Business
  • Blockchain Technology
  • Education Technology
  • Quantum Computation

Wolfram Consulting

Wolfram Solutions

  • Data Science
  • Artificial Intelligence
  • Biosciences
  • Healthcare Intelligence
  • Sustainable Energy
  • Control Systems
  • Enterprise Wolfram|Alpha
  • Blockchain Labs

More Wolfram Solutions

Wolfram Solutions For Education

  • Research Universities
  • Colleges & Teaching Universities
  • Junior & Community Colleges
  • High Schools
  • Educational Technology
  • Computer-Based Math

More Solutions for Education

  • Contact Us
Learning & Support

Get Started

  • Wolfram Language Introduction
  • Fast Intro for Programmers
  • Fast Intro for Math Students
  • Wolfram Language Documentation

More Learning

  • Highlighted Core Areas
  • Demonstrations
  • YouTube
  • Daily Study Groups
  • Wolfram Schools and Programs
  • Books

Grow Your Skills

  • Wolfram U

    Courses in computing, science, life and more

  • Community

    Learn, solve problems and share ideas.

  • Blog

    News, views and insights from Wolfram

  • Resources for

    Software Developers

Tech Support

  • Contact Us
  • Support FAQs
  • Support FAQs
  • Contact Us
Company
  • About Wolfram
  • Career Center
  • All Sites & Resources
  • Connect & Follow
  • Contact Us

Work with Us

  • Student Ambassador Initiative
  • Wolfram for Startups
  • Student Opportunities
  • Jobs Using Wolfram Language

Educational Programs for Adults

  • Summer School
  • Winter School

Educational Programs for Youth

  • Middle School Camp
  • High School Research Program
  • Computational Adventures

Read

  • Stephen Wolfram's Writings
  • Wolfram Blog
  • Wolfram Tech | Books
  • Wolfram Media
  • Complex Systems

Educational Resources

  • Wolfram MathWorld
  • Wolfram in STEM/STEAM
  • Wolfram Challenges
  • Wolfram Problem Generator

Wolfram Initiatives

  • Wolfram Science
  • Wolfram Foundation
  • History of Mathematics Project

Events

  • Stephen Wolfram Livestreams
  • Online & In-Person Events
  • Contact Us
  • Connect & Follow
Wolfram|Alpha
  • Your Account
  • User Portal
  • Wolfram Cloud
  • Products
    • Wolfram|One
    • Mathematica
    • Notebook Assistant + LLM Kit
    • Compute Services
    • System Modeler
    • Finance Platform
    • Wolfram|Alpha Notebook Edition
    • Application Server
    • Enterprise Private Cloud
    • Wolfram Engine
    • Wolfram Player
    • Wolfram Cloud App
    • Wolfram Player App

    More mobile apps

    • Core Technologies
      • Wolfram Language
      • Computable Data
      • Wolfram Notebooks
      • AI & Linguistic Understanding
    • Deployment Options
      • Wolfram Cloud
      • wolframscript
      • Wolfram Engine Community Edition
      • Wolfram LLM API
      • WSTPServer
      • Wolfram|Alpha APIs
    • From the Community
      • Function Repository
      • Community Paclet Repository
      • Example Repository
      • Neural Net Repository
      • Prompt Repository
      • Wolfram Demonstrations
      • Data Repository
    • Group & Organizational Licensing
    • All Products
  • Consulting & Solutions

    We deliver solutions for the AI era—combining symbolic computation, data-driven insights and deep technical expertise

    WolframConsulting.com

    Wolfram Solutions

    • Data Science
    • Artificial Intelligence
    • Biosciences
    • Healthcare Intelligence
    • Sustainable Energy
    • Control Systems
    • Enterprise Wolfram|Alpha
    • Blockchain Labs

    More Wolfram Solutions

    Wolfram Solutions For Education

    • Research Universities
    • Colleges & Teaching Universities
    • Junior & Community Colleges
    • High Schools
    • Educational Technology
    • Computer-Based Math

    More Solutions for Education

    • Contact Us
  • Learning & Support

    Get Started

    • Wolfram Language Introduction
    • Fast Intro for Programmers
    • Fast Intro for Math Students
    • Wolfram Language Documentation

    Grow Your Skills

    • Wolfram U

      Courses in computing, science, life and more

    • Community

      Learn, solve problems and share ideas.

    • Blog

      News, views and insights from Wolfram

    • Resources for

      Software Developers
    • Tech Support
      • Contact Us
      • Support FAQs
    • More Learning
      • Highlighted Core Areas
      • Demonstrations
      • YouTube
      • Daily Study Groups
      • Wolfram Schools and Programs
      • Books
    • Support FAQs
    • Contact Us
  • Company
    • About Wolfram
    • Career Center
    • All Sites & Resources
    • Connect & Follow
    • Contact Us

    Work with Us

    • Student Ambassador Initiative
    • Wolfram for Startups
    • Student Opportunities
    • Jobs Using Wolfram Language

    Educational Programs for Adults

    • Summer School
    • Winter School

    Educational Programs for Youth

    • Middle School Camp
    • High School Research Program
    • Computational Adventures

    Read

    • Stephen Wolfram's Writings
    • Wolfram Blog
    • Wolfram Tech | Books
    • Wolfram Media
    • Complex Systems
    • Educational Resources
      • Wolfram MathWorld
      • Wolfram in STEM/STEAM
      • Wolfram Challenges
      • Wolfram Problem Generator
    • Wolfram Initiatives
      • Wolfram Science
      • Wolfram Foundation
      • History of Mathematics Project
    • Events
      • Stephen Wolfram Livestreams
      • Online & In-Person Events
    • Contact Us
    • Connect & Follow
  • Wolfram|Alpha
  • Wolfram Cloud
  • Your Account
  • User Portal
Wolfram Language & System Documentation Center
HermiteDecomposition
  • See Also
    • HermiteReduce
    • SmithDecomposition
    • RowReduce
    • LatticeReduce
    • ExtendedGCD
  • Related Guides
    • Matrix Decompositions
    • Discrete & Integer Data
  • Tech Notes
    • Advanced Matrix Operations
    • See Also
      • HermiteReduce
      • SmithDecomposition
      • RowReduce
      • LatticeReduce
      • ExtendedGCD
    • Related Guides
      • Matrix Decompositions
      • Discrete & Integer Data
    • Tech Notes
      • Advanced Matrix Operations

HermiteDecomposition[m]

gives the Hermite normal form decomposition of an integer matrix m.

Details and Options
Details and Options Details and Options
Examples  
Basic Examples  
Scope  
Basic Uses  
Special Matrices  
Applications  
Properties & Relations  
See Also
Tech Notes
Related Guides
History
Cite this Page
BUILT-IN SYMBOL
  • See Also
    • HermiteReduce
    • SmithDecomposition
    • RowReduce
    • LatticeReduce
    • ExtendedGCD
  • Related Guides
    • Matrix Decompositions
    • Discrete & Integer Data
  • Tech Notes
    • Advanced Matrix Operations
    • See Also
      • HermiteReduce
      • SmithDecomposition
      • RowReduce
      • LatticeReduce
      • ExtendedGCD
    • Related Guides
      • Matrix Decompositions
      • Discrete & Integer Data
    • Tech Notes
      • Advanced Matrix Operations

HermiteDecomposition

HermiteDecomposition[m]

gives the Hermite normal form decomposition of an integer matrix m.

Details and Options

  • The result is given in the form {u,r} where u is a unimodular matrix, r is an upper triangular matrix, and u.m==r.
  • An integer matrix is unimodular if it has determinant of 1 or . This means it can be inverted over the integers, that is, without requiring fractions.

Examples

open all close all

Basic Examples  (1)

Decompose m into a unimodular matrix u and an upper triangular matrix r:

The determinant of u has absolute value 1:

Confirm the decomposition:

Scope  (12)

Basic Uses  (8)

Find the Hermite decomposition of an integer square matrix:

Format the result:

Hermite decomposition of a singular matrix:

The number of nonzero rows in r is equal to the rank of m:

Hermite decomposition for a rectangular matrix:

The square matrix u brings m into diagonal rectangular form:

Use HermiteDecomposition for a rational matrix:

Hermite decomposition for a Gaussian integer matrix:

Hermite decomposition for a Gaussian rational matrix m:

Hermite decomposition works only with rational matrices:

The Hermite decomposition for a large, integer matrix is computed efficiently:

Special Matrices  (4)

Find the Hermite decomposition for sparse matrices:

Hermite decompositions of structured matrices:

Hermite decomposition of an IdentityMatrix consists of two identity matrices:

Hermite decomposition of HilbertMatrix:

Applications  (3)

HermiteDecomposition can be used to determine if two integer lattices are equivalent. If the generators of the lattices are put in row matrices, the lattices are equal if and only if the matrices of the Hermite decompositions of the corresponding matrices are the same. Consider the lattices generated by , , and , , :

As the matrices of and are equal, the two sets of generators create the same lattice:

Confirm the result using LatticeReduce, which gives the same reduction up to overall sign:

Solve a linear Diophantine equation :

Form a homogenized system:

Rows of are integer combinations of rows of :

The second row of gives a solution of :

The last two rows of give a basis of solutions to the homogeneous equation :

Reduce uses HermiteDecomposition to solve linear Diophantine equations:

The Smith decomposition can often be found by two iterations of the Hermite decomposition:

The first use of HermiteDecomposition gives a unimodular matrix and an upper triangular matrix:

A second application, to TemplateBox[{{(, {r, _, 1}, )}}, Transpose], gives another unimodular matrix and a diagonal matrix:

Compare , and TemplateBox[{vt}, Transpose] with the result given by SmithDecomposition:

Properties & Relations  (9)

HermiteDecomposition gives a unimodular matrix and an upper triangular matrix:

The matrices satisfy the equation u.m==r:

Det of a unimodular matrix has absolute value 1:

Inverse of a unimodular integer matrix is an integer matrix:

For an matrix , the matrix of HermiteDecomposition[a] has the same dimensions:

The matrix as a square matrix:

The matrix always has integer values, irrespective of whether the input is integer or rational:

This extends to the real and imaginary parts of the result if the input matrix is complex:

The matrix has integer values if the input matrix is integer:

If the input matrix has noninteger rational elements, so will the matrix:

For a real-valued input, the entries of the matrix are non-negative:

For complex-valued input, the imaginary parts of the entries are non-negative:

The real parts can be negative:

Both HermiteDecomposition and QRDecomposition give unimodular and triangular matrices:

For HermiteDecomposition the decomposition is m=TemplateBox[{u}, Inverse].h and the matrices returned are integer:

For QRDecomposition the decomposition is m=TemplateBox[{q}, ConjugateTranspose].r and matrices returned can have any values:

Elements of form an upper triangular basis of the lattice generated by the rows of m:

The inverse of provides an explicit representation of rows of m in terms of the basis:

LatticeReduce gives a basis consisting of shorter vectors:

The second matrix in the Hermite decomposition is the Hermite normal form given by HermiteReduce:

HermiteDecomposition works over the Euclidean ring of the integers:

The entries above each pivot are always smaller in absolute value than that pivot:

The determinant of u must be 1 or , as these are the only invertible integers:

In contrast, PolynomialHermiteDecomposition works over the Euclidean ring of univariate polynomials:

Now the entries above each pivot are always lower in degree than that pivot:

The determinant of u2 must be a nonzero number, as these are exactly the invertible polynomials:

Note that integers and polynomials are different as rings, and in particular one does not recover anything resembling the integer Hermite decomposition by making the polynomial variable zero:

See Also

HermiteReduce  SmithDecomposition  RowReduce  LatticeReduce  ExtendedGCD

Function Repository: PolynomialHermiteDecomposition  SmallIntegerLinearSolve

Tech Notes

    ▪
  • Advanced Matrix Operations

Related Guides

    ▪
  • Matrix Decompositions
  • ▪
  • Discrete & Integer Data

History

Introduced in 2007 (6.0)

Wolfram Research (2007), HermiteDecomposition, Wolfram Language function, https://reference.wolfram.com/language/ref/HermiteDecomposition.html.

Text

Wolfram Research (2007), HermiteDecomposition, Wolfram Language function, https://reference.wolfram.com/language/ref/HermiteDecomposition.html.

CMS

Wolfram Language. 2007. "HermiteDecomposition." Wolfram Language & System Documentation Center. Wolfram Research. https://reference.wolfram.com/language/ref/HermiteDecomposition.html.

APA

Wolfram Language. (2007). HermiteDecomposition. Wolfram Language & System Documentation Center. Retrieved from https://reference.wolfram.com/language/ref/HermiteDecomposition.html

BibTeX

@misc{reference.wolfram_2025_hermitedecomposition, author="Wolfram Research", title="{HermiteDecomposition}", year="2007", howpublished="\url{https://reference.wolfram.com/language/ref/HermiteDecomposition.html}", note=[Accessed: 01-March-2026]}

BibLaTeX

@online{reference.wolfram_2025_hermitedecomposition, organization={Wolfram Research}, title={HermiteDecomposition}, year={2007}, url={https://reference.wolfram.com/language/ref/HermiteDecomposition.html}, note=[Accessed: 01-March-2026]}

Top
Introduction for Programmers
Introductory Book
Wolfram Function Repository | Wolfram Data Repository | Wolfram Data Drop | Wolfram Language Products
Top
  • Products
  • Wolfram|One
  • Mathematica
  • Notebook Assistant + LLM Kit
  • Compute Services
  • System Modeler

  • Wolfram|Alpha Notebook Edition
  • Wolfram|Alpha Pro
  • Mobile Apps

  • Wolfram Engine
  • Wolfram Player

  • Volume & Site Licensing
  • Server Deployment Options
  • Consulting
  • Wolfram Consulting
  • Repositories
  • Data Repository
  • Function Repository
  • Community Paclet Repository
  • Neural Net Repository
  • Prompt Repository

  • Wolfram Language Example Repository
  • Notebook Archive
  • Wolfram GitHub
  • Learning
  • Wolfram U
  • Wolfram Language Documentation
  • Webinars & Training
  • Educational Programs

  • Wolfram Language Introduction
  • Fast Introduction for Programmers
  • Fast Introduction for Math Students
  • Books

  • Wolfram Community
  • Wolfram Blog
  • Public Resources
  • Wolfram|Alpha
  • Wolfram Problem Generator
  • Wolfram Challenges

  • Computer-Based Math
  • Computational Thinking
  • Computational Adventures

  • Demonstrations Project
  • Wolfram Data Drop
  • MathWorld
  • Wolfram Science
  • Wolfram Media Publishing
  • Customer Resources
  • Store
  • Product Downloads
  • User Portal
  • Your Account
  • Organization Access

  • Support FAQ
  • Contact Support
  • Company
  • About Wolfram
  • Careers
  • Contact
  • Events
Wolfram Community Wolfram Blog
Legal & Privacy Policy
WolframAlpha.com | WolframCloud.com
© 2026 Wolfram
© 2026 Wolfram | Legal & Privacy Policy |
English