0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Frosty FridayAdvent Calendar 2024

Day 8

Frosty Friday Week 87解説:SnowflakeでLLMを始めよう

Last updated at Posted at 2024-12-07

この記事はFrosty Friday Advent Calendar 2024の8日目です。
みんなでFrosty Fridayをやってみよう!

Frosy Fridayとは

Frosty Fridayとは「Snowflakeユーザが、Snowflakeユーザのために作成し、Snowflakeスキルの練習と開発に役立つ」チャレンジです。
原文:
to help you practice and develop your Snowflake skills, created by Snowflake users, for Snowflake users.

こちらのサイトで毎週新しいチャレンジが公開されます。簡単な問題もあるのでSnowflake初心者が練習するときにちょうどいいですよ!

解説

今回はWeek 87をやっていきましょう。
Snowflake CortexというAI/ML/LLMに関する機能群の入門編で、LLMによる翻訳をやってみよう!というチャレンジです!
AI/ML/LLMを使うのは従来はデータサイエンティストがPythonなどでプログラムを作って…という感じでハードルが高い印象でしたが、Snowflake Cortexは代表的なAI/ML/LLMの機能をSQL文から簡単に呼び出せるようになっています。本当に簡単なのでWeek 87を通じてそれを体験してみましょう!
もちろん、複雑な課題が対象のときやある課題に特化したいときは従来のようなやり方が必要になると思いますが、それでも色々なところで活用できるはずですよ!

回答例はここにアップロードしてあります。

まず、テーブルを作成します。
チャレンジの説明文そのままですね。

-- 課題として与えられたテーブル
-- greetingに記載されたメッセージをlanguage_codesに記載された言語コードに翻訳するのが目的
CREATE OR REPLACE TABLE WEEK_87 AS
SELECT 
    'Happy Easter' AS greeting,
    ARRAY_CONSTRUCT('DE', 'FR', 'IT', 'ES', 'PL', 'RO', 'JA', 'KO', 'PT') AS language_codes
;

作成されたテーブルを確認してみましょう。
ARRAYという半構造化データで言語コードが格納されているので、これが1行1行になるようにLATERAL FLATTENも試してみます。

-- テーブルを確認する
SELECT * FROM WEEK_87;

-- 半構造化データであるARRAYをバラバラにする(LATERAL FLATTEN)
SELECT
  WEEK_87.greeting,
  LF.VALUE AS LANGUAGE_CODE
FROM WEEK_87,
LATERAL FLATTEN(WEEK_87.language_codes) LF;

ここからが回答例になります。
まず、Snowflake Cortexを初めて使うときは権限設定が必要になります。
データベースロールという機能で権限を取得することになります。
データベースロールについては少し専門的ですが、こちらの記事で解説されているので気になる方は確認してみてください。

-- Cortexを使う権限の付与
-- User名がmr_frostyであるとする
USE ROLE ACCOUNTADMIN;
CREATE ROLE cortex_user_role;
GRANT DATABASE ROLE SNOWFLAKE.CORTEX_USER TO ROLE cortex_user_role;
GRANT ROLE cortex_user_role TO USER mr_frosty;

翻訳にはCORTEX.TRANSLATEという関数を使います。
Snowflake Cortexの関数はSQL文で使えるようになっているので、テーブルをSELECTしているときに呼び出すことができます。

-- Cortex LLM Functionsの一つ、CORTEX.TRANSLATEを使って翻訳する
SELECT
    LF.VALUE AS LANGUAGE_CODE,
    SNOWFLAKE.CORTEX.TRANSLATE(
        WEEK_87.greeting,
        'EN',
        LF.VALUE
    ) AS TRANSLATED_GREETING
FROM
    WEEK_87,
LATERAL FLATTEN(WEEK_87.language_codes) LF;

これで無事にチャレンジクリアです!

Challenge Clear

おまけ

今回のチャレンジではCORTEX.TRANSLATEという翻訳してくれる関数を使うものでしたが、メッセージに対する応答を生成する、ザ・LLMな機能も用意されています。
これはCORTEX.COMPLETEという関数なので、試しに使ってみましょう。

-- おまけ:Cortex LLM Functionsの一つ、CORTEX.COMPLETEを使うとメッセージに対する応答を生成できる
-- 利用できるモデルは英語版のドキュメントを確認する
-- https://docs.snowflake.com/en/user-guide/snowflake-cortex/llm-functions
SELECT
    SNOWFLAKE.CORTEX.COMPLETE(
        'llama3.1-70b',
        'Hello, how are you?'
    ) AS RESPONSE;

もちろん、CORTEX.TRANSLATEと組み合わせることもできます。
英語しか話せないモデルを使うときなどに応用できますね。

-- CORTEX.COMPLETEとCORTEX.TRANSLATEを組み合わせて翻訳したメッセージに対する応答を生成する
WITH
    TRANSLATED AS (
        SELECT
            SNOWFLAKE.CORTEX.TRANSLATE(
                WEEK_87.greeting,
                'EN',
                LF.VALUE
            ) AS TRANSLATED_GREETING
        FROM
            WEEK_87,
        LATERAL FLATTEN(WEEK_87.language_codes) LF
    )
SELECT
    TRANSLATED_GREETING,
    SNOWFLAKE.CORTEX.COMPLETE(
        'llama3.1-70b',
        TRANSLATED_GREETING
    ) AS RESPONSE
FROM
    TRANSLATED;

Combination

Frosty Fridayを始めよう!

Frosty Fridayの解法を紹介するYouTube番組をやっているGakuさんの記事を参考にして、ぜひチャレンジしてみてください。

こちらのYouTube番組はゲスト出演者も随時募集しているそうなので、Snowflakeに慣れてきたらぜひ出演を目指してみてくださいね!

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?