Metadata-Version: 2.4
Name: pypbee
Version: 1.2.0
Summary: Performance-Based Earthquake Engineering toolkit
Author-email: Angshuman Deb <angshuman311@gmail.com>
License-Expression: MIT
Project-URL: Homepage, https://github.com/angshuman311/PyPBEE
Requires-Python: <3.13,>=3.12
Description-Content-Type: text/markdown
License-File: LICENSE.md
Requires-Dist: numpy>=1.26
Requires-Dist: scipy<=1.15.3
Requires-Dist: matplotlib>=3.8.2
Requires-Dist: pygmm>=0.7.1
Requires-Dist: pathos>=0.3.4
Requires-Dist: pydoe3>=1.0.4
Requires-Dist: xlrd>=2.0.1
Requires-Dist: eqsig>=1.2.17
Requires-Dist: openpyxl>=3.1.5
Requires-Dist: python-benedict>=0.35.0
Requires-Dist: PyQt5<5.16,>=5.15
Requires-Dist: openseespy>=3.7
Provides-Extra: numba
Requires-Dist: numba>=0.61; extra == "numba"
Dynamic: license-file

# PyPBEE — Performance-Based Earthquake Engineering in Python
A modular, high-performance framework that lets researchers and engineers run the full Performance-Based Earthquake Engineering (PBEE) workflow — from site-specific seismic hazard analysis to demand, damage and (soon) loss hazard analysis — entirely in Python.

[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

---

## Key Capabilities
* **End-to-end PBEE pipeline**  
  Probabilistic Seismic Hazard Analysis (PSHA), Ground Motion Selection (GMS), Nonlinear Time-History Analysis (NLTHA), Probabilistic Seismic Demand Hazard Analysis (PSDemHA) and Probabilistic Seismic Damage Hazard Analysis (PSDamHA).  
* **Object-oriented core, plug-and-play extensions**  
  Clean template-method lifecycle (`setup → run → wrap_up`) and abstract entity classes (`IM`, `EDP`, `DS`, `Structure`) make it straightforward to add new intensity measures, demand parameters, fragilities, or analysis stages.  
* **Advanced Uncertainty Quantification**  
  Treat aleatory *and* epistemic sources (random FE parameters, parameter estimation uncertainty, model-form alternatives) with `MultivariateNataf`, `Mixture`, Latin Hypercube sampling, etc.  
* **Finite-element backends out of the box**  
  Adapters for **OpenSeesTcl** and **OpenSeesPy**; extendable to Abaqus, Ansys, …  
* **Scales from laptop to cluster**  
  Local multiprocessing via *pathos* or embarrassingly-parallel Slurm jobs on HPC/HTC systems.  
* **Built-in visualisation**  
  Hazard curves, conditional spectra, demand / damage hazard surfaces, deaggregation plots — all ready for publication.  


## PyPBEE Installation Guide
**Supported Python Versions:** 3.12

---

### Recommended: Create a Fresh Environment
It is **highly recommended** to install PyPBEE in a **new isolated environment**.

You can set up PyPBEE using **five primary installation routes**. The first four require [forking and cloning the PyPBEE repository](#forking-and-cloning-the-repository):

| Route | Platform | Tool | Description |
|--------|-----------|------|--------------|
| [1. Windows (venv)](#installing-on-windows-using-virtual-environment-venv-using-setup_venvbat) | Windows | Virtual environment (`venv`) | Uses `setup_venv.bat` to create and configure a venv automatically |
| [2. Windows (Conda)](#installing-on-windows-conda) | Windows | Conda | Uses the provided `environment.yml` to set up a Conda environment |
| [3. macOS (venv)](#installing-on-macos-using-virtual-environment-venv) | macOS | Virtual environment (`venv`) | Manual venv setup using `python3 -m venv` |
| [4. macOS (Conda)](#installing-on-macos-conda) | macOS | Conda | Uses the provided `environment.yml` to create a Conda environment |
| [5. PyPI](#installing-directly-from-pypi) | All | pip | Install directly from PyPI |




---

### Forking and Cloning the Repository

1. Install **Git** from [git-scm.com](https://git-scm.com/install/)
2. Go to [https://github.com/angshuman311/PyPBEE](https://github.com/angshuman311/PyPBEE) and click **Fork** (top-right corner)  
   This creates your own copy of the repository under your GitHub account.
3. Open **Git Bash** on Windows (or **Terminal** on macOS)
4. Navigate (`cd`) to the folder where you want the code to reside:
   ```
   cd path/to/your/projects
   ```
5. Clone **your fork** instead of the main repo:
   ```
   git clone https://github.com/<your-github-username>/PyPBEE
   ```

---

### Installing on Windows using virtual environment (venv): Using `setup_venv.bat`

1. Install **Python >=3.12, <3.13** from [python.org](https://www.python.org/downloads/)
2. Locate `setup_venv.bat` in your repository directory
3. Double-click `setup_venv.bat`
4. When prompted, browse to your `python.exe` location (from step 1)
5. The script will:
   - Create `venv\pypbee` inside the repository directory
   - Install all requirements from `requirements.txt`
6. Point your **IDE's Python interpreter** (for example, in VS Code, PyCharm, or Spyder) to the **`python.exe`** inside the **virtual environment** you just created (`venv\pypbee`)

---

### Installing on Windows (Conda)

1. Install the **Anaconda** distribution
2. Open **Anaconda Prompt**
3. Navigate to the cloned repository directory:
   ```
   cd path\to\your\PyPBEE
   ```
4. Create the environment from the provided file:
   ```
   conda env create -f environment.yml
   ```
5. Point your **IDE's Python interpreter** (e.g., in VS Code, PyCharm, or Spyder) to the **conda environment** you just created (`pypbee`)

---

### Installing on macOS using virtual environment (venv)

1. Install **Python ≥3.12, <3.13** from [python.org](https://www.python.org/downloads/)
2. Open **Terminal**
3. Navigate to your cloned repository directory:
   ```
   cd path/to/your/PyPBEE
   ```
4. Create a new virtual environment inside the repository directory:
   ```
   python3 -m venv venv/pypbee
   ```
5. Activate the environment:
   ```
   source venv/pypbee/bin/activate
   ```
6. Upgrade pip and install all required dependencies:
   ```
   python -m pip install --upgrade pip
   pip install -r requirements.txt
   ```
   **Note:** If you encounter issues when installing `numba` on macOS, use the alternate file:
   ```
   pip install -r requirements-no-numba.txt
   ```
7. Point your **IDE's Python interpreter** (for example, in VS Code, PyCharm, or Spyder) to the **`python`** binary inside the virtual environment you just created (`venv/pypbee/bin/python`)

---

### Installing on macOS (Conda)

1. Install the **Anaconda** distribution
2. Open **Terminal**
3. Navigate to the cloned repository directory:
   ```
   cd path/to/your/PyPBEE
   ```
4. Create the environment from the provided file:
   ```
   conda env create -f environment.yml
   ```
   **Note:** If installation errors related to `numba` occur, use the alternate environment file:
   ```
   conda env create -f environment-no-numba.yml
   ```
5. Activate the environment:
   ```
   conda activate pypbee
   ```
6. Point your **IDE's Python interpreter** (e.g., in VS Code, PyCharm, or Spyder) to the **conda environment** you just created (`pypbee`)

---

### Installing Directly from PyPI

PyPBEE is also available on **[PyPI](https://pypi.org/project/pypbee/)**.

> ⚠️ **Important:**  
> We **strongly recommend** installing PyPBEE inside a **new, isolated virtual environment** (using `venv`) or a **Conda environment**.  
> **Do not** install PyPBEE in your base Python or base Conda environment — this helps avoid version conflicts and dependency issues with other packages.


**Step 1: Install Python (or Anaconda)**

Before proceeding, ensure you have **Python 3.12 ≤ version < 3.13** installed.  
You can choose one of the two following options:

- Install **Python 3.12 ≤ version < 3.13** directly from [python.org/downloads](https://www.python.org/downloads/).  
  During installation on Windows, make sure to **check “Add Python to PATH.”**.  
  To create a new environment:
  1. Open a **terminal** (macOS/Linux) or **Command Prompt** (Windows).
  2. Navigate (`cd`) to the folder where you want to create the virtual environment — typically inside your project directory.  
   Example:
   ```
   cd path/to/your/project
   ```
  3. Create and activate the virtual environment:
   ```
   python -m venv pypbee-venv
   source pypbee-venv/bin/activate    # macOS/Linux
   pypbee-venv\Scripts\activate       # Windows
   ```

- Or install the **Anaconda distribution** (which includes Python and Conda).  
  When creating the environment later, Conda will automatically install the correct Python version **(>=3.12, <3.13)**.  
  To create a new environment, do this inside an **Anaconda Prompt** (Windows) or a **terminal** (macOS/Linux):
  ```
  conda create -n pypbee python=3.12.10
  conda activate pypbee
  ```


**Step 2: Install PyPBEE from PyPI**

Without Numba:
```
pip install pypbee
```

With Numba acceleration enabled:
```
pip install "pypbee[numba]"
```

---

## Verifying Installation

Run Python and import PyPBEE:
```python
import pypbee
print(pypbee.__version__)
```

If no errors appear, your environment is correctly set up.

## User Manual

The **PyPBEE User Manual (v2.0.0)** is now available and provides detailed, end-to-end documentation of the framework, including model definition, uncertainty handling, analysis workflows, and result interpretation.

The manual is located in the repository in the `docs` folder. You can also access it directly [here](docs/PyPBEE%20User%20Manual.pdf)


## Ground Motion Database Setup

The ground motions currently supported by PyPBEE have been prepackaged and are available as a zipped archive. 
It can be downloaded either from the [GitHub Releases page](https://github.com/angshuman311/PyPBEE/releases/tag/v1.1.0) or using
[Dropbox](https://www.dropbox.com/scl/fi/utdpchf06qtdu0swceu94/NGA_PEER_EQ_DB.zip?rlkey=t3p0434mvbcz13djlmlpsw9s1&st=96mig508&dl=0)

Please download and extract this archive using **7-Zip** (recommended for faster extraction), place the extracted directory in a **non-repository location**, and provide the path to that directory as `gm_database_dir_path` in `nltha.setup(...)`.

In its current state, PyPBEE operates with approximately **3,500 NGA-West2 records**. Support for automatically generating RSNs for selected records, downloading the corresponding ground motions, and programmatically adding them to the local database is under active development. This functionality will be documented and released in a future update.

- Original PEER Report: Ancheta, T. D., R. B. Darragh, J. P. Stewart, E. Seyhan, W. J. Silva, B. S.-J. Chiou, K. E. Wooddell, R. W. Graves, A. R. Kottke, D. M. Boore, T. Kishida, and J. L. Donahue. 2014. “NGA-West2 Database.” Earthquake Spectra, 30 (3): 989–1005. https://doi.org/10.1193/070913EQS197M.


- Database maintained by PEER: https://ngawest2.berkeley.edu/


## Conceptual PSEUDO code
```python
from pypbee.structure                               import OSB               # Ordinary Standard Bridge
from pypbee.avg_sa                                  import AvgSa
from pypbee.edp                                     import MaxColRebarStrain
from pypbee.ds                                      import DS
from pypbee.analysis                                import PrelimAnalysis, PSHA, GMS, NLTHA, PSDemHA, PSDamHA
from pypbee.utility                                 import Utility
from pypbee.pygmm_extension.boore_atkinson_2008     import BooreAtkinson2008
from pygmm.baker_jayaram_2008                       import calc_correls

# 1 ── define model‐params & site info ------------------------------------------------
# See files `osb_info_*.py` in `examples/Bridge_*/osb_info_*.py` for model_params and location_info definition
name = 'Bridge_A'
model_files_path = f'path/to/{name}'
model_params = Utility.import_attr_from_module(module_path=model_files_path, module_name=f"osb_info_{name}", attr='model_params')
location_info = Utility.import_attr_from_module(module_path=model_files_path, module_name=f"osb_info_{name}", attr='location_info')
local_python_path = '/path/to/PyPBEE/venv/pypbee/Scripts/python.exe'
model_work_dir_path = f'path/to/a/working/directory/for/results/data/storage/for/{name}'

# 2 ── create entities ---------------------------------------------------------------
structural_analysis_platform = OpenSeesPy(model_files_path, local_python_path)
osb         = OSB(name, location_info, model_files_path, model_work_dir_path, model_params, structural_analysis_platform)
im          = AvgSa(osb, gmm=BooreAtkinson2008, correl_func=calc_correls, define_range=['T_1_trans', 'T_1_trans'], range_multiplier=[1, 2.5])
edp_list    = [
                    MaxColRebarStrain(max_what='compression', frame_structure=osb, tag='1', recorder_file_storage='shared'),
                    MaxColRebarStrain(max_what='tension', frame_structure=osb, tag='2', recorder_file_storage='shared'),
                    MaxSpringDeformation(spring_type='shear_key', max_what='compression', frame_structure=osb, tag='4', recorder_file_storage='separate', normalize_with='D3')
              ]
ds_list     = [
                    DS(
                        edp=edp_list[0], predictor=lambda x: 0.004,
                        haz_req={'normalized_fragility_dist': lognorm(0.326, 0, 1.02),
                                'estimation_sample_size': 5},
                        ds_type='col_rebar_strain_damage'
                    )
                    DS(
                        edp=edp_list[1], predictor=lambda x: 0.03 + 700 * x[1] * x[2] / x[3] - 0.1 * x[8] / (x[4] * x[5]),
                        haz_req={'normalized_fragility_dist': lognorm(0.201, 0, 1.05),
                                'estimation_sample_size': 5},
                        ds_type='col_rebar_strain_damage'
                    )
                    DS(
                        edp=edp_list[2], predictor=lambda x: 1.0,
                        haz_req={'normalized_fragility_dist': lognorm(0.11, 0, 1.14),
                                'estimation_sample_size': 5},
                        ds_type='spring_deformation_damage',
                    )
              ]


# 3 ── assemble analyses -------------------------------------------------------------
pre         = PrelimAnalysis(osb, num_modes=8)
psha        = PSHA(im)
gms         = GMS(im)
nltha       = NLTHA(im, edp_list)
psdemha     = PSDemHA(edp_list, im)
psdamha     = PSDamHA(ds_list, im, sol_type='numerical')

# 4 ── run workflow ------------------------------------------------------------------
for a in (pre, psha, gms, nltha, psdemha, psdamha):
    a.setup(...)
    a.run(...)
    a.wrap_up(...)
```
Full, commented examples live in `scripts/examples`.

## Contributing
1. Fork this repository and clone your fork locally.   
2. Create a feature branch, make your changes (e.g., add a new `IM`, `EDP`, etc.), and push the branch to your fork.  
3. Open a pull request describing *what* you changed and *why* it’s useful.
4. Bug reports and feature requests are equally welcome — open a GitHub issue.

## Acknowledgements
Development supported by **Caltrans (65A0594, Task 2880)**, **PEER Transportation Systems Research Program (Project #1147-NCTRTE)**, and the **Reissner Chair, UC San Diego**. HPC tests used TACC resources.

## License
This project is released under the [MIT License](LICENSE.md).
