In [1]:

```
import proveit
# Prepare this notebook for defining the theorems of a theory:
%theorems_notebook # Keep this at the top following 'import proveit'.
from proveit import Lambda, Conditional
from proveit import f, x, A, B, fx
from proveit.logic import Forall, Equals, InSet
from proveit.logic.sets import Functions
```

In [2]:

```
%begin theorems
```

In [3]:

```
membership_unfolding = Forall(
(A, B), Forall(f, Forall(x, InSet(fx, B), domain=A),
domain=Functions(A, B)))
```

In [4]:

```
membership_folding = Forall(
(A, B), Forall(f, InSet(f, Functions(A, B)),
condition=Forall(x, InSet(fx, B), domain=A)))
```

In [5]:

```
elim_domain_condition = Forall(
(A, B), Forall(f, InSet(f, Functions(A, B)),
condition=InSet(Lambda(x, Conditional(fx, InSet(x, A))),
Functions(A, B))))
```

In [6]:

```
%end theorems
```

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.