Microsoft Ignite 2021の基調講演で発表された「Azure OpenAI Service」。公式ページにある通りOpenAI でOpenAI APIを発行してもらったので、Expamplesにある49個のアプリから「Turn by turn directions」をPythonから実行して試行錯誤します。
OpenAIのExpamplesにあるTurn by turn directionsとは
公式の説明では「Convert natural language to turn-by-turn directions.」とあり、“自然言語をターン・バイ・ターン・ガイドに変換”となります。
” turn-by-turn directions”とはGoogleマップなどで経路を検索した詳細に表示される
- 国道○号線を真っすぐ進みます
- 〇〇交差点を左折して、旧○号線を進みます
- 〇〇を右折して目的地は右です
のようなナビゲーションを指します。
公式のタグでは「Transformation」と「Generation」の2つが付与されています。
プログラムを見ると、エンジンは「davinci-instruct-beta」という「davinci-instruct」というエンジンのβ版となっています。文章を理解して要約するので「davinci」かと思いましたが、指示する要素があるので「davinci-instruct」なのかもしれません。
サンプルコードでは最初に「Create turn-by-turn directions from this text:(このテキストからターンバイターンの案内を作成します。)」とあり、” turn-by-turn directions”を作ることが最初に明示されています。
早速使ってみた
公式にあるコードを参考に、好きな文章を入れられるように str という変数に会話を入れて実行できるようにします。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
Python Code ‘’’ import os import openai openai.api_key = os.getenv("OPENAI_API_KEY") str = """ Create turn-by-turn directions from this text: Go south on 95 unto you hit Sunrise boulevard then take it east to us 1 and head south. Tom Jenkins bbq will be on the left after several miles. 1.""" response = openai.Completion.create( engine="davinci-instruct-beta", prompt=str, temperature=0, max_tokens=64, top_p=1.0, frequency_penalty=0.0, presence_penalty=0.0 ) print(response["choices"][0]["text"]) ‘’’ |
道案内の文章をターンバイターンナビゲーションに変換してくれる
道案内情報として「Go south on 95 unto you hit Sunrise boulevard then take it east to us 1 and head south. Tom Jenkins bbq will be on the left after several miles.(95号線を南下し、Sunrise boulevardにぶつかるまで行き、そこから東に進み、US1に出て南に向かいます。Tom Jenkins bbqは数マイル先の左手にあります。)」と目的地であるTom Jenkins bbqまでの行き方を説明しています。
実行すると、
「 1. Drive south on 95.(95号線を南下する。)
2. Turn left onto Sunrise Blvd.(Sunrise Blvdを左折します。)
3. Turn left onto US-1 SE.(US-1 SEを左折します。)
4. Tom Jenkins BBQ will be on the left.(Tom Jenkins BBQは左手にあります。) 」
となりました。
元の文章を見ると、「Sunrise boulevardにぶつかるまで行き、そこから東に進み」という部分をその前の南下したことから東=左折としています。単純に文章を分割しているだけでなく、方角を解釈して右折・左折といった正しい指示をしてくれます。
どんなときに使えるのか?
いくつかのシチュエーションで試みたのですが、なかなか思うような結果を返してくれませんでした。これはbeta版だからそのような結果になった可能性が高いと思われます。
OpenAIでは、文章から方角や方向と言った地理的な内容まで理解し文章にしてくれます。ナビゲーションだけであればGoogleマップやYahoo!カーナビのようなアプリケーションで行うことが出来ますが、文章から地理的なものまで理解するOpenAIの凄さを改めて感じました。