Metadata-Version: 2.1
Name: anatomy-graphdb
Version: 1.2.0
Summary: Canonical anatomy domain dataset and Neo4j graph builder.
Home-page: https://github.com/Freehily/stronger-domain-graphdb
License: MIT
Keywords: anatomy,neo4j,graphdb,fitness,domain-model
Author: Tom
Author-email: tomrfreeman3@gmail.com
Requires-Python: >=3.12,<4.0
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Scientific/Engineering :: Medical Science Apps.
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Provides-Extra: neo4j
Requires-Dist: neo4j (>=6.0.2,<7.0.0) ; extra == "neo4j"
Requires-Dist: pyyaml (>=6.0.3,<7.0.0)
Project-URL: Changelog, https://github.com/Freehily/stronger-domain-graphdb/blob/main/CHANGELOG.md
Project-URL: Documentation, https://github.com/Freehily/stronger-domain-graphdb#readme
Project-URL: Repository, https://github.com/Freehily/stronger-domain-graphdb
Description-Content-Type: text/markdown

# anatomy-graphdb

`anatomy-graphdb` is a Python package for loading, validating, and exporting a structured human anatomy graph from YAML configuration.

It provides:

- canonical anatomy config data under `config/`
- typed Python loaders and domain models in `anatomy_graphdb/`
- a CLI (`anatomy-graphdb`) for validation, catalog export, and Neo4j ingestion
- packaged overlay SVG assets (`anatomy_graphdb/assets/`)

## What You Can Do With It

- Validate cross-references across anatomy entities (muscles, heads, bones, nerves, arteries, actions)
- Load region-scoped or multi-region anatomy models in Python
- Export canonical catalog JSON for downstream systems
- Export Neo4j CSV artifacts or ingest directly via Bolt
- Refresh a Neo4j graph using Make against any running Neo4j instance

## Install

```bash
pip install anatomy-graphdb
```

With Neo4j ingestion support:

```bash
pip install "anatomy-graphdb[neo4j]"
```

For development:

```bash
poetry install
```

## Quick Start

### Python API

```python
from anatomy_graphdb.databases.anatomy.loader import AnatomyLoader
from anatomy_graphdb.domain import build_anatomy_model

loader = AnatomyLoader()
region = loader.load_region("chest")
model = build_anatomy_model(region)

print(model.region)
print(len(model.muscles))
```

### CLI

List regions:

```bash
poetry run anatomy-graphdb --list-regions
```

Validate all regions:

```bash
poetry run anatomy-graphdb --region all --validate-only
```

Export Neo4j CSV artifacts:

```bash
poetry run anatomy-graphdb --region all --output data/neo4j --validate
```

Export canonical catalog JSON:

```bash
poetry run anatomy-graphdb --export-catalog --region all --catalog-output data/catalog/anatomy_catalog.json
```

Direct Bolt ingestion (requires `neo4j` extra):

```bash
poetry run anatomy-graphdb --region all --mode bolt --validate
```

## Neo4j Refresh Workflow

Run an end-to-end graph refresh into a running Neo4j instance:

```bash
make neo4j-refresh REGION=all NEO4J_URI=bolt://localhost:7687 NEO4J_AUTH=neo4j/password
```

Override defaults if needed:

```bash
make neo4j-refresh REGION=chest NEO4J_URI=bolt://localhost:7688 NEO4J_AUTH=neo4j/password
```

## Assets

Packaged assets:

- manifest: `anatomy_graphdb/assets/overlay_manifest.json`
- SVG files: `anatomy_graphdb/assets/anatomy/*.svg`

Source SVG layout (referenced by `config/body/muscles.yaml` overlays):

- `svgs/front/muscles/*.svg`
- `svgs/rear/muscles/*.svg`
- templates: `svgs/front/front_template.svg`, `svgs/rear/rear_template.svg`

Frontend muscle overlay flow:

```bash
poetry run anatomy-graphdb --export-catalog --region all --catalog-output data/catalog/anatomy_catalog.json
```

Use `muscle_overlays` and `muscle_groups` from the catalog JSON so a selected group
or muscle slug maps directly to one or more SVG overlay paths.

## Development

Run tests:

```bash
poetry run pytest
```

## Docs

- API stability: `docs/API_STABILITY.md`
- Changelog: `CHANGELOG.md`
- Releasing: `docs/RELEASING.md`
- Asset attribution: `docs/ASSET_ATTRIBUTION.md`

## Package Metadata

- Distribution: `anatomy-graphdb`
- Import namespace: `anatomy_graphdb`
- Python: 3.12+
- License: MIT

