<div align="center">
<h1 align="center">
  <img width="45" alt="PEPflow logo" src="docs/assets/pepflow-logo.svg">
  PEPFlow: Performance <br />  Estimation Problem Workflow
</h1>

[![CI](https://github.com/pepflow-lib/pepflow/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/pepflow-lib/pepflow/actions/workflows/ci.yml)
[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
[![Pypi](https://img.shields.io/pypi/v/pepflow.svg?logo=python&logoColor=white&label=PyPI&color=fcbc2c)](https://pypi.org/project/pepflow/)
[![Documentation](https://github.com/pepflow-lib/pepflow/actions/workflows/deploy-docs.yml/badge.svg?branch=main)](https://pepflow-lib.github.io/PEPFlow/)

</div>

<span style="color:#6B4497; font-weight:bold">PEPFlow</span> builds on the Performance Estimation Problem (PEP) framework, a powerful approach for analyzing the convergence of optimization algorithms. PEP formulates performance guarantees of an algorithm into tractable optimization problems and helps provide analytical proofs of convergence. <span style="color:#6B4497; font-weight:bold">PEPFlow</span> streamlines the entire PEP workflow:

1. Express the algorithm in a mathematical-like syntax
2. Formulate Primal/Dual PEP
3. Numerically verify convergence rate
4. Manipulate Primal/Dual PEP via interactive dashboard
5. Find analytical proofs using PEPFlow and SymPy symbolic engine jointly
6. Verify analytical proofs using PEPFlow and SymPy symbolic engine jointly

<span style="color:#6B4497; font-weight:bold">PEPFlow</span> offers the following key features for building a systematic and interactive <span style="color:red; font-weight:bold">workflow</span>

- Automated process for setting up and solving Primal/Dual PEPs;
- Interactive dashboard to explore and search exact relaxations of Primal PEPs;
- Interactive dashboard to numerically verify dual variable values of Dual PEPs;
- Direct access to key mathematical objects for deriving and verifying analytical proofs in symbols.

## Example and Tutorials

Please visit our [document website](https://pepflow-lib.github.io/PEPFlow/tutorial.html) to explore more features in PEPFlow

- [QuickStart](https://pepflow-lib.github.io/PEPFlow/quickstart.html)
- [Tutorials](https://pepflow-lib.github.io/PEPFlow/tutorial.html)
- [Encyclopedia](https://pepflow-lib.github.io/PEPFlow/encyclopedia.html)
  - [Gradient Descent Example](https://pepflow-lib.github.io/PEPFlow/examples/gd_example.html)
  - [Accelerated Gradient Method Example](https://pepflow-lib.github.io/PEPFlow/examples/agm_example.html)
  - [Proximal Gradient Method Example](https://pepflow-lib.github.io/PEPFlow/examples/pgm_example.html)
  - [Douglas–Rachford Splitting Method Example](https://pepflow-lib.github.io/PEPFlow/examples/drs_example.html)
  - and more

## <span style="color:#6B4497; font-weight:bold">Peppy</span> Workflow Guides

<span style="color:#6B4497; font-weight:bold">Peppy</span> is the AI-agent workflow for constructing <span style="color:#6B4497; font-weight:bold">PEPFlow</span>-based convergence proofs, from numerical PEP setup through dual certificate inspection, Lyapunov construction, and closed-form symbolic verification. The guides are available as Claude commands under `.claude/commands/` and as Codex plugin skills under `plugins/pepflow-workflows/`.

The main workflow blocks are:

- `pep-implement`: define the algorithm and run the initial PEP checks
- `pep-full-proof`: derive and inspect a full PEP-style dual certificate
- `lyap-define`: construct Lyapunov partial sums
- `lyap-vectors`: identify a compact vector basis
- `lyap-closed-form`: produce the final closed-form theorem and symbolic verification

## Installation

After downloading and unzipping the workshop submission, install <span style="color:#6B4497; font-weight:bold">PEPFlow</span> from the local source directory.

If you use `uv`, run:

On Windows PowerShell:

```powershell
cd Peppy
uv venv
.venv\Scripts\activate
uv pip install -e .
```

On macOS/Linux:

```bash
cd Peppy
uv venv
source .venv/bin/activate
uv pip install -e .
```

If you do not use `uv`, create and activate a virtual environment with your preferred Python tooling. For example, with Python's built-in `venv`:

On Windows PowerShell:

```powershell
cd Peppy
python -m venv .venv
.venv\Scripts\activate
pip install -e .
```

On macOS/Linux:

```bash
cd Peppy
python -m venv .venv
source .venv/bin/activate
pip install -e .
```

## Development Guide

We use `uv` to manage the packages and python environments. To start

```bash
uv sync; source .venv/bin/activate;
```

In windows, use `.venv\Scripts\activate` instead.

### Lint & Testing

We use `ruff` to do the formatting and linting and `isort` to do the import ordering.

```bash
ruff format;
ruff check .;
isort .;
```

We use `pytest` framework to do the test. To run all unit tests, run the following command:

```bash
pytest -s -vv pepflow
```

We have a convenient scripts to do the above

```bash
scripts/check.sh [format|lint|typecheck|test]
```

See the script for the options.

### Build doc website

Install the required library (one-time) and `pandoc` in order to build ipynb.

```bash
uv pip install -r docs/requirements.txt
```

To build the website, run

```bash
scripts/build_doc.sh [--serve-only]
```

The argument `--serve-only` is optional for hosting the website locally.

## Pre-Release Notice

This library is still in the pre-alpha phase. More information about the features and architecture of <span style="color:#6B4497; font-weight:bold">PEPFlow</span> is provided in our workshop paper, which is available on [OpenReview](https://openreview.net/forum?id=tJqsZZBmmB).
