ソラカメ対応カメラはイベントを検知して、イベント発生時の画像や動画を クラウドに保存 します。このイベント発生時の画像や動画を活用することで、イベントがあった時の状況や内容を把握できます。
たとえば、出入り口や搬入口にカメラを設置して、イベント発生時の画像や動画で人の数や車の台数、何が記録されているかを確認を取りたい場合があるとします。 その際、手作業で確認する場合は、検知したイベントの数に比例して多くの時間を使ってしまいます。AI を利用して、画像や映像から物体が検出できれば自動で人数カウントや、何が記録されているかを確認できます。
ここでは、SORACOM API (以下、API) を使ったサンプルコードを実行することで、イベント画像に対して学習済みモデルを使った物体検出を体験できます。サンプルコードは、Colaboratory(以下、Colab) を使って実行します。
Colaboratory はソラコムが提供するサービスではありません
- Colaboratory の利用には Google アカウントが必要です。
- ソラコムは、Colaboratory に関するサポートを行いません。
- Colaboratory については、Colaboratory の運営会社へ お問い合わせ ください。
サンプルコードの利用について
- サンプルコードでは、API を使って録画データを操作するため、クラウドに動画が保存 されている必要があります。
- サンプルコードの実行には SORACOM ユーザーコンソールの ログイン情報 が必要です。
- サンプルコードでは、実際に動画や静止画のエクスポートを行うため、動画のエクスポート可能時間 が消費されます。
- サンプルコードは、API の使いかたを紹介することを目的として提供されています。SORACOM サポートではサポートを行いません。
- サンプルコードを実行したことによる利用者自身、もしくは第三者が被った損害に対して、直接的、間接的を問わず、株式会社ソラコムは責任を負いかねます。
操作を始める前に準備が必要です (クリックして確認してください)
(1) サンプルコードを実行するための環境を準備する
ソラカメ対応カメラでクラウドに録画した映像を、SORACOM API を使って操作できることを確認してください。詳しくは、API の使いかたについて を参照してください。
準備完了サンプルコード
このページで使用するサンプルコードです。
リンクをクリックして Colab で開いて、ガイドページに沿って体験してください。
警告が表示されることがあります
GitHub からサンプルコードを実行する際、「警告: このノートブックは Google が作成したものではありません。」と表示されることがあります。表示された内容を確認して、
をクリックしてください。GitHub から実行したサンプルコードを修正して保存する際、「変更を保存できませんでした」と表示されることがあります。保存する場合には表示された内容を確認して、
をクリックしてください。ログインしている Google アカウントの Google ドライブ にノートブックのコピーが保存されます。
ステップ 1: 物体検出に使うライブラリをインストールする
サンプルコードで利用する、物体検出のライブラリをインストールします。Colab では pip コマンドが利用できるため、必要なライブラリを簡単にインストールできます。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。pip コマンドが実行されライブラリのインストールが開始されます。インストールが正常に完了すると
Successfully installed ultralytics-8.0.124
のようなメッセージが表示されます。利用しているライブラリ
- ここでは ultralytics / ultralytics を利用しています。
- 利用しているライブラリは GNU Affero General Public License v3.0 で提供されています。
ステップ 2: サンプルコードの実行に必要なライブラリや定数を設定する
サンプルコード全体で利用するライブラリや関数、定数の定義を行います。ここで定義された内容は、他のコードセルでも利用できます。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果に Python のバージョン (例:
# ℹ️ Python Version = 3.10.12 (main, Jun 7 2023, 12:45:35) [GCC 9.4.0]
) が表示されます。
ステップ 3: SORACOM API を使うための認証処理をする
SORACOM API を使うための認証処理を行います。ユーザーコンソールのログイン情報を入力するフォームに必要な情報を入力して、 をクリックすると SORACOM API の認証処理が実行され、このステップ以降で SORACOM API が実行できます。
呼び出している SORACOM API
このステップでは、以下の SORACOM API を呼び出しています。
API | 説明 |
---|---|
Auth:auth API | API アクセスの認証を行い、API キーと API トークンを発行する |
サンプルコードの
の以下の項目を設定します。項目 説明 SORACOM API の日本カバレッジのエンドポイント ( https://api.soracom.io/v1
) を入力します。SORACOM API を利用するユーザーの種別を選択します。具体的なログイン情報は、手順 3 で入力します。
- Root User: ルートユーザーのログイン情報が分かる場合
- SAM User: SAM ユーザーのログイン情報が分かる場合
多要素認証 (Multi-Factor Authentication: MFA) を有効化しているユーザーの場合はチェックします。
具体的なワンタイムパスワード (Time-based One-Time Password: TOTP) 情報は、手順 3 で入力します。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果にログイン情報の入力フォームが表示されます。
ログイン情報を入力して、
をクリックします。手順 2 の
で「Root User」を選択した場合は、ルートユーザーのメールアドレスとパスワードを入力します。手順 2 の
で「SAM User」を選択した場合は、SAM ユーザーが所属するオペレーターのオペレーター ID、SAM ユーザー名、パスワードを入力します。手順 2 の
をチェックした場合は、MFA 認証コードを入力します。
正しい認証情報を入力していれば、
# 🔑 API access has been authenticated 💯
と表示され、入力欄が初期化されます。
ステップ 4: カメラを 1 台選択する
ソラカメ対応カメラの一覧を取得し、そこからソラカメ対応カメラを 1 台選択します。このステップ以降では、ここで選択したソラカメ対応カメラがクラウドに保存した動画や画像に対して、API で操作を行います。
呼び出している SORACOM API
このステップでは、以下の SORACOM API を呼び出しています。
API | 説明 |
---|---|
SoraCam:listSoraCamDevices API | ソラカメ対応カメラの一覧を取得する |
SoraCam:getSoraCamDevice API | ソラカメ対応カメラの情報を取得する |
SoraCam:getSoraCamDeviceExportUsage API | ソラカメ対応カメラの静止画のエクスポート可能枚数や録画映像のエクスポート可能時間を取得する |
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果に表示された
をクリックします。1 行ごとに 1 台のソラカメ対応カメラの情報が、
名前 / 状態 / ファームウェアバージョン / 製品名 / デバイス ID
の順に表示されます。ソラカメ対応カメラを選択します。
選択したソラカメ対応カメラの詳細情報 (JSON) と、選択したカメラのエクスポート可能時間 (JSON および
🔎 Time remaining of month = 72 hours 0 minutes 0 seconds
) が表示されます。選択したカメラの詳細情報:
選択したカメラのエクスポート可能時間:
Time remaining of month
が、選択したカメラの「今月の残り時間」です。72 hours 0 minutes 0 seconds
と表示されている場合は、今月はあと 72 時間分の動画をエクスポートできます。このあとのステップで今月の残り時間を超えると、サンプルコードが動作しない可能性があります。必要に応じて、動画のエクスポート可能時間の上限を設定してください。詳しくは、動画のエクスポート可能時間の上限を設定する を参照してください。
ステップ 5: イベント一覧を取得する期間を設定する
このステップと次のステップでは、前のステップで選択したソラカメ対応カメラがクラウドに記録したイベント一覧を取得して、イベントを 1 つ選択します。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。などの入力欄が表示されます。
以下の項目を入力します。
項目 説明 開始日。例: 2023/05/02
開始時刻。例: 10:33:31
終了日。例: 2023/05/02
終了時刻。例: 10:38:31
開始日時と終了日時を設定してください
開始日時と終了日時の初期値は、どちらも実行した日時です。開始日時と終了日時を変更せずに
をクリックすると、エラーが表示されます。をクリックします。
イベントを取得する期間が設定されます。
すべての期間を対象にする場合
記録されているすべてのイベントを対象にする場合は、開始日時と終了日時を設定せずに、
をクリックします。 、 、 、および は使用されません。
ステップ 6: 設定した期間のイベントから 1 つ選択する
前のステップで設定した期間で、ソラカメ対応カメラがクラウドに記録したイベント一覧を取得して、イベントを 1 つ選択します。
呼び出している SORACOM API
このステップでは、以下の SORACOM API を呼び出しています。
API | 説明 |
---|---|
SoraCam:listSoraCamDeviceEventsForDevice API | ソラカメ対応カメラのイベント一覧を取得する |
サンプルコードの
の以下の項目を設定します。項目 説明 ストリーミング再生できるイベントのみを表示する場合は、チェックを入れます。 サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果に表示された
をクリックします。1 行ごとに 1 つのイベント情報が、
日時 / イベントタイプ / イベントの録画状況 / イベント画像の有無 / イベント動画のストリーミング再生可否
の順に表示されます。イベントを選択します。
選択したイベントの情報 (JSON) が表示されます。
イベント画像の有無と、イベント動画のストリーミング再生可否は、
eventInfo.atomEventV1
の以下のプロパティを確認しています。picture
の URL がある場合は、イベント画像があると判定しています。startTime
とendTime
がある場合は、イベント動画がストリーミング再生できると判定しています。
ステップ 7: 選択したイベントのストリーミングを再生する
前のステップで選択したイベントの動画を、ストリーミング再生 します。再生するイベント動画の長さ分「動画のエクスポート可能時間」が消費されます。Colab 上で動画を再生することで、この後のステップで検出できる対象物があるかどうかを確認します。
呼び出している SORACOM API
このステップでは、以下の SORACOM API を呼び出しています。
API | 説明 |
---|---|
SoraCam:getSoraCamDeviceStreamingVideo API | ストリーミング映像 (リアルタイム映像 / 録画映像) をダウンロードするための情報を取得する |
SoraCam:getSoraCamDeviceExportUsage API | ソラカメ対応カメラの静止画のエクスポート可能枚数や録画映像のエクスポート可能時間を取得する |
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。ストリーミング再生用の URL が発行され、動画の再生が始まります。
URL には有効期限が設定されているため一定時間で再生が停止します
- ストリーミング再生用の URL には有効期限が設定されています。そのため、有効期限が経過してから再生バーを操作すると、動画は再生されません。
- をクリックすると、同じイベント動画のストリーミング再生がもう一度行われます。「動画のエクスポート可能時間」が消費されます。
ステップ 8: 選択したイベントの画像をダウンロードする
選択したイベントの画像をダウロードします。ダウンロード先は Colab 内です。この操作で「動画のエクスポート可能時間」は消費されません。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。静止画ファイル (jpg ファイル) が Colab 内にダウンロードされます。 ダウンロードが正常に完了すると
The event image has been saved.
のようなメッセージが表示されます。イベント画像のダウンロード用 URL には有効期限が設定されているため一定時間で URL が失効します
- イベント画像のダウンロード用 URL には有効期限が設定されています。そのため、有効期限が経過してから上記の操作を行ってもダウンロードできません。
- ステップ 6: 設定した期間のイベントから 1 つ選択する から再実行してダウンロードしてください。
をクリックします。
「event_image」ディレクトリと、ダウンロードされたイベント画像ファイルが表示されます。
ステップ 9: ダウンロードしたイベント画像を確認する
前のステップで Colab 内にダウンロードしたイベント画像を表示して確認します。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果にダウンロードしたイベント画像が表示されます。
イベント画像が正しく表示されない場合は
をクリックして画像ファイルを直接確認してください。
ステップ 10: イベント画像に映っている物体を検出する
Colab 内にダウンロードしたイベント画像に対して、ライブラリを利用して物体検出を行います。
初回実行時に、物体検出に利用する学習済みモデル (例: yolov8n.pt
) が自動的に Colab にダウンロードされます。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果に物体検出の実行状況が表示されます。
実行結果には、検出した物体の名称 (
# Object type name =
) と検出の適合率 (# Precision of detection =
) が出力されます。をクリックします。
「runs/detect/predict」ディレクトリと、物体検出の結果画像ファイルが表示されます。
ステップ 11: 物体検出の結果を確認する
前のステップで Colab 内に保存された物体検出の結果画像を表示して確認します。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。実行結果に、物体検出の結果画像が表示されます。
結果画像には、前のステップで数値で表示されていた物体の名前と適合率が表示されています。
- 上の画像の例では、赤枠の「person 0.82」と、緑枠の「handbag 0.28」です。
- person は適合率が高いため、正しく検出されていることがわかります。
- handbag は適合率が低くなっています。この例では Laptop PC を handbag と誤認識しています。サンプルコードでは、適合率が低い場合 (誤認識している可能性が高い場合) でも枠を出力していますが、適合率によって枠を非表示にするなど、さまざまな工夫が考えられます。
物体検出の結果画像が正しく表示されない場合は
をクリックして画像ファイルを直接確認してください。
ステップ 12: ローカル環境にダウンロードするディレクトリを選択する
これまでのステップで Colab 内に保存したファイルを、ローカル環境にダウンロードするための準備として、物体検知の結果画像ファイルが保存されているディレクトリを選択します。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。をクリックして、「/content/runs/detect」を選択します。
# 📄 File List
(ディレクトリ内のファイル一覧) が表示されます。
ステップ 13: 選択したディレクトリをローカル環境にダウンロードする
Colab 内に保存したファイルしを zip 形式で圧縮して、ローカル環境にダウンロードします。
サンプルコードの
のコードセルにマウスポインターを合わせて クリックします。前のステップで選択したディレクトリを zip 形式で圧縮したファイルがダウンロードされます。
ローカル環境にダウンロードされた zip 形式で圧縮したファイルを展開して、物体検出の結果画像ファイルが表示できることを確認します。
上記の例では、
_20230701_193245_archive_.zip
という zip 形式のファイルがローカルにダウンロードされます。Colab 内のファイルとローカル環境のファイルを比較してください
「/content/__zip_work/」ディレクトリのすべてのファイルがローカル環境にダウンロードされていれば、実行は成功しています。
上記の例では、jpg ファイルが 物体検出の結果画像ファイルです。
なお、ブラウザの設定で複数ファイルのダウンロードが許可されていない場合は、上記のような表示が出ることがあります。表示内容を確認し、
をクリックして、ダウンロードを続行してください。
まとめ
SORACOM API とライブラリを使って、ユーザーコンソールでは実現できない イベント画像に映っている物体を検出する サンプルコードを Colab で体験できました。ステップごとの解説とサンプルコードを参考に、実際のユースケースでも SORACOM API やライブラリを活用して、新しい使いかたや自動化、省力化にチャレンジしてください。
(参考) サンプルコードを変更する場合
最後に参考として、サンプルコードを変更して実行する場合の簡単な Tips を紹介します。
サンプルコードの利用について
- サンプルコードは、API の使いかたを紹介することを目的として提供されています。SORACOM サポートではサポートを行いません。
- サンプルコードを実行したことによる利用者自身、もしくは第三者が被った損害に対して、直接的、間接的を問わず、株式会社ソラコムは責任を負いかねます。
別の学習済みモデルを利用して AI を試してみる
サンプルコードでは、物体検出の学習済みモデルを利用しました。今回利用したライブラリは他にも 学習済みモデル が用意されています。別の学習済みモデルを利用する場合には、サンプルコードの detect_objects()
を呼び出す際、引数 model_name
に任意のモデル名称を指定することで、指定した学習済みモデルで AI を試せます。その他詳しい内容はライブラリのページを参照してください。
# Perform object detection using a trained model.
def detect_objects(model_name: str, file_name: str, output_path: str) -> dict:
print()
print('# 🎰 Starting object detection = ', datetime.now(JST))
print('# 🕹️ Model to be used = ', model_name)
print('# Target file = ', file_name)
# Load trained model (If the model is not available, it will be downloaded here)
model = YOLO(model_name)
API トークンの有効期限を変更する
サンプルコードでは、API トークンの有効期限を「3600 秒 (1 時間)」に設定しています。有効期限を変更する場合には authenticate_user()
を呼び出す際、引数 timeout
に有効期限を設定してください。有効期限に指定できる範囲については、Auth:auth API
を参照してください。
# /auth
# Authenticate API access and issue API key and API token
# https://users.soracom.io/ja-jp/tools/api/reference/#/Auth/auth
def authenticate_user(self, email: str, password: str, opid: str, name: str, mfa_code: str = None, timeout: int = 3600) -> APIResult:
api_path = '/auth/'
url = merge_url(self.endpoint_url, api_path)
headers = {'Content-Type': 'application/json'}
# authentication uses the following values
# Root: email, password
# SAM: opid, name, password
data = dict()
# prepare the value for the Root case
if email != None and email != '':
if password != None and password != '':
data['email'] = email
data['password'] = password
# prepare the value for the SAM case
# If both are valid, SAM is preferred
if opid != None and opid != '':
if name != None and name != '':
if password != None and password != '':
data['operatorId'] = opid
data['userName'] = name
data['password'] = password
# set the API key expiration time (Default 1 hour)
data['tokenTimeoutSeconds'] = timeout
# MFA Authentication Code
if mfa_code != None and mfa_code != '':
data['mfaOTPCode'] = mfa_code
# Send Request
return send_post_request(url, headers=headers, data=data)