Medical-research-skills ctd-api
Accesses Comparative Toxicogenomics Database (CTD) for chemical, gene, disease, and pathway interaction data. Invoke when user needs to query CTD, retrieve toxicogenomics data, or investigate chemical-disease relationships.
git clone https://github.com/aipoch/medical-research-skills
T=$(mktemp -d) && git clone --depth=1 https://github.com/aipoch/medical-research-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/scientific-skills/Evidence Insight/ctd-api" ~/.claude/skills/aipoch-medical-research-skills-ctd-api && rm -rf "$T"
scientific-skills/Evidence Insight/ctd-api/SKILL.mdComparative Toxicogenomics Database (CTD) API
This skill allows you to query the Comparative Toxicogenomics Database (CTD) using the Batch Query API. You can retrieve curated and inferred associations between chemicals, diseases, genes, pathways, and phenotypes.
When to Use
- Use this skill when the request matches its documented task boundary.
- Use it when the user can provide the required inputs and expects a structured deliverable.
- Prefer this skill for repeatable, checklist-driven execution rather than open-ended brainstorming.
Key Features
- Scope-focused workflow aligned to: "Accesses Comparative Toxicogenomics Database (CTD) for chemical, gene, disease, and pathway interaction data. Invoke when user needs to query CTD, retrieve toxicogenomics data, or investigate chemical-disease relationships.".
- Packaged executable path(s):
.scripts/query_ctd.py - Reference material available in
for task-specific guidance.references/ - Structured execution path designed to keep outputs consistent and reviewable.
Dependencies
:Python
. Repository baseline for current packaged skills.3.10+
:Third-party packages
. Add pinned versions if this skill needs stricter environment control.not explicitly version-pinned in this skill package
Example Usage
cd "20260316/scientific-skills/Evidence Insight/ctd-api" python -m py_compile scripts/query_ctd.py python scripts/query_ctd.py --help
Example run plan:
- Confirm the user input, output path, and any required config values.
- Edit the in-file
block or documented parameters if the script uses fixed settings.CONFIG - Run
with the validated inputs.python scripts/query_ctd.py - Review the generated output and return the final artifact with any assumptions called out.
Implementation Details
- Execution model: validate the request, choose the packaged workflow, and produce a bounded deliverable.
- Input controls: confirm the source files, scope limits, output format, and acceptance criteria before running any script.
- Primary implementation surface:
.scripts/query_ctd.py - Reference guidance:
contains supporting rules, prompts, or checklists.references/ - Parameters to clarify first: input path, output path, scope filters, thresholds, and any domain-specific constraints.
- Output discipline: keep results reproducible, identify assumptions explicitly, and avoid undocumented side effects.
Capabilities
1. Batch Query
Retrieve data for a list of terms.
Script:
scripts/query_ctd.py
Usage:
python scripts/query_ctd.py --inputType <type> --inputTerms <term1> <term2> ... --report <report_type> [--format <format>]
Parameters:
:inputType
,chem
,disease
,gene
,go
,pathway
,phenotypereference
: List of identifiers (MeSH IDs, NCBI Gene IDs, etc.) or names.inputTerms
: The type of data to retrieve (e.g.,report
,genes_curated
). Seediseases_curated
for valid combinations.references/ctd_api_docs.md
:format
(default),json
,tsv
,csv
.xml
2. Direct Link Generation
To generate a URL for a specific entity (no script needed, just text generation):
- Chemical:
https://ctdbase.org/detail.go?type=chem&acc={ID} - Disease:
https://ctdbase.org/detail.go?type=disease&acc={ID} - Gene:
https://ctdbase.org/detail.go?type=gene&acc={ID} - GO Term:
https://ctdbase.org/detail.go?type=go&acc={ID} - Pathway:
https://ctdbase.org/detail.go?type=pathway&acc={ID}
Examples
Get curated genes associated with a chemical (e.g., Mercury):
python scripts/query_ctd.py --inputType chem --inputTerms "Mercury" --report genes_curated --format json
Get diseases associated with a gene (e.g., APP):
python scripts/query_ctd.py --inputType gene --inputTerms "APP" --report diseases_curated
References
See
references/ctd_api_docs.md for a complete list of valid inputType and report combinations.
When Not to Use
- Do not use this skill when the required source data, identifiers, files, or credentials are missing.
- Do not use this skill when the user asks for fabricated results, unsupported claims, or out-of-scope conclusions.
- Do not use this skill when a simpler direct answer is more appropriate than the documented workflow.
Required Inputs
- A clearly specified task goal aligned with the documented scope.
- All required files, identifiers, parameters, or environment variables before execution.
- Any domain constraints, formatting requirements, and expected output destination if applicable.
Recommended Workflow
- Validate the request against the skill boundary and confirm all required inputs are present.
- Select the documented execution path and prefer the simplest supported command or procedure.
- Produce the expected output using the documented file format, schema, or narrative structure.
- Run a final validation pass for completeness, consistency, and safety before returning the result.
Output Contract
- Return a structured deliverable that is directly usable without reformatting.
- If a file is produced, prefer a deterministic output name such as
unless the skill documentation defines a better convention.ctd_api_result.md - Include a short validation summary describing what was checked, what assumptions were made, and any remaining limitations.
Validation and Safety Rules
- Validate required inputs before execution and stop early when mandatory fields or files are missing.
- Do not fabricate measurements, references, findings, or conclusions that are not supported by the provided source material.
- Emit a clear warning when credentials, privacy constraints, safety boundaries, or unsupported requests affect the result.
- Keep the output safe, reproducible, and within the documented scope at all times.
Failure Handling
- If validation fails, explain the exact missing field, file, or parameter and show the minimum fix required.
- If an external dependency or script fails, surface the command path, likely cause, and the next recovery step.
- If partial output is returned, label it clearly and identify which checks could not be completed.
Quick Validation
Run this minimal verification path before full execution when possible:
python scripts/query_ctd.py --help
Expected output format:
Result file: ctd_api_result.md Validation summary: PASS/FAIL with brief notes Assumptions: explicit list if any