Project Icon

StegaStamp

在物理照片中隐匿和提取数据的技术

此页面介绍了一种在图像中隐藏和提取数据的方法,能够在经过打印和摄影负载后保持图像的感知相似性。项目提供了所需的代码和预训练模型,以便复现研究成果。内容涵盖了训练编码器和解码器模型的步骤,并详细说明了在图像中编码和解码信息的过程。

StegaStamp:实体照片中的隐形超链接 [项目主页]

CVPR 2020

Matthew TancikBen MildenhallRen Ng 加州大学伯克利分校

简介

本仓库是此ArXiv报告的代码发布。该项目探索了在保持视觉相似性的同时在图像中隐藏数据的方法。我们的贡献在于能够在编码图像(StegaStamp)被打印并用相机拍摄后(这些步骤会引入图像损坏)提取数据。本仓库包含了复现论文中结果所需的代码和预训练模型。此外,仓库还包含了训练编码器和解码器模型所需的代码。

引用

如果您发现我们的工作有用,请考虑引用:

    @inproceedings{2019stegastamp,
        title={StegaStamp: Invisible Hyperlinks in Physical Photographs},
        author={Tancik, Matthew and Mildenhall, Ben and Ng, Ren},
        booktitle={IEEE Conference on Computer Vision and Pattern Recognition (CVPR)},
        year={2020}
    }

安装

  • 克隆仓库并安装子模块
git clone --recurse-submodules https://github.com/tancik/StegaStamp.git
cd StegaStamp
  • 安装tensorflow(已在tf 1.13上测试)
  • 需要Python 3
  • 下载依赖项
pip install -r requirements.txt

训练

编码器/解码器

  • 在train.py中设置数据集路径
TRAIN_PATH = 数据集图像目录
  • 训练模型
bash scripts/base.sh 实验名称

训练在train.py中进行。有许多超参数,其中许多对应于增强参数。scripts/bash.sh提供了一个很好的起点。

检测器

检测器模型(用于分割StegaStamps)的训练代码未包含在此仓库中。论文中使用的模型是使用这里发布的BiSeNet模型进行训练的。CROP_WIDTH和CROP_HEIGHT设置为1024,所有其他参数设置为默认值。数据集是通过将扭曲的StegaStamps随机放置在较大的图像上生成的。

Tensorboard

要可视化训练过程,请运行以下命令并在浏览器中导航到http://localhost:6006。

tensorboard --logdir logs

编码消息

脚本encode_image.py可用于将消息编码到图像或图像目录中。默认模型期望一个utf-8编码的秘密,长度<=7个字符(100位消息->ECC后56位)。

将消息编码到图像中:

python encode_image.py \
  saved_models/stegastamp_pretrained \
  --image test_im.png  \
  --save_dir out/ \
  --secret Hello

这将保存StegaStamp和应用于原始图像的残差。

解码消息

脚本decode_image.py可用于从StegaStamp中解码消息。

使用示例:

python decode_image.py \
  saved_models/stegastamp_pretrained \
  --image out/test_hidden.png

检测和解码

脚本detector.py可用于检测和解码图像中的StegaStamps。这在存在多个StegaStamps或StegaStamp不填满图像框架的情况下非常有用。

要使用检测器,请确保按照安装部分的说明下载检测器模型。推荐的输入视频分辨率为1920x1080。

python detector.py \
  --detector_model detector_models/stegastamp_detector \
  --decoder_model saved_models/stegastamp_pretrained \
  --video test_vid.mp4

添加--save_video 文件名标志以保存结果。

--visualize_detector标志可用于可视化检测器网络的输出。掩码对应于分割掩码,彩色多边形使用一组启发式方法拟合到这个分割掩码上。检测器输出可能会有噪声,并且对stegastamp的大小敏感。本文未探讨进一步优化检测网络。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号