Giter VIP home page Giter VIP logo

Comments (14)

kyakuno avatar kyakuno commented on September 27, 2024 1

2GBを超えるONNXをエクスポートした場合に、複数のpbに出力されるのは規定の動作です。出力した後で、ONNXのAPIで読み込み、all_tensors_to_one_file=Trueで書き出すと、1つのonnxと、1つのpbに結合可能です。
https://github.com/onnx/onnx/blob/main/docs/PythonAPIOverview.md

diffuserを使用しているモデルのエクスポート例です。拡散モデルなので、tokenizerとddimのsamplerのコードをdiffuserから持ってくる必要があると思います。
#1379

from ailia-models.

kyakuno avatar kyakuno commented on September 27, 2024 1

dynamoでエクスポートするとどうでしょうか?
pytorch/pytorch#112382
ailiaのメモリについては、memory_mode=11を与えてみてください。

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

メモ

  • CPUバージョンで動かせるアプリケーションを作成した例:https://github.com/rupeshs/instantidcpu
  • InstantIDのレポジトリ自体はApacheライセンスで商用利用可能だが、ダウンロードして利用されるモデルは商用利用ができないライセンスとなっているので注意が必要

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

ControlNetおよびIP-AdapterのONNX化検討メモ

  • ControlNetのONNXエクスポートは可能
    • エクスポートすると大量のファイルにbiasなどが分かれてしまう(MatMulやAddなど)
    • オプションなどを見ても避けることは難しそう(関連イシュー
  • パイプラインがdiffusersの機能を利用して記述されており、両モデルをONNXとして出力して利用する場合、diffusers実装を再現するようなコードを記述する必要あり
    • 関連場所をチェックすると移植部分は相当数あると見込んでいる

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

@kyakuno
ご教授ありがとうございます。
頂いた内容を元に移植作業を進めさせて頂きます。

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

ControlNetについてはcontrolnet.onnxとcontrolnet.pbに書き出し、onnxruntime.InferenceSession("controlnet.onnx")で読み込めることを確認

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

@kyakuno
UNetをエクスポートするときに以下のエラーが出ます。
torch.onnx.errors.UnsupportedOperatorError: Exporting the operator 'aten::fft_fftn' to ONNX opset version 17 is not supported.

以前にも同じ問題が発生した経験がある場合、どのように対処したかご教授いただけますと幸いです

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

メモ:

  • ailia SDKを使うと、ローカルでONNXバージョンで動かそうとするとメモリが不足してPCから警告が出され処理が中断されてしまう(24GBのmacbook proで確認)
    • スワップ領域を数十GB消費している
    • onnxruntimeを利用した場合はメモリ消費量が少ないようです

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

@kyakuno
ご教授ありがとうございます。無事unetはエクスポートできました!

エクスポートしたファイルをonnxruntimeで読み込もうとするとSegumentation faultが発生して強制終了されるのでそれの原因調査中ですが、それが完了すればあとは調整のみとなります。
時間がかかっており申し訳ないですが、進捗あり次第再度共有させていただきます

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

@kyakuno
UNetをエクスポートしたファイルをailia SDKで読み込もうとすると以下のようなエラーになるようです。

814EBB50-E21E-4DAE-BBA3-7B30CAA6F9A6_4_5005_c

一方、onnxruntimeで開こうとするとsegmentation falutが発生する問題がまだ解決できておりません。
引き続きチェックを進めます

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024
  • unetをエクスポートするとpbファイルが12GBほどになる。

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

今まで対応した内容まとめ

    • torch.onnx.export
      • FFTとかがエクスポートできないので不可
  • torch.onnx.dynamo_export
    • ファイル自体はエクスポートされる
    • pbファイルが12GB程度になる
    • onnsruntime.InferenceSesionで開こうとするとSegmentation faultになって落ちる
      • SessionOptionsでいかを設定しても状況変化なし
        • enable_mem_pattern=False
        • enable_cpu_mem_arena=False
        • execution_mode=ExecutionMode.ORT_PARALLEL
        • intra_op_num_threads=4
    • onnx.loadで開くことはできて、onnx.checker.check_modelもエラーがない
    • onnxoptimizerを使ってFP16に変換してファイル容量を小さくできるか試してみた
      • IRバージョンが合っていないということでエラーになり実行不可(からのonnxファイルだけ生成される)
  • エクスポートする場所を変えると何故かtorch.onnx.exportでもエクスポートできた
    • しかしエクスポートできたunetを推論に使うと以下のエラーが発生する模様
onnxruntime.capi.onnxruntime_pybind11_state.Fail: [ONNXRuntimeError] : 1 : FAIL : Non-zero status code returned while running Split node. Name:'/time_proj/Slice_1/GatherSliceToSplitFusion/' Status Message: Cannot split using values in 'split' attribute. Axis=1 Input shape={1,1,320} NumOutputs=2 Num entries in 'split' (must equal number of outputs) was 2 Sum of sizes in 'split' (must equal size of selected axis) was 320

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024

こちらの方法でonnxにしてみる(方法は同じだがパラメータが違う)
https://zenn.dev/xiangze/articles/b984d5e806e1dd

from ailia-models.

Akasan avatar Akasan commented on September 27, 2024
  • torch.onnx.exportでエクスポートできたが、prototxtが44GBになったりとかなり怪しい(external_dataを一つにまとめずに実行した場合)

from ailia-models.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.