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.2.tar.gz (20.2 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.2-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: hmbp-0.2.2.tar.gz
  • Upload date:
  • Size: 20.2 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.2.tar.gz
Algorithm Hash digest
SHA256 996404808b2d070a8b40d0f8c925226b5ddd0267669e0ffd5ef595dea0af5b5d
MD5 5d759436084a3b873cf370acae6ff335
BLAKE2b-256 466b48a462cc176b5551db962460cdfc981ab4243cd48e7958c56f0089b383b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for hmbp-0.2.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: hmbp-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 16.4 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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d1fa25f2658200ee491b395919347ecda3a50f076365e264bc3059cbf36a39fa
MD5 a0ddefa70e80e53684619d3c3c26b69b
BLAKE2b-256 835874bddaf10a6f080b7329c4c541ff7db08a5f651eecdf887905cc2de16e14

See more details on using hashes here.

Provenance

The following attestation bundles were made for hmbp-0.2.2-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