EmguCV学习笔记 C# 11.7 风格迁移

  版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。

教程VB.net版本请访问:EmguCV学习笔记 VB.Net 目录-CSDN博客

教程C#版本请访问:EmguCV学习笔记 C# 目录-CSDN博客

笔者的博客网址:https://blog.csdn.net/uruseibest

教程配套文件及相关说明以及如何获得pdf教程和代码,请移步:EmguCV学习笔记

学习VB.Net知识,请移步: vb.net 教程 目录_vb中如何用datagridview-CSDN博客

 学习C#知识,请移步:C# 教程 目录_c#教程目录-CSDN博客

本节内容以前发过,为了教程完整新,重新再发一遍。

11.7 风格迁移

斯坦福大学李飞飞团队的风格迁移模型是一种基于深度学习的图像处理技术,可以将一张图像的风格转移到另一张图像上。该模型最初由Gatys等人提出,后来被李飞飞团队进一步优化和改进。该模型在图像处理领域具有广泛的应用,例如艺术风格转换、视频风格迁移等。

【代码位置:frmChapter11】Button7_Click

        //风格序号

        int styleindex = 0;

        //风格迁移

        private void Button7_Click(object sender, EventArgs e)

        {

            //需要测试的图像文件

            Mat m = new Mat("C:\\learnEmgucv\\tower.jpg", ImreadModes.Color);

            Single hm = m.Height;

            Single wm = m.Width;

            //10种风格迁移

            string[] styles = new string[10];

            styles[0] = "C:\\learnEmgucv\\styletransfer\\eccv16\\starry_night.t7";

            styles[1] = "C:\\learnEmgucv\\styletransfer\\eccv16\\composition_vii.t7";

            styles[2] = "C:\\learnEmgucv\\styletransfer\\eccv16\\la_muse.t7";

            styles[3] = "C:\\learnEmgucv\\styletransfer\\eccv16\\the_wave.t7";

            styles[4] = "C:\\learnEmgucv\\styletransfer\\instance_norm\\candy.t7";

            styles[5] = "C:\\learnEmgucv\\styletransfer\\instance_norm\\feathers.t7";

            styles[6] = "C:\\learnEmgucv\\styletransfer\\instance_norm\\la_muse.t7";

            styles[7] = "C:\\learnEmgucv\\styletransfer\\instance_norm\\mosaic.t7";

            styles[8] = "C:\\learnEmgucv\\styletransfer\\instance_norm\\the_scream.t7";

            styles[9] = "C:\\learnEmgucv\\styletransfer\\instance_norm\\udnie.t7";

            Net net;

            net = DnnInvoke.ReadNet(styles[styleindex]);

            Mat blob ;

            blob = DnnInvoke.BlobFromImage(m, 1.0, new Size((int)wm, (int)hm), new MCvScalar(0, 0, 0), false, false);

            net.SetInput(blob);

            Mat mout = new Mat();

            mout = net.Forward();

            //返回一个四维数组

            Single[,,,] fout;

            fout = (Single[,,,])mout.GetData();

            //返回维度:

            //1维:图像数量,这里是1

            //2维:通道数量   //3

            //3维:高度    //

            //4维:宽度    //

            //在实际中需要将第2维、第3维、第4维提取出来组成一个图像

            int channels = fout.GetLength(1);

            int height = fout.GetLength(2);

            int width = fout.GetLength(3);

            VectorOfMat vm = new VectorOfMat();

            for (int i = 0; i < channels; i++)

            {

                //取出每个通道

                Matrix<int> matr = new Matrix<int>(new Size(width, height));

                for (int j = 0; j < height; j++)

                    for (int k = 0; k < width; k++)

                        matr[j, k] = (int)fout[0, i, j, k];

                //将每个通道图像加入到VectorOfMat,总共3个通道

                vm.Push(matr.Mat);

            }

            Mat outputmat = new Mat();

            //合并通道

            CvInvoke.Merge(vm, outputmat);

            ImageBox1.Image = outputmat;

            if (styleindex == 9)

                styleindex = 0;

            else

                styleindex += 1;

        }

输出结果如下图所示:

 

 图11-6 风格迁移后的图像

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值