生活

プロンプトとは何か?基本概念や活用方法などわかりやすく解説!

プロンプト

はじめに

プロンプトとは、生成的人工知能(AI)モデルに対して特定のタスクを指示するために使用される自然言語のテキストです。このテキストは、AIが何を行うべきかを的確に理解し、適切な結果を生成するための指針となります。AIモデルは非常に多様なタスクに対応できますが、その能力を正確に発揮させるには、適切に設計されたプロンプトが必要不可欠です。

特に大規模言語モデル(LLM)は、膨大なデータを基に学習した高度な自然言語処理能力を持つモデルであり、質問に対する回答の生成、文章の翻訳、さらには複雑な問題の解決まで、多岐にわたるタスクを実行可能です。しかし、AIモデルの性能はプロンプトの質に大きく依存します。不適切なプロンプトでは曖昧な回答が返される可能性が高く、一方で明確で具体的なプロンプトはAIの性能を最大限に引き出します。

プロンプトは単なる指示文ではなく、AIモデルの能力を最大化するための戦略的な設計が必要な重要な要素です。 適切なプロンプト設計は、AIモデルの性能を大きく左右し、ユーザーの期待する結果を得るための鍵となります。例えば、AIに「小説の冒頭を書いてください」と依頼する際、特定のスタイルや内容を指定しなければ、モデルは一般的な形式でしか応答しません。しかし、「推理小説風で、登場人物が孤独な探偵である冒頭を書いてください」といった詳細なプロンプトを提供することで、AIはより的確な応答を生成することができます。

このように、プロンプトはAIの操作を明確にする役割を果たし、ユーザーの意図を正確に伝えるためのツールとして機能します。本記事では、プロンプトの基本的な定義からその役割、さらに生成的AIモデルの活用における具体的な重要性について詳しく解説します。また、プロンプト設計の具体例やその効果的な活用方法についても触れ、AIを利用する上での最善のアプローチを探ります。

プロンプトの基本概念

プロンプトとは、生成的人工知能(AI)モデルに対して実行すべきタスクやその方向性を指示する自然言語テキストのことを指します。生成AIモデルが多様なタスクを実行する際、このプロンプトが重要な役割を果たします。例えば、大規模言語モデル(LLM)は、プロンプトによって「次の単語を予測する」だけではなく、質問に答える、物語を作る、要約を行うなどの高度なタスクを遂行します。プロンプトは、AIに意図を伝えるための媒介として、ユーザーとモデルをつなぐ橋のような存在です。

AIに与えるプロンプトは、単なる指示ではなく、構造的かつ明確である必要があります。曖昧なプロンプトでは、AIが正確な出力を生成することが困難になる一方で、具体的で適切なプロンプトはAIの能力を最大限に引き出します。例えば、「この文章を改善して」という指示では出力が漠然とする可能性がありますが、「この文章を学術的なトーンに変えてください」といった明確なプロンプトを与えることで、期待する結果に近づくことができます。

プロンプトが自然言語テキストである理由

プロンプトが自然言語テキストとして設計される主な理由は、AIモデルが人間の言語パターンに基づいて学習しているためです。大規模言語モデルは、膨大な量の自然言語データを基にトレーニングされており、人間の文章や会話を模倣する能力に優れています。このため、自然言語によるプロンプトはモデルにとって最も解釈しやすい形式となります。

また、自然言語テキストは人間にとっても直感的であり、専門知識がなくてもAIを操作できる利便性を提供します。例えば、プログラムコードのような形式的な記述を使わず、「英語の文章を日本語に翻訳してください」といった日常的な言葉でプロンプトを与えるだけで、モデルは高度な翻訳を行います。このシンプルさが、生成的AI技術を広範なユーザー層に普及させる原動力となっています。

「テキストからテキスト」型や「テキストから画像」型モデルへの応用例

プロンプトの力は、「テキストからテキスト」型や「テキストから画像」型モデルを活用する際に顕著に表れます。「テキストからテキスト」型モデルでは、プロンプトを通じて特定のタスクを指示することで、回答や創造的なテキストを生成できます。例えば、「フェルマーの小定理について説明してください」といったプロンプトを使用すると、詳細で正確な解説が得られます。また、「この文章を5行以内で要約してください」といった命令は、効率的な情報抽出に役立ちます。

一方、「テキストから画像」型モデルでは、プロンプトが芸術作品や視覚的なイメージを生成する手段として機能します。例えば、「宇宙飛行士が馬に乗っている写真を生成してください」といったプロンプトを入力するだけで、高度な画像生成モデルがこの要求に応じた作品を作り出します。さらに、「明るい夕日の風景をリアルな油絵風で描いてください」と指定することで、様々なスタイルや媒体に応じた画像が生成可能です。

これらの応用例は、プロンプトが生成的AIの動作においていかに重要な役割を果たすかを示しています。プロンプトを適切に設計することが、AIの性能を最大限に引き出す鍵であり、ユーザーが望む結果を得るためには欠かせない要素です。

プロンプト・エンジニアリングとは

プロンプト

プロンプト・エンジニアリングとは、生成的AIモデルや大規模言語モデル(LLM)が解釈しやすい指示文を設計・構築する技術です。この技術は、モデルの性能を最大限に引き出し、ユーザーの期待する結果を得るための鍵となる要素です。プロンプトは、AIが受け取る入力の中核であり、その構造と内容が出力の精度や品質に直接影響を与えます。プロンプト・エンジニアリングは、AIとユーザーの間のコミュニケーションを効果的にするための基盤的な技術と言えます。

生成的AIの普及とともに、プロンプト・エンジニアリングは特に重要性を増しています。単純な命令や質問だけでなく、複雑な文脈を提供することで、AIはより洗練された応答を生成することが可能となります。この技術は、AIの可能性を引き出すだけでなく、幅広い業界や分野でのAI活用を支える基盤となっています。

プロンプト・エンジニアリングの定義

プロンプト・エンジニアリングは、AIモデルが受け取る入力文(プロンプト)を最適化するプロセスとして定義されます。具体的には、AIがユーザーの意図を正確に解釈し、期待する結果を生成するようにプロンプトを設計します。このプロセスでは、単語選び、文法構造、さらには文脈の詳細まで考慮されます。

例えば、「数学の問題を解いてください」と単純に指示する場合と、「この数式を具体的な手順で解いてください」と指示する場合では、AIの応答に大きな違いが生じます。プロンプトの設計次第でAIの能力を十分に発揮させることができるため、この技術はAIを活用する上で不可欠です。

プロンプト・エンジニアリングの重要性と具体的な役割

プロンプト・エンジニアリングが重要である理由は、AIモデルが与えられたプロンプトをそのまま基にして応答を生成する仕組みにあります。プロンプトが曖昧であれば、モデルの応答も不明確である可能性が高くなります。一方で、具体的かつ明確なプロンプトを与えることで、AIの応答の精度と信頼性が向上します。

具体的な役割としては、以下の点が挙げられます:

  • モデルが取り組むべきタスクを正確に定義する。
  • モデルに必要な文脈や背景情報を提供する。
  • 出力結果の形式やトーンを指定する。

例えば、学術的なトーンで文章を生成させる場合、「学術的な文体で」と明記するプロンプトを使用すると、より適切な結果が得られます。このように、プロンプト・エンジニアリングはAIの性能を最大限に引き出す役割を担っています。

クエリの言い回し、様式の指定、関連するコンテキスト提供などの手法

プロンプト・エンジニアリングには、さまざまな手法が含まれます。その中でも特に重要な要素が、クエリの言い回し、様式の指定、関連するコンテキストの提供です。

まず、クエリの言い回しについてです。簡潔で明確な言葉遣いを用いることで、AIモデルが指示を正確に理解しやすくなります。例えば、「説明してください」といった一般的な指示よりも、「簡潔に要約してください」と明確に指示する方が適切です。

次に、様式の指定です。たとえば、文体やトーンを具体的に設定することで、期待する出力の方向性を明確に示すことができます。例として、「フレンドリーな口調で回答してください」といった指示をプロンプトに含めることで、応答の雰囲気が大きく変わります。

最後に、関連するコンテキストの提供です。AIモデルに対して事前の情報や背景をプロンプトに含めることで、より正確な応答を得ることができます。例えば、「この文章はビジネスプレゼンテーション用です」と文脈を提供することで、AIが適切な内容を生成する助けとなります。

これらの手法を活用することで、AIの出力結果がユーザーの期待に近づきます。プロンプトの工夫次第で、AIの応答が大きく変わることを理解し、適切なプロンプト設計を行うことが重要です。

プロンプトを活用方法

プロンプトは、生成的AIモデルの出力を最適化するための強力なツールです。その中でも、少数ショット学習やゼロショット学習、思考連鎖プロンプト、その他のプロンプト・エンジニアリング手法が注目されています。これらの手法を活用することで、モデルの応答品質を向上させ、より具体的で正確な結果を得ることが可能となります。

特に、大規模言語モデル(LLM)は、提示されたプロンプトの質と構造に大きく依存しています。適切なプロンプト設計が、AIモデルの性能を左右するため、各手法を理解し、効果的に活用することが重要です。

少数ショット学習とゼロショット学習

少数ショット学習(Few-shot learning)は、モデルに少数の具体例を提示することで、その例を基に新しいタスクを遂行させる手法です。これにより、モデルはタスクのコンテキストを理解しやすくなり、正確な応答を生成する可能性が高まります。例えば、翻訳タスクにおいて「maison→家、chat→猫、chien→」といった例を提示することで、「犬」という正しい翻訳を導き出すことができます。

一方、ゼロショット学習(Zero-shot learning)は、具体例を提示せずにプロンプトだけでモデルにタスクを遂行させる手法です。ゼロショット学習では、モデルの事前学習データと汎用的な理解能力が重要となります。この手法は、例を用意する手間を省きつつも、適切なプロンプト設計によって高い精度を実現できます。

少数ショットとゼロショットは、状況に応じて使い分けるべき手法であり、それぞれに長所と短所があります。適切な選択によってモデルの応答品質を最適化することが可能です。

思考連鎖プロンプトの例とその効果

思考連鎖プロンプト(Chain-of-thought prompting)は、複数のステップからなる推論タスクを分解し、各ステップを順序立てて解決する手法です。このプロンプト手法は、モデルに論理的な思考過程を模倣させることで、複雑な問題に対する解答精度を向上させます。

例えば、「食堂に23個のリンゴがあり、昼食の準備で20個を使用し、その後6個購入した場合、リンゴは何個あるか?」という問題に対し、思考連鎖プロンプトは以下のようにモデルを導きます:

「A: 最初に23個のリンゴがありました。20個を使用したので、23−20=3個残っています。さらに6個購入したので、3+6=9個になります。答えは9個です。」

この手法により、モデルは計算や論理的推論を段階的に進めることができ、最終的な応答の正確性が大幅に向上します。特に数学的推論や常識的推論において有効です。

その他のプロンプト・エンジニアリング手法

思考連鎖プロンプト以外にも、さまざまなプロンプト・エンジニアリング手法が存在します。それぞれの手法には独自の特徴と適用範囲があり、タスクに応じて使い分けることでモデルの能力を最大限に引き出すことができます。

生成的知識プロンプト

生成的知識プロンプト(Generated knowledge prompting)は、モデルに関連する事実を生成させ、それを基にタスクを解決する手法です。これにより、モデルは背景知識を考慮した応答を生成できるため、より深い理解が求められるタスクに適しています。

自己一貫性デコーディング

自己一貫性デコーディング(Self-consistency decoding)は、思考連鎖を複数回実行し、最も一致した結論を選択する手法です。これにより、異なる推論経路で得られる結果の一貫性を確保し、応答の信頼性を高めます。

Tree-of-thought

Tree-of-thoughtは、思考連鎖をさらに一般化した手法であり、複数の「次の可能なステップ」を生成し、それらを幅優先探索やビーム探索で評価することで最適な解答を導き出します。これは、複雑な常識的推論や大規模な選択肢があるタスクにおいて特に有効です。

これらの手法を活用することで、モデルの性能を多面的に引き出すことが可能です。それぞれの手法の特性を理解し、適切に組み合わせることで、生成的AIモデルの可能性を最大限に活用できます。

「テキストから画像」へのプロンプトの応用

プロンプト

「テキストから画像」モデルは、人工知能の進化における重要なマイルストーンとして注目されています。これらのモデルは、ユーザーが入力したテキストを基に画像を生成する技術であり、DALL-E、Stable Diffusion、MidJourneyなどのツールがその代表例です。この技術の普及により、アート、デザイン、広告などの分野での新しい可能性が広がっています。

「テキストから画像」技術は、創造性とテクノロジーの融合を可能にする画期的な手段であり、テキストプロンプトの構造や設計が生成結果の質に大きな影響を与えます。

テキストから画像モデルの登場と普及

DALL-EはOpenAIが開発したモデルで、入力されたテキストを基に高品質な画像を生成する能力を持っています。この技術は、2021年に初めて公開され、以降多くの改良が施されてきました。Stable DiffusionやMidJourneyも同様に、ユーザーに直感的で使いやすいインターフェースを提供し、個人から企業まで幅広い利用者を対象としています。

これらのツールの普及は、商業的利用だけでなく、個人の創作活動にも新たな可能性をもたらしました。例えば、ゲーム開発者はキャラクターデザインに、広告業界では視覚的にインパクトのあるキャンペーンの作成に使用しています。さらに、アートやエンターテインメント分野における新しい表現方法としても注目されています。

テキストから画像モデルでのプロンプトの構造

テキストから画像モデルにおけるプロンプトは、生成される画像の質やスタイルを大きく左右します。プロンプトの構造には以下の要素が含まれます:

  • 主題:生成したい画像の中心的な要素(例:猫、風景、建築物など)。
  • スタイル:生成画像の美的方向性やアートスタイル(例:印象派、写実主義、アニメスタイルなど)。
  • 詳細:画像に含めたい特定のディテールや要素(例:夕日の下、青い服を着たキャラクター)。

効果的なプロンプトは、モデルに対して具体的で明確な指示を与えます。例えば、「青い空と緑の草原の中に立つ赤い風車」というプロンプトは、生成される画像の構成を具体的に規定します。一方、抽象的なプロンプトでは、モデルの解釈により多様な結果が得られる場合があります。

プロンプトの設計次第で生成結果の方向性が大きく変わるため、目的に応じて適切なプロンプトを作成することが重要です。

ネガティブプロンプトやアーティストの作風を模倣するプロンプトの使用例

「ネガティブプロンプト」は、画像に含めたくない要素を指定する技法です。これにより、生成結果から望ましくない要素を排除し、品質を向上させることができます。例えば、「暗い背景を除外」「歪んだ形を避ける」といった指示を与えることで、視覚的により洗練された画像を得ることが可能です。

また、アーティストの作風を模倣するプロンプトも一般的です。例えば、「ヴァン・ゴッホ風の夜空の下に咲くひまわり」や「宮崎駿のアニメに登場するようなファンタジーの街並み」というプロンプトは、特定の芸術スタイルを取り入れた画像を生成する際に役立ちます。

ネガティブプロンプトと作風模倣プロンプトは、ユーザーが期待する結果を明確に実現するための強力なツールです。これらを組み合わせることで、より高度で洗練された画像生成が可能となります。

「テキストから画像」モデルのプロンプト設計は、生成結果のクオリティやクリエイティブな表現を最大限に引き出す鍵となります。そのため、目的に応じて柔軟かつ詳細なプロンプトを構築するスキルが求められます。

プロンプト設計の課題と解決策

プロンプト設計は、生成AIモデルの性能を最大限に引き出すための重要な要素ですが、その過程にはさまざまな課題が伴います。これらの課題を解決するためには、モデルの感度への対処、自動化技術の活用、そしてセキュリティリスクの軽減が求められます。

プロンプト設計の成功は、適切な構造とモデル特性を考慮した柔軟なアプローチにかかっています。ここでは、主要な課題とその解決策について詳しく解説します。

モデルのプロンプトに対する感度や形式依存の問題

生成AIモデルは、プロンプトの微妙な違いによって大きく異なる結果を出力することがあります。この感度は、特に言語モデルで顕著であり、フォーマット、語順、文法、さらには言葉の選び方が結果に影響します。例えば、「説明してください」と「教えてください」のような些細な言い回しの違いでも、モデルの応答が変わる場合があります。

また、モデルはプロンプトの形式にも依存します。例えば、フォーマットが整っていないプロンプトや、冗長な文では意図した結果が得られないことがあります。この問題に対処するためには、以下のような方法が有効です:

  • 標準化されたフォーマットを使用することでモデルの感度を抑える。
  • 異なる表現や構造を試行錯誤することで、モデルが一貫して望ましい結果を出すプロンプトを特定する。

フォーマットと表現を洗練させることで、モデルの感度を管理し、安定した出力を得ることが可能になります

プロンプトの生成における自動化技術

プロンプト設計の効率を向上させるために、自動化技術が活用されています。その中でも代表的な手法がRetrieval-augmented generation(RAG)とGraphRAGです。

RAGは、文書検索と生成モデルを組み合わせた手法で、モデルに対して適切な文脈情報を提供します。具体的には、クエリに関連する文書をベクトル検索で抽出し、それをプロンプトに組み込むことで、より正確で豊かな生成結果を得ることができます。この手法は、特に動的な情報や外部データを参照する必要がある場合に効果的です。

一方、GraphRAGは知識グラフを活用することで、より高度な情報統合と洞察の生成を可能にします。複数のデータソースから得られた情報を知識グラフとして構造化し、モデルに提供することで、広範な意味理解が可能となります。

自動化技術の活用により、プロンプト設計の効率化とモデルの応答精度の向上が実現します

プロンプト・インジェクションとセキュリティリスク

プロンプト・インジェクションは、生成AIモデルに悪意ある指示を組み込むことで、意図しない動作を引き起こす攻撃手法です。この問題は、特に商業利用されるモデルや公共APIで深刻なセキュリティリスクをもたらします。たとえば、通常は非公開のシステムプロンプトを暴露させたり、生成ポリシーに違反する出力を引き出したりすることが可能です。

このリスクを軽減するためには、以下の対策が必要です:

  • プロンプトの入力を検証し、不正な内容が含まれていないことを確認する。
  • プロンプトとシステムの応答を監視し、異常な動作を早期に検出する。
  • モデルにおける不適切な応答を防ぐために、厳密なガイドラインを設定する。

セキュリティリスクへの対応は、プロンプト設計とモデル運用の信頼性を確保する上で欠かせない要素です

プロンプト設計における課題を克服し、解決策を適切に実施することで、生成AIモデルの可能性を最大限に引き出すことができます。これには、技術的なアプローチと倫理的配慮の両方が不可欠です。

プロンプトとコンテキスト内学習

プロンプト

コンテキスト内学習(In-context learning)は、生成AIモデルや大規模言語モデル(LLM)が与えられたプロンプト内で一時的に学習し、その情報を活用して適切な応答を生成する能力を指します。この手法は、従来の明示的なモデルトレーニングとは異なり、モデルの既存の知識と与えられたプロンプトの文脈を組み合わせることで、高度なタスク処理を可能にします。

コンテキスト内学習は、モデルが動的に応答を調整するための柔軟な手法であり、リアルタイムでの情報利用を可能にします。ここでは、プロンプトが一時的な学習を実現する仕組みや、この技術の利点について詳しく説明します。

コンテキスト内学習の概要

コンテキスト内学習とは、モデルがあらかじめ学習された固定されたパラメータを変更することなく、入力されたプロンプトの内容から必要な情報を抽出し、その文脈に基づいて応答を生成する能力を指します。この手法は、ユーザーから提供される追加情報を即座に活用し、新しいタスクや質問に対応するための基盤を提供します。

具体的には、モデルはプロンプト内の例や説明からパターンを認識し、そのパターンをもとに未知の質問やタスクに対応します。これにより、長期間のトレーニングプロセスを経ることなく、迅速かつ効率的な応答生成が可能になります。

プロンプトが一時的な学習を可能にする仕組み

プロンプトは、コンテキスト内学習を実現するための主要な要素です。具体的には、プロンプト内に含まれる例やヒントが、モデルに対して一時的な「学習データ」の役割を果たします。この仕組みは以下のように動作します:

  • プロンプト内にタスクの例や目標を提示し、モデルがそのパターンを抽出できるようにします。
  • 提示された例に基づき、モデルは同様のパターンを新しいタスクに適用します。
  • プロンプトが終了するまでの間、モデルはこれらの情報を保持し続けます。

プロンプト内で提供される情報の質と構造は、コンテキスト内学習の効果に直接影響を与えます。例えば、明確で一貫性のあるプロンプトは、モデルの応答の精度を向上させます。

コンテキスト内学習の創発的特性とその利点

コンテキスト内学習の特筆すべき点は、モデルが既存の知識に基づき、提供されたプロンプトから新しいタスクに対する解決策を「創発的」に見つけ出す能力です。これは、以下の利点をもたらします:

  • 柔軟性: モデルが固定されたタスクに限定されることなく、新しい問題に迅速に対応できます。
  • 効率性: 長期的なトレーニングが不要で、短期間で応答を生成可能です。
  • コスト削減: トレーニングデータの準備やモデルの再トレーニングにかかるリソースを削減できます。

さらに、コンテキスト内学習は、ユーザーの意図や文脈に基づいたカスタマイズされた応答を提供するため、より高いユーザーエクスペリエンスを実現します。

この技術は、動的な情報処理が求められるタスクにおいて特に強力であり、生成AIの幅広い応用を支える重要な基盤となっています

コンテキスト内学習は、生成AIの可能性を大きく広げる技術であり、プロンプト設計の重要性をさらに高める要因ともなっています。適切なプロンプトの活用と工夫によって、この技術のポテンシャルを最大限に引き出すことが可能です。

プロンプトの未来と可能性

プロンプトは、生成AIや大規模言語モデル(LLM)の性能を最大限に引き出す鍵として、その役割がますます重要になっています。今後、プロンプトがAI研究や産業全体に与える影響は多大であり、さまざまな分野でその可能性が広がると予測されています。さらに、プロンプト設計やエンジニアリングの進化により、自動化されたプロンプト生成やより高度な応用が現実のものとなるでしょう。

プロンプトの進化は、AIの能力をさらに引き出し、社会全体に新たな価値をもたらす可能性を秘めています。ここでは、プロンプトがAI研究や産業に与える影響、進化の方向性、そして社会への応用について展望を述べます。

プロンプトがAI研究や産業に与える影響

プロンプトは、AI研究の中核的なテーマとして進化を続けています。たとえば、プロンプト設計の工夫によって、AIモデルの性能が著しく向上することが知られています。これにより、AI研究者は、プロンプトを通じてモデルの限界を理解し、新しいアルゴリズムや技術を開発する契機を得ています。

産業分野においては、プロンプトは製品やサービスの開発においても重要な役割を果たしています。例えば、カスタマーサポートでは、プロンプトを活用してより正確で迅速な回答を提供できるようになりました。また、マーケティングや広告分野では、プロンプトを通じて消費者の意図を把握し、パーソナライズされたコンテンツを生成する技術が進んでいます。

プロンプトは単なるAIの補助要素ではなく、研究開発から商業応用に至るまでの幅広い領域で不可欠な基盤となりつつあります

プロンプトの進化と自動化の方向性

プロンプト設計は、従来は人間が手作業で行うものでしたが、現在ではその自動化が進んでいます。自動プロンプト生成技術は、AIモデルの応答精度を向上させるだけでなく、効率的なシステム設計を可能にします。特に、Retrieval-augmented Generation(RAG)やGraphRAGのような技術が注目されています。

将来的には、AIモデル自体が学習を通じてプロンプト設計を最適化する能力を持つと期待されています。このような進化により、人間が関与しなくても、タスクに最適化されたプロンプトが生成される仕組みが普及するでしょう。

プロンプトの自動化は、AIの応用範囲を大幅に広げ、より柔軟で高度なシステムの構築を可能にします

プロンプト・エンジニアリングの社会への応用

プロンプト・エンジニアリングの応用は、教育、医療、ビジネスなど、さまざまな社会的領域で期待されています。教育分野では、プロンプトを活用して個別化された学習体験を提供するシステムが開発されています。例えば、生徒の理解度に応じて適切な質問を生成し、学習の進行を支援することが可能です。

医療分野では、診断支援や治療プランの提案においてプロンプトが活用されています。例えば、患者の症状を基に適切な診断プロセスを導くプロンプトを設計することで、医療の質を向上させることができます。また、ビジネス分野では、プロンプトを活用して効率的な意思決定支援やデータ分析を行うシステムが普及しています。

プロンプト・エンジニアリングは、社会全体の生産性と利便性を向上させる強力なツールとして、今後さらに重要性を増すでしょう

プロンプトの未来は、AIの進化とともに広がり続けています。その可能性を最大限に引き出すためには、プロンプト設計の技術革新と応用領域の拡大が求められています。

PHPとは何か?構文や機能、セキュリティなどわかりやすく解説!

-生活

© 2025 ザッタポ Powered by AFFINGER5