Skip to main content

Simple matplotlib and PGFPlots plotting with consistent, publication-ready styling

Project description

hmbp

A simple matplotlib wrapper with consistent, publication-ready styling.

Installation

pip install hmbp

Style

  • Font: Helvetica
  • Colormap: RdPu (primary), PiYG (secondary/diverging)
  • 400 DPI output
  • Consistent sizing: title 15pt, labels 14pt, ticks 13pt, legend 12pt

Usage

import hmbp

fig, ax = hmbp.new_figure()
hmbp.line_plot(y_values, x_values, label="Model A")
hmbp.set_labels("Title", "X Label", "Y Label")
hmbp.save("output.png")

Available Functions

Function Description
line_plot Line with optional fill and smoothing
multi_line_plot Multiple lines on same axes with smoothing
scatter_plot Scatter with optional color mapping
histogram Color-mapped histogram
histogram_overlay Overlaid histograms for comparison
bar_plot Vertical/horizontal bars
box_plot Box plot distributions
violin_plot Violin plot distributions
heatmap 2D heatmap with colorbar
line_plot_with_error Line with shaded error region
confusion_matrix Annotated confusion matrix
roc_curve ROC curve with AUC
precision_recall_curve PR curve with AP
residual_plot Regression residuals
learning_curve Train/val learning curves
metric_comparison Horizontal bar comparison
volcano_plot Volcano plot for differential analysis

Smoothing

Line plots support EMA smoothing for noisy data (e.g., training curves):

# smooth=0.9 means 90% weight on previous value (heavy smoothing)
hmbp.quick_line(noisy_loss, smooth=0.9, path="smoothed.png")
hmbp.quick_lines([y1, y2], labels=["A", "B"], smooth=0.8, path="comparison.png")

Helpers

  • new_figure(figsize) - Create figure and axes
  • set_labels(title, xlabel, ylabel) - Apply labels
  • save(path, fig, close) - Save with auto-legend

Quick API

Single-call functions that create, label, and save in one step:

import hmbp

hmbp.quick_histogram(data, title="Scores", xlabel="Value", path="hist.png")
hmbp.quick_bar(values, labels, title="Comparison", ylabel="F1", path="bars.png")
hmbp.quick_confusion_matrix(cm, class_names=["A", "B"], path="cm.png")

Available: quick_line, quick_lines, quick_scatter, quick_histogram, quick_histogram_overlay, quick_bar, quick_heatmap, quick_confusion_matrix, quick_roc, quick_volcano

PGFPlots Output

Generate LaTeX figures using PGFPlots for direct inclusion in papers:

import hmbp.pgfplots as pgf

# Step-by-step
pgf.new_figure()
pgf.line_plot(y, x=x, label="Data", marker="*")
pgf.set_labels(title="Results", xlabel="Time", ylabel="Value")
pgf.save("figure.tex")  # Creates .tex and .pdf

# Quick API
pgf.quick_bar(values, labels, title="Comparison", path="bars.tex")
pgf.quick_histogram(data, title="Distribution", path="hist.tex")

Features:

  • Outputs both .tex and compiled .pdf files
  • Helvetica font, clean axis styling, y-major grids
  • Supports line_plot, multi_line_plot, bar_plot, histogram
  • Log scale via new_figure(ymode='log')

Requires a LaTeX distribution with lualatex or pdflatex.

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

hmbp-0.2.1.tar.gz (19.9 kB view details)

Uploaded Source

Built Distribution

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

hmbp-0.2.1-py3-none-any.whl (16.2 kB view details)

Uploaded Python 3

File details

Details for the file hmbp-0.2.1.tar.gz.

File metadata

  • Download URL: hmbp-0.2.1.tar.gz
  • Upload date:
  • Size: 19.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hmbp-0.2.1.tar.gz
Algorithm Hash digest
SHA256 72eee564c42cfca59f71aee3d39ba286e1f423fff23e892cad8cb6032cf7178d
MD5 ffa2119b70a5ee086c12f1024acb2045
BLAKE2b-256 339c7c116bbe70c326d9ef70b3673f814b418a10aae3455abba4188cfe3b03d0

See more details on using hashes here.

Provenance

The following attestation bundles were made for hmbp-0.2.1.tar.gz:

Publisher: pypi.yml on hmblair/hmbp

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

File details

Details for the file hmbp-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: hmbp-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 16.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hmbp-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4493b7ecf58253ac9fcdac37259d59a259e99667aaccc794e6640223ae70490a
MD5 0b1bb91a5e13b3b08f7b91df75eb8076
BLAKE2b-256 429cbb5edcf06ed6bc3fe34acb0b5b3d7397a3236ae3ab280646e49c9cea06ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for hmbp-0.2.1-py3-none-any.whl:

Publisher: pypi.yml on hmblair/hmbp

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