In [1]:

```
import proveit
from proveit import A, B
from proveit.logic.booleans.conjunction import true_and_true
theory = proveit.Theory() # the theorem's theory
```

In [2]:

```
%proving and_if_both
```

In [3]:

```
AeqT = A.evaluation(assumptions=[A])
```

In [4]:

```
BeqT = B.evaluation(assumptions=[B])
```

In [5]:

```
true_and_true
```

In [6]:

```
AandT = AeqT.sub_left_side_into(true_and_true.inner_expr().operands[0],
auto_simplify=False)
```

In [7]:

```
AandB = BeqT.sub_left_side_into(AandT, assumptions=[A, B],
auto_simplify=False)
```

In [8]:

```
# To do this manually, execute AandB.generalize((A, B), conditions=[A, B]).
# But this can be figured out via automation.
%qed
```

Out[8]:

These web pages were generated on 2023-08-23 by Prove-It Beta Version 0.3, licensed under the GNU Public License by Sandia Corporation.

Presented proofs are not absolutely guaranteed. For assurance, it is important to check the structure of the statement being proven, independently verify the derivation steps, track dependencies, and ensure that employed axioms are valid and properly structured. Inconsistencies may exist, unknowingly, in this system.

This material is based upon work supported by the U.S. Department of Energy, Office of Science, Office of Advanced Scientific Computing Research, under the Quantum Computing Application Teams program. Sandia National Labs is managed and operated by National Technology and Engineering Solutions of Sandia, LLC, a subsidiary of Honeywell International, Inc., for the U.S. Dept. of Energy's NNSA under contract DE-NA0003525. The views expressed above do not necessarily represent the views of the DOE or the U.S. Government.

Please send questions/comments to: wwitzel@sandia.gov.