生成AIに疑似コードで指示すると自然言語よりも効率的にプログラムが生成できるというアイデアから生まれた、生成AI用の疑似言語「SudoLang」

2024年7月8日

ChatGPTやCopilotなどの生成AIを用いてコードを生成しようとすると、多くの場合プロンプトを自然言語で書くことになるでしょう。

しかし自然言語で的確にプログラムの内容を表現するのは、ときに面倒だったり、あいまいさを排除することが難しかったりします。

一方で、プログラマが自分でコードを書こうとするとき、あるいは他のプログラマとコードの内容を議論するときに、自然言語をプログラミング言語のような構文で書く、いわゆる「擬似コード」を使うことがよくあります。

例えばこんな風に自然言語をコードっぽくホワイトボードに書いたことのあるプログラマの方は多いのではないでしょうか?

入力値を処理するための関数(A、B){
  Aは数字かどうか確認する
  Bは日付かどうか確認する
  Bの日付が有効範囲かどうかを確認する
  ………
  ………
}

このような疑似コードを、生成AIと人間がやりとりするためのプログラミング言語として発展させ、構文などを定義した生成AI用の疑似プログラミング言語「SudoLang」が提唱されています。

生成AIによるコード生成の面で大変興味深い取り組みに見えたので、ここで紹介したいと思います。

SudoLangをトランスパイルしてJavaScriptを生成

SudoLangは前述の擬似コードのように、自然言語による柔軟で分かりやすい記述に、プログラミング言語のような構造を持たせたものといえるでしょう。

これを生成AIが備える強力な推論の能力やコードの生成能力と組み合わせることで、単に自然言語で指示するよりも効率的で正確にプログラマの意図を生成AIに伝えることができ、的確なコードが生成できるようになるわけです。

言語の詳しい説明などはGitHubの「paralleldrive/sudolang-llm-support」で紹介されています。

SudoLangの開発者であるEric Elliott氏はAdobeでFireflyのエンジニアリングマネージャを務めている人物で、JavaScriptのエキスパートとしても知られています。

Eric Elliott氏は自身でSudoLangを開発した後、SudoLangをトランスパイルしてJavaScriptのコードやテストを生成できるようになったため、もうJavaScriptを自分で書きたくないと発言しています。

下記はオライリーのブログに投稿されたSudoLangを紹介する記事「Unlocking the Power of AI Driven Development with SudoLang」です。

このオライリーの記事はSudoLangの開発者であるEric Elliott氏自身が書いています。

fig

SudoLangは生成AIがランタイムでありトランスパイラである

SudoLangが興味深いのは、単に擬似コードで生成AIに意図を伝えるだけではありません。

開発プラットフォームとして生成AIがどう振る舞うべきかまでSudoLangのコード内に記述することで、生成AIをSudoLangコードのランタイムとしてそのまま実行させてロールプレイングゲームの相手として振る舞わせること(Example:Singular: A SudoLang Adventure)や、SudoLangコードの中に生成AIをコマンドラインインターフェイスのような開発環境としての振る舞いまで記述することで、生成AIに読み込ませたSudoLangコードの参照や変更、テストコードの生成、SudoLangからJavaScriptなどの実際のコードへのトランスパイルなどまで実行させることなどもできます(Example:autodux.sudo)。

(記事の最後の方で紹介する動画を見れば、上記のサンプルコードをそのままChatGPTにペーストしてSudoLangを試す方法がなんとなく分かるはずです)

例えば下記が「autodux.sudo」のSudoLangコード内で生成AIにSudoLangからJavaScriptへのトランスパイルを命じているコードです。生成AIの高い推論能力に期待して、正確に、読みやすく、関数的に、などなど口頭で人間に説明するみたいに書かれていて面白いですね。

transpile() {
  Constraints {
    !Concise
    Readable
    Functional
    Use arrow functions
    Use implicit returns when possible
    Supply all of the files listed in the files property 
    in separate JavaScript code blocks.
  }
}

あるいは下記のように自然言語でざっくり書くだけで(実際にはもう少しSudoLangコードには振る舞いが書き込まれていますが)、生成AIはそれがどのようなものかを推測し、コマンドプロンプトとして振る舞い、「/」から始まる命令を受け入れて実行してくれます。

  /help - Explain how to use Autodux and list commands.
  /example - Show example usage.
  /save - Return the Dux in SudoLang format.
  /test cases - List the test cases in SudoLang 
      format: TestCases [ ... ]
  /add [prop] [value] to the Dux object
  /transpile

下記の動画もEric Elliott氏が上記のautodux.studioのSudoLangコードをChatGPT-4に読み込ませた上で、対話や操作の後にトランスパイルでJavaScriptコードを生成している様子を紹介しています。

プロンプトエンジニアリングは生成AIが未成熟であるがゆえに必要なテクニックであり、生成AIの能力が高まれば不要になるのではないか、という議論があります。

一方で、自然言語が持つあいまいさや、人間の正確に自然言語を記述できる限られた能力は今後も変わらないとすると、生成AIの能力向上とは別に、この課題を解決する上でSudoLangのような言語のアイデアは有用なのではないかと思わされます。

あわせて読みたい

プログラミング言語 機械学習・AI




タグクラウド

クラウド
AWS / Azure / Google Cloud
クラウドネイティブ / サーバレス
クラウドのシェア / クラウドの障害

コンテナ型仮想化

プログラミング言語
JavaScript / Java / .NET
WebAssembly / Web標準
開発ツール / テスト・品質

アジャイル開発 / スクラム / DevOps

データベース / 機械学習・AI
RDB / NoSQL

ネットワーク / セキュリティ
HTTP / QUIC

OS / Windows / Linux / 仮想化
サーバ / ストレージ / ハードウェア

ITエンジニアの給与・年収 / 働き方

殿堂入り / おもしろ / 編集後記

全てのタグを見る

Blogger in Chief

photo of jniino

Junichi Niino(jniino)
IT系の雑誌編集者、オンラインメディア発行人を経て独立。2009年にPublickeyを開始しました。
詳しいプロフィール

Publickeyの新着情報をチェックしませんか?
Twitterで : @Publickey
Facebookで : Publickeyのページ
RSSリーダーで : Feed

最新記事10本