We use a spatial and motion stream cnn with ResNet101 for modeling video information in UCF101 dataset.
- [1] Two-stream convolutional networks for action recognition in videos
- [2] Temporal Segment Networks: Towards Good Practices for Deep Action Recognition
- [3] TS-LSTM and Temporal-Inception: Exploiting Spatiotemporal Dynamics for Activity Recognition
pip install virtualenv
virtualenv twostream
source twostream/bin/activate
pip install -r requirements.txt
- We extract RGB frames from each video in UCF101 dataset with sampling rate: 10 and save as .jpg image in disk which cost about 5.9G.
In motion stream, we use two methods to get optical flow data.
- Download the preprocessed tvl1 optical flow dataset directly from https://github.com/feichtenhofer/twostreamfusion.
- Using flownet2.0 method to generate 2-channel optical flow image and save its x, y channel as .jpg image in disk respectively, which cost about 56G.
1.3 (Alternative)Download the preprocessed data directly from feichtenhofer/twostreamfusion)
- RGB images
wget http://ftp.tugraz.at/pub/feichtenhofer/tsfusion/data/ucf101_jpegs_256.zip.001
wget http://ftp.tugraz.at/pub/feichtenhofer/tsfusion/data/ucf101_jpegs_256.zip.002
wget http://ftp.tugraz.at/pub/feichtenhofer/tsfusion/data/ucf101_jpegs_256.zip.003
cat ucf101_jpegs_256.zip* > ucf101_jpegs_256.zip
- Optical Flow
wget http://ftp.tugraz.at/pub/feichtenhofer/tsfusion/data/ucf101_tvl1_flow.zip.001
wget http://ftp.tugraz.at/pub/feichtenhofer/tsfusion/data/ucf101_tvl1_flow.zip.002
wget http://ftp.tugraz.at/pub/feichtenhofer/tsfusion/data/ucf101_tvl1_flow.zip.003
cat ucf101_tvl1_flow.zip* > ucf101_tvl1_flow.zip
- Create directory to locate those downloaded dataset as follows
# At the project directory (ex: /../two-stream-action-recognition)
mkdir ../dataset
mv ucf101_jpegs_256.zi ../dataset
mv ucf101_tvl1_flow.zip ../dataset
cd ../dataset
unzip ucf101_jpegs_256.zip
unzip ucf101_tvl1_flow.zip
- As mention before, we use ResNet101 first pre-trained with ImageNet then fine-tuning on our UCF101 spatial rgb image dataset.
- Input data of motion cnn is a stack of optical flow images which contained 10 x-channel and 10 y-channel images, So it's input shape is (20, 224, 224) which can be considered as a 20-channel image.
- In order to utilize ImageNet pre-trained weight on our model, we have to modify the weights of the first convolution layer pre-trained with ImageNet from (64, 3, 7, 7) to (64, 20, 7, 7).
- In [2] Wang provide a method called Cross modality pre-training to do such weights shape transform. He first average the weight value across the RGB channels and replicate this average by the channel number of motion stream input( which is 20 is this case)
- Here we utilize the techniques in Temporal Segment Network. For every videos in a mini-batch, we randomly select 3 frames from each video. Then a consensus among the frames will be derived as the video-level prediction for calculating loss.
- In every mini-batch, we randomly select 64 (batch size) videos from 9537 training videos and futher randomly select 1 stacked optical flow in each video.
- Both stream apply the same data augmentation technique such as random cropping.
- For every 3783 testing videos, we uniformly sample 19 frames in each video and the video level prediction is the voting result of all 19 frame level predictions.
- The reason we choose the number 19 is that the minimun number of video frames in UCF101 is 28 and we have to make sure there are sufficient frames for testing in 10 stack motion stream.
network | top1 |
---|---|
Spatial cnn | 82.1% |
Motion cnn | 79.4% |
Average fusion | 88.5% |
- Please modify this path and this funcition to fit the UCF101 dataset on your device.
- Training and testing
python spatial_cnn.py --resume PATH_TO_PRETRAINED_MODEL
- Only testing
python spatial_cnn.py --resume PATH_TO_PRETRAINED_MODEL --evaluate
- Please modify this path and this funcition to fit the UCF101 dataset on your device.
- Training and testing
python motion_cnn.py --resume PATH_TO_PRETRAINED_MODEL
- Only testing
python motion_cnn.py --resume PATH_TO_PRETRAINED_MODEL --evaluate