Whisper文字起こしの使い方と無料で試せる方法は?

議事録生成AI

こんにちは。AINow編集部です。近年、AI技術の発展により、音声認識や文字起こしの精度が飛躍的に向上しています。その中でも、OpenAIが開発したWhisperは、高精度で多言語対応の文字起こしモデルとして注目を集めています。

Whisperは、大規模な多言語データセットで訓練された音声認識モデルであり、その精度と汎用性から、ビジネスや研究分野で幅広く活用されています。2024年8月現在、Whisperの文字起こし技術は、より高度化し、様々な場面で利用されるようになりました。

本記事では、Whisperの概要から具体的な利用方法、さらには無料で試す方法まで、詳しく解説します。また、Whisperを使ったビジネス活用のメリットや注意点についても触れ、読者の皆様がWhisperの可能性を最大限に活用できるよう、有益な情報をお届けします。

Whisperとは?概要と特徴

Whisperは、OpenAIが開発した革新的な音声認識モデルです。その高い精度と多言語対応能力により、文字起こしや音声翻訳などの分野で大きな注目を集めています。

Whisperの特徴は、大規模な多言語データセットで訓練されていることにあります。これにより、様々な言語や方言、さらにはノイズのある音声でも高い精度で認識することができます。

Whisperについて

Whisperは、以下のような特徴を持っています:

  1. 多言語対応:100言語以上の音声認識が可能
  2. ロバスト性:背景ノイズや話者の多様性に強い
  3. オープンソース:誰でも無料で利用可能
  4. 柔軟性:音声認識、翻訳、言語識別など多様なタスクに対応

Whisperの最大の強みは、その汎用性と高い精度にあります。従来の音声認識システムでは困難だった多言語環境や、ノイズの多い実環境での認識も、Whisperは高いパフォーマンスを発揮します。

Whisperの特徴

Whisperの主な特徴を詳しく見ていきましょう:

  1. 高精度な認識:
  • クリーンな音声だけでなく、ノイズのある実環境音声でも高い認識精度
  • 方言や訛りにも強い適応能力
  1. 多言語対応:
  • 100以上の言語に対応
  • 言語間の翻訳機能も内蔵
  1. 柔軟なモデルサイズ:
  • tiny, base, small, medium, largeの5種類のモデルサイズ
  • 用途や計算リソースに応じて選択可能
  1. オープンソース:
  • GitHub上で公開されており、誰でも利用可能
  • カスタマイズや改良が可能
  1. マルチタスク能力:
  • 音声認識だけでなく、言語識別や翻訳も可能
  • 一つのモデルで複数のタスクをこなせる

これらの特徴により、Whisperは様々な分野で活用されています。例えば、音声認識・文字起こしツール「Otter AI」のような既存のツールと比較しても、Whisperは高い競争力を持っています。

Whisperの仕組み

Whisperの仕組みは、以下のような流れで構成されています:

  1. 音声入力:
  • 音声データをモデルに入力
  1. スペクトログラム変換:
  • 音声データを周波数と時間の2次元表現に変換
  1. Transformer処理:
  • 変換されたデータをTransformerアーキテクチャで処理
  • 自己注意機構により、音声の長期依存関係を捉える
  1. デコーディング:
  • 処理結果をテキストにデコード
  1. 出力:
  • 認識されたテキストを出力

Whisperの優れた性能の鍵は、大規模なデータセットでの事前学習にあります。68万時間以上の多言語音声データで訓練されており、これにより様々な言語や音声環境に対応できる汎用性を獲得しています。

次のセクションでは、Whisperの具体的な利用方法について解説します。Google Colaboratoryを使った実行環境の設定から、API活用、さらにはオープンソースコミュニティでの試用方法まで、詳しく見ていきましょう。

Whisperの利用方法

Whisperを利用するには、いくつかの方法があります。ここでは、Google Colaboratoryを使った方法、Whisper APIの活用方法、そしてオープンソースコミュニティ「Hugging Face」での試用方法について詳しく解説します。

Google Colaboratoryを使ったWhisperの実行環境設定

Google Colaboratoryは、ブラウザ上でPythonを実行できる環境を提供するGoogle のサービスです。Whisperを手軽に試すのに適しています。

  1. Google Colaboratoryにアクセス:
  • Googleアカウントでログイン
  • 新しいノートブックを作成
  1. 必要なライブラリのインストール:
   !pip install git+https://github.com/openai/whisper.git
   !pip install ffmpeg-python
  1. Whisperのインポートと音声ファイルのアップロード:
   import whisper
   from google.colab import files
   uploaded = files.upload()
  1. モデルのロードと音声認識の実行:
   model = whisper.load_model("base")
   result = model.transcribe("your_audio_file.mp3")
   print(result["text"])

Google Colaboratoryを使うことで、特別な環境構築なしにWhisperを試すことができます。これは、Whisperの文字起こし機能を手軽に体験したい場合に特に有用です。

Whisper APIの活用方法

OpenAIは、Whisper APIも提供しています。これを使用することで、より簡単にWhisperの機能を自身のアプリケーションに組み込むことができます。

  1. OpenAI APIキーの取得:
  • OpenAIのウェブサイトでアカウントを作成
  • APIキーを取得
  1. 必要なライブラリのインストール:
   pip install openai
  1. APIを使用した文字起こし:
   import openai

   openai.api_key = "your-api-key"

   audio_file = open("your_audio_file.mp3", "rb")
   transcript = openai.Audio.transcribe("whisper-1", audio_file)

   print(transcript["text"])

APIを使用することで、サーバーサイドでの高度な処理が可能になり、より柔軟なアプリケーション開発ができます。

オープンソースコミュニティ「Hugging Face」での試用方法

Hugging Faceの利用ガイドにあるように、Hugging Faceは機械学習モデルのハブとして知られています。Whisperもここで試すことができます。

  1. Hugging FaceのWhisperデモページにアクセス
  2. 音声ファイルをアップロードまたはマイクで録音
  3. 「Run」ボタンをクリックして文字起こしを実行
  4. 結果を確認し、必要に応じてダウンロード

Hugging Faceを使用することで、コードを書くことなくWhisperの機能を試すことができます。これは、Whisperの性能を素早く評価したい場合に便利です。

これらの方法を使って、Whisperの文字起こし機能を実際に試してみてください。次のセクションでは、Whisperを使った具体的な文字起こしの手順について、より詳しく解説します。

Whisperを使った文字起こしの手順

Whisperを使って実際に文字起こしを行う手順を、詳しく見ていきましょう。ここでは、音声データの準備から実際の文字起こし作業まで、ステップバイステップで解説します。

音声データの準備

文字起こしを行う前に、適切な音声データを準備することが重要です。以下のポイントに注意してください:

  1. 音声フォーマット:
  • WAV、MP3、M4A、OGGなどの一般的な音声フォーマットに対応
  • 可能であれば、WAVフォーマットを使用するのが望ましい
  1. サンプリングレート:
  • 16kHz以上のサンプリングレートを推奨
  • 低すぎるサンプリングレートは認識精度に影響する可能性あり
  1. 音質:
  • できるだけクリアな音声を使用
  • ノイズの少ない環境での録音が望ましい
  1. 音声の長さ:
  • 長時間の音声は分割して処理することを推奨
  • 30分程度を目安に分割すると良い

適切な音声データを準備することで、Whisperの文字起こし精度を最大限に引き出すことができます

音声データのアップロード方法

準備した音声データをアップロードする方法は、使用する環境によって異なります。ここでは、Google Colaboratoryを使用する場合の手順を示します:

  1. Google Colaboratoryのノートブックを開く
  2. 以下のコードを実行して音声ファイルをアップロード:
   from google.colab import files
   uploaded = files.upload()
  1. ローカルのファイル選択ダイアログが開くので、準備した音声ファイルを選択
  2. アップロードが完了したら、以下のコードでファイル名を確認:
   import os
   for filename in os.listdir():
       if filename.endswith(('.wav', '.mp3', '.m4a', '.ogg')):
           print(f"Uploaded audio file: {filename}")

このようにして、音声データをGoogle Colaboratory環境にアップロードすることができます。

実際の文字起こしの手順

音声データの準備とアップロードが完了したら、いよいよ文字起こしを行います。以下の手順で進めてください:

  1. Whisperモデルのロード:
   import whisper
   model = whisper.load_model("base")  # モデルサイズを選択(tiny, base, small, medium, large)
  1. 文字起こしの実行:
   result = model.transcribe("your_audio_file.mp3")
  1. 結果の出力:
   print(result["text"])
  1. 結果の保存(オプション):
   with open("transcription.txt", "w") as f:
       f.write(result["text"])
  1. タイムスタンプ付きの出力(オプション):
   for segment in result["segments"]:
       print(f"{segment['start']:.2f} - {segment['end']:.2f}: {segment['text']}")

これらの手順を踏むことで、Whisperを使用した高精度な文字起こしが可能になります。Notta AIの自動文字起こしのような商用ツールと比較しても、Whisperは十分に競争力のある精度を提供します。

次のセクションでは、Whisperの様々なモデルサイズとその精度について詳しく解説します。用途や要求される精度に応じて、適切なモデルを選択することが重要です。

Whisperのモデルと精度

Whisperは、異なるサイズと性能のモデルを提供しています。ここでは、各モデルサイズの特徴や、文字起こし精度の比較について詳しく解説します。

Whisperのモデルサイズの種類

Whisperには、以下の5つのモデルサイズが用意されています:

  1. tiny:最小サイズのモデル
  2. base:基本的な性能を持つモデル
  3. small:中程度の性能を持つモデル
  4. medium:高い性能を持つモデル
  5. large:最高性能のモデル

これらのモデルは、パラメータ数や計算量が異なり、それに応じて性能と処理速度のバランスが変わってきます。

各モデルサイズの特徴

各モデルサイズの特徴を詳しく見ていきましょう:

  1. tiny:
  • パラメータ数:約3,900万
  • 特徴:最も軽量で高速、但し精度は低め
  • 用途:リアルタイム処理や軽量デバイスでの使用
  1. base:
  • パラメータ数:約7,400万
  • 特徴:tinyより高精度だが、依然として軽量
  • 用途:一般的な文字起こしタスク、リソースが限られた環境
  1. small:
  • パラメータ数:約2億4,400万
  • 特徴:精度と速度のバランスが良い
  • 用途:中規模のプロジェクト、一般的なビジネス利用
  1. medium:
  • パラメータ数:約7億6,900万
  • 特徴:高い精度を持つが、計算リソースを多く必要とする
  • 用途:高精度が要求される専門的な文字起こし
  1. large:
  • パラメータ数:約15億
  • 特徴:最高の精度を持つが、最も計算リソースを必要とする
  • 用途:最高品質の文字起こしが必要な場合、研究目的

モデルサイズの選択は、必要な精度と利用可能な計算リソースのバランスを考慮して行うことが重要です。例えば、モバイルデバイスでの利用を考えている場合は、tiny や base モデルが適しているでしょう。

文字起こし精度の比較

各モデルサイズの文字起こし精度を比較してみましょう。以下は、英語の音声に対する単語誤り率(Word Error Rate, WER)の例です:

モデルサイズWER (%)
tiny10.5
base8.8
small7.2
medium6.1
large5.4

(注:これらの数値は一例であり、実際の性能は音声の品質や話者、環境などによって変動します)

精度は、モデルサイズが大きくなるにつれて向上していますが、同時に必要な計算リソースも増加します。例えば、large モデルは tiny モデルよりも約2倍高い精度を示していますが、計算量は約38倍になります。

ChatGPTと生成AIの発展により、Whisperのような音声認識モデルの重要性はますます高まっています。文字起こしの結果を ChatGPT などの言語モデルと組み合わせることで、より高度な自然言語処理タスクが可能になるからです。

次のセクションでは、Whisper をビジネスに活用するメリットについて詳しく解説します。高精度な文字起こしがもたらす業務効率化や新たなビジネス機会について、具体的に見ていきましょう。

Whisperをビジネスに活用するメリット

Whisper の高精度な文字起こし技術は、様々なビジネスシーンで活用することができます。ここでは、Whisper をビジネスに導入することのメリットについて、具体的に解説します。

高精度な文字起こし

Whisper の最大の強みは、その高い文字起こし精度にあります。

  1. 会議議事録の自動作成:
  • 会議の音声を自動で文字起こし
  • 人手による作業時間を大幅に削減
  • 正確な記録により、情報の欠落を防止
  1. カスタマーサポートの品質向上:
  • 顧客との通話内容を自動で文字化
  • 対応内容の分析や改善点の抽出が容易に
  • コンプライアンス遵守の証跡として活用
  1. メディアコンテンツの字幕生成:
  • 動画や音声コンテンツの自動字幕生成
  • 多言語対応により、グローバル展開をサポート
  • アクセシビリティの向上に貢献

高精度な文字起こしにより、これまで時間と労力を要していた作業を効率化し、より戦略的なタスクに注力することが可能になります

多言語対応

Whisper の多言語対応能力は、グローバルビジネスにおいて大きな強みとなります。

  1. 国際会議の円滑な運営:
  • 複数言語での発言を自動で文字起こし
  • リアルタイムで多言語の議事録を作成
  • 言語の壁を越えたコミュニケーションを促進
  1. 多言語コンテンツの制作:
  • 一つの音声コンテンツから多言語の文字起こしを生成
  • ローカライゼーションの効率を大幅に向上
  • グローバル市場への迅速な展開をサポート
  1. 外国語学習支援:
  • 外国語の音声を文字起こしして学習材料を作成
  • リスニング能力と読解能力を同時に向上
  • 社員の語学力向上に貢献

Whisper の多言語対応により、言語の壁を越えたグローバルなビジネス展開が可能になります。

コストパフォーマンスの良さ

Whisper は無料で利用できるオープンソースモデルであり、高いコストパフォーマンスを誇ります。

  1. 初期導入コストの削減:
  • 高額なライセンス費用が不要
  • 既存のインフラを活用して導入可能
  1. カスタマイズの自由度:
  • オープンソースのため、自社のニーズに合わせて改良可能
  • 特定のドメインや業界用語に特化した学習も可能
  1. スケーラビリティ:
  • 利用量に応じて柔軟にリソースを調整
  • クラウドサービスと組み合わせて大規模処理にも対応

Whisper の活用により、高品質な文字起こしサービスを低コストで実現することができます。

APIを活用した柔軟な利用

Whisper API を利用することで、既存のシステムやアプリケーションに容易に統合することができます。

  1. 社内システムとの連携:
  • CRM や ERP など既存のシステムと連携
  • 音声データの自動文字起こしと分析を一元管理
  1. モバイルアプリケーションの開発:
  • スマートフォンアプリに音声認識機能を追加
  • ユーザー体験の向上と新しい使用シーンの創出
  1. IoT デバイスとの統合:
  • スマートスピーカーやウェアラブルデバイスに音声認識機能を実装
  • 音声インターフェースによる新しいサービスの開発

API を活用することで、Whisper の高度な機能を様々なビジネスシーンに柔軟に適用することができます。

SoundHound AI のような音声認識技術の進化と相まって、Whisper の活用はビジネスにおける音声データの利用可能性を大きく広げています。次のセクションでは、Whisper 利用時の注意点について解説します。高度な技術を効果的に活用するためには、潜在的な課題や制限事項を理解することが重要です。

Whisper利用時の注意点

Whisper は非常に強力なツールですが、効果的に活用するためにはいくつかの注意点があります。ここでは、実行環境の構築の難しさ、セキュリティ面の課題、処理速度の問題について詳しく解説します。

実行環境の構築の難しさ

Whisper を自前の環境で運用する場合、適切な実行環境の構築が必要となります。

  1. 計算リソースの要求:
  • 特に大規模モデル(medium, large)では、高性能なGPUが必要
  • クラウドGPUインスタンスの利用も検討が必要
  1. 依存ライブラリの管理:
  • PyTorch や FFmpeg など、複数の依存ライブラリが必要
  • バージョン管理や互換性の確保に注意が必要
  1. 環境構築の複雑さ:
  • CUDA や cuDNN など、GPU関連のセットアップが複雑
  • 適切な環境構築には一定の技術的知識が必要

実行環境の構築には、十分な計画と技術的なノウハウが必要です。特に、大規模な導入を検討する場合は、専門家のサポートを受けることも検討すべきでしょう。

セキュリティ面の課題

Whisper を使用する際は、セキュリティ面での配慮も重要です。

  1. データプライバシー:
  • 音声データには個人情報が含まれる可能性がある
  • GDPR や CCPA などの法規制への対応が必要
  1. データの保護:
  • 音声データや文字起こし結果の適切な暗号化が必要
  • アクセス制御や監査ログの実装を検討
  1. モデルの脆弱性:
  • 敵対的攻撃などのAIセキュリティリスクへの対応
  • 定期的なモデルの更新とセキュリティパッチの適用
  1. API利用時の注意:
  • API キーの適切な管理
  • HTTPS 通信の徹底

AIに学習させないための効果的な方法 で紹介されているようなプライバシー保護技術を併用することで、より安全な Whisper の運用が可能になります。

処理速度の問題

Whisper の処理速度は、モデルサイズや使用する環境によって大きく変わります。

  1. リアルタイム処理の制限:
  • 大規模モデルではリアルタイム処理が困難
  • 用途に応じて適切なモデルサイズの選択が必要
  1. バッチ処理の必要性:
  • 大量のデータを処理する場合、バッチ処理が効率的
  • 処理時間の見積もりと適切なスケジューリングが重要
  1. ハードウェアの影響:
  • GPU の性能が処理速度に大きく影響
  • 必要に応じて、高性能な GPU や複数 GPU の利用を検討
  1. 最適化の必要性:
  • モデルの量子化や蒸留などの最適化技術の適用
  • 処理パイプラインの効率化

処理速度の問題に対しては、用途に応じた適切なモデルサイズの選択と、ハードウェアやソフトウェアの最適化が重要です。

これらの注意点を十分に考慮し、適切な対策を講じることで、Whisper を安全かつ効果的に活用することができます。次のセクションでは、Whisper 以外の文字起こしツールについて紹介します。各ツールの特徴を比較することで、自社のニーズに最適なソリューションを選択する際の参考になるでしょう。

Whisper以外の文字起こしツールの紹介

Whisper は優れた文字起こしツールですが、他にも多くの選択肢があります。ここでは、Whisper 以外の代表的な文字起こしツールを紹介し、その特徴や使い方について解説します。

AIGIJIROKU

AIGIJIROKU は、日本語に特化した文字起こしツールです。

特徴:

  • 日本語の文章構造や慣用句を考慮した高精度な文字起こし
  • 業界用語や固有名詞の辞書登録機能
  • リアルタイムでの文字起こしが可能

使い方:

  1. 音声ファイルをアップロードまたはリアルタイム入力
  2. AIが自動で文字起こしを実行
  3. 必要に応じて人手で修正
  4. テキストファイルとしてエクスポート

AIGIJIROKUは、特に日本語の会議録や講演の文字起こしに強みを持っています。

Rimo Voice

Rimo Voice は、クラウドベースの音声認識・文字起こしサービスです。

特徴:

  • マルチデバイス対応(PC、スマートフォン、タブレット)
  • リアルタイムでの文字起こしと翻訳機能
  • 複数話者の識別機能

使い方:

  1. Rimo Voice のウェブサイトにアクセスまたはアプリをインストール
  2. 音声ファイルをアップロードまたはマイクから直接入力
  3. 自動で文字起こしが開始
  4. 結果を確認し、必要に応じて編集

Rimo Voice は、特にリモートワーク環境での会議や遠隔教育での活用が期待されています。

Notta

Notta AIの自動文字起こしは、AIを活用した高性能な文字起こしツールです。

特徴:

  • 高精度な音声認識と自動文字起こし
  • 多言語対応(100以上の言語とアクセントに対応)
  • 話者の識別と分離機能

使い方:

  1. Notta のウェブサイトにアクセスし、アカウントを作成
  2. 音声ファイルをアップロードまたはリアルタイムで録音
  3. AIが自動で文字起こしを実行
  4. 結果を確認し、必要に応じて編集ツールで修正
  5. テキストや字幕ファイルとしてエクスポート

Notta AIは、特に多言語環境でのビジネス会議や学術研究での利用に適しています。

スマート書記

スマート書記は、日本の企業が開発した文字起こしサービスです。

特徴:

  • 日本語に特化した高精度な文字起こし
  • 専門用語辞書の充実
  • 議事録作成支援機能

使い方:

  1. スマート書記のウェブサイトにアクセス
  2. 音声ファイルをアップロード
  3. AIによる自動文字起こしが実行される
  4. 結果を確認し、編集インターフェースで修正
  5. 議事録形式でエクスポート

スマート書記は、特に企業の会議や公的機関の議事録作成に強みを持っています。

これらの文字起こしツールは、それぞれに特徴があり、用途や要求される精度に応じて選択することが重要です。例えば、日本語の会議録作成が主な用途であれば AIGIJIROKU やスマート書記が適している一方、多言語環境での使用を考えている場合は Notta AI が良い選択肢となるでしょう。

Whisper と比較すると、これらのツールは特定の用途や言語に特化している点が特徴です。一方で、Whisper はオープンソースであり、カスタマイズの自由度が高いという利点があります。

次のセクションでは、Whisper を使ったより応用的な使い方について解説します。処理経過の可視化や英語翻訳の活用など、Whisper の高度な機能を最大限に活用する方法を紹介します。

Whisperを使った応用的な使い方

Whisper の基本的な文字起こし機能に加えて、より高度な活用方法があります。ここでは、処理経過の可視化と英語翻訳の活用方法について詳しく解説します。これらの応用的な使い方を理解することで、Whisper の可能性をさらに広げることができるでしょう。

処理経過の可視化

Whisper の処理経過を可視化することで、文字起こしの過程をより詳細に理解し、必要に応じて調整を行うことができます。

  1. タイムスタンプ付き出力:
   result = model.transcribe("audio.mp3")
   for segment in result["segments"]:
       print(f"{segment['start']:.2f} - {segment['end']:.2f}: {segment['text']}")

この方法で、各セグメントの開始時間と終了時間、そして対応するテキストを表示できます。

  1. 信頼度スコアの表示:
   for segment in result["segments"]:
       print(f"Text: {segment['text']}")
       print(f"Confidence: {segment['confidence']:.2f}")

各セグメントの信頼度スコアを表示することで、認識の確実性を評価できます。

  1. スペクトログラムの表示:
   import matplotlib.pyplot as plt
   import librosa

   y, sr = librosa.load("audio.mp3")
   D = librosa.stft(y)
   S_db = librosa.amplitude_to_db(np.abs(D), ref=np.max)

   plt.figure(figsize=(12, 8))
   librosa.display.specshow(S_db, sr=sr, x_axis='time', y_axis='hz')
   plt.colorbar(format='%+2.0f dB')
   plt.title('Spectrogram')
   plt.show()

音声のスペクトログラムを表示することで、音声の特徴をビジュアル化できます。

処理経過の可視化により、Whisper の文字起こし過程をより深く理解し、問題点の特定や精度向上のための調整が可能になります

英語翻訳の活用方法

Whisper は文字起こしだけでなく、多言語間の翻訳機能も備えています。特に英語への翻訳機能は高い精度を誇ります。

  1. 英語への翻訳:
   result = model.transcribe("non_english_audio.mp3", task="translate")
   print(result["text"])

このように、task="translate" オプションを指定することで、入力音声を英語に翻訳できます。

  1. 原語と英訳の同時出力:
   result_orig = model.transcribe("non_english_audio.mp3")
   result_trans = model.transcribe("non_english_audio.mp3", task="translate")

   for seg_orig, seg_trans in zip(result_orig["segments"], result_trans["segments"]):
       print(f"Original: {seg_orig['text']}")
       print(f"English: {seg_trans['text']}")
       print("---")

この方法で、原語のトランスクリプションと英訳を並べて表示できます。

  1. 多言語コンテンツの作成:
   languages = ["ja", "fr", "de", "es"]
   results = {}

   for lang in languages:
       results[lang] = model.transcribe("audio.mp3", language=lang)

   for lang, result in results.items():
       print(f"Language: {lang}")
       print(result["text"])
       print("---")

この例では、同じ音声を複数の言語で文字起こしし、多言語コンテンツを作成しています。

Whisper の翻訳機能を活用することで、国際的なコミュニケーションや多言語コンテンツの作成が容易になります。例えば、生成AIを活用した英語学習と教育の最新事例で紹介されているような教育分野での活用も期待できます。

これらの応用的な使い方を理解し、実践することで、Whisper の機能をより深く、より効果的に活用することができます。文字起こしの精度向上や多言語対応など、様々なニーズに応じた柔軟な運用が可能となるでしょう。

まとめ

Whisper は高精度で多言語対応の文字起こしツールとして、ビジネスや研究分野で広く活用されています。無料で利用できる点や、APIを通じた柔軟な統合が可能な点が大きな魅力です。適切な運用とセキュリティ対策を行うことで、効果的に活用できるでしょう。

Comments

Copied title and URL