🔥Official implement of "Point Long-Term Locality-Aware Transformer for Point Cloud Video Understanding"
🔥Point cloud videos have been widely used in real-world applications to understand 3D dynamic objects and scenes. However, there still exist significant challenges in effectively embedding the inter-frame motion. Another crucial challenge lies in the failure to consider the long-term dependencies within local regions, which is an important factor for the efficacy of the neural model yet largely under-explored. In this paper, we propose an effective Point Long-term Locality-aware Transformer network to meet these challenges, termed as PL2-Transformer. First, the Point 4D Convolution (4DConv) is harnessed as the 4D backbone to aggregate the short-term spatial-temporal local information. Second, to enhance motion dynamics understanding, we introduce an inter-frame motion embedding, which captures the motion between frames and provides reliable motion cues for the subsequent Transformer network. Finally, we propose an effective Long-Term Locality-Aware Transformer (LLT), which utilizes a novel Long-Term Locality-Aware Attention (LLA) mechanism to capture long-term dependencies within local regions across the entire Point cloud video. Extensive experiments on multiple benchmarks demonstrate the effectiveness of our approach, surpassing the current state-of-the-art (SOTA) methods, or being comparable to the current SOTA methods while having fewer parameters. Source codes will be made publicly available.
The code is tested with Red Hat Enterprise Linux Workstation release 7.7 (Maipo), g++ (GCC) 8.3.1, PyTorch v1.8.1, CUDA 10.2 and cuDNN v7.6.
Device : 2 × RTX 2080Ti (22G)
Compile the CUDA layers for PointNet++, which we used for furthest point sampling (FPS) and radius neighbouring search:
cd modules
python setup.py install
Some core codes will coming soon after paper accepted (NTU Syn NVg).
🌱The MSR dataset encompasses 20 actions, a total of 23K frames. Thanks to this author Meteornet for providing us with data preprocessing code.
(about 800M)
🌱The NTU RGB+D 60 dataset encompasses 60 actions, a total of 4M frames. Thanks to this author PSTNet for providing us with data preprocessing code.
(about 800G)
🌱The Synthia 4D dataset. Synthia 4D is a synthetic dataset for outdoor autonomous driving. Thanks to this author P4transformer for providing us with data preprocessing code.
(about 5G)
🌱The NVgesture dataset. Thanks to this author MaST-Pre for providing us with data preprocessing code.
(about 10G)
🤗Lets train the model!
python train-msr-meduim.py
python train-msr-full.py
📢The log has been uploaded!
- PointNet++ PyTorch implementation: https://github.com/facebookresearch/votenet/tree/master/pointnet2
- Transformer: https://github.com/lucidrains/vit-pytorch
- P4Transformer: https://github.com/hehefan/P4Transformer
- PST-Transformer:https://github.com/hehefan/PST-Transformer
💡We thank the authors of P4transformer and PST-Transformer for their interesting work.