Skip to main content

Automated Macroscopic Fabric and Orientation Analysis for ceramic sherds

Project description

AMFOrA (Automated Macroscopic Fabric and Orientation Analysis)

A Python package for automated quantitative analysis of ceramic sherd fabric from flatbed-scanner images — inclusion detection, void analysis, size and orientation measurements, and color characterization.

Built for archaeological and materials-science workflows that need reproducible, DPI-aware measurements across many sherds.

Features

  • Inclusion detection — Blob and contour-based detectors with a paste-anchored MAD-scaled pop gate that handles dense clusters, fine grains on uniform paste, and mottled tempers consistently.
  • Void analysis — Brightness-gated dark feature detection that separates pores from dark mineral inclusions.
  • Watershed cluster recovery — Dense touching grains are split into individual sub-grains rather than being counted as one lumpy contour.
  • Size and density metrics — Areas in cm², densities per cm², with the denominator computed over the actually-searched area (not the full sherd) so cross-sherd comparisons stay valid.
  • Orientation and color — Per-inclusion orientation distributions and CIELAB color summaries.
  • Batch processing — Run a whole folder of sherd scans into a single CSV via full_analysis.

Installation

pip install amfora

Or, to develop against the latest source:

git clone https://github.com/aleciaco/AMFOrA_public.git
cd AMFOrA_public
pip install -e .

PyPI project page: pypi.org/project/amfora

Dependencies

Python 3.10+, OpenCV, NumPy, pandas, matplotlib, SciPy, scikit-image, Pillow. All pulled in automatically by pip install.

Quickstart

import cv2
import amfora

# Load a raw scanned sherd image (background still present)
image = cv2.imread('sherd.jpg')

# One-call analysis: masking, blob + contour detection, color, orientation
results = amfora.analyze_single_sherd(image, scan_dpi=1200)

print(f"Blob inclusions: {results['blob_inclusion_count']}")
print(f"Contour inclusions: {results['contour_inclusion_count']}")
print(f"Inclusion density: {results['contour_inclusion_density_per_cm2']:.1f} per cm²")

For a batch of sherds in a folder:

df = amfora.full_analysis('path/to/sherd_scans/', scan_dpi=1200)
df.to_csv('results.csv')

See examples/ for working notebooks and docs/ for the full user guide.

Documentation

The Jupyter Book under docs/ builds locally with jupyter-book build docs/ and covers installation, quickstart, the user guide, full API reference, and tutorials. Online publishing via GitHub Pages is planned (link will go here once the site is live).

Core entry points

  • analyze_single_sherd(image, scan_dpi) — Mask + detect + measure a single sherd; returns a dict of metrics.
  • full_analysis(folder_path, scan_dpi) — Run analyze_single_sherd over a directory; returns a pandas DataFrame and writes CSV.
  • sherd_mask(image, scan_dpi) — GrabCut-based mask isolating the sherd from scanner background.
  • sherd_blobs(masked_image, scan_dpi) — SimpleBlobDetector with adaptive thresholds and paste-anchored pop gating.
  • contour_detection(masked_image, scan_dpi) — Contour-based detection with watershed cluster recovery and multigrain split.

Every function has a NumPy-style docstring with parameter and return-value details.

DPI and units

All measurements are DPI-aware. The default is scan_dpi=1200. Conversion factor is dpcm = scan_dpi * 0.3937; areas are returned in cm². Set scan_dpi to match your scanner.

Scientific applications

Designed for:

  • Quantitative petrographic analysis of ceramic fabrics
  • Inclusion size and shape distribution studies
  • Void analysis (organic burnout, shrinkage cracks)
  • Orientation analysis of elongated inclusions
  • Color characterization (paste, inclusion populations, core-periphery firing-atmosphere indicators)

Cross-fabric inclusion-density comparisons are limited by optical contrast: grains that share the matrix's color are invisible to scanning regardless of detection parameters. See analyze_single_sherd's docstring for the full discussion and the R08G/R08TC calibration data showing the ~2.3× density gap on bars sharing identical sand temper.

Contributing

Pull requests welcome — see CONTRIBUTING.md for development setup, code style, and PR guidelines. By participating you agree to the Code of Conduct.

Disclosure: use of generative AI tools

Parts of this package have been developed and refined with assistance from generative AI tools (Anthropic Claude, primarily for testing, repackaging in modern Python standards, docstring and documentation drafting, code review, and iterative tuning of detector parameters). All algorithmic design decisions, validation against real sherd data, and final acceptance of changes were performed by the human maintainer. As a solo archaeologist who knows Python, I had a glaring gap in my ability to actually format the github in the modern standard where it would be useful by other researchers, so I turned to Anthropic Claude to help format the documentation, make docstrings make enough sense for other users, write tests, and do linting/CI because I had never learned how to do that. If there are any issues with this content, please reach out or suggest better ways of maintaining it!

License

MIT License — see LICENSE.

Citation

If you use AMFOrA in published work, please cite:

Iacobucci, A. (2026). AMFOrA: Automated Macroscopic Fabric and Orientation Analysis for ceramic sherds (Version 1.0.0) [Computer software]. https://pypi.org/project/amfora/

A DOI / Zenodo archive will be added in a future release.

Support

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

amfora-1.0.1.tar.gz (108.4 kB view details)

Uploaded Source

Built Distribution

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

amfora-1.0.1-py3-none-any.whl (107.4 kB view details)

Uploaded Python 3

File details

Details for the file amfora-1.0.1.tar.gz.

File metadata

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

File hashes

Hashes for amfora-1.0.1.tar.gz
Algorithm Hash digest
SHA256 962de774ec247e1ba850a54f253b5d5c4bd22e06f5d021e7390c878ea6cf8a54
MD5 9dcc9341e4c864f14facbd57b617d20e
BLAKE2b-256 61405c1a0a26f1f43a678dcda2b8469ba0917348a53302e37119325c7b64e953

See more details on using hashes here.

Provenance

The following attestation bundles were made for amfora-1.0.1.tar.gz:

Publisher: publish.yml on aleciaco/AMFOrA_public

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

File details

Details for the file amfora-1.0.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for amfora-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 36de92bd29bd50335a49b5012363775bfa6a60a141126e3fa4a1ea2ca47fba17
MD5 6d08bdd43c096dfa4c972ed9607c61af
BLAKE2b-256 35596d9dfe43fc6367f820837052bafc6f3a1c805325ab3106bf037831ab7604

See more details on using hashes here.

Provenance

The following attestation bundles were made for amfora-1.0.1-py3-none-any.whl:

Publisher: publish.yml on aleciaco/AMFOrA_public

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