1
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?

OCIを使った画像分類システムの構築 - 初心者向け完全ガイド

Posted at

はじめに

皆さん、こんにちは。今回は、Oracle社が提供するクラウドサービス「OCI(Oracle Cloud Infrastructure)」を使って、画像分類システムを構築する方法をご紹介します。AIや機械学習に興味はあるけれど、実際にどう始めればいいのか分からない方や、OCIの機能を活用したい方に向けて、できるだけわかりやすく解説していきます。

OCIとは?

OCIとは「Oracle Cloud Infrastructure」の略で、Oracleが提供するクラウドコンピューティングサービスです。AWSやGCP、Azureなどと同様に、コンピューティングリソース、ストレージ、ネットワーク、そして今回取り上げるAI・機械学習サービスなど、様々なクラウドサービスを提供しています。

OCIの特徴として、エンタープライズ向けの高性能・高信頼性を重視していることや、従来のOracleデータベースとの親和性が高いことなどが挙げられます。また、無料枠も用意されているため、個人での学習用途にも適しています。

画像分類とは?

画像分類(Image Classification)は、AIが画像を分析して、その画像が何を表しているかを判断する技術です。例えば、「この画像は猫である」「この画像は犬である」というように、画像をあらかじめ定義されたカテゴリに分類します。

画像分類の応用例としては以下のようなものがあります:

  • 自動車の車種識別
  • 商品の自動分類
  • 医療画像の診断支援
  • 農作物の生育状態の判定
  • セキュリティカメラでの異常検知

本記事の目的と対象読者

この記事では、OCIのVISIONサービスを使って、画像分類システムを構築する方法を解説します。OCIのコンソールを使った操作を中心に説明しつつ、一部でPythonを使った実装例も紹介します。

対象読者は以下の方々です:

  • OCIを使ったことがない初心者の方
  • AIや機械学習に興味があるが、実践経験が少ない方
  • 画像分類システムを実際に構築してみたい方

前提知識としては、クラウドサービスの基本的な概念を理解していることが望ましいですが、初めての方でも手順に沿って進めることで、OCIの画像分類機能を利用できるようになります。

完成イメージ

この記事の手順に従うと、以下のようなことができるようになります:

  1. OCIのアカウントを作成し、必要な設定を行う
  2. OCIのオブジェクトストレージに画像をアップロードする
  3. OCIのデータラベリングサービスでデータセットを作成する
  4. OCIのVISIONサービスでカスタムモデルを作成・利用する

それでは、実際に手順を追って進めていきましょう!

環境構築

この章では、OCIを使った画像分類システムを構築するための環境を準備します。OCIアカウントの準備から基本的な設定までを解説します。

OCIアカウントの準備

まず最初に、OCIのアカウントが必要です。まだお持ちでない方は、以下の手順でアカウントを作成しましょう。

  1. Oracle Cloudのウェブサイトにアクセスします
  2. 「無料アカウントを作成」ボタンをクリックします
  3. 必要な情報を入力し、アカウントを作成します
  4. メールアドレスの確認と支払い情報の登録を行います(無料枠でも必要です)
  5. アカウント作成が完了したら、OCIコンソールにログインします

OCIは無料枠(Always Free)を提供しており、一定のリソースを無料で使用できます。今回の画像分類システムの構築には、この無料枠のリソースで十分です。

OCIコンソールへのログイン

アカウントを作成したら、OCIコンソールにログインしましょう。

  1. Oracle Cloudのウェブサイトにアクセスします
  2. 右上の「サインイン」ボタンをクリックします
  3. アカウント作成時に設定したユーザー名(メールアドレス)とパスワードを入力します
  4. 「サインイン」ボタンをクリックします

ログインに成功すると、OCIのダッシュボードが表示されます。

リージョンの確認と選択

OCIは世界中の様々な地域(リージョン)にデータセンターを持っています。日本国内では東京リージョンが利用可能です。

  1. OCIコンソールの右上にあるリージョン表示をクリックします
  2. 「日本東部(東京)」を選択します

リージョンを選択することで、そのリージョンのデータセンターにあるリソースを利用できるようになります。

コンパートメントの確認

OCIでは、リソースを「コンパートメント」という単位で管理します。コンパートメントは、リソースをグループ化するための論理的な区画です。

  1. OCIコンソールの左上にあるハンバーガーメニュー(三本線のアイコン)をクリックします
  2. 「アイデンティティとセキュリティ」→「コンパートメント」を選択します
  3. デフォルトのルートコンパートメントが表示されます

初めて利用する場合は、このデフォルトのコンパートメントを使用するか、必要に応じて新しいコンパートメントを作成します。

APIキーの設定(オプション)

OCIのAPIを使用する場合は、APIキーの設定が必要です。今回はコンソールでの操作が中心ですが、Pythonを使った操作も行うため、以下の手順でAPIキーを設定しておきましょう。

  1. OCIコンソールの右上にあるプロフィールアイコンをクリックします
  2. 「ユーザー設定」を選択します
  3. 「APIキー」タブを選択し、「APIキーの追加」をクリックします
  4. 「キー・ペアの生成」を選択し、秘密キーと公開キーをダウンロードします
  5. 「追加」ボタンをクリックします

これで、OCIのAPIを使用するための準備が整いました。

Python環境の準備(オプション)

Pythonを使ってOCIのAPIを利用する場合は、OCIのPython SDKをインストールする必要があります。以下のコマンドでインストールできます:

pip install oci

また、設定ファイルを作成する必要があります。APIキーの設定時にダウンロードした設定ファイルを、~/.oci/config(Windowsの場合はC:\Users\<ユーザー名>\.oci\config)に保存します。

以上で環境構築は完了です。次の章では、OCIのオブジェクトストレージを使って画像データを管理する方法を解説します。

OCIオブジェクトストレージの活用

この章では、OCIのオブジェクトストレージを使って画像データを管理する方法を解説します。オブジェクトストレージとは何か、バケットの作成方法、画像データのアップロード方法などを学びましょう。

オブジェクトストレージとは

オブジェクトストレージは、クラウド上でファイルを保存・管理するためのサービスです。OCIのオブジェクトストレージは、以下のような特徴があります:

  • 高い耐久性と可用性を持つ
  • 容量制限がなく、必要に応じて拡張可能
  • データへのアクセス制御が可能
  • REST APIを通じてプログラムからアクセス可能
  • 様々なタイプのデータ(画像、動画、テキストなど)を保存可能

オブジェクトストレージでは、データは「バケット」と呼ばれるコンテナに保存されます。バケットはフォルダのようなもので、関連するファイルをグループ化するのに役立ちます。

バケットの作成

OCIコンソールを使ってバケットを作成する方法を説明します。

  1. OCIコンソールにログインします
  2. 左上のハンバーガーメニューをクリックし、「ストレージ」→「バケット」を選択します
  3. 「バケットの作成」ボタンをクリックします
  4. 以下の情報を入力します:
    • バケット名:image-classification(任意の名前でOK)
    • デフォルト・ストレージ・ティア:「標準」を選択
    • 暗号化:デフォルト(Oracle管理キー)を使用
  5. 「作成」ボタンをクリックします

これでバケットが作成されました。

画像データのアップロード

次に、画像データをオブジェクトストレージにアップロードします。OCIコンソールを使った方法とPythonを使った方法の両方を説明します。

OCIコンソールを使ったアップロード

  1. OCIコンソールで作成したバケットを開きます
  2. 「オブジェクトのアップロード」ボタンをクリックします
  3. 「ファイルの選択」をクリックし、アップロードしたい画像ファイルを選択します
    • 複数のファイルを選択することも可能です
    • ドラッグ&ドロップでファイルを追加することもできます
  4. 「アップロード」ボタンをクリックします

アップロードが完了すると、バケット内にファイルが表示されます。

Pythonを使ったアップロード

多数の画像ファイルをアップロードする場合は、Pythonスクリプトを使うと効率的です。以下は、指定したディレクトリ内の画像ファイルをバケットにアップロードするスクリプトの例です:

# upload_images.py
import oci
import os
import sys
from concurrent.futures import ThreadPoolExecutor
import time

# 設定ファイルからの読み込み
config = oci.config.from_file()

# オブジェクトストレージクライアントの作成
object_storage = oci.object_storage.ObjectStorageClient(config)

# ネームスペースの取得
namespace = object_storage.get_namespace().data

# バケット名
bucket_name = "image-classification"

# アップロードするディレクトリ
upload_dir = "images"

# アップロード済みファイル数のカウンタ
uploaded_count = 0
total_files = 0

# 進捗表示用の関数
def show_progress():
    sys.stdout.write(f"\rアップロード進捗: {uploaded_count}/{total_files} ファイル ({uploaded_count/total_files*100:.2f}%)")
    sys.stdout.flush()

# ファイルをアップロードする関数
def upload_file(file_path, object_name):
    global uploaded_count
    
    with open(file_path, "rb") as file:
        object_storage.put_object(
            namespace,
            bucket_name,
            object_name,
            file.read()
        )
    
    uploaded_count += 1
    show_progress()

# ディレクトリ内のファイルを再帰的に探索してアップロードする関数
def upload_directory(directory, prefix=""):
    global total_files
    
    # アップロードするファイルの総数を数える
    for root, dirs, files in os.walk(directory):
        for file in files:
            if file.lower().endswith((".jpg", ".jpeg", ".png")):
                total_files += 1
    
    print(f"合計 {total_files} ファイルをアップロードします...")
    
    # ThreadPoolExecutorを使って並列アップロード
    with ThreadPoolExecutor(max_workers=10) as executor:
        for root, dirs, files in os.walk(directory):
            for file in files:
                if file.lower().endswith((".jpg", ".jpeg", ".png")):
                    file_path = os.path.join(root, file)
                    
                    # オブジェクト名を作成(ディレクトリ構造を保持)
                    rel_path = os.path.relpath(file_path, directory)
                    object_name = os.path.join(prefix, rel_path).replace("\\", "/")
                    
                    # ファイルをアップロード
                    executor.submit(upload_file, file_path, object_name)
    
    print("\nアップロード完了!")

# メイン処理
if __name__ == "__main__":
    start_time = time.time()
    
    # ディレクトリ内のファイルをアップロード
    upload_directory(upload_dir)
    
    end_time = time.time()
    print(f"所要時間: {end_time - start_time:.2f}")

このスクリプトを実行すると、imagesディレクトリ内のすべての画像ファイル(.jpg、.jpeg、.png)がバケットにアップロードされます。ディレクトリ構造も保持されるため、サブフォルダ内のファイルも適切に整理されます。

フォルダ構造の作成

画像を整理するために、フォルダ構造を作成することができます。OCIのオブジェクトストレージでは、実際のフォルダは存在せず、オブジェクト名にスラッシュ(/)を含めることでフォルダのように見せる仕組みになっています。

  1. バケットの詳細ページで「フォルダの作成」ボタンをクリックします
  2. フォルダ名を入力します(例:「cats」や「dogs」など)
  3. 「作成」ボタンをクリックします
  4. 作成したフォルダをクリックして開きます
  5. 「オブジェクトのアップロード」ボタンをクリックし、そのフォルダに画像をアップロードします

このようにして、画像を分類ごとにフォルダに整理することができます。

アップロードの確認

アップロードが完了したら、OCIコンソールでバケットの内容を確認しましょう。

  1. OCIコンソールでバケットを開きます
  2. オブジェクトのリストが表示されます
  3. フォルダをクリックして中身を確認できます

また、Pythonを使ってバケット内のオブジェクトを一覧表示することもできます:

# list_objects.py
import oci

# 設定ファイルからの読み込み
config = oci.config.from_file()

# オブジェクトストレージクライアントの作成
object_storage = oci.object_storage.ObjectStorageClient(config)

# ネームスペースの取得
namespace = object_storage.get_namespace().data

# バケット名
bucket_name = "image-classification"

# オブジェクトの一覧を取得
objects = object_storage.list_objects(namespace, bucket_name)

# オブジェクトの一覧を表示
print(f"バケット '{bucket_name}' 内のオブジェクト:")
for obj in objects.data.objects:
    print(f" - {obj.name} ({obj.size} バイト)")

# フォルダ(プレフィックス)の一覧を表示
print(f"\nバケット '{bucket_name}' 内のフォルダ:")
for prefix in objects.data.prefixes:
    print(f" - {prefix}")

アクセス権限の設定

デフォルトでは、バケット内のオブジェクトは非公開になっています。必要に応じて、特定のオブジェクトを公開することができます。

  1. バケットの詳細ページで、公開したいオブジェクトを選択します
  2. 「アクション」メニューから「詳細の表示」を選択します
  3. 「事前認証済みリクエストの作成」ボタンをクリックします
  4. 以下の情報を設定します:
    • アクセスタイプ:「オブジェクト」を選択
    • 名前:任意の名前
    • アクセス権限:「読み取り」を選択
    • 有効期限:アクセスを許可する期間を設定
  5. 「作成」ボタンをクリックします

作成された事前認証済みリクエストのURLを使用して、認証なしでオブジェクトにアクセスできるようになります。

これで、オブジェクトストレージへの画像データのアップロードは完了です。次の章では、OCIのデータラベリングサービスを使ってデータセットを作成する方法を解説します。

OCIでのデータセット作成

この章では、OCIのデータラベリングサービスを使ってデータセットを作成し、画像にラベルを付ける方法を解説します。

データラベリングサービスの説明

OCIのデータラベリングサービス(Data Labeling)は、機械学習モデルのトレーニングに必要なデータセットの作成と管理を支援するサービスです。このサービスを使うと、以下のことが可能になります:

  • オブジェクトストレージ上の画像データからデータセットを作成する
  • 画像に対してラベル(分類カテゴリ)を付ける
  • ラベル付けされたデータセットをエクスポートする
  • データセットの品質を管理する

データラベリングは機械学習プロジェクトの重要なステップであり、高品質なラベル付きデータがあれば、より精度の高いモデルを構築することができます。

データセットの作成手順

OCIコンソールを使ってデータセットを作成する方法を説明します。

  1. OCIコンソールにログインします
  2. 左上のハンバーガーメニューをクリックし、「分析と AI」→「データラベリング」を選択します
  3. 「データセットの作成」ボタンをクリックします
  4. 以下の情報を入力します:
    • コンパートメント:デフォルトのコンパートメントを選択
    • 名前:image-classification-dataset(任意の名前でOK)
    • 説明:「画像分類のためのデータセット」など
    • アノテーションのフォーマット:「分類」を選択
    • ラベル:分類したいカテゴリの名前を追加(例:「猫」と「犬」)
    • データセットのソース:「オブジェクト・ストレージ」を選択
    • バケット:前章で作成したバケットを選択
    • プレフィックス:空欄のままでOK(バケット内のすべての画像を使用)
  5. 「作成」ボタンをクリックします

データセットの作成には数分かかる場合があります。ステータスが「アクティブ」になったら、次のステップに進みましょう。

ラベル付けの方法

作成したデータセットに対して、画像にラベルを付ける方法を説明します。OCIコンソールを使った手動のラベル付けと、Pythonを使った一括ラベル付けの両方を紹介します。

OCIコンソールを使ったラベル付け

  1. OCIコンソールのデータラベリングサービスで、作成したデータセットをクリックします
  2. 「ラベル付け」タブを選択します
  3. ラベル付けされていない画像が表示されます
  4. 各画像に対して、適切なラベル(例:「猫」または「犬」)を選択します
  5. 「送信」ボタンをクリックして、ラベルを確定します

この作業を繰り返し、すべての画像にラベルを付けていきます。多数の画像がある場合は、時間がかかる作業になりますが、高品質なデータセットを作成するためには重要なステップです。

Pythonを使ったラベル一括登録

多数の画像にラベルを付ける場合は、Pythonスクリプトを使って一括登録すると効率的です。以下は、フォルダ名に基づいて画像にラベルを付けるスクリプトの例です:

# bulk_labeling.py
import oci
import time
import sys

# 定数
DATASET_ID = "ocid"  # 実際のデータセットIDに置き換えてください
FOLDER_LABEL_MAPPING = {
    "cats/": "",
    "dogs/": ""
}

# 設定ファイルからの読み込み
config = oci.config.from_file()

# クライアントの作成
data_labeling = oci.data_labeling_service.DataLabelingClient(config)

# データセット内のレコードを取得
def get_dataset_records():
    records = []
    next_page = None
    
    while True:
        if next_page:
            response = data_labeling.list_records(
                dataset_id=DATASET_ID,
                page=next_page
            )
        else:
            response = data_labeling.list_records(
                dataset_id=DATASET_ID
            )
        
        records.extend(response.data.items)
        
        if response.has_next_page:
            next_page = response.next_page
        else:
            break
    
    return records

# ラベルを登録する関数
def add_label(record_id, label):
    # ラベルの登録
    annotation_details = oci.data_labeling_service.models.AddLabelAnnotationDetails(
        label=label
    )
    
    response = data_labeling.add_annotation(
        dataset_id=DATASET_ID,
        record_id=record_id,
        add_annotation_details=annotation_details
    )
    
    return response

# メイン処理
def main():
    # データセット内のレコードを取得
    print("データセット内のレコードを取得中...")
    records = get_dataset_records()
    total_records = len(records)
    print(f"合計 {total_records} レコードを取得しました")
    
    # 各レコードに対してラベルを付ける
    processed_count = 0
    success_count = 0
    
    for record in records:
        processed_count += 1
        
        # 進捗表示
        sys.stdout.write(f"\r処理中: {processed_count}/{total_records} ({processed_count/total_records*100:.2f}%)")
        sys.stdout.flush()
        
        try:
            # レコードからオブジェクト名を取得
            object_name = record.record_details.source_details.object_location.object_name
            
            # オブジェクト名からラベルを決定
            label = None
            for folder, folder_label in FOLDER_LABEL_MAPPING.items():
                if object_name.startswith(folder):
                    label = folder_label
                    break
            
            # ラベルが見つからない場合はスキップ
            if not label:
                continue
            
            # ラベルを登録
            add_label(record.id, label)
            success_count += 1
            
            # APIレート制限を避けるために少し待機
            time.sleep(0.5)
            
        except Exception as e:
            print(f"\nエラー: {e}")
    
    print(f"\n処理完了: {success_count}/{total_records} レコードにラベルを付けました")

if __name__ == "__main__":
    main()

このスクリプトを実行する前に、以下の点に注意してください:

  • DATASET_IDを実際のデータセットIDに置き換える必要があります
  • データセットIDはOCIコンソールのデータセットの詳細ページで確認できます
  • FOLDER_LABEL_MAPPINGは、フォルダ名とラベルの対応関係を定義しています。実際のフォルダ構造に合わせて変更してください

データセットの管理

ラベル付けが完了したら、OCIコンソールでデータセットの状態を確認しましょう。

  1. OCIコンソールのデータラベリングサービスで、データセットを開きます
  2. 「概要」タブでは、ラベル付けの進捗状況が表示されます
  3. 「ラベル付け」タブでは、ラベル付けされた画像を確認できます
  4. 「エクスポート」タブでは、ラベル付きデータセットをエクスポートできます

データセットのエクスポート機能を使うと、ラベル付きデータをJSONL形式でエクスポートできます。これは、他の機械学習プラットフォームでデータセットを使用する場合に便利です。

データセットの品質向上

データセットの品質を向上させるためのヒントをいくつか紹介します:

  1. バランスの取れたデータセット: 各クラスのサンプル数がバランスよく分布するようにする
  2. 多様なサンプル: 様々な角度、照明条件、背景の画像を含める
  3. クリーンなデータ: 不適切な画像や低品質な画像を除外する
  4. 一貫したラベル付け: 同じ基準でラベル付けを行う

これらの点に注意することで、より高品質なデータセットを作成でき、結果としてより精度の高いモデルを構築することができます。

以上で、OCIのデータラベリングサービスを使ったデータセットの作成は完了です。次の章では、OCIのVISIONサービスを使ってカスタムモデルを作成・利用する方法を解説します。

OCIのVISIONサービスの活用

この章では、OCIのVISIONサービスを使ってカスタムモデルを作成し、実際に利用する方法を解説します。

OCIのVISIONサービスの説明

OCIのVISIONサービスは、画像認識や分析のための機械学習サービスです。このサービスには以下の特徴があります:

  • 事前トレーニング済みのモデルを使った画像分析(物体検出、テキスト認識など)
  • カスタムモデルのトレーニングと管理
  • REST APIを通じたモデルの利用
  • 高い精度と拡張性

VISIONサービスを使うことで、独自の画像分類モデルを簡単に作成し、アプリケーションに組み込むことができます。

カスタムモデルの作成手順

OCIコンソールを使ってカスタムモデルを作成する方法を説明します。

  1. OCIコンソールにログインします
  2. 左上のハンバーガーメニューをクリックし、「分析と AI」→「VISION」を選択します
  3. 「プロジェクト」タブを選択し、「プロジェクトの作成」ボタンをクリックします
  4. 以下の情報を入力します:
    • コンパートメント:デフォルトのコンパートメントを選択
    • 名前:image-classification-project(任意の名前でOK)
    • 説明:「画像分類プロジェクト」など
  5. 「作成」ボタンをクリックします
  6. 作成したプロジェクトをクリックします
  7. 「モデルの作成」ボタンをクリックします
  8. 以下の情報を入力します:
    • モデルタイプ:「画像分類」を選択
    • 名前:image-classifier(任意の名前でOK)
    • 説明:「画像分類モデル」など
    • データセット:前章で作成したデータセットを選択
  9. 「作成」ボタンをクリックします

モデルの作成(トレーニング)には数十分から数時間かかる場合があります。ステータスが「アクティブ」になったら、次のステップに進みましょう。

モデルのトレーニングと評価

モデルのトレーニングが完了したら、その性能を評価しましょう。

  1. OCIコンソールのVISIONサービスで、作成したモデルをクリックします
  2. 「評価」タブを選択します
  3. モデルの評価指標(精度、適合率、再現率など)が表示されます

評価指標の見方:

  • 精度(Accuracy): 正しく分類されたサンプルの割合
  • 適合率(Precision): 特定のクラスと予測されたサンプルのうち、実際にそのクラスであるサンプルの割合
  • 再現率(Recall): 特定のクラスに属するサンプルのうち、正しくそのクラスと予測されたサンプルの割合
  • F1スコア: 適合率と再現率の調和平均

これらの指標が高いほど、モデルの性能が良いことを示します。

OCIコンソールを使ったモデルのテスト

作成したモデルをOCIコンソールでテストする方法を説明します。

  1. OCIコンソールのVISIONサービスで、作成したモデルをクリックします
  2. 「テスト」タブを選択します
  3. 「ファイルのアップロード」ボタンをクリックし、テストしたい画像をアップロードします
  4. 「分析」ボタンをクリックします
  5. 予測結果(クラスと信頼度)が表示されます

この方法は、モデルの動作を簡単に確認するのに便利です。

Pythonを使ったモデルの利用

作成したモデルをPythonから利用する方法を説明します。以下は、画像を分類するPythonスクリプトの例です:

# use_vision_model.py
import oci
import base64
import json
import sys
from PIL import Image
import io

# 設定ファイルからの読み込み
config = oci.config.from_file()

# VISIONクライアントの作成
vision_client = oci.ai_vision.AIServiceVisionClient(config)

# モデルID(OCIコンソールのモデル詳細ページで確認できます)
model_id = "ocid"  # 実際のモデルIDに置き換えてください

# 画像を分析する関数
def analyze_image(image_path):
    # 画像を読み込み
    with open(image_path, "rb") as image_file:
        image_data = image_file.read()
    
    # 画像をBase64エンコード
    image_base64 = base64.b64encode(image_data).decode("utf-8")
    
    # 分析リクエストの作成
    analyze_image_details = oci.ai_vision.models.AnalyzeImageDetails(
        image=oci.ai_vision.models.ImageDetails(
            data=image_base64,
            source="INLINE"
        ),
        features=[
            oci.ai_vision.models.ImageClassificationFeature(
                model_id=model_id
            )
        ]
    )
    
    # 画像分析の実行
    response = vision_client.analyze_image(
        analyze_image_details=analyze_image_details
    )
    
    return response.data

# 結果を表示する関数
def display_results(results):
    # 分類結果を取得
    for feature in results.image_classification_features:
        print("分類結果:")
        for label in feature.labels:
            print(f" - {label.name}: {label.confidence:.2f}")

# メイン処理
def main():
    if len(sys.argv) < 2:
        print("使用方法: python3 use_vision_model.py <画像ファイルパス>")
        return
    
    image_path = sys.argv[1]
    print(f"画像 '{image_path}' を分析中...")
    
    try:
        results = analyze_image(image_path)
        display_results(results)
    except Exception as e:
        print(f"エラー: {e}")

if __name__ == "__main__":
    main()

このスクリプトを実行する前に、以下の点に注意してください:

  • model_idを実際のモデルIDに置き換える必要があります
  • モデルIDはOCIコンソールのモデル詳細ページで確認できます

実行方法:

python3 use_vision_model.py /path/to/test_image.jpg

実行すると、指定した画像がモデルによって分析され、分類結果(クラスと信頼度)が表示されます。

実践的な応用例

OCIのVISIONサービスを使った画像分類モデルの実践的な応用例をいくつか紹介します:

  1. Eコマースサイトの商品分類: アップロードされた商品画像を自動的に分類し、適切なカテゴリに割り当てる

  2. 医療画像の診断支援: X線やMRI画像を分析し、異常の可能性を検出する

  3. 農業における作物の健康状態監視: 作物の画像から病気や害虫の被害を検出する

  4. 製造業の品質管理: 製品の画像から欠陥を自動検出する

  5. セキュリティシステム: 監視カメラの映像から不審な行動や物体を検出する

これらの応用例では、OCIのVISIONサービスを活用することで、専門的な機械学習の知識がなくても高度な画像分析システムを構築することができます。

以上で、OCIのVISIONサービスを使ったカスタムモデルの作成と利用の解説は完了です。次の章では、これまでの内容をまとめ、さらなる発展方法について説明します。

まとめと発展的な活用方法

この記事では、Oracle Cloud Infrastructure(OCI)を使って画像分類システムを構築する方法を解説しました。ここでは、これまでの内容をまとめ、さらなる発展方法について説明します。

本記事のまとめ

この記事では、以下の内容を学びました:

  1. 環境構築: OCIアカウントの作成と基本的な設定方法
  2. OCIオブジェクトストレージの活用: 画像データのクラウドへのアップロード方法
  3. OCIデータラベリングサービスの利用: データセットの作成とラベル付け方法
  4. OCIのVISIONサービスの活用: カスタムモデルの作成と利用方法

これらのステップを通じて、OCIの様々なAIサービスを活用した画像分類システムの構築方法を学ぶことができました。

学んだ技術のポイント

この記事を通じて学んだ重要なポイントをまとめます:

  1. クラウドAIサービスの利点:

    • インフラ管理の手間が不要
    • スケーラブルなリソース利用
    • 高度なAI機能の簡単な利用
  2. OCIのAI関連サービスの特徴:

    • データラベリングサービス: データセット作成の効率化
    • VISIONサービス: 高精度な画像認識モデルの簡単な構築
    • オブジェクトストレージ: 大量の画像データの効率的な管理
  3. 機械学習の基本的なワークフロー:

    • データ収集と前処理
    • モデルの構築とトレーニング
    • モデルの評価と改善
    • モデルのデプロイと利用

これらの知識は、他のAIプロジェクトにも応用できる基礎となります。

発展的な活用方法

ここでは、今回学んだ内容をさらに発展させる方法をいくつか紹介します:

1. 多クラス分類への拡張

今回は2クラス分類(例:猫と犬)を例に説明しましたが、これを拡張して多クラス分類に発展させることができます:

  • 商品カテゴリの分類: 衣類、電子機器、食品など
  • 動物の種類の分類: 犬、猫、鳥、魚など
  • 風景の分類: 山、海、都市、森など

2. 物体検出への発展

画像分類から一歩進んで、物体検出(Object Detection)に発展させることができます:

  • OCIのVISIONサービスの物体検出機能を活用
  • 画像内の複数のオブジェクトを検出し、その位置を特定
  • 例:小売店の棚の商品検出、交通監視システムなど

3. OCIの他のAIサービスとの連携

OCIには、VISIONサービス以外にも様々なAIサービスがあります:

  • OCI Language: テキスト分析、感情分析、エンティティ抽出など
  • OCI Speech: 音声認識、テキスト読み上げなど
  • OCI Document Understanding: ドキュメント分析、情報抽出など

これらのサービスを組み合わせることで、より高度なAIアプリケーションを構築できます。

4. ビジネスへの応用

OCIのAIサービスをビジネスに応用する方法:

  • 顧客体験の向上: 商品レコメンデーション、視覚的な検索など
  • 業務効率化: 書類の自動分類、データ入力の自動化など
  • 品質管理: 製品の欠陥検出、品質チェックの自動化など
  • セキュリティ強化: 不審な行動の検出、アクセス制御など

学習リソースと参考情報

さらに学習を深めるための参考リソースを紹介します:

  1. Oracle Cloud公式ドキュメント:

  2. Oracle Cloudの学習リソース:

  3. コミュニティとフォーラム:

最後に

この記事では、OCIを使った画像分類システムの構築方法を解説しました。クラウドAIサービスを活用することで、専門的な知識がなくても高度な画像認識システムを構築できることがお分かりいただけたと思います。

OCIのAIサービスは日々進化しており、今後もさらに多くの機能が追加されることが期待されます。この記事で学んだ基礎知識をベースに、ぜひ独自のAIプロジェクトに挑戦してみてください。

質問やフィードバックがあれば、コメント欄でお待ちしています。皆さんの創造的なプロジェクトに、この記事が少しでも役立てば幸いです。

Happy Coding!

1
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
1
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?