Skip to main content

iinfer: An application that executes AI model files in onnx or mmlab format.

Project description

iinfer (Image Inference Application)

onnx又はmmlabフォーマットのAIモデルファイルを実行するアプリケーションです。 ドキュメントはこちら

iinferの動作イメージ

iinferの動作イメージ

  1. iinfer clientimageファイルcamera から画像を取得し、 推論結果 predict.json を出力します。
  2. iinfer server は推論を行うサーバーです。 iinfer client からの要求に応えて、推論結果を iinfer client に返します。
  3. iinfer server は予め ai model をロードしておくことで、推論を高速化します。
  4. iinfer clientiinfer serverRedis 経由で通信します。
  5. iinfer serverRedisdockerコンテナ を使用して起動させることが出来ます。

インストール方法

次の手順でインストールしてください:

  1. pipを使用してインストールします:
pip install --upgrade pip
pip install iinfer
eval "$(register-python-argcomplete iinfer)" # Ubuntuの場合コマンドラインオプションを補完できるようにします。
  1. コンテナをインストールして起動します。: ※docker及びdocker-composeを別途インストールしておく必要があります。
cd ~/
iinfer -m install -c server
docker-compose -f up -d

※インストールを実行したフォルダに docker-compose.yml が作成されます。

iinferの使用方法

iinferを使用するには、次のコマンドを実行します:

  1. guiモードで利用する場合:

guiモードのイメージ

iinfer -m gui -c start
  1. コマンドモードで利用する場合

    1. AIモデルのデプロイ:
    # 画像AIモデルのデプロイ
    # 推論タイプはモデルのAIタスクやアルゴリズムに合わせて指定する。指定可能なキーワードは"iinfer -m client -c predict_type_list"コマンド参照。
    iinfer -m client -c deploy -n <任意のモデル名> -f \
                               --model_file <モデルファイル> \
                               --model_conf_file <モデル設定ファイル> \
                               --predict_type <推論タイプ> \
                               --label_file <ラベルファイル>
    
    # デプロイされている画像AIモデルの一覧
    iinfer -m client -c deploy_list -f
    
    1. AIモデルのセッションを開始:
    # 画像AIモデルを起動させて推論可能な状態に(セッションを確保)する
    # use_trackを指定するとObjectDetectionタスクの結果に対して、MOT(Multi Object Tracking)を実行しトラッキングIDを出力する。
    iinfer -m client -c start -n <モデル名> -f \
                              --use_track
    
    1. 推論を実行:
    # 推論を実行する
    # output_previewを指定するとimshowで推論結果画像を表示する(GUI必要)
    iinfer -m client -c predict -n <モデル名> -f \
                                -i <推論させる画像ファイル> \
                                -o <推論結果の画像ファイル> \
                                --output_preview
    
    # カメラキャプチャー画像を元に推論を実行し、クラススコアが0.8以上の物体のみを検出する
    # --stdin --image_type capture で標準入力のキャプチャー画像を推論する
    iinfer -m client -c capture | \
    iinfer -m client -c predict -n <モデル名> \
                                --stdin \
                                --image_type capture \
                                --nodraw | \
    iinfer -m postprocess -c det_filter -f -P \
                                --stdin \
                                --score_th 0.8
    
    1. AIモデルのセッションを開放:
    # 画像AIモデルを停止させてセッションを開放
    iinfer -m client -c stop -n <モデル名> -f
    

Lisence

This project is licensed under the MIT License, see the LICENSE file for details

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iinfer-0.5.3.tar.gz (455.9 kB view details)

Uploaded Source

Built Distribution

iinfer-0.5.3-py3-none-any.whl (837.9 kB view details)

Uploaded Python 3

File details

Details for the file iinfer-0.5.3.tar.gz.

File metadata

  • Download URL: iinfer-0.5.3.tar.gz
  • Upload date:
  • Size: 455.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for iinfer-0.5.3.tar.gz
Algorithm Hash digest
SHA256 08d9d0cb40d317aef8cca687e55671d164e94ed35b40239f4de75dcbd26cc9de
MD5 cf6380bc0501e437dd5349f8081b9b06
BLAKE2b-256 077532933c44218abc3b5344c094a1f6c9a299f59de24e1ffd72373790f9d26d

See more details on using hashes here.

File details

Details for the file iinfer-0.5.3-py3-none-any.whl.

File metadata

  • Download URL: iinfer-0.5.3-py3-none-any.whl
  • Upload date:
  • Size: 837.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for iinfer-0.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4853892a4b03ef164199bc7829edfc3a4008eed0324ec3b0dce2c52cb1649756
MD5 76e30839f5a0b2716d01ec3b849cd90e
BLAKE2b-256 ecbd875c1d6a2444fcd1b51e374ac95464d51baef55802e88edc5ae35ee7a222

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page