Skip to main content

AMS Meta-Analysis Streamlit app by Anuraj Sudhakaran for R-backed evidence synthesis workflows.

Project description

AMS Meta-Analysis Streamlit App

Created by Anuraj Sudhakaran.

An installable Streamlit GUI for R-backed Python meta-analysis workflows, including workbook routing, pairwise analyses, diagnostic accuracy analyses, network meta-analysis, LLM-assisted study assessment, and in-app output review.

What It Runs

  • Workbook-level auto routing through the original main.py
  • Binary pairwise meta-analysis
  • Continuous pairwise meta-analysis
  • Single-arm proportion and mean meta-analysis
  • Diagnostic accuracy meta-analysis
  • Frequentist and Bayesian network meta-analysis
  • LM Studio model detection, with manual study-characteristic controls when LM Studio is not reachable
  • Ollama local model support at http://localhost:11434/v1, with hardware-aware model suggestions and CLI setup guidance when no local LLM is available

Install From PyPI

Use the PyPI package page:

https://pypi.org/project/ams-meta-analysis/

Install or upgrade the Python package:

python -m pip install --upgrade ams-meta_analysis

Install or repair the external R runtime and R packages:

meta-analysis-install-r --dry-run
meta-analysis-install-r --yes
meta-analysis-doctor

Launch the Streamlit GUI:

ams-meta_analysis

Example complete first-time setup:

python -m pip install --upgrade ams-meta_analysis
meta-analysis-install-r --yes
meta-analysis-doctor
ams-meta_analysis

If R is installed but Rscript is not on PATH, the app and command-line runner automatically try common R install locations and add the discovered Rscript folder to the current process and analysis runs. To add it permanently in your shell too, run the command shown by meta-analysis-doctor, for example:

export PATH="/Library/Frameworks/R.framework/Resources/bin:$PATH"

Images And Forest Plots

The PyPI package itself does not include study-specific screenshots or example forest plots because those are generated from the user's workbook. When an analysis produces images, the Streamlit app shows them in the Forest Plots viewer with previous/next controls and the selected image name. The same images are also saved in the selected output folder and included in the downloadable output zip.

Examples

Binary adverse events. Upload a sheet with study labels plus treatment and control event/total columns. Choose Binary pairwise or let the app assess the sheet, then run to generate summaries, forest plots, and logs.

Multi-outcome workbook. Upload an Excel workbook with sheets such as Adverse Events, Clinical Success, Reintervention, and Length of Stay. Choose Select all sheets with Auto route workbook so the app can route each outcome to the appropriate runner and collect outputs.

Subgroups and meta-regression. Use the GUI to select columns such as etiology, control type, study design, publication year, or sample size. Supported pairwise runners pass those choices into subgroup and meta-regression analyses.

Local model assistance. If neither LM Studio nor Ollama is available, the sidebar shows local setup guidance. The app suggests an Ollama model based on available hardware and shows the CLI commands to install Ollama and pull the model.

Updates

The Streamlit sidebar includes a Package updates panel. It checks PyPI for a newer ams-meta_analysis release and can run the upgrade command from inside the app. When an update is available, the panel also shows a short What's included list with the release highlights:

python -m pip install --upgrade ams-meta_analysis

After an in-app update, use the Restart Streamlit App button so the running process loads the new package files.

Local LLM Options

The app first checks LM Studio and Ollama. It only shows local install guidance when neither local provider is reachable. The sidebar estimates whether the machine has GPU support and suggests one Ollama model:

  • CPU-only or lower-memory systems: llama3.2:3b
  • GPU systems with typical memory: llama3.1:8b
  • Higher-memory GPU systems: qwen3:14b

Install and start Ollama from the command line, then pull the suggested model:

# macOS with Homebrew
brew install --cask ollama

# Linux
curl -fsSL https://ollama.com/install.sh | sh

# Windows
winget install Ollama.Ollama

ollama serve
ollama pull llama3.2:3b

Run the original workbook orchestrator from the installed package:

meta-analysis-runner "/path/to/workbook.xlsx" --yes

Check the local environment:

meta-analysis-doctor

Install or repair the external R runtime after pip install:

meta-analysis-install-r --dry-run
meta-analysis-install-r

If R is already installed outside PATH, meta-analysis-install-r uses the discovered absolute Rscript path automatically when installing R packages. When R is missing, the Streamlit sidebar also shows an Install R Runtime button that runs the same setup helper from inside the app.

External Requirements

Python dependencies are installed by pip, but the statistical analyses still need R and the R packages used by the original generated scripts. The package does not silently install system software during pip install; instead it installs a helper command that shows and runs the platform-specific R setup:

meta-analysis-install-r --dry-run
meta-analysis-install-r

If you prefer to manage R yourself, install R, make sure Rscript is on PATH, then install the common R packages:

packages <- c(
  "meta",
  "metafor",
  "readxl",
  "dplyr",
  "ggplot2",
  "netmeta",
  "gemtc",
  "rjags",
  "RTSA"
)
if (.Platform$OS.type == "windows") {
  options(install.packages.compile.from.source = "never")
  install.packages(packages, repos = "https://cloud.r-project.org", type = "binary")
} else {
  install.packages(packages, repos = "https://cloud.r-project.org")
}

On older Windows R installations, the binary install path avoids CRAN choosing newer source packages that can fail during compilation.

Bayesian network meta-analysis also needs JAGS installed on the system.

Trial sequential analysis can use the external TSA engine expected by the original code. If needed, point to it with:

export TSA_ANALYSIS_PY="/path/to/tsa_analysis.py"

LLM Provider Behavior

By default, the app checks http://localhost:1234/v1 for LM Studio. If LM Studio is not available, it can use OpenAI-compatible hosted APIs instead.

Supported GUI options:

  • LM Studio: http://localhost:1234/v1
  • OpenAI: https://api.openai.com/v1
  • Gemini through Google's OpenAI-compatible endpoint: https://generativelanguage.googleapis.com/v1beta/openai
  • Custom OpenAI-compatible endpoint
  • Manual/no LLM

The app auto-selects the first available option in this order: LM Studio, OPENAI_API_KEY, GEMINI_API_KEY or GOOGLE_API_KEY, META_ANALYSIS_LLM_API_KEY, then manual mode.

For command-line runs, hosted APIs can also be used with the original --lmstudio-url option because the packaged runners now support OpenAI-compatible authentication headers:

export META_ANALYSIS_LLM_API_KEY="$OPENAI_API_KEY"
meta-analysis-runner "/path/to/workbook.xlsx" \
  --lmstudio-url "https://api.openai.com/v1" \
  --model "your-model" \
  --yes

For Gemini:

export META_ANALYSIS_LLM_API_KEY="$GEMINI_API_KEY"
meta-analysis-runner "/path/to/workbook.xlsx" \
  --lmstudio-url "https://generativelanguage.googleapis.com/v1beta/openai" \
  --model "your-gemini-model" \
  --yes

When no provider is reachable, the GUI still works: it passes --no-lmstudio and asks you to choose basic study characteristics such as analysis route, binary effect size, single-arm outcome type, diagnostic mode, and network model settings.

Output Location

Uploaded workbooks and generated outputs are staged under:

~/.meta_analysis_streamlit/runs/

The app writes a run log and offers a zip download for completed outputs.

Development

Run the tests:

pytest

Build a wheel:

python3 -m build
python3 -m twine check dist/*

See PUBLISHING.md for PyPI release steps, including Trusted Publishing through GitHub Actions.

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

ams_meta_analysis-0.1.34.tar.gz (236.3 kB view details)

Uploaded Source

Built Distribution

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

ams_meta_analysis-0.1.34-py3-none-any.whl (236.7 kB view details)

Uploaded Python 3

File details

Details for the file ams_meta_analysis-0.1.34.tar.gz.

File metadata

  • Download URL: ams_meta_analysis-0.1.34.tar.gz
  • Upload date:
  • Size: 236.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for ams_meta_analysis-0.1.34.tar.gz
Algorithm Hash digest
SHA256 6ed024508e9ec88be9c4966d9c73eb9121bfb21999e83e5a6a96116ca3562ff5
MD5 d640bf1453c5d7e1330c83faa11aa5bc
BLAKE2b-256 face556eac134da42731f075b62d76d33e38d208a0496dd3594ad1ab64337c3f

See more details on using hashes here.

File details

Details for the file ams_meta_analysis-0.1.34-py3-none-any.whl.

File metadata

File hashes

Hashes for ams_meta_analysis-0.1.34-py3-none-any.whl
Algorithm Hash digest
SHA256 1901650a15509371ba25796a737edba0370b30a5e0ba223422101b1cb7859651
MD5 de9099e193e821647b00c0456f3ffd9e
BLAKE2b-256 61bdf576743724931f7286b99d26c573467772ed0cb2276777790636cdd3c453

See more details on using hashes here.

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