microscopy-scale-bar-adder

$npx mdskill add aipoch/medical-research-skills/microscopy-scale-bar-adder

Generate publication-ready scale bars for microscopy images using calibration data.

  • Converts pixel measurements to physical units for journal-quality figures.
  • Depends on Pillow for image processing and path traversal security.
  • Validates inputs against documented scope before executing image modifications.
  • Delivers structured results separating assumptions, deliverables, and risks.

SKILL.md

.github/skills/microscopy-scale-bar-adderView on GitHub ↗
---
name: microscopy-scale-bar-adder
description: Add accurate, publication-ready scale bars to microscopy images given pixel-to-unit calibration data.
license: MIT
author: aipoch
---
> **Source**: [https://github.com/aipoch/medical-research-skills](https://github.com/aipoch/medical-research-skills)
# Microscopy Scale Bar Adder

Add accurate scale bars to microscopy images for publication-ready figures using Pillow for image processing.

> ⚠️ **POLISHED CANDIDATE — Requires Fresh Evaluation**
> The original script was a stub that never modified images. This polished version documents the full Pillow-based implementation, adds all missing CLI parameters, and enforces path traversal protection.

## When to Use

- Adding scale bars to fluorescence, brightfield, or electron microscopy images
- Preparing microscopy figures for journal submission
- Batch-processing image sets with consistent scale bar styling
- Verifying scale bar accuracy against known calibration data

## Workflow

1. Confirm the user objective, required inputs, and non-negotiable constraints before doing detailed work.
2. Validate that the request matches the documented scope and stop early if the task would require unsupported assumptions.
3. Use the packaged script path or the documented reasoning path with only the inputs that are actually available.
4. Return a structured result that separates assumptions, deliverables, risks, and unresolved items.
5. If execution fails or inputs are incomplete, switch to the fallback path and state exactly what blocked full completion.

## Usage

```text
# Add a 50 µm scale bar to a TIFF image
python scripts/main.py --image image.tif --scale 50 --unit um

# Specify output path and bar position
python scripts/main.py --image image.tif --scale 10 --unit um --output annotated.tif --position bottomright

# Custom bar and label colors
python scripts/main.py --image image.tif --scale 100 --unit nm --bar-color white --label-color white --bar-thickness 4
```

## Parameters

| Parameter | Type | Required | Default | Description |
|-----------|------|----------|---------|-------------|
| `--image` | path | Yes | - | Input image file path |
| `--scale` | float | Yes | - | Scale bar length in physical units |
| `--unit` | str | No | `um` | Unit: `um`, `nm`, `mm` |
| `--pixels-per-unit` | float | No | from TIFF metadata | Calibration override (pixels per unit) |
| `--output` | path | No | `<input>_scalebar.<ext>` | Output file path |
| `--position` | str | No | `bottomright` | Bar position: `bottomright`, `bottomleft`, `topright`, `topleft` |
| `--bar-color` | str | No | `white` | Scale bar fill color |
| `--label-color` | str | No | `white` | Label text color |
| `--bar-thickness` | int | No | `3` | Bar height in pixels |

## Implementation Notes (for script developer)

The script must implement using `PIL.Image`, `PIL.ImageDraw`, `PIL.ImageFont`:

1. **Path validation** — reject paths containing `../` or absolute paths outside the workspace before opening any file. Print `Error: Path traversal detected: {path}` to stderr and exit with code 1.
2. **Image open** — `PIL.Image.open(args.image)`. Raise `FileNotFoundError` if missing.
3. **Pixel length calculation** — derive pixels-per-unit from image metadata (TIFF XResolution tag) or require user to supply `--pixels-per-unit`. Scale bar pixel length = `scale * pixels_per_unit`.
4. **Draw scale bar** — use `PIL.ImageDraw.Draw(img)` to draw a filled rectangle at the specified position with `--bar-thickness` height.
5. **Draw label** — use `PIL.ImageFont` to render `"{scale} {unit}"` above or below the bar.
6. **Save output** — `img.save(output_path)`. Print the output path to stdout.

## Features

- Automatic scale bar pixel length calculation from calibration metadata or user-supplied `--pixels-per-unit`
- Support for common microscopy formats: TIFF, PNG, JPG, BMP
- Configurable bar size, color, and label style (`--bar-color`, `--label-color`, `--bar-thickness`)
- Configurable position: `bottomright`, `bottomleft`, `topright`, `topleft`
- Preserves original image resolution and metadata
- Path traversal protection (rejects `../` paths and absolute paths outside workspace)

## Quick Check

```bash
python -m py_compile scripts/main.py
python scripts/main.py --help
```

## Input Validation

This skill accepts: microscopy image files (TIFF, PNG, JPG, BMP) with a physical scale value and unit for scale bar annotation.

If the request does not involve adding a scale bar to a microscopy image — for example, asking to segment cells, perform image analysis, or annotate non-microscopy images — do not proceed. Instead respond:

> "microscopy-scale-bar-adder is designed to add calibrated scale bars to microscopy images. Your request appears to be outside this scope. Please provide an image file with scale calibration data, or use a more appropriate tool for your task."

## Error Handling

- If `--image` or `--scale` is missing, state exactly which fields are missing and request only those.
- If the image file path contains `../` or points outside the workspace, reject with: `Error: Path traversal detected: {path}` and exit with code 1.
- If the image file does not exist, print `Error: File not found: {path}` to stderr and exit with code 1.
- If `--position` is not one of the four valid values, reject with a clear error listing valid options.
- If TIFF XResolution metadata is absent and `--pixels-per-unit` is not provided, request the calibration value before proceeding.
- If the task goes outside the documented scope, stop instead of guessing or silently widening the assignment.
- If `scripts/main.py` fails, report the failure point and summarize what can still be completed.
- Do not fabricate scale values or calibration data.

## Fallback Template

When execution fails or inputs are incomplete, respond with this structure:

```
FALLBACK REPORT
───────────────────────────────────────
Objective      : [restate the goal]
Blocked by     : [exact missing input or error]
Partial result : [what can be completed without the missing input]
Next step      : [minimum action needed to unblock]
───────────────────────────────────────
```

## Response Template

1. Objective
2. Inputs Received
3. Assumptions
4. Workflow
5. Deliverable
6. Risks and Limits
7. Next Checks

## Prerequisites

Requires Pillow: `pip install Pillow`

More from aipoch/medical-research-skills

SkillDescription
3d-molecule-ray-tracerGenerate photorealistic rendering scripts for PyMOL and UCSF ChimeraX.
abstract-summarizerTransform lengthy academic papers into concise, structured 250-word abstracts.
abstract-trimmerPrecision editing tool that reduces abstract word count through intelligent compression techniques, maintaining scientific rigor while meeting strict journal and conference requirements.
academic-abstract-refinerRefines long medical academic texts into SCI-style unstructured Chinese and English abstracts; use when you need to condense drafts/reports/summaries into bilingual abstracts and generate Summary_Report.md.
academic-cv-generatorGenerate structured academic CVs from free-form Chinese/English text and export to Word (.docx). Use this skill when you are asked to organize, generate, or optimize an academic CV (e.g., publications/projects/awards) into a consistent, formatted document with uniform-colored section headers and optional bilingual output.
academic-highlight-generatorGenerates submission-ready Elsevier/SCI Highlights from manuscript text or extracted PDF/DOCX/TXT content. Use when a user needs 3-5 concise, evidence-grounded highlight bullets for a research paper, review, meta-analysis, case report, or bioinformatics manuscript.
academic-norm-reviewDetects content similarity, verifies standardized citations and abbreviations, and flags potential academic integrity risks; use it before submission, during academic writing QA, or for compliance reviews.
academic-poster-generatorComplete workflow for generating academic research posters from PDF literature; use when you need to extract paper content from PDFs and produce a LaTeX-based poster (beamerposter/tikzposter/baposter) with mandatory figure generation and a final rendered HTML deliverable.
acronym-unpackerIntelligent medical abbreviation disambiguation tool that resolves ambiguous acronyms using clinical context, specialty-specific knowledge, and document-level semantic analysis.
active-comparator-single-soc-faers-safety-comparisonGenerates complete FAERS pharmacovigilance study designs for multi-drug or class-level safety comparison inside one predefined SOC or AE family using active comparators, disproportionality analysis, subgroup characterization, and reviewer-facing evidence control.