Skip to content

fujiki-1emon/TCCL.pytorch

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TCCL.pytorch

Temporal Cycle-Consistency Learning

書誌情報

  • Debidatta Dwibedi, Yusuf Aytar, Jonathan Tompson, Pierre Sermanet, Andrew Zisserman
  • Google Brain and DeepMind
  • CVPR2019

問題

  • 動画の時系列位置合わせの問題を扱う。
    • 動画内の行動を認識するような課題と比較して、動画の時系列的な発展の関係を扱うこと比較的少ないため、研究の価値がある。
    • self-supervised な方法で時系列位置合わせが可能であるため、フレームごとの対応を取るような大量の supervision を必要としない。
    • self-supervised に時系列位置合わせをした後、1つの動画の他のモダリティのデータ (e.g. 音) やアノテーションラベルを、位置合わせした他の動画に伝搬させることができる。また、時系列の異常検知に応用することができる。

手法・要点

手法のポイントは、動画の画像フレームの時系列的な対応関係が取れるような embedding space を学習することである。 画像から訓練済みモデル等 一般的な CNN を使って抽出した画像特徴量に基づいて embedding に変換する。 異なる動画の画像フレーム (s_i, t_j) から求めた embedding の系列 (u_i, v_j)に対して、その時系列的な位置の対応を取る損失を取る。

スクリーンショット 2020-08-05 11 45 57

より具体的には、u の soft nearest neighbor (v_tilda) を求め、その soft nearest neighbor を cycle-back した時に、元の u と一致する時系列のインデックスを持つようにする損失を取る。 損失には、Cycle-back Classification と Cycle-back Regression の2つが提案されている。Cycle-back Classification は cycle-back した時の時系列インデックスを分類によって位置合わせする損失である。しかし、分類では時系列位置の遠近が考慮されないため、ターゲット位置を中心とした分布を考えて時系列のインデックスを回帰する Cycle-back Regression が提案されている。

スクリーンショット 2020-08-05 11 43 05

以上の図は、原著論文から引用した。

Implementation & Results

  • 以上の Temporal Cycle-Consistency Learning を実現する最小限の実装を行なった。
    • データセットに、容器に液体を注ぐ動作を収めた動画データセット (pouring) を使用した。
    • また、Cycle-back Regression が最も良い結果であったという報告に基づいて、その損失のみを扱った。
  • 学習した embedding によって最近傍を求めて位置合わせをした結果を以下に掲載する。
    • 500 イテレーションを学習したモデルは、対応するフレームをある程度求めることができているが、対応が崩れた箇所が見られる。
    • 3,500 イテレーションを学習したモデルは、上のモデルより良くフレームの対応づけを取ることができている。
  • 他の動画での有効性など汎化性能を詳細に確かめることまではできておらず、その確認は課題である。

結果例1

20200803152325 checkpoint_00500 0_17

20200803152325 checkpoint_03500 0_17

結果例2

20200803152325 checkpoint_00500 50_67

20200803152325 checkpoint_03500 50_67

Usage

$ python main.py --normalize_indices --num_frames 20 --batch_size 4 

If you have more GPU memory (~30,000MiB),

$ python main.py --normalize_indices --num_frames 32 --batch_size 8 (--weight_decay 0.)

Found that the latter settings resulted in a better/stable learning by a few experiments. Might need more hyper parameter tuning with the implementation.

Acknowledgement

  • Temporal Cycle-Consistency Learning [PDF]
  • Pytorch+Tensorflowのちゃんぽんコードのすゝめ(tfdsでpytorchをブーストさせる話) [Qiita]

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages