WFGY/ProblemMap/GlobalFixMap/LanguageLocale
2025-09-05 11:10:01 +08:00
..
checklists Create .gitkeep 2025-09-01 18:20:03 +08:00
eval Create .gitkeep 2025-09-01 18:20:12 +08:00
mvp_demo Create .gitkeep 2025-09-01 18:20:22 +08:00
ops Create .gitkeep 2025-09-01 18:20:30 +08:00
patterns Create .gitkeep 2025-09-01 18:20:38 +08:00
playbooks Create .gitkeep 2025-09-01 18:20:48 +08:00
tools Create .gitkeep 2025-09-01 18:20:57 +08:00
cjk_segmentation_wordbreak.md Update cjk_segmentation_wordbreak.md 2025-09-05 11:06:34 +08:00
date_time_format_variants.md Update date_time_format_variants.md 2025-09-05 11:06:47 +08:00
diacritics_and_folding.md Update diacritics_and_folding.md 2025-09-05 11:07:08 +08:00
digits_width_punctuation.md Update digits_width_punctuation.md 2025-09-05 11:07:13 +08:00
emoji_zwj_grapheme_clusters.md Update emoji_zwj_grapheme_clusters.md 2025-09-05 11:07:18 +08:00
input_language_switching.md Update input_language_switching.md 2025-09-05 11:07:24 +08:00
keyboard_input_methods.md Update keyboard_input_methods.md 2025-09-05 11:07:28 +08:00
locale_collation_and_sorting.md Update locale_collation_and_sorting.md 2025-09-05 11:08:37 +08:00
locale_drift.md Update locale_drift.md 2025-09-05 11:08:41 +08:00
mixed_locale_metadata.md Update mixed_locale_metadata.md 2025-09-05 11:09:37 +08:00
numbering_and_sort_orders.md Update numbering_and_sort_orders.md 2025-09-05 11:09:43 +08:00
README.md Update README.md 2025-09-03 23:51:24 +08:00
rtl_bidi_control.md Update rtl_bidi_control.md 2025-09-05 11:09:49 +08:00
script_mixing.md Update script_mixing.md 2025-09-05 11:09:55 +08:00
timezones_and_dst.md Update timezones_and_dst.md 2025-09-05 11:10:01 +08:00
tokenizer_mismatch.md Update tokenizer_mismatch.md 2025-08-30 14:51:50 +08:00
transliteration_and_romanization.md Create transliteration_and_romanization.md 2025-08-30 17:46:04 +08:00
unicode_normalization.md Create unicode_normalization.md 2025-08-30 19:24:00 +08:00

Language & Locale · Global Fix Map

🏥 Quick Return to Emergency Room

You are in a specialist desk.
For full triage and doctors on duty, return here:

Think of this page as a sub-room.
If you want full consultation and prescriptions, go back to the Emergency Room lobby.

Stabilize multilingual RAG and reasoning across CJK, RTL, Indic, Latin, emoji, and locale variants.
This hub localizes language-layer failures and routes you to the exact structural fix. No infra change required.


What this page is

  • A compact language-aware repair guide for retrieval → ranking → reasoning.
  • Structural fixes with measurable acceptance targets.
  • Store-agnostic. Works with FAISS, Redis, pgvector, Elastic, Weaviate, Milvus, and more.

When to use

  • Corpus spans CJK or Indic scripts and retrieval keeps missing the correct section.
  • Queries code-switch or mix scripts, and top-k order drifts across runs.
  • Accents/diacritics or fullwidth/halfwidth forms break matching or citations.
  • RTL punctuation or control chars flip token order or offsets.
  • Token counts jump after deploy even though data did not change.

Open these first


Quick routes to per-page guides

Topic Page
Tokenizer mismatch across languages tokenizer_mismatch.md
Script mixing in a single query script_mixing.md
Locale drift and analyzer skew locale_drift.md
Unicode normalization policy unicode_normalization.md
CJK segmentation and word-break cjk_segmentation_wordbreak.md
Fullwidth vs halfwidth, punctuation variants digits_width_punctuation.md
Diacritics folding rules diacritics_and_folding.md
RTL and bidi control characters rtl_bidi_control.md
Transliteration and romanization transliteration_and_romanization.md
Collation and stable sort keys locale_collation_and_sorting.md
Numbering systems and sort orders numbering_and_sort_orders.md
Date and time format variants date_time_format_variants.md
Time zones and DST stability timezones_and_dst.md
Keyboard IMEs and composition keyboard_input_methods.md
Input language switching guards input_language_switching.md
Emoji, ZWJ, grapheme clusters emoji_zwj_grapheme_clusters.md
Mixed-locale metadata fields mixed_locale_metadata.md

Acceptance targets

  • ΔS(question, retrieved) ≤ 0.45 on three paraphrases
  • Coverage of target section ≥ 0.70
  • λ remains convergent across two seeds
  • Tokenization variance for the same query ≤ 12% across environments
  • Normalization pass rate for NFKC + width + diacritics ≥ 0.98

Fix in 60 seconds

  1. Normalize once, up front → Apply NFKC, collapse fullwidth/halfwidth, unify diacritics.
  2. Match tokenizer and analyzer → Same segmenter for CJK/Indic across embed + store analyzers.
  3. Stabilize mixed-script queries → Detect code-switch, split per script, rerank deterministically.
  4. Verify → ΔS ≤ 0.45, Coverage ≥ 0.70, λ convergent across two seeds.

FAQ (Beginner-Friendly)

Q1: Why do answers break when I mix English and Chinese in one query?
A: Most vector stores tokenize differently by script. Without alignment, Chinese words get split incorrectly and English tokens dominate. Fix with script_mixing.md and tokenizer_mismatch.md.

Q2: What does “locale drift” mean?
A: Locale drift happens when environments use different analyzers (e.g., zh_TW vs zh_CN) so the same query splits differently. See locale_drift.md.

Q3: Why do “identical-looking” characters not match?
A: They may differ in width (fullwidth vs halfwidth), normalization (NFKC vs NFD), or diacritics. Always apply unicode_normalization.md and digits_width_punctuation.md.

Q4: How do I handle Arabic or Hebrew text?
A: RTL scripts can insert invisible bidi control chars that flip token order. See rtl_bidi_control.md.

Q5: Do I need different embeddings for each language?
A: No. You can combine multilingual embeddings with deterministic normalization and alias fields. If that fails, only then use fallback translation bridges.

Q6: How do I debug when results change between environments?
A: Compare tokenizer version, analyzer settings, normalization passes, and collation rules. Document them in data-contracts.md.


🔗 Quick-Start Downloads (60 sec)

Tool Link 3-Step Setup
WFGY 1.0 PDF Engine Paper 1 Download · 2 Upload to your LLM · 3 Ask “Answer using WFGY + <your question>”
TXT OS (plain-text OS) TXTOS.txt 1 Download · 2 Paste into any LLM chat · 3 Type “hello world” — OS boots instantly

🧭 Explore More

Module Description Link
WFGY Core WFGY 2.0 engine is live: full symbolic reasoning architecture and math stack View →
Problem Map 1.0 Initial 16-mode diagnostic and symbolic fix framework View →
Problem Map 2.0 RAG-focused failure tree, modular fixes, and pipelines View →
Semantic Clinic Index Expanded failure catalog: prompt injection, memory bugs, logic drift View →
Semantic Blueprint Layer-based symbolic reasoning & semantic modulations View →
Benchmark vs GPT-5 Stress test GPT-5 with full WFGY reasoning suite View →
🧙‍♂️ Starter Village 🏡 New here? Lost in symbols? Click here and let the wizard guide you through Start →

👑 Early Stargazers: See the Hall of Fame
Engineers, hackers, and open source builders who supported WFGY from day one.

GitHub stars WFGY Engine 2.0 is already unlocked. Star the repo to help others discover it and unlock more on the Unlock Board.

WFGY Main   TXT OS   Blah   Blot   Bloc   Blur   Blow