Maximal free expression

From HaskellWiki

A free expression which is as large as it can be in the sense that is not a proper subexpression of another free expression.

This is within the context of a given expression, and subexpressions are partially ordered with respect to containment, and have finite length, so there will always be maximal (but possibly not unique) free (sub-)expressions. Note that there is a subtle but important difference between the words maximal and maximum. An element x of a partially ordered set (S,) is called maximal if there is no yS such that xy, and it is called a maximum if yS,xy. If a maximum exists, it is unique, but there can be many maximal (but not maximum) elements.