视频的帧内置乱及逆置乱

2024-02-24 12:32
文章标签 视频 内置 逆置 乱及

本文主要是介绍视频的帧内置乱及逆置乱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

置乱

%特定帧的帧内置乱
%程序开发: lilizong@gmail.com
%2013-9-19
clc;
clear all;
aviobj=avifile('myAVI\myAVI');
aviobj.Quality=100;
aviobj.compression='None';
mov=mmreader('aviVideo\vipfly.avi');     %用mmreader读入视频文件  50帧
mySize=read(mov,1);
[m n]=size(mySize);
nShort=n/3;    %彩色图像的其中一帧
%产生混沌序列
%产生第1个混沌序列
l=linspace(0,0,m*nShort);
l(1)=0.98;
for i=2:m*nShortl(i)=1-2*l(i-1)*l(i-1);
end
[lsort,lindex]=sort(l);
%产生第2个混沌序列
l(1)=0.99;
for i=2:m*nShortl(i)=1-2*l(i-1)*l(i-1);
end
[lsort,lindex2]=sort(l);
%产生第3个混沌序列
l(1)=0.92;
for i=2:m*nShortl(i)=1-2*l(i-1)*l(i-1);
end
[lsort,lindex3]=sort(l);
% b1=ones(m,n,3);
% b3=b1;
begin=5;  %开始置乱的帧数
myEnd=10;   %结束置乱的帧数
for i=1:begin-1b=read(mov,i);aviobj=addframe(aviobj,b);
end
%%%%%%%%%%%%%%%置乱
for i=begin:myEnd       %将特定帧置乱b=read(mov,i);%彩色图像中的R层b1=reshape(b(:,:,1),1,m*nShort);for k=1:m*nShortb2(k)=b1(lindex(k));endb3(:,:,1)=reshape(b2,m,nShort);%彩色图像中的G层b1=reshape(b(:,:,2),1,m*nShort);for k=1:m*nShortb2(k)=b1(lindex2(k));endb3(:,:,2)=reshape(b2,m,nShort);%彩色图像中的B层置乱b1=reshape(b(:,:,3),1,m*nShort);for k=1:m*nShortb2(k)=b1(lindex3(k));endb3(:,:,3)=reshape(b2,m,nShort);%     b2=reshape(b1,m,n);aviobj=addframe(aviobj,b3);
end
%%%%%%%%%%%%%%%置乱
for i=myEnd+1:mov.numberofframesb=read(mov,i);aviobj=addframe(aviobj,b);
end
aviobj=close(aviobj);
mplay('myAVI\myAVI.avi');

逆置乱:

%特定帧的帧内逆置乱
%程序开发: lilizong@gmail.com
%2013-9-19
clc;
clear all;
aviobj=avifile('myAVI\myAVI');
aviobj.Quality=100;
aviobj.compression='None';
mov=mmreader('aviVideo\myAVI.avi');     %用mmreader读入视频文件  50帧
mySize=read(mov,1);
[m n]=size(mySize);
nShort=n/3;    %彩色图像的其中一帧
%产生混沌序列
%产生第一个混沌序列
l=linspace(0,0,m*nShort);
l(1)=0.98;
for i=2:m*nShortl(i)=1-2*l(i-1)*l(i-1);
end
[lsort,lindex]=sort(l);
[lsort,invertlindex]=sort(lindex);
%产生第2个混沌序列
l(1)=0.99;
for i=2:m*nShortl(i)=1-2*l(i-1)*l(i-1);
end
[lsort,lindex2]=sort(l);
[lsort,invertlindex2]=sort(lindex2);
%产生第3个混沌序列
l(1)=0.92;
for i=2:m*nShortl(i)=1-2*l(i-1)*l(i-1);
end
[lsort,lindex3]=sort(l);
[lsort,invertlindex3]=sort(lindex3);
% b1=ones(m,n,3);
% b3=b1;
begin=5;  %开始置乱的帧数
myEnd=10;   %结束置乱的帧数
for i=1:begin-1b=read(mov,i);aviobj=addframe(aviobj,b);
end
%%%%%%%%%%%%%%%置乱
for i=begin:myEnd       %将特定帧置乱b=read(mov,i);%彩色图像中的R层b1=reshape(b(:,:,1),1,m*nShort);for k=1:m*nShortb2(k)=b1(invertlindex(k));endb3(:,:,1)=reshape(b2,m,nShort);%彩色图像中的G层b1=reshape(b(:,:,2),1,m*nShort);for k=1:m*nShortb2(k)=b1(invertlindex2(k));endb3(:,:,2)=reshape(b2,m,nShort);%彩色图像中的B层置乱b1=reshape(b(:,:,3),1,m*nShort);for k=1:m*nShortb2(k)=b1(invertlindex3(k));endb3(:,:,3)=reshape(b2,m,nShort);%     b2=reshape(b1,m,n);aviobj=addframe(aviobj,b3);
end
%%%%%%%%%%%%%%%置乱
for i=myEnd+1:mov.numberofframesb=read(mov,i);aviobj=addframe(aviobj,b);
end
aviobj=close(aviobj);
mplay('myAVI\myAVI.avi');


这篇关于视频的帧内置乱及逆置乱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742111

相关文章

Nginx添加内置模块过程

《Nginx添加内置模块过程》文章指导如何检查并添加Nginx的with-http_gzip_static模块:确认该模块未默认安装后,需下载同版本源码重新编译,备份替换原有二进制文件,最后重启服务验... 目录1、查看Nginx已编辑的模块2、Nginx官网查看内置模块3、停止Nginx服务4、Nginx

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Java如何获取视频文件的视频时长

《Java如何获取视频文件的视频时长》文章介绍了如何使用Java获取视频文件的视频时长,包括导入maven依赖和代码案例,同时,也讨论了在运行过程中遇到的SLF4J加载问题,并给出了解决方案... 目录Java获取视频文件的视频时长1、导入maven依赖2、代码案例3、SLF4J: Failed to lo

Python实现多路视频多窗口播放功能

《Python实现多路视频多窗口播放功能》这篇文章主要为大家详细介绍了Python实现多路视频多窗口播放功能的相关知识,文中的示例代码讲解详细,有需要的小伙伴可以跟随小编一起学习一下... 目录一、python实现多路视频播放功能二、代码实现三、打包代码实现总结一、python实现多路视频播放功能服务端开

Python实现视频转换为音频的方法详解

《Python实现视频转换为音频的方法详解》这篇文章主要为大家详细Python如何将视频转换为音频并将音频文件保存到特定文件夹下,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5. 注意事项