A composable pipeline for brand name generation, evaluation, and availability checking
Project description
brand
A composable pipeline for brand name generation, evaluation, and availability checking.
Not just domain checking — a full brand naming workbench. Generate candidates, score them on phonetics, linguistics, and sound symbolism, filter by availability across platforms, and persist every intermediate result for inspection and branching.
To install:
pip install brand
pip install brand[phonetics] # adds BLICK, epitran, panphon
pip install brand[all] # everything including AI generation
Quick Start
Evaluate a single name:
import brand
result = brand.evaluate_name('figiri')
print(result['scores'])
# {'syllables': 3, 'stress_pattern': 'unknown', 'spelling_transparency': 0.88,
# 'sound_symbolism': {'profile': 'modern/sharp', ...}, 'novelty': 1.0, ...}
Pipelines
The core abstraction is a pipeline — a sequence of Generate, Score, and Filter stages that progressively enriches, scores, and narrows a set of candidate names.
Run a pre-configured template
results = brand.run_pipeline('tech_startup', names=['figiri', 'lumex', 'voxen'])
for candidate in results['candidates']:
print(f"{candidate['name']}: {candidate['scores']}")
Available templates:
| Template | Use case |
|---|---|
quick_screen |
Fast local-only checks. No network. Screen thousands in seconds. |
tech_startup |
.com + GitHub + full phonolinguistic battery |
python_package |
PyPI + GitHub + short name + keyboard distance |
consumer_global |
Cross-linguistic safety + trademark + .com mandatory |
developer_tool |
Short (4-6 chars), easy to type, PyPI + npm + GitHub |
ai_ml_product |
.ai TLD preferred, modern sound profile, high distinctiveness |
consultancy |
Professional tone, .com mandatory, company registration |
open_source |
GitHub + PyPI + npm, fun/memorable, less trademark concern |
youtube_channel |
YouTube availability, memorable, pronounceable |
full_audit |
Every scorer, every check. Thorough but expensive. |
Build a custom pipeline
from brand import Generate, Score, Filter, run_pipeline
results = run_pipeline([
Generate('cvcvcv_filtered'),
Score(['syllables', 'spelling_transparency', 'sound_symbolism', 'novelty']),
Filter(top_n=500, by='spelling_transparency'),
Score(['dns_com', 'dns_io']),
Filter(rules={'dns_com': True}),
Score(['whois_com']),
Filter(rules={'whois_com': True}),
Score(['github_org']),
])
print(f"{len(results['candidates'])} names survived the pipeline")
print(f"Artifacts saved to: {results['project_dir']}")
Every run persists intermediate artifacts to disk. You can resume from any stage, branch from any checkpoint, and inspect what happened at each step.
Registry
All components are discoverable:
import brand
# See what's available
list(brand.scorers) # ['syllables', 'phonotactic', 'dns_com', ...]
list(brand.generators) # ['cvcvcv', 'ai_suggest', 'morpheme_combiner', ...]
brand.list_templates() # ['tech_startup', 'python_package', ...]
# Inspect a scorer
brand.scorers['dns_com'].cost # 'cheap'
brand.scorers['dns_com'].requires_network # True
brand.scorers['whois_com'].latency # 'slow'
Register a custom scorer
@brand.scorers.register('my_vowel_ratio')
def my_vowel_ratio(name: str) -> float:
vowels = sum(1 for c in name.lower() if c in 'aeiouy')
return vowels / len(name)
# Now use it in a pipeline
results = brand.run_pipeline([
Generate('from_list', params={'names': ['alpha', 'beta', 'omega']}),
Score(['my_vowel_ratio', 'syllables']),
])
Generators
# CVCVCV combinatoric (371k+ candidates)
names = list(brand.generators['cvcvcv']())
# CVCVCV with few-uniques filter
names = list(brand.generators['cvcvcv_filtered']())
# Custom CV pattern
names = list(brand.generators['pattern'](pattern='CVCCV'))
# Morpheme combiner (portmanteau-style)
names = list(brand.generators['morpheme_combiner'](
prefixes=['lum', 'vox', 'syn'],
suffixes=['ify', 'io', 'ar'],
))
# AI-assisted (requires 'oa' package)
names = list(brand.generators['ai_suggest'](context='AI data tools'))
# From a file or list
names = list(brand.generators['from_list'](names=['alpha', 'beta']))
Scorers
Phonetic (local, fast)
syllables— syllable count via CMU dict or vowel heuristicstress_pattern— stress digits from ARPAbet (trochaic "10" is ideal)phonotactic— BLICK well-formedness (0 = perfect English phonotactics) [requiresbrand[phonetics]]articulatory_complexity— place-of-articulation transitions [requiresbrand[phonetics]]sound_symbolism— front/back vowel and voiceless/voiced ratios mapped to brand archetypes
Linguistic (local, fast)
novelty— word frequency inverse (1.0 = novel, 0.0 = very common)existing_word— collision with known English wordsspelling_transparency— grapheme-to-phoneme ambiguity scoresubstring_hazards— profanity substring scan
Linguistic (network)
cross_linguistic— word frequency in 11 languagesphonetic_neighbors— similar-sounding words via Datamuse API
Visual / Typing
letter_balance— ascender/descender/neutral proportionskeyboard_distance— mean QWERTY distance between consecutive lettersname_length— character count
Availability (network)
dns_com,dns_net,dns_org,dns_io,dns_ai,dns_co,dns_dev,dns_app— domain availabilitywhois_com— WHOIS verification (.com)github_org— GitHub organizationpypi— PyPI projectnpm— npm packageyoutube— YouTube channel
Name Availability Check (legacy API)
The original availability-checking API still works:
from brand import is_available_as
list(is_available_as)
# ['domain_name', 'github_org', 'npm_package', 'pypi_project', 'youtube_channel']
is_available_as.github_org('thorwhalen') # False
is_available_as.pypi_project('brand') # False
from brand import domain_name_is_available
domain_name_is_available('google') # False
AI-Assisted Workflows
Generate names with AI
from brand import ask_ai_to_generate_names
names = ask_ai_to_generate_names('AI-powered data visualization platform')
Analyze names with AI
from brand import ai_analyze_names
analysis = ai_analyze_names(['figiri', 'lumex', 'datavox'], context='data viz platform')
Claude Skills and Agents
When using this project with Claude Code, several skills and agents are available:
Skills (in .claude/skills/):
brand-evaluate— Structured name evaluation combining computed metrics + expert judgmentbrand-generate— Creative name generation using available generatorsbrand-pipeline-designer— Interactive pipeline design based on your specific needsbrand-research— Deep cross-linguistic, cultural, and competitive research on a name
Agents (in .claude/agents/):
brand-scout— Autonomous generate-evaluate-recommend cyclebrand-audit— Comprehensive risk/opportunity audit of existing namesbrand-pipeline-runner— Pipeline execution, monitoring, resumption, and comparison
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file brand-0.1.1.tar.gz.
File metadata
- Download URL: brand-0.1.1.tar.gz
- Upload date:
- Size: 32.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f4d5059ac0ee0cf136c75c6028855eddab65896321e338c90f3084cd28343cc2
|
|
| MD5 |
316a1df0a2c6872803c88ab0a8fdf7b7
|
|
| BLAKE2b-256 |
cf121ba513f6e703c08fb4f55cd4d7b3f46c80247ea3a26bb93b3af5c5e987da
|
File details
Details for the file brand-0.1.1-py3-none-any.whl.
File metadata
- Download URL: brand-0.1.1-py3-none-any.whl
- Upload date:
- Size: 41.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.2 {"installer":{"name":"uv","version":"0.11.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c978ba4d3f9945a63de875a47f0c89e8b40e079509021a06fd8f985c0154ce99
|
|
| MD5 |
426996b2a4333838bd2eefaf66e426fb
|
|
| BLAKE2b-256 |
27c108db5e7f87e97e088a4406df1bad52a3099b1b37674fee5b6c9f6f0c1e01
|