This is documentation for Mathematica 5, which was
based on an earlier version of the Wolfram Language.
View current documentation (Version 11.2)

Documentation / Mathematica / The Mathematica Book / Advanced Mathematics in Mathematica / Manipulating Equations and Inequalities /

3.4.7 Solving Logical Combinations of Equations

When you give a list of equations to Solve, it assumes that you want all the equations to be satisfied simultaneously. It is also possible to give Solve more complicated logical combinations of equations.

Solve assumes that the equations x + y == 1 and x - y == 2 are simultaneously valid.

In[1]:= Solve[{x + y == 1, x - y == 2}, {x, y}]


Here is an alternative form, using the logical connective && explicitly.

In[2]:= Solve[ x + y == 1 && x - y == 2, {x, y}]


This specifies that either x + y == 1 or x - y == 2. Solve gives two solutions for x, corresponding to these two possibilities.

In[3]:= Solve[ x + y == 1 || x - y == 2, x ]


Solve gives three solutions to this equation.

In[4]:= Solve[x^3 == x, x]


If you explicitly include the assertion that x != 0, one of the previous solutions is suppressed.

In[5]:= Solve[x^3 == x && x != 0, x]


Here is a slightly more complicated example. Note that the precedence of || is lower than the precedence of &&, so the equation is interpreted as (x^3 == x && x != 1) || x^2 == 2, not x^3 == x && (x != 1 || x^2 == 2).

In[6]:= Solve[x^3 == x && x != 1 || x^2 == 2 , x]


When you use Solve, the final results you get are in the form of transformation rules. If you use Reduce or Eliminate, on the other hand, then your results are logical statements, which you can manipulate further.

This gives a logical statement representing the solutions of the equation x^2 == x.

In[7]:= Reduce[x^2 == x, x]


This finds values of x which satisfy x^5 == x but do not satisfy the statement representing the solutions of x^2 == x.

In[8]:= Reduce[x^5 == x && !%, x]


The logical statements produced by Reduce can be thought of as representations of the solution set for your equations. The logical connectives &&, || and so on then correspond to operations on these sets.

Operations on solution sets.

You may often find it convenient to use special notations for logical connectives, as discussed in Section 3.10.4.

The input uses special notations for Implies and Or.

In[9]:= Reduce[x^2 == 1 Implies (x == 1 Or x == -1), x]