TS と AI が出会うと何が起こるでしょうか?

TS と AI が出会うと何が起こるでしょうか?

人工知能は日々進歩しており、大規模な言語モデルはますます強力になっています。仕事に役立つ AI ツールを使用すると、作業効率が大幅に向上します。数文字入力して Tab キーを押すだけで、コードがインテリジェントに完成します。

コード補完に加えて、AI を利用して関数を自動化し、必要な JSON データを返すこともできます。

例を見てみましょう:

 // index.ts interface Height { meters: number; feet: number; } interface Mountain { name: string; height: Height; } // @ts-ignore // @magic async function getHighestMountain(): Promise<Mountain> { // Return the highest mountain } (async () => { console.log(await getHighestMountain()); })();

上記のコードでは、世界最高峰の情報を取得するための getHighestMountain 非同期関数を定義しています。その戻り値は、Mountain インターフェイスで定義されたデータ構造です。関数内には特定の実装はなく、コメントを通じて関数が実行する必要があることを記述するだけです。

上記のコードをコンパイルして実行すると、コンソールに次の結果が出力されます。

 { name: 'Mount Everest', height: { meters: 8848, feet: 29029 } }

世界で最も高い山はエベレストです。ヒマラヤ山脈の主峰であり、標高8,848.86メートルで世界最高峰でもあります。すごいと思いませんか?

次に、getHighestMountain関数の秘密を明らかにします。

getHighestMountain 非同期関数内で何が起こっているかを理解するために、コンパイルされた JS コードを見てみましょう。

 const { fetchCompletion } = require("@jumploops/magic"); // @ts-ignore // @magic function getHighestMountain() { return __awaiter(this, void 0, void 0, function* () { return yield fetchCompletion("{\n // Return the highest mountain\n}", { schema: "{\"type\":\"object\",\"properties\":{\"name\":{\"type\":\"string\"},\"height\":{\"$ref\":\"#/definitions/Height\"}},\"required\":[\"height\",\"name\"],\"definitions\":{\"Height\":{\"type\":\"object\",\"properties\":{\"meters\":{\"type\":\"number\"},\"feet\":{\"type\":\"number\"}},\"required\":[\"feet\",\"meters\"]}},\"$schema\":\"http://json-schema.org/draft-07/schema#\"}" }); }); }

上記のコードからわかるように、@jumploops/magic ライブラリの fetchCompletion 関数は getHighestMountain 関数内で呼び出されます。

この関数のパラメータから、前の TS 関数の関数注釈がわかります。さらに、スキーマ属性を含むオブジェクトも確認できます。このプロパティの値は、Mountain インターフェイスに対応する JSON スキーマ オブジェクトです。

次に、@jumploops/magic ライブラリの fetchCompletion 関数の分析に焦点を当てます。この関数は fetchCompletion.ts ファイルで定義されており、内部処理フローは次の 3 つのステップに分かれています。

  • Chat Completions API に必要なプロンプトを組み立てます。
  • 応答結果を取得するには、Chat Completions API を呼び出します。
  • 応答を解析し、JSON スキーマを使用して応答オブジェクトを検証します。
 // fetchCompletion.ts export async function fetchCompletion( existingFunction: string, { schema }: { schema: any }) { let completion; // (1) const prompt = ` You are a robotic assistant. Your only language is code. You only respond with valid JSON. Nothing but JSON. For example, if you're planning to return: { "list": [ { "name": "Alice" }, { "name": "Bob" }, { "name": "Carol"}] } Instead just return: [ { "name": "Alice" }, { "name": "Bob" }, { "name": "Carol"}] ... Prompt: ${existingFunction.replace('{', '') .replace('}', '').replace('//', '').replace('\n', '')} JSON Schema: \`\`\` ${JSON.stringify(JSON.parse(schema), null, 2)} \`\`\` `; // (2) try { completion = await openai.createChatCompletion({ model: process.env.OPENAI_MODEL ? process.env.OPENAI_MODEL : 'gpt-3.5-turbo', messages: [{ role: 'user', content: prompt }], }); } catch (err) { console.error(err); return; } const response = JSON.parse(completion.data.choices[0].message.content); // (3) if (!validateAPIResponse(response, JSON.parse(schema))) { throw new Error("Invalid JSON response from LLM"); } return JSON.parse(completion.data.choices[0].message.content); }

Prompt では、AI の役割を設定し、有効な JSON 形式を返すようにガイドするための例をいくつか用意しました。

Chat Completions API を呼び出して応答結果を取得し、openai ライブラリによって提供される createChatCompletion API を直接使用します。

応答結果を解析した後、validateAPIResponse 関数が呼び出され、応答オブジェクトが検証されます。この機能の実装も比較的簡単です。 ajv ライブラリは、JSON スキーマに基づくオブジェクト検証を実装するために内部的に使用されます。

 export function validateAPIResponse( apiResponse: any, schema: object): boolean { const ajvInstance = new Ajv(); ajvFormats(ajvInstance); const validate = ajvInstance.compile(schema); const isValid = validate(apiResponse); if (!isValid) { console.log("Validation errors:", validate.errors); } return isValid; }

次に、TS コードを fetchCompletion 関数を呼び出す JS コードにコンパイルする方法を分析します。

ttypescript ライブラリは @jumploops/magic によって内部的に使用され、tsconfig.json ファイルでカスタム トランスフォーマーを構成できるようになります。

トランスフォーマー内には、TypeScript によって提供される API があり、これを使用して AST を解析および操作し、目的のコードを生成します。トランスフォーマー内部の主な処理フローも、次の 3 つのステップに分けられます。

  • // @magicannotation; を含む AI 関数のソース コードをスキャンします。
  • AI関数の戻り値の型に応じて、対応するJSONスキーマオブジェクトを生成します。
  • AI関数本体から関数アノテーションを抽出し、fetchCompletion関数を呼び出すコードを生成します。

この記事では、TypeScript コンパイラによって生成された AST オブジェクトを解析および操作する方法については重点的に扱いません。興味があれば、@jumploops/magic プロジェクトの transformer.ts ファイルを読んでみてください。 AI機能を自分で体験したい場合は、この記事の例にあるpackage.jsonとtsconfig.jsonの設定を参考にしてください。

パッケージ.json

 { "name": "magic", "scripts": { "start": "ttsc && cross-env OPENAI_API_KEY=sk-*** node src/index.js" }, "keywords": [], "author": "", "license": "ISC", "devDependencies": { "@jumploops/magic": "^0.0.6", "cross-env": "^7.0.3", "ts-patch": "^3.0.0", "ttypescript": "^1.5.15", "typescript": "4.8.2" } }

tsconfig.json ファイル

{ "compilerOptions": { "target": "es2016", "module": "commonjs", "esModuleInterop": true, "allowSyntheticDefaultImports": true, "strict": true, "skipLibCheck": true, "plugins": [{ "transform": "@jumploops/magic" }] }, "include": ["src/**/*.ts"], "exclude": [ "node_modules"], }

チャット完了 API は必ずしも期待される形式で有効な JSON オブジェクトを返すとは限らないため、実際には適切な例外処理ロジックを追加する必要があることに注意してください。

現在、@jumploops/magic ライブラリは簡単な例のみを提供し、関数パラメータの設定はサポートしていません。この部分については、Marvin ライブラリの AI 関数に関するドキュメントを読むことができます。

大規模言語モデルが要件に応じて制御可能な方法で構造化データを出力できる場合。そうすれば、私たちにできることはたくさんあります。

現在、多くのローコード プラットフォームや RPA (ロボティック プロセス オートメーション) プラットフォームは、対応する JSON スキーマ オブジェクトを取得できます。

@jumploops/magic のソリューションを使用すると、ローコード プラットフォームや RPA プラットフォームをよりスマートにすることができます。たとえば、フォーム ページをすばやく作成したり、さまざまなタスクを自然言語で公開したりできます。

最後に、@jumploops/magic ライブラリの背後にある作業をまとめましょう。このライブラリは、TypeScript トランスフォーマーを使用して関数の戻り値の型を取得し、その型を JSON スキーマ オブジェクトに変換してから、ソース コード関数の本体を // @magic アノテーション付き関数に置き換え、チャット完了 API を呼び出して、応答を JSON スキーマに対して検証します。

本日の記事はこれで終わりです。お役に立てれば幸いです。

<<:  バンク・オブ・アメリカのアナリスト:チャットボットの中ではChatGPTが最大の優位性を持っており、ユーザーの半数以上が有料サービスにお金を支払うだろう

>>:  誰でも簡単にウェブサイトを構築できる 5 つの AI ウェブサイトビルダー

ブログ    
ブログ    
ブログ    
ブログ    

推薦する

ビル・ゲイツ:中国がAIで他国を追い抜くとは思わない

マイクロソフトの創業者ビル・ゲイツは、現在のAIの開発動向についてどう考えているのでしょうか?最近の...

ChatGPT Civilization Simulator が再びオンラインになりました!クリックひとつで、火山噴火の日の古代都市ポンペイにタイムスリップ

GPT-4のアップデート機能により、AIを使って歴史をシミュレートすることは、単なる「テキストロール...

機械学習: 決定木について

ロジスティック回帰の基本原理と勾配降下法の導出プロセスについて説明しました。このコードは、分類アルゴ...

百度AIシティが上海と契約を締結、インテリジェントイノベーションで上海に新たな伝説を刻む

11月27日、百度は上海市政府と戦略的協力枠組み協定を締結した。上海市党委員会書記の李強氏と市党委員...

Nvidia は、実物大、数千ポンドを持ち上げることができるロボットなど 6 台のロボットを披露します...

近年、黄氏はグラフィックカードに加え、AIやロボットにもますます注目している。来月開催されるGTC ...

...

...

グラフィカル分散コンセンサスアルゴリズム

本日の記事では、グラフを使用して分散一貫性の実装原則を深く研究し、理解します。まず、自己を見つめ直す...

...

あなたの GPU は Llama 2 のような大規模なモデルを実行できますか?このオープンソースプロジェクトを試してみてください

コンピューティング能力が重要視される時代に、GPU は大規模モデル (LLM) をスムーズに実行でき...

...

...

自動配送物流における人工知能の応用

[[406604]]コロナウイルスの流行を受けて、企業はサプライチェーンの複雑性と労働力不足の課題を...

2019年の中国人工知能産業の競争環境の分析

近年、人工知能の技術と応用は成熟を続けており、人工知能市場の規模は徐々に拡大しています。中国情報通信...

【他者から学ぶ】360 多面的関心の想起マインド実践的最適化

1. 事業背景ショートビデオや情報ストリームなどのシナリオの増加に伴い、ユーザーはこれらのシナリオで...