著录项信息
专利名称 | 一种基于机器学习的人脸卡通画生成方法 |
申请号 | CN201110030099.6 | 申请日期 | 2011-01-27 |
法律状态 | 权利终止 | 申报国家 | 中国 |
公开/公告日 | 2011-06-15 | 公开/公告号 | CN102096934A |
优先权 | 暂无 | 优先权号 | 暂无 |
主分类号 | G06T11/00 | IPC分类号 | G;0;6;T;1;1;/;0;0;;;G;0;6;K;9;/;4;6;;;G;0;6;N;9;9;/;0;0查看分类表>
|
申请人 | 电子科技大学 | 申请人地址 | 四川省成都市高新区(西区)西源大道2006号
变更
专利地址、主体等相关变化,请及时变更,防止失效 |
权利人 | 电子科技大学 | 当前权利人 | 电子科技大学 |
发明人 | 李宏亮;张春婷 |
代理机构 | 电子科技大学专利中心 | 代理人 | 周永宏 |
摘要
本发明公开了一种基于机器学习的人脸卡通画生成方法。本发明针对现有的人脸卡通画生成方法中的缺陷,包括生成的人脸卡通画形象不够逼真和缺少纹理特征,通过对人脸图像库及其对应的卡通图像库的图像进行轮廓提取及对齐,保证了生成的人脸卡通画与真实人脸之间的相似性,通过图像的分块处理和机器学习,产生一个最优滤波器组,使得生成的人脸卡通画具有较强的纹理特征。本发明的方法包括如下步骤:图像的轮廓提取及对齐;图像的分块处理;计算滤波器组;人脸卡通画的绘制合成。
1.一种基于机器学习的人脸卡通画生成方法,包括如下步骤:
S1.图像的轮廓提取及对齐,分别从人脸图像库及其对应的卡通图像库,提取真实的人脸轮廓和人脸卡通画轮廓,分别用Sphoto和Scartoon表示人脸轮廓点和对应的人脸卡通画轮廓点的坐标值,通过平移和尺度变换使真实的人脸轮廓和对应的人脸卡通画轮廓对齐,即使得E=e(Sphoto,Scartoon)最小,其中e(Sphoto,Scartoon)表示的是通过马氏距离来衡量真实人脸和对应的人脸卡通轮廓对齐误差,最后统计所对齐的轮廓,即计算对齐后的轮廓坐标的平均值,形成归一化模板;
S2.图像的分块处理,分别将对齐的人脸图像库及其对应的卡通图像库分成相互重叠相同大小的块,每一个人脸图像由若干个块组成,用 表示,
其中 表示人脸图像库中第i幅人脸图像的第j个块图像,同理,每一个对应的卡通图像也由相同的若干个块组成,用 表示,其中 表示卡
通图像库中第i幅人脸卡通画的第j个块图像,其中,j的取值为:j=1,...,N,N表示一幅图像分得的块数,i的取值为:i=1,…,M,M表示人脸图像库包含的图像的数目,S3.计算滤波器组F,预设一个滤波器组F′,滤波器组包含N个滤波器,用F′={f′1,f′2,…,f′N}表示,具体计算过程如下:
S30.初始化化图像块矩阵 和 其中 是由每一
幅人脸图像中第j个块图像组成的矩阵, 是由每一幅卡
通图像中第j个块图像组成的矩阵,其中j=1,…,N;
S31.计 算 其 中 作
为初始人脸卡通画的结果,比较生成的初始人脸卡通画 和对应的 即得到
S32.利用对比发散和随机梯度上升法,通过Errorj获得一个新的滤波器fj,用fj代替f′j,重复步骤S31,获得一个新的
S33.比较Errorj和Errorj′,若Errorj和Errorj′的差值的绝对值大于预设的值,使Errorj=Errorj′,重复步骤S32,否则,fj即为所求的滤波器,
S34.分别使j=1,2,…,N,重复步骤S31-S33,即可求出对应的N个滤波器,得到滤波器组F={f1,f2,…,fN};
S4.人脸卡通画的绘制合成,输入一幅真实人脸图像,提取其轮廓,使其与
步骤S1中形成的归一化模板对齐,并分成与图像库中块大小相同的N个块,用
表示,利用步骤S3得到的滤波器组F={f1,f2,…,fN}计算
生成的每一个卡通块,即 j=1,…,N,将得到的每一个卡通块按分块的
顺序组合成人脸卡通画,相邻块重叠部分的像素值取这相邻两块重叠部分的平均值。
2.根据权利要求1所述的基于机器学习的人脸卡通画生成方法,其特征在于,步骤S1所述的轮廓提取采用的是主动形状模型方法。
一种基于机器学习的人脸卡通画生成方法\n技术领域\n[0001] 本发明涉及计算机视觉和计算机图形图像处理技术,特别涉及一种面向人脸视觉感知信息的非真实感表现技术,具体涉及人脸卡通画的生成方法。\n背景技术\n[0002] 随着数字媒体技术的快速发展,人们的生活和工作方式也发生了很大的改变,通过计算机生成人物的卡通画在很多领域都有着广泛的应用,例如在移动数字娱乐、视频会议、网络游戏中,采用虚拟的卡通头像代替真实的人脸,不仅可以提高网络的数据传输速度,还营造了轻松和谐的氛围。\n[0003] 在已有的技术中,由计算机生成人脸卡通画主要包括三种方法:基于模板的方法、基于样本学习的方法和直接基于图像处理方法,下面分别进行阐述。\n[0004] 1.基于模板的方法\n[0005] 基于模板的方法主要是通过人为指定夸张变形参数并将其应用到任何脸部待夸张区域。该方法生成卡通人脸笔调生硬,难以表现艺术家多样的夸张模式。较早的二维卡通人脸合成研究是Brennan在1982年提出了一套以互动方式产生夸张肖像的系统,从认知学的角度对人脸特征突出的部分进行夸张,以此产生幽默感。随后产生了对输入照片的人脸轮廓进行夸张变形的方法,主要是通过人脸特征提取和获得的平均人脸特性进行比对,发现其相对突出的特征,采用主动形状模型特征提取和特征线对相结合的方法,对突出的特征实现自动变形,生成人物的卡通肖像。这种方法能够给出简单的人脸线条画,并对突出特征进行夸张变形。变形时,该方法针对一种特征进行变形可以得到一定的夸张效果,但对多个突出特征进行变形时不能保证特征的整体协调性,使生成的卡通画与源图像不一致。\n[0006] 2.基于样本学习的方法\n[0007] 基于样本学习的方法是以画家画的具有某种风格的肖像画数据库为基础,从训练样本中学习到的夸张模式运用到输入的真实人脸上,从而得到具有这种画家风格的卡通人脸肖像画。如在文献“H.Chen,L.Liang,Y.Q.Xu,H.Y.Shum,and N.N.Zheng,Example-based Automatic Portraiture,in Proc.5th Asia Conference.on Computer Vision,2002,\n127-140”中采用非均匀的马尔科夫随机场模型来描述肖像画与人脸图像之间的统计关系,对不同特征进行非参数采样来获取复杂的统计特征,最终可以自动生成与本人照片相似的特定风格的线条卡通画。但这种方法生成的卡通画不够逼真形象。\n[0008] 3.基于图像自身的方法\n[0009] 在文献:“Gooch B.,Reinhard E.,Gooch A.,Human facial illustrations:\nCreation and psychophysical evaluation.ACM Transactions on Graphics 23(1),\n2004,27-44”中提出对人脸照片进行卷积计算,在频域获得人脸特征并进行处理,最后经过简单变形也可以获得卡通画,但这种方法生成的是简单的线条画,缺少纹理特征。\n发明内容\n[0010] 本发明的目的是为了解决上述现有的人脸卡通画生成方法中的缺陷,包括生成的人脸卡通画形象不够逼真和缺少纹理特征,提出了一种基于机器学习的人脸卡通画生成方法。\n[0011] 为了实现上述目的,本发明的技术方案是:一种基于机器学习的人脸卡通画生成方法,包括如下步骤:\n[0012] S1.图像的轮廓提取及对齐,分别从人脸图像库及其对应的卡通图像库,提取真实的人脸轮廓和人脸卡通画轮廓,分别用Sphoto和Scartoon表示人脸轮廓点和对应的人脸卡通画轮廓点的坐标值,通过平移和尺度变换使真实的人脸轮廓和对应的人脸卡通画轮廓对齐,即使得E=e(Sphoto,Scartoon)最小,其中e(Sphoto,Scartoon)表示的是通过马氏距离来衡量真实人脸和对应的人脸卡通轮廓对齐误差,最后统计所对齐的轮廓,即计算对齐后的轮廓坐标的平均值,形成归一化模板;\n[0013] S2.图像的分块处理,分别将对齐的人脸图像库及其对应的卡通图像库分成相互重叠相同大小的块,每一个人脸图像由若干个块组成用 表\n示,其中 表示人脸图像库中第i幅人脸图像的第j个块图像,同理,每一个对应的卡通图像也由相同的若干个块组成,用 表示,其中 表\n示卡通图像库中第i幅人脸卡通画的第j个块图像,其中,j的取值为:j=1,…,N,N表示一幅图像分得的块数,i的取值为:i=1,…,M,M表示人脸图像库包含的图像的数目,[0014] S3.计算滤波器组F,预设一个滤波器组F′,滤波器组包含N个滤波器,用F′={f′1,f′2,…,f′N}表示,具体计算过程如下:\n[0015] S30.初始化化图像块矩阵 和 其中 是由\n每一幅人脸图像中第j个块图像组成的矩阵, 是由每一\n幅卡通图像中第j个块图像组成的矩阵,其中j=1,…,N;\n[0016] S31.计 算 其 中\n作为初始人脸卡通画的结果,比较生成的初始人脸卡通画 和对应的 即得到\n[0017] S32.利用对比发散和随机梯度上升法,通过Errorj获得一个新的滤波器fj,用fj代替f′j,重复步骤S31,获得一个新的\n[0018] S33.比较Errorj和Errorj′,若Errorj和Errorj′的差值的绝对值大于预设的值,使Errorj=Errorj′,重复步骤S32,否则,fj即为所求的滤波器,\n[0019] S34.分别使j=1,2,…,N,重复步骤S31-S33,即可求出对应的N个滤波器,得到滤波器组F={f1,f2,…,fN};\n[0020] S4.人脸卡通画的绘制合成,输入一幅真实人脸图像,提取其轮廓,使其与步骤S1中形成的归一化模板对齐,并分成与图像库中块大小相同的N个块,用表示,利用步骤S3得到的滤波器组F={f1,f2,…,fN}计算\n生成的每一个卡通块,即 j=1,…,N,将得到的每一个卡通块按分块的\n顺序组合成人脸卡通画,相邻块重叠部分的像素值取这相邻两块重叠部分的平均值。至此,完成了人脸卡通画的绘制。\n[0021] 本发明的有益效果:本发明通过对人脸图像库及其对应的卡通图像库的图像进行轮廓提取及对齐,保证了生成的人脸卡通画与真实人脸之间的相似性,通过图像的分块处理和机器学习,产生一个最优滤波器组,使得生成的人脸卡通画具有较强的纹理特征。\n附图说明\n[0022] 图1是图像数据库中部分真实人脸图像和对应的人脸卡通画图像。\n[0023] 图2是本发明的基于机器学习的人脸卡通画生成方法的流程示意图。\n[0024] 图3是本发明的基于机器学习的人脸卡通画生成方法的仿真结果示意图。\n具体实施方式\n[0025] 下面结合附图和具体实施例对本发明进行进一步的说明。\n[0026] 本发明首先通过对人脸图像库及其对应的卡通图像库的图像进行轮廓提取及对齐,保证了生成的人脸卡通画与真实人脸之间的相似性,使得生成的人脸卡通画形象逼真;\n通过图像的分块处理和机器学习,产生一个最优滤波器组,使得生成的人脸卡通画具有较强的纹理特征。本实施例使用的图像数据库中部分真实人脸图像和对应的人脸卡通画图像如图1所示,由于篇幅限制,只给出了部分图像。本发明的基于机器学习的人脸卡通画生成方法的流程示意图如图2所示,具体展开如下:\n[0027] S1.图像的轮廓提取及对齐,分别从包含如图1所示的90幅人脸图像库及其对应的90幅卡通图像库中提取人脸轮廓和人脸卡通画轮廓,分别用Sphoto和Scartoon表示人脸轮廓和人脸卡通画轮廓点的坐标值,这里的轮廓点为68个点,通过平移和尺度变换使真实的人脸轮廓和对应的人脸卡通画轮廓对齐,即使得E=e(Sphoto,Scartoon)最小,其中e(Sphoto,Scartoon)表示的是通过马氏距离来衡量真实人脸和对应的人脸卡通轮廓对齐误差,最后统计所对齐的轮廓,即计算对齐后的轮廓坐标的平均值,形成归一化模板。这里的轮廓提取采用主动形状模型方法进行,具体可参考:“T.F Cootes,C.J Taylor,D.H Cooper,et al.Active Shape Models-Their Training and Application.Computer Vision and Image Under standing V01.61,NO.1,January,1995,28-59”;\n[0028] S2.图像的分块处理,分别将对齐的人脸图像库及其对应的卡通图像库分成相互重叠相同大小的块,每幅图像的大小128×96,每个块的大小为16×16,重叠12个像素,每幅图像分成609个块,用 表示,其中 表示人脸图像库\n中第i幅人脸图像的第j个块图像,同理,每一个对应的卡通图像也由相同的若干个块组成,用 表示,其中 表示卡通图像库中第i幅人脸\n卡通画的第j个块图像,其中,j的取值为:j=1,…,N,N表示一幅图像分得的块数,这里N=609,i的取值为:i=1,…,M,M表示人脸图像库包含的图像的数目,人脸图像库和卡通人脸图像库的图像数目相同,这里M=90;\n[0029] 这样,图像库中所有的人脸图像分成的图像块可以用下面一个矩阵表示:\n[0030] \n[0031] 同理,图像库中所有的卡通图像分成的图像块也可以用下面一个矩阵表示:\n[0032] \n[0033] S3.计算滤波器组F,预设一个滤波器组F′,滤波器组包含N个滤波器,每个滤波器采用的是3*3的随机滤波器,用F′={f′1,f′2,…,f′N}表示,具体计算过程如下:\n[0034] S30. 初 始 化 化 图 像 块 矩 阵 和 其 中\n是 由 每\n一幅人脸图像中第j个块图像组成的矩阵,即上述矩阵A的第j列列向量,\n是由每一幅卡通图像库中的卡通图像的第j个块图像组\n成的矩阵,即上述矩阵B的第j列列向量,其中j=1,…,609;\n[0035] S31.计算 作为初始人脸卡通画的结果,比较生成的初始人\n脸卡通画 和对应的 即得到\n[0036] S32.利用对比发散和随机梯度上升法,通过Errorj获得一个新的滤波器fj,用fj代替f′j,重复步骤S31,获得一个新的\n对比发散法可参考文献:“Hinton,G.E.Training products of experts by minimizing contrastive divergence.Neural Computation,14(8),1771-1800”,随 机 梯 度 上 升法 可 参 考 文 献:“Bottou L.Stochastic learning.Advanced lectures on machine learning.2004”,在此不再进行详细描述;\n[0037] S33.比较Errorj和Errorj′,若Errorj和Errorj′的差值的绝对值大于预设的值,预设的阈值为0.8,使Errorj=Errorj′,重复步骤S32,否则,fj即为所求的滤波器;\n[0038] S34.分别使j=1,2,…,609,重复步骤S31-S33,即可求出对应的609个滤波器,得到滤波器组F={f1,f2,…,f609};\n[0039] 以上步骤S1-S3为训练过程,也是机器学习的过程,即利用人脸图像库,通过多次迭代,获得所需要的滤波器组的过程。\n[0040] S4.人脸卡通画的绘制合成,输入一幅真实人脸图像,提取其轮廓,使其与步骤S1中形成的归一化模板对齐,即脸部器官的对齐,分成相同大小的609个块,用表示,利用步骤S3得到的滤波器组计算每一个人脸块生成的\n卡通块,即 j=1,…,609。将得到的每一个人脸卡通块按分块的顺序组\n合成人脸卡通画,相邻块重叠部分的像素值取这相邻两块重叠部分的平均值。步骤S4可以看作是测试过程,也即是最终的人脸卡通画的绘制合成过程。\n[0041] 在本实施例中,如图3上部分所示,采用了4幅人脸图像进行测试。图3下部分是仿真生成的人脸卡通画,从图上可以看出,生成的人脸卡通画形象与真实的人脸图像相比,形象逼真并且具有较强的纹理特征。\n[0042] 本领域的普通技术人员将会意识到,这里所述的实施例是为了帮助读者理解本发明的原理,应被理解为发明的保护范围并不局限于这样的特别陈述和实施例。凡是根据上述描述做出各种可能的等同替换或改变,均被认为属于本发明的权利要求的保护范围。
法律信息
- 2017-03-22
未缴年费专利权终止
IPC(主分类): G06T 11/00
专利号: ZL 201110030099.6
申请日: 2011.01.27
授权公告日: 2012.05.23
- 2012-05-23
- 2011-08-10
实质审查的生效
IPC(主分类): G06T 11/00
专利申请号: 201110030099.6
申请日: 2011.01.27
- 2011-06-15
引用专利(该专利引用了哪些专利)
序号 | 公开(公告)号 | 公开(公告)日 | 申请日 | 专利名称 | 申请人 | 该专利没有引用任何外部专利数据! |
被引用专利(该专利被哪些专利引用)
序号 | 公开(公告)号 | 公开(公告)日 | 申请日 | 专利名称 | 申请人 | 1 | | 2013-11-13 | 2013-11-13 | | |
2 | | 2013-11-13 | 2013-11-13 | | |