WOLFRAM

finds a minimal-length disjunctive normal form representation of expr.

BooleanMinimize[expr,form]

finds a minimal-length representation for expr in the specified form.

BooleanMinimize[expr,form,cond]

finds a minimal-length expression in the specified form that is equivalent to expr when cond is true.

Details and Options

  • BooleanMinimize[expr,form] always produces an expression equivalent to expr.
  • Available forms are:
  • "DNF","SOP"disjunctive normal form, sum of products
    "CNF","POS"conjunctive normal form, product of sums
    "ANF"algebraic normal form
    "NOR"two-level Nor and Not
    "NAND"two-level Nand and Not
    "AND"two-level And and Not
    "OR"two-level Or and Not
  • In general, there may be several minimal-length representations for a particular expression in a certain form. BooleanMinimize gives one of them.
  • BooleanMinimize supports a Method option that specifies the detailed method to use.

Examples

open allclose all

Basic Examples  (2)Summary of the most common use cases

Find the minimal disjunctive normal form:

Out[1]=1

A Boolean counting function in disjunctive normal form:

Out[1]=1

Find a minimal disjunctive normal form:

Out[2]=2

Scope  (2)Survey of the scope of standard use cases

A Boolean function of five variables represented in DNF:

Out[1]=1

Minimal-length DNF:

Out[2]=2
Out[3]=3

Minimal-length CNF:

Out[4]=4

Minimal-length NAND form:

Out[5]=5

Minimal-length NOR form:

Out[6]=6

Minimal-length ANF:

Out[7]=7

Show that all the forms are equivalent:

Out[8]=8

Minimize a Boolean function using a "care set" or condition:

Out[1]=1
Out[2]=2
Out[3]=3
Out[4]=4

The resulting forms are equivalent when cond is true:

Out[5]=5

They are not equivalent without the condition:

Out[6]=6

Typically the forms are longer without conditions:

Out[7]=7
Out[8]=8

Applications  (1)Sample problems that can be solved with this function

Distribution of Minimal Size  (1)

Compute the minimal DNF representation:

Plot the size as a function of index:

Out[3]=3

Get its distribution:

Out[4]=4

Compute the size for the first 1000 four-variable functions:

Out[6]=6
Out[7]=7

Properties & Relations  (4)Properties of the function, and connections to other functions

The output from BooleanMinimize is equivalent to its input:

Out[1]=1
Out[2]=2
Out[3]=3

The output from BooleanMinimize with condition is conditionally equivalent to its input:

Out[1]=1
Out[3]=3

The forms f and g are equivalent when cond is true:

Out[4]=4

They are not equivalent on their own:

Out[5]=5

The minimal lengths "DNF", "CNF", "NAND", or "NOR" are not unique:

Out[1]=1

BooleanMinimize will produce an expression of length 3:

Out[2]=2

Another equivalent expression of length 3 is given by exchanging b and c:

Out[3]=3
Out[4]=4

Similar examples for "CNF", "NAND", and "NOR":

Out[5]=5
Out[6]=6
Out[7]=7

Use BooleanConvert when the minimal length form is not required:

Out[1]=1
Out[2]=2

BooleanConvert can also convert to additional forms:

Out[3]=3
Wolfram Research (2008), BooleanMinimize, Wolfram Language function, https://reference.wolfram.com/language/ref/BooleanMinimize.html.
Wolfram Research (2008), BooleanMinimize, Wolfram Language function, https://reference.wolfram.com/language/ref/BooleanMinimize.html.

Text

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

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

CMS

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

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

APA

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

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

BibTeX

@misc{reference.wolfram_2024_booleanminimize, author="Wolfram Research", title="{BooleanMinimize}", year="2008", howpublished="\url{https://reference.wolfram.com/language/ref/BooleanMinimize.html}", note=[Accessed: 10-January-2025 ]}

@misc{reference.wolfram_2024_booleanminimize, author="Wolfram Research", title="{BooleanMinimize}", year="2008", howpublished="\url{https://reference.wolfram.com/language/ref/BooleanMinimize.html}", note=[Accessed: 10-January-2025 ]}

BibLaTeX

@online{reference.wolfram_2024_booleanminimize, organization={Wolfram Research}, title={BooleanMinimize}, year={2008}, url={https://reference.wolfram.com/language/ref/BooleanMinimize.html}, note=[Accessed: 10-January-2025 ]}

@online{reference.wolfram_2024_booleanminimize, organization={Wolfram Research}, title={BooleanMinimize}, year={2008}, url={https://reference.wolfram.com/language/ref/BooleanMinimize.html}, note=[Accessed: 10-January-2025 ]}