10
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

日本語Wikipediaから、エンティティ・リンキング用のデータセットを作製する

Last updated at Posted at 2021-05-01

なんの記事?

  • 日本語のWikipediaダンプから、エンティティの付与された固有表現抽出データセットを作製しました。また前処理のスクリプトも併せて公開しました。前回の記事からwikipedia向けに改良を加えたものになります。

  • 20210420時点での日本語のWikipediaダンプから、27,954,057 メンション及び、紐付け先エンティティ(リダイレクト解消済み)の付与された26,700,456メンションを生成しました。

  • データセットのリポジトリはこちらになります。CC-BY-SA 3.0ライセンスの下でサンプルデータセットを公開しました。

データセットのサンプル

  • Wikipediaのハイパーリンクが付与された部分について、リンク先のエンティティの情報との紐付けを行いました。リダイレクト先がある場合、その解消も行いました。
annotation.json
{
  "document_title": "浅草",
  "anchor_sent": "昭和初期には、<a>浅草国際通り</a>沿いに森下仁丹が広告塔を建設。",
  "annotation_doc_entity_title": "東京都道462号蔵前三ノ輪線",
  "mention": "浅草国際通り",
  "original_sentence": "昭和初期には、浅草国際通り沿いに森下仁丹が広告塔を建設。",
  "original_sentence_mention_start": 7,
  "original_sentence_mention_end": 13
},
{
  "document_title": "浅草",
  "anchor_sent": "昭和初期には、浅草国際通り沿いに<a>森下仁丹</a>が広告塔を建設。",
  "annotation_doc_entity_title": "森下仁丹",
  "mention": "森下仁丹",
  "original_sentence": "昭和初期には、浅草国際通り沿いに森下仁丹が広告塔を建設。",
  "original_sentence_mention_start": 16,
  "original_sentence_mention_end": 20
}, ...

また、紐付け先のエンティティ集合と、それに紐づく説明文について文分割したものについてもあわせて作製しました。

title2doc.json
{
  "浅草": [
              "浅草(あさくさ)は、東京都台東区の町名。",
              "または、旧東京市浅草区の範囲を指す地域名である。",
              "浅草寺の門前町として繁華街および観光地となっている。",
              "また浅草駅は東京メトロ銀座線、都営浅草線と東武スカイツリーラインが接続しているほか、つくばエクスプレスの浅草駅とも近接しており、東京都区部と北関東を結ぶ拠点となっている。",
              "浅草(地域).",
              "東京都台東区のおよそ東半分を範囲とし、江戸・東京の下町を構成している地域の一つである。",
              "浅草は下谷・本所・深川と並ぶ、東京下町の外郭をなす。",
              ...
          ],
  "東京都道462号蔵前三ノ輪線": [
              "東京都道462号蔵前三ノ輪線(とうきょうとどう462ごう くらまえみのわせん)は、東京都台東区にある特例都道であり、江戸通り(国道6号)と蔵前橋通りが交わる蔵前一丁目交差点から分岐して、昭和通り・日光街道(国道4号)と明治通りが交わる大関横丁交差点までを結ぶ。"
              ...
          ],      
  ... 
}

エンティティ・リンキングについて

エンティティ・リンキングとは,文書中に存在する,メンションと呼ばれるテキスト範囲を知識グラフ内に存在するエンティティへとマッピングするタスクです。自然言語理解及び応用における重要なタスクの一つとされています。

image.png

(画像はこのスライドより引用)

今回、日本語のエンティティ・リンキングを行うためにWikipediaに前処理を行い、前処理のスクリプトとともに公開しました。

他の日本語エンティティ・リンキングデータセットとの比較

日本語の固有表現抽出データセットは多くあれど、日本語のエンティティ・リンキングに特化したデータはこれまで多くありませんでした。以下、データセットを2つ紹介します。

  • 日本語wikificationコーパス[1] : BCCWJコーパスの一部にWikipediaのエントリを付与したものになります。アノテーションされたメンション数は約2万メンションです。BCCWJコーパスの購入が別途必要です。

  • Mewsli-9 Dataset[2]: WikiNewsからWikidataにリンクされたメンションを集めたデータです。日本語のメンション数は約3万4000メンションです。Wikidataとの紐付けが別途必要です。

どちらも前処理スクリプトは公開されていません。またメンション数も比較的小規模で、別途リンク先のアノテーションの前処理も必要です。

使用したライブラリ・コードについて

Wikipediaの前処理にWikiExtractor、文章分割にはkonohaを使用しました。また、リダイレクト解消ではWikipedia2Vecのソースコードを参考にしました。

まとめ

日本語のWikipediaについてデータを前処理し、エンティティ・リンキング用に使いやすい形で公開しました。

何かありましたらリポジトリでissueを建てて頂くか、ご連絡を頂ければ幸いです。

参考文献

  • [1] Davaajav Jargalsaikhan, 岡崎直観, 松田耕史, 乾健太郎. 日本語 Wikification コーパスの構築に向けて. 言語処理学会第22回年次大会(NLP2016), March 2016.

  • [2] Botha, Jan A., Zifei Shan, and Daniel Gillick. "Entity Linking in 100 Languages." arXiv preprint arXiv:2011.02690 (2020).

10
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
10
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?