Skip to main content

PLS-SEM compute engine, a maintained fork of plspm-python with advanced analyses (PLSc, IPMA, PLSpredict, moderation, FIMIX-PLS, Gaussian-copula endogeneity, disjoint two-stage HOC, specific indirect effects) and extended metrics (SRMR, d_ULS, HTMT, HTMT2, Q², MGA, Cohen f², Fornell-Larcker, publication-ready Report) powering OpenPLS.

Project description

openpls engine

A modern, maintained Python engine for Partial Least Squares Structural Equation Modeling (PLS-SEM).

CI PyPI version Python versions License: GPL-3.0-or-later DOI Validation DOI

Documentation  ·  Quickstart  ·  API reference  ·  Changelog


openpls-engine is the compute core behind OpenPLS and a standalone PyPI package. It is a maintained fork of plspm-python by Jez Humble (Google), with the original algorithm kept intact and modern PLS-SEM reporting, advanced analyses, and two new inner-weighting schemes layered on top.

Status: stable as of 1.0.0. Public API follows semver. See CHANGELOG.md for the version history.

Install

pip install openpls-engine

Pin a specific version for reproducible analyses:

pip install openpls-engine==1.4.0

Or work from source:

git clone https://github.com/jojacobsen/openpls-engine.git
cd openpls-engine
python3 -m pip install -e .

Quickstart

import pandas as pd
from openpls import Plspm
import openpls.config as c
from openpls.scheme import Scheme
from openpls.mode import Mode

satisfaction = pd.read_csv("tests/data/satisfaction.csv", index_col=0)

structure = c.Structure()
structure.add_path(["IMAG"], ["EXPE", "SAT", "LOY"])
structure.add_path(["EXPE"], ["QUAL", "VAL", "SAT"])
structure.add_path(["QUAL"], ["VAL", "SAT"])
structure.add_path(["VAL"],  ["SAT"])
structure.add_path(["SAT"],  ["LOY"])

config = c.Config(structure.path(), scaled=False)
for lv in ["IMAG", "EXPE", "QUAL", "VAL", "SAT", "LOY"]:
    config.add_lv_with_columns_named(lv, Mode.A, satisfaction, lv.lower())

fit = Plspm(satisfaction, config, Scheme.CENTROID)
print(fit.inner_summary())
print(fit.path_coefficients())
print(fit.report().reliability())  # alpha, rho_A, rho_C, AVE

See the Quickstart guide for the full walkthrough.

What's inside

Quality criteria — HTMT and HTMT2 (geometric-mean refinement, Roemer et al. 2021), SRMR, d_ULS, Cronbach α, Dijkstra-Henseler ρ_A and ρ_C, adjusted R², BIC, Stone-Geisser Q² (blindfolding), Cohen f² effect sizes, Fornell-Larcker discriminant validity, per-indicator and per-predictor VIF, CTA-PLS (confirmatory tetrad analysis for reflective measurement).

Advanced analyses — PLSc (consistent-PLS bias correction, Dijkstra & Henseler 2015), Gaussian-copula endogeneity test (Park & Gupta 2012; Hult et al. 2018), disjoint two-stage higher-order constructs covering all four canonical types (R-R / R-F / F-R / F-F), IPMA (Importance-Performance Map Analysis), PLSpredict with the complete Shmueli et al. 2019 panel (RMSE / MAE / MAPE, in-sample + out-of-sample, PLS + LM benchmark), two-stage moderation, FIMIX-PLS finite-mixture segmentation, specific indirect effects with bootstrap percentile CIs, multi-group analysis with Henseler permutation tests.

Engine internals — five inner-weighting schemes (Centroid, Factorial, Path plus the new quasi-Newton/BFGS and Lohmöller PCA schemes), mean-replacement missing-value strategy alongside the upstream casewise default, long-running bootstrap with BCa percentile CIs and progress streaming, publication-ready Plspm.report() that bundles every reviewer-standard panel for one-call export.

Documentation

Full docs at openpls.app/engine:

  • Introduction — what the library does and who it is for.
  • Installation — pip and source installs.
  • Quickstart — end-to-end fit on the satisfaction dataset.
  • Core concepts — PLS-SEM, Mode A/B, inner-weighting schemes, missing-value strategies.
  • API reference — the full public surface.
  • Examples — runnable snippets for each advanced analysis.
  • Changelog — version history with per-feature notes.

Development

python3 -m venv .venv
source .venv/bin/activate
pip install -r requirements-dev.txt
pip install -e .

pytest          # run the test suite
ruff check .    # lint

CI runs lint and tests on Python 3.10 through 3.13 against every push and pull request against main.

Versioning

openpls-engine follows Semantic Versioning. The public API is stable as of 1.0.0. Tagged releases (vX.Y.Z) trigger a GitHub Actions workflow that builds the package and publishes it to PyPI via OIDC trusted publishing. The version is the single source of truth in pyproject.toml and is exposed at runtime as openpls.__version__. 1.0.0 renamed the import namespace from plspm to openpls; consumers upgrading from 0.7.x must rewrite their imports (see CHANGELOG → Breaking).

Cite

If you use openpls-engine in academic work, please cite the software via its Zenodo DOI and the validation dataset via 10.5281/zenodo.20511533. See CITATION.cff for the structured metadata.

License

GNU General Public License v3.0, see LICENSE. Inherited from upstream plspm-python (also GPL-3.0).

Attribution

This project is a fork of googlecloudplatform/plspm-python by Jez Humble. The upstream R package plspm by Gaston Sanchez and the seminr package by Soumya Ray and Nicholas Danks remain the conceptual references for the algorithm. See ATTRIBUTION.md for details.

OpenPLS is an independent project and not affiliated with Google.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

openpls_engine-1.4.0.tar.gz (120.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openpls_engine-1.4.0-py3-none-any.whl (109.0 kB view details)

Uploaded Python 3

File details

Details for the file openpls_engine-1.4.0.tar.gz.

File metadata

  • Download URL: openpls_engine-1.4.0.tar.gz
  • Upload date:
  • Size: 120.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for openpls_engine-1.4.0.tar.gz
Algorithm Hash digest
SHA256 0b490908a8702a4df8c9f970818916ea8822c1d62b00cda1a3604a849a9f8f27
MD5 f240c243ad652bc33dad5ea7c7b1a1df
BLAKE2b-256 c108231779390ff034946950b258ab0fd17358cfd051532f1bfb798e6fec7949

See more details on using hashes here.

Provenance

The following attestation bundles were made for openpls_engine-1.4.0.tar.gz:

Publisher: release.yml on jojacobsen/openpls-engine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openpls_engine-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: openpls_engine-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 109.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for openpls_engine-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 00fa827f6b374e51a9e44c41dd40db073fe0d901a41fd6c003ae34e89329ef65
MD5 c1e2e96f43beef008ed24dfd1f181d90
BLAKE2b-256 d16be425192dd65d8dd857397cc7d2abcb4c31e48309b8039849723a2ddb4001

See more details on using hashes here.

Provenance

The following attestation bundles were made for openpls_engine-1.4.0-py3-none-any.whl:

Publisher: release.yml on jojacobsen/openpls-engine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page