Skip to content

Fusion Transformer with Object Mask Guidance for Image Forgery Analysis

License

Notifications You must be signed in to change notification settings

mever-team/omgfuser

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OMG-Fuser

Official code repository for the paper Fusion Transformer with Object Mask Guidance for Image Forgery Analysis.

OMG-Fuser is a transformer-based fusion network designed to extract information from various forensic signals to enable robust image forgery detection and localization. It can operate with an arbitrary number of forensic signals and leverages object information for their analysis.

summary

🔨 Setup

The best way to install OMG-Fuser is through an Anaconda environment, as following:

conda create -n omgfuser python=3.10
conda activate omgfuser
conda install pytorch==1.13.1 torchvision==0.14.1 torchaudio==0.13.1 pytorch-cuda=11.7 -c pytorch -c nvidia
pip install -r requirements.txt

CUDA-enabled GPUs are required to run the code. The code originally targeted HPC nodes with 4 x Nvidia A100 40GB for training and Nvidia RTX 3090 for inference. However, more GPUs should be supported.

OMG-Fuser was originally developed to be integrated into a complex distributed system consisting of several components for generating the input signals, training the models, evaluating and serving them. As we integrate more functionalities under a monolithic architecture, we will keep updating this repository.

⏳ Inference

The score-level fusion variant can be tested using the following cli command:

python -m omgfuser test \
  --experiment_name omgfuser_score_fusion \
  --gpu_id 0 \
  --checkpoint_path ./checkpoints/omgfuser_score_fusion.pth \
  --dataset_csv ./data/[test_csv_name] \
  --model_name "masked_attention_positional_fusion_double_conv_upscaler_transformer_single_mlp_detector_dinov2frozen_feat_int_drop_stream_drop_path_5_inputs" \
  --input_signals "image,span,mvssnetplus,ifosn,catnetv2,trufor,sam_raw" \
  --signals_channels "3,1,1,1,1,1,0" \
  --loss_function "class_aware_localization_detection_bce_dice"

The feature-level fusion variant can be tested using the following cli command:

python -m omgfuser test \
  --experiment_name omgfuser_score_fusion \
  --gpu_id 0 \
  --checkpoint_path ./checkpoints/omgfuser_feature_fusion.pth \
  --dataset_csv ./data/[test_csv_name] \
  --model_name "masked_attention_positional_fusion_double_conv_upscaler_transformer_single_mlp_detector_dinov2patchembedfrozen_feat_int_bilinear_drop_stream_drop_path_2_inputs_448" \
  --input_signals "image,npp,dct,sam_raw" \
  --signals_channels "3,1,2,0" \
  --loss_function "class_aware_localization_detection_bce_dice"

📎 License

Copyright 2024 Media Analysis, Verification and Retrieval Group -
Information Technologies Institute - Centre for Research and Technology Hellas

The code included in this repository is licensed under the 
Apache License, Version 2.0. A copy of the license can be found in 
the LICENSE file.

Unless required by applicable law or agreed to in writing, software
distributed under this repository is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the license for the specific language governing permissions and
limitations under the License.

📜 Citation

When using any content included in this repository, the following paper should be cited.

@inproceedings{karageorgiou2024fusion,
  title={Fusion Transformer with Object Mask Guidance for Image Forgery Analysis},
  author={Karageorgiou, Dimitrios and Kordopatis-Zilos, Giorgos and Papadopoulos, Symeon},
  booktitle={Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition},
  pages={4345--4355},
  year={2024}
}

This work was supported by the Horizon Europe vera.ai project (grant no.101070093), Junior Star GACR (grant no. GM 21-28830M), and EuroHPC for providing access to MeluXina supercomputer (grant no. EHPC-DEV-2023D03-008).

📫 Contact

For any question regarding this project you may contact [email protected]

Releases

No releases published

Packages

No packages published

Languages