Unicodeの互換文字
出典: フリー百科事典『ウィキペディア(Wikipedia)』
文字の種類 |
---|
字母やその他の |
UnicodeとUCSについて議論するとき、互換文字に言及することは多い。互換文字とは、ユニコードコンソーシアムが使わないことを推奨している図形文字である。具体的には、既存の文字コードとの往復変換のためだけに収録されたような文字のことである[1]。
しかし、定義は用語集に表れているものよりも複雑である。ユニコードコンソーシアムが文字に与えているプロパティの1つとして、文字の分解や互換分解がある。ほとんどの文字はこのプロパティに値を持たないが、5千を超える文字に互換文字から1つかそれ以上の他の文字へ互換分解がある。Unicodeは分解プロパティを設定されている文字が互換文字であると定めている。これらの互換性を指示することの理由はさまざまであり、詳細は後述する。文字は1文字に「分解」される場合もあるので、分解という用語は混乱を招くことがある。この場合、1文字の分解は単に等価な (もしくはおおむね等価な) 別の文字への置き換えである。
この項目には、一部のコンピュータや一部の閲覧ソフトで表示できない文字が含まれています(詳細)。 |
目次 |
[編集] 正規と非正規
5,402種類のUnicode互換文字の互換分解プロパティには、互換文字を17の論理的なグループに分けるキーワードが含まれている。キーワードのないものは正規等価な (英語:canonical equivalent) もしくは正規分解可能な文字という用語で呼ばれる。これらの文字は最も近い関係を持つ。他のキーワードは以下のとおりである: <initial>、<medial>、<final>、<isolated>、<wide>、<narrow>、<small>、<square>、<vertical>、<circle>、<noBreak>、<fraction>、<subscript>、<superscript>、<compat>。これらのキーワードは、互換文字とその互換分解文字の並びとの間に存在する関係を暗示する。しかし、互換文字は — 正規であるかどうかを問わず — 3つの基本的なカテゴリに分けられる:
- 複数の代替字形に対応する文字と合成済みのダイアクリティカルマーク。完全なUnicodeのテキスト描画処理に対応していないソフトウェアやフォントの実装をサポートするためもの。
- 他の文字コードから収録された文字。さもなければUnicodeの目的であるプレーンテキストよりむしろリッチテキストの構成要素としてUCSに追加されたもの。
- その他の意味的には異なるが、視覚的には似ている文字。
これらの意味的に異なる文字は他の文字のグリフと似たグリフで表示されることがあるので、テキスト処理ソフトウェアは起こりうる混乱を解決するようエンドユーザーのために努力すべきである。テキスト文字列の比較や照合 (並べ替え) を行うとき、異なる字形や文字のリッチテキスト版がテキスト処理の結果を変えるべきではない。たとえば、ソフトウェアの利用者は大文字のラテン文字‘I’をページ上で検索したときに、そのソフトウェアが視覚的に類似したローマ数字の‘Ⅰ’を見つけられなかったら混乱するかもしれない。
[編集] 互換マッピングの種類
[編集] グリフの置換と合成
互換文字の中には、テキスト処理や表示を行うソフトウェアにとってUnicode標準へ適合するためにまったく重要でないものも存在する。これらは以下の通り:
- 合成済みダイアクリティカルマーク。たとえば Å, (U+00C5) など。Unicodeはこれらの書記素を大文字の‘ラテン文字A’に‘Combining Ring Above’ (U+030A) を結合した、2つの別々の文字として扱うことを好む。
- 合字。ラテン文字において、‘ffi’のような合字は従来の文字コードではしばしば別々の文字として符号化される。Unicodeの合字に対するアプローチはそれらをリッチテキストとして扱い、もし有効にされたら、グリフ置換で扱うことである。
- 合成済みローマ数字。たとえば、ローマ数字の12 (‘Ⅻ’: U+216B) はローマ数字の10 (‘Ⅹ’: U+2169) と2つのローマ数字1 (‘Ⅰ’: U+2160) に分解できる。
- 合成済み分数記号。これらの分解はキーワード <fraction> を持つ。完全に適合するテキスト処理実装は分数 ¼ (U+00BC) と合成された分数 1⁄4 (数字 1 に分数用スラッシュ U+2044 と数字 4 を付けたもの) を同じように表示すべきである[2]。
- 文脈依存のグリフや字形。これらは基本的にアラビア文字で発生する。OpenTypeやTrueType GXのようにグリフ置換の機能を持つフォントを使うことにより、Unicodeに適合するソフトウェアは文字が単語の先頭、中央、末尾のどこに現れるか、あるいは単独で現れるかに応じて、同じ文字を適切なグリフに置換できる。このようなグリフ置換機能は東アジア言語の一部で縦書き (上から下への) テキスト描画を行うためにも必要である。この場合グリフは全角、半角、小書きなどの字形に置換されたり合成されたりしなければならない。Unicode適合でないソフトウェアや他の文字コードを使うソフトウェアは、位置に応じて同じ字母を使う代わりに複数の独立した文字を同じ字母に使う。これによってテキスト処理はさらに複雑になる。
UCS、Unicodeの文字プロパティとUnicodeのアルゴリズムはソフトウェア実装がこれらの文字を、その対応する分解から正しく表示するために必要なものをすべて提供する。そのためこれらの分解可能な互換文字は冗長で不必要なものとなる。それらが文字コードに存在することによって、テキストを正しく比較や照合するために余分なテキスト処理が必要になってしまう (Unicode正規化を参照)。しかも、これらの互換文字によって意味が追加されたり区別されたりすることはない。これらの文字にはテキスト描画処理とフォントがUnicode適合であるときに提供される描画結果との、視覚的な違いもない。さらに、これらの文字は他の文字コードとの往復変換のために必要なわけでもない。翻字によって、分解された文字を他の文字コードの対応する合成済み文字にマップできるからである。同様に、アラビア文字の語尾形のような文脈依存の字形は、その単語中の位置によって適切な従来文字コードの字形文字にマップできる。
これらの互換文字を捨てるために、テキスト処理ソフトウェアはいくつかのUnicodeの規約に適合しなければならない。ソフトウェアは以下のことができなければならない:
- 字母を表す文字と1つかそれ以上の独立した合成用ダイアクリティカルマークからダイアクリティカルマーク付きの書記素を合成すること。
- (書き手や読み手の判断によって) 合字や文脈依存のグリフ変化形を置換できること。
- フォントデータから、もしくは必要に応じて合成することにより、小書き、縦書き、半角、全角用のグリフに置換してCJKVのテキストを (書き手や読み手の判断によって) 縦方向に描画できること。
- ‘分数用スラッシュ’文字 (U+2044) と任意の他の文字を使って分数を組み立てられること。
- ‘Combining Long Solidus Overlay’ ( ̸ U+0338) と他の記号と組み合わせられること:たとえば ∄ (U+2203) に対する ∄ や ∄ 。
互換文字であると指定された5,402種類の文字のうち合計3,779文字が、不完全なUnicode実装のためにまとめて収録されている互換文字である。これらにはキーワード <initial>、<medial>、<final>、<isolated>、<fraction>、<wide>、<narrow>、<small>、<vertical>、<square> を付けられた互換文字がすべて含まれる。さらに、ほとんどすべての正規分解とほとんどの <compat> キーワードが付いた互換文字が含まれる (<compat> キーワードが付いた文字のうち例外となるのは囲み英数字、囲み漢字および後続の節で述べるものである)。
[編集] リッチテキスト互換文字
他の互換文字の多くは、Unicodeがリッチテキストであると考え、それゆえUnicodeとUCSの目標から外れたものからなる。ある意味では前節で述べた互換文字 — 従来のソフトウェアが合字や縦書きテキストを表示するためのものもの — でさえリッチテキスト形からなると言える。なぜならばリッチテキストの規約がテキストの表示される方法を決定するからである。しかし、テキストの表示に合字を使うか使わないかや縦書きと横書きのどちらを使うかの選択は、どちらも意味を含まないリッチテキストである。それらは単なるスタイルの違いである。これはのような斜体、上付き文字、下付き文字やリストマーカーのような、スタイルがそれに伴う何らかの意味を暗示する他のリッチテキストとは対照的である。
プレーンテキストの比較、照合、処理、格納の目的では、リッチテキストの変化形は意味的に冗長である。たとえば、上付き数字 4 の使用は標準の数字 4 を使ってからそれを上付きにするリッチテキスト規約を使うことと識別不可能な可能性が高い。このようなリッチテキストを代替する文字は、来往するプレーンテキスト文字にリッチテキストの整形を施したものと視覚的に区別がつかないので、曖昧さを作り出す。これらのリッチテキスト互換文字には以下のものが含まれる:
- 数学用英数記号。これらの記号は単にラテン文字とギリシア文字とインド・アラビア数字に15の異なる書体で繰り返し複製しただけである。これらは数式表記用に任意の文字を提供するパレットを目的としている。しかし、これらは文字の符号化と視覚的なグリフの符号化との区別や、プレーンテキストの文字のみをサポートするというUnicodeの目標を損ないがちである。このようなスタイルを代わる代わる並べた数学記号用のパレットは、リッチテキストの規約を代わりに使うことで簡単に作成できる。
- 括弧付き文字 (マーカー)。これらは基本的にリストマーカー用として用意された文字である。プレーンテキストの構成要素ではない。しかも、UCSが提供する括弧付き文字の種類は限られているので、他のリッチテキスト規約を使うほうが適切である。
- 丸付き英数字と丸付き漢字。この丸付き字形もマーカーがよくある用途である。繰り返しになるが、文字とともにリッチテキスト規約を使って文字を丸で囲むほうがより柔軟である。
- さまざまな幅の空白とノーブレークスペース。これらの文字は単に、通常の空白 (U+0020) やノーブレークスペース (U+00A0) のリッチテキスト版である。代わりにトラッキング、カーニング、ワードスペーシング属性のような、他のリッチテキスト規約を使うべきである。
- 上付き文字と下付き文字。上付きと下付きの文字はその多くが国際音声記号や他の文字体系とは実際に意味が異なる文字であり、実際にはリッチテキストの範疇には含まれない。しかし、それ以外のギリシア文字、ラテン文字、数字に関しては、単なるリッチテキストの表現形を構成しているだけである。これらのリッチテキストの上付き文字や下付き文字はこのリッチテキスト互換文字用のカテゴリに正しく所属する。これらのほとんどは“Superscripts and Subscripts”か“Basic Latin”ブロックに存在する。
以上のリッチテキスト互換文字のいずれについても、グリフの表示は通常その互換分解 (関連) 文字と異なる。しかし、これらは互換文字であるとみなされ、ユニコードコンソーシアムは使わないことを推奨している。なぜならばそれらはUnicodeがUCSと関連する規約によってサポートしようとしているプレーンテキスト文字ではないからである。リッチテキストはUnicodeの規約ではなく、HTML、CSS、RTF等々のUnicode以外の規約によって処理されるべきである。
リッチテキスト互換文字は5,402種類の互換文字のうち1,451種類を占める。キーワード <circle> と <font> が付けられた互換文字は (以下に述べる意味的な違いのある3つを除けば) すべてこの中に含まれる; <compat> と正規文字のうち空白の変種11種; および“Superscripts and Subscripts”ブロックにある、キーワード <superscript> と <subscript> が付けられたもののうちいくつか。
[編集] 意味的に違いのある文字
多くの互換文字は表現するグリフを他の文字と共有するかもしれないが、意味的には違いのある文字である。これらの文字のうちいくつかは、1つの用字系や表記体系に特化した他の文字コードのほとんどのために含まれている場合がある。たとえば、ISOや他のラテン文字集合はπ (pi) 用の文字を含んでいる可能性が高い。なぜならば、基本的に1つの表記体系や用字系に集中するとき、それらの文字コードはそうでもしなければよく使われる数学記号であるπ用の文字を含むことはないからである。しかし、Unicodeでは、数学者は世界中の既知の用字系から自由に文字を使ったり、数学的な集合や数学的な定数の代わりとして統合漢字を選択したりできる。今まで、Unicodeはごく少数の数学定数用に特定の意味的サポートを追加しただけである (たとえばプランク定数: U+210E やオイラー数 U+2107 はどちらもUnicodeが互換文字であると考えているものである)。そのためUnicodeはギリシア文字やヘブライ文字に基づくいくつかの数学記号を互換文字に指定している。これには以下のものが含まれる:
- ヘブライ文字に基づく記号 (4): ℵ アレフ (ℵ U+2135)、ベート (ℶ U+2136)、ギーメル (ℷ U+2137) およびダレット (ℸ U+2138)
- ギリシア文字に基づく記号 (8): ベータ (ϐ U+03D0)、シータ (ϑ U+03D1)、ファイ (ϕ U+03D5)、パイ (ϖ U+03D5)、カッパ (ϰ U+03F0)、ロー (ϱ U+03F1)、大文字のシータ (ϴ U+03F4)、プロスゲグラメニ (ι U+1FBE)
- ラテン文字の異体 (1): Long Latin Letter S (ſ U+017F)。このラテン文字の字母はゲール語で使われる。
これらの互換文字はその互換分解文字とは、名前に“symbol”が付けられているという点でのみ区別されるが、数式の表記においては長年異なる意味を表している。しかし、すべての現実的な目的ではそれらは互換等価なギリシア文字やヘブライ文字と同じ意味を共有している。これらは意味的に識別可能な文字の境界線上にあると考えられるので、互換文字の合計数には含めていない。
Unicodeはその他の字母に似た記号28種類も互換文字に指定している。
- その他のギリシア文字に基づく記号 (4): Lunate Epsilon (ϵ U+03F5)、Lunate Sigma (ϲ U+03F2)、大文字Lunate Sigma (Ϲ U+03F9)、Upsilon with Hook (ϒ U+03D2)
- 数学定数と物理定数 (3): オイラー数 (ℇ U+2107)、プランク定数 (ℎ U+210E)、ディラック定数 (ℏ U+210F)、
- 単位記号 (6): オングストローム (Å U+212B)、オーム (Ω, U+2126)、ケルビン (K U+212A)、華氏 (℉ U+2109)、摂氏 (℃ U+2103)、マイクロ記号 (U+00B5)
- 通貨記号: ルピー記号 (U+20A8)
- 約物 (4): 一点リーダ (U+2024)、ノーブレークスペース (U+00A0)、ノーブレークハイフン (U+2011)、Tibetan Mark Delimitter Tsheg Bstar (U+0F0C)
- 他の字母に類似した記号 (10): Information Source (ℹ U+2139)、Account Of (℀ U+2100)、Addressed to the Subject (℁ U+2101)、Care of (℅ U+2105)、Cada una (℆ U+2106)、Numero (№ U+2116)、電話記号 (℡ U+2121)、FAX記号 (℻ U+213B)、商標 (™ U+2122)、サービスマーク (℠ U+2120)
加えて、いくつかの用字系は意味を区別するために上付きや下付きのグリフ位置を使う。これらの場合、上付き文字や下付き文字は単なるリッチテキストではなく、表記体系において — ダイアクリティカルマークと字母の混合と同様に — 異なる文字を構成する (合計130種)。
- 国際音声記号のような発音記号からの、抽象的な音素を表現する文字112種類。グリフの位置が意味的な違いを表す (U+1D2C – U+1D6A, U+1D78, U+1D9B – U+1DBF, U+02B0 – U+02B8, U+02E0 – U+02E4)
- 漢文ブロックからの14文字 (U+3192 – U+319F)
- ティフナグ文字からの1文字: Tifinagh Modifier Letter Labialization Mark (ⵯ U+2D6F)
- グルジア文字からの1文字: Modifier Letter Georgian Nar (ჼ U+10FC)
- ラテン1補助ブロックに含まれる男性記号 (U+00BA) と女性記号 (U+00AA) の序数標識
最後に、Unicodeはローマ数字が同じグリフを共有するラテン文字と互換等価であると指定している。ここでUnicode標準はしばしば防ごうと努めてきた、グリフと文字の混同と同じ過ちを犯している。確かにこれらの文字が同じグリフを共有していた場合の視覚的な曖昧さを解決する必要はあるが、桁記号記数法の数字用である片方はラテン文字の大文字や小文字の‘i’とは確実に意味的な違いがある。同様の視覚的な曖昧さはラテン大文字A (U+0041) とギリシア大文字アルファ (Α U+0391) のような文字の間にもあるが、Unicodeはこれらの文字を統合していない。
- 大文字のローマ数字: 1 (Ⅰ U+2160)、5 (Ⅴ U+2164)、10 (Ⅹ U+2169)、50 (Ⅼ U+216C)、100 (Ⅽ U+216D)、500 (Ⅾ U+216E)、1000 (Ⅿ U+216F)
- および小文字版: 1 (ⅰ U+2170)、5 (ⅴ U+2174)、10 (ⅹ U+2179)、50 (ⅼ U+217C)、100 (ⅽ U+217D)、500 (ⅾ U+217E)、1000 (ⅿ U+217F)
- 18種類の合成済みローマ数字の大文字版と小文字版 (2-4、6-9 および 11-12)
ローマ数字の1000は実際には同じ意味的な単位を表す第三の字形またはグリフを表現する第三の文字を持つ: One Thousand C D (ↀ U+2180)。このグリフからは、ラテン文字 M 使用の慣習によって生ずるものを見られる。奇妙なことに、Unicodeは sign-value ローマ数字をまったく異なる (しかし視覚的には類似した) ラテン文字に統合しているが、インド・アラビアの位取り十進記数法に使われる数字はUCS全体を通して24回繰り返され (10種類の数字に合計240のコードポイントが使われ)、それらの間にはいかなる関係や分解マッピングも定義されていない。
互換文字の中に (18種類の合成済みローマ数字と11種類のヘブライ文字やギリシア文字に基づく記号に加えて) これら146種類の視覚的には類似しているが意味的に異なる文字が存在していることが、互換文字の話題を複雑にしている。内容の書き手は互換文字を使わないよう推奨することを提案している者もいる。しかし、特定の専門領域ではこれらの文字は重要であり、互換文字に混ざられなかった他の文字ときわめて類似している。たとえば、特定の学会においてはローマ数字の使用を同じグリフを共有するラテン文字と区別することには、楔形文字の数字と古代ギリシア文字の数字を区別することと違いがない。ローマ数字の文字をラテン字母の文字にまとめることは、意味的な違いを失わせる。同様の状況が上付きや下付きのグリフを使用する発音記号にも存在する。発音記号を使用する専門分野の学会では、書き手はリッチテキスト規約の助けを借りずに達成できるべきである。
[編集] 互換ブロック
符号位置 | 文字 |
---|---|
U+FA0E | 﨎 |
U+FA0F | 﨏 |
U+FA11 | 﨑 |
U+FA13 | 﨓 |
U+FA14 | 﨔 |
U+FA1F | 﨟 |
U+FA21 | 﨡 |
U+FA23 | 﨣 |
U+FA24 | 﨤 |
U+FA27 | 﨧 |
U+FA28 | 﨨 |
U+FA29 | 﨩 |
いくつかのUnicode文字のブロックは完全に、もしくはほとんど完全に互換文字のみを含んでいる。これらの互換ブロックは意味的に違いのある互換文字を含んでいないので、推奨されない文字の集合へ曖昧さなしに分類できる。Unicodeはプレーンテキストの対応する互換分解を代わりに使用し、リッチテキストのマークアップで補完することを書き手に推奨している。このアプローチは、ひとつだけ例をあげれば丸付きや括弧付きの英数字の有限の集合を使うよりもはるかに柔軟で、制約が少ない。
残念ながら、互換ブロックに存在しながらそれ自身は互換文字ではなく、それゆえに書き手に混乱をもたらす可能性のある文字が少数存在する。“Enclosed CJK Letters and Months”ブロックは互換文字でない文字を1つ含んでいる: ‘韓国規格記号’ (㉿ U+327F) である。この記号と 12 の他の文字が互換文字のブロックに含まれている理由は不明である。“CJK互換漢字”ブロックがこれらの互換漢字ではない統合漢字を含んでいる。
これら13種類の文字は互換文字でもなければ、いかなる意味で使用が非推奨なわけでもない。
これらのブロックに含まれる他の文字のいくつかは互換分解を持たないが、明らかに従来文字コードのサポートを意図している:
アルファベット表現形 (1)
- Hebrew Point Judeo-Spanish Varika (U+FB1E): ﬞ. これは Hebrew Point Rafe (U+05BF): ֿ の異体字であるが、Unicodeは互換分解を与えていない。
アラビア文字表現形 (4)
- “Ornate Left Parenthesis” (U+FD3E): ﴾. U+0029 ‘)’の異体字
- “Ornate Right Parenthesis” (U+FD3F): ﴿. U+0028 ‘ (’の異体字
- “Ligature Bismillah Ar-Rahman Ar-Raheem” (U+FDFD): ﷽. バスマラ (بسملة) は Teh Marbuta (U+0629)、Lam (U+0644)、Meem (U+0645)、Seen (U+0633)、Beh (U+0628)、の合字である。
- “Arabic Tail Fragment” (U+FE73): ﹳ 文脈依存のグリフ処理に対応していない文章システムのサポート用
CJK互換形 (2種類、両方ともCJK統合漢字の U+4E36 丶 と関係)
- 傍点 (U+FE45): ﹅
- 白い傍点 (U+FE46): ﹆
囲み英数字 (21のリッチテキスト変種)
- 10種類の黒丸数字 (0 と 11 から 20) (U+24FF と U+24EB から U+24F4): ⓫ – ⓴
- 11種類の二重丸付き数字 (0 から 10) (U+24F5 から U+24FE): ⓵ – ⓾
[編集] 正規化
詳細はUnicode正規化を参照
正規化は、Unicodeに適合するソフトウェアがテキスト文字列の比較や照合を最初に行う互換分解の手続きである。これは、たとえば、利用者があるテキスト内で大文字小文字やダイアクリティカルマークを区別しない検索を行うときに必要とされる他の処理に似ている。このような場合ソフトウェアは通常同一視したり無視したりしない文字を同一視したり無視したりしなければならない。一般に正規化は構成する格納テキストのデータを変更することなしに行われる (可逆である)。しかし、ソフトウェアによっては正規等価な互換文字を、場合によっては正規等価でない互換文字さえも取り除く永久的な変更をテキストに加える可能性があるかもしれない (不可逆)。
[編集] 脚注
- ^ Unicode Consortium - Glossary - Compatibility Character (英語)
- ^ The Unicode Consortium (2006-11-03). The Unicode Standard, Version 5.0. Addison-Wesley Professional, p212. ISBN 978-0321480910.