原地址:http://www.cnblogs.com/zengqs/archive/2009/02/12/1389208.html

OpenCV训练分类器

OpenCV训练分类器

一、简介

目标检测方法最初由Paul Viola [Viola01]提出,并由Rainer Lienhart [Lienhart02]对这一方法进行了改善。该方法的基本步骤为: 首先,利用样本(大约几百幅样本图片)的 harr 特征进行分类器训练,得到一个级联的boosted分类器。

分类器中的"级联"是指最终的分类器是由几个简单分类器级联组成。在图像检测中,被检窗口依次通过每一级分类器, 这样在前面几层的检测中大部分的候选区域就被排除了,全部通过每一级分类器检测的区域即为目标区域。

分类器训练完以后,就可以应用于输入图像中的感兴趣区域(与训练样本相同的尺寸)的检测。检测到目标区域(汽车或人脸)分类器输出为1,否则输出为0。为了检测整副图像,可以在图像中移动搜索窗口,检测每一个位置来确定可能的目标。为了搜索不同大小的目标物体,分类器被设计为可以进行尺寸改变,这样比改变待检图像的尺寸大小更为有效。所以,为了在图像中检测未知大小的目标物体,扫描程序通常需要用不同比例大小的搜索窗口对图片进行几次扫描。

目前支持这种分类器的boosting技术有四种: Discrete Adaboost, Real Adaboost, Gentle Adaboost and Logitboost。

"boosted" 即指级联分类器的每一层都可以从中选取一个boosting算法(权重投票),并利用基础分类器的自我训练得到。

根据上面的分析,目标检测分为三个步骤:

、 样本的创建

、 训练分类器

、 利用训练好的分类器进行目标检测。

二、样本创建

训练样本分为正例样本和反例样本,其中正例样本是指待检目标样本(例如人脸或汽车等),反例样本指其它任意图片,所有的样本图片都被归一化为同样的尺寸大小(例如,20x20)。

负样本

负样本可以来自于任意的图片,但这些图片不能包含目标特征。负样本由背景描述文件来描述。背景描述文件是一个文本文件,每一行包含了一个负样本图片的文件名(基于描述文件的相对路径)。该文件必须手工创建。

e.g: 负样本描述文件的一个例子:

假定目录结构如下:

/img

img1.jpg

img2.jpg

bg.txt

则背景描述文件bg.txt的内容为:

img/img1.jpg

img/img2.jpg

正样本

正样本由程序craatesample程序来创建。该程序的源代码由OpenCV给出,并且在bin目录下包含了这个可执行的程序。

正样本可以由单个的目标图片或者一系列的事先标记好的图片来创建。

Createsamples程序的命令行参数:

命令行参数:

-vec

训练好的正样本的输出文件名。

-img

源目标图片(例如:一个公司图标)

-bg

背景描述文件。

-num

要产生的正样本的数量,和正样本图片数目相同。

-bgcolor

背景色(假定当前图片为灰度图)。背景色制定了透明色。对于压缩图片,颜色方差量由bgthresh参数来指定。则在bgcolor-bgthresh和bgcolor+bgthresh中间的像素被认为是透明的。

-bgthresh

-inv

如果指定,颜色会反色

-randinv

如果指定,颜色会任意反色

-maxidev

背景色最大的偏离度。

-maxangel

-maxangle,

-maxzangle

最大旋转角度,以弧度为单位。

-show

如果指定,每个样本会被显示出来,按下"esc"会关闭这一开关,即不显示样本图片,而创建过程继续。这是个有用的debug选项。

-w

输出样本的宽度(以像素为单位)

-h《sample_height》

输出样本的高度,以像素为单位。

注:正样本也可以从一个预先标记好的图像集合中获取。这个集合由一个文本文件来描述,类似于背景描述文件。每一个文本行对应一个图片。每行的第一个元素是图片文件名,第二个元素是对象实体的个数。后面紧跟着的是与之匹配的矩形框(x, y, 宽度,高度)。

下面是一个创建样本的例子:

假定我们要进行人脸的检测,有5个正样本图片文件img1.bmp,…img5.bmp;有2个背景图片文件:bg1.bmp,bg2.bmp,文件目录结构如下:

positive

img1.bmp

……

Img5.bmp

negative

bg1.bmp

bg2.bmp

info.dat

bg.txt

正样本描述文件info.dat的内容如下:

Positive/imag1.bmp

……

Positive/imag5.bmp

图片img1.bmp包含了单个目标对象实体,矩形为(,,,)。

注意:要从图片集中创建正样本,要用-info参数而不是用-img参数。

-info

标记特征的图片集合的描述文件。

背景(负样本)描述文件的内容如下:

nagative/bg1.bmp

nagative/bg2.bmp

我们用一个批处理文件run.bat来进行正样本的创建:该文件的内容如下:

cd e:\face\bin

CreateSamples -vec e:\face\a.vec

-info e:\face\info.dat

-bg e:\face\bg.txt

-num

-show

-w

-h

其中e:\face\bin目录包含了createsamples可执行程序,生成的正样本文件a.vec在e:\face目录下。

三、训练分类器

样本创建之后,接下来要训练分类器,这个过程是由haartraining程序来实现的。该程序源码由OpenCV自带,且可执行程序在OpenCV安装目录的bin目录下。

Haartraining的命令行参数如下:

-data

存放训练好的分类器的路径名。

-vec

正样本文件名(由trainingssamples程序或者由其他的方法创建的)

-bg

背景描述文件。

-npos,

-nneg

用来训练每一个分类器阶段的正/负样本。合理的值是:nPos = ;nNeg =

-nstages

训练的阶段数。

-nsplits

决定用于阶段分类器的弱分类器。如果1,则一个简单的stump classifier被使用。如果是2或者更多,则带有number_of_splits个内部节点的CART分类器被使用。

-mem

预先计算的以MB为单位的可用内存。内存越大则训练的速度越快。

-sym(default)

-nonsym

指定训练的目标对象是否垂直对称。垂直对称提高目标的训练速度。例如,正面部是垂直对称的。

-minhitrate《min_hit_rate》

每个阶段分类器需要的最小的命中率。总的命中率为min_hit_rate的number_of_stages次方。

-maxfalsealarm

没有阶段分类器的最大错误报警率。总的错误警告率为max_false_alarm_rate的number_of_stages次方。

-weighttrimming

指定是否使用权修正和使用多大的权修正。一个基本的选择是0.

-eqw

-mode

选择用来训练的haar特征集的种类。basic仅仅使用垂直特征。all使用垂直和45度角旋转特征。

-w《sample_width》

-h《sample_height》

训练样本的尺寸,(以像素为单位)。必须和训练样本创建的尺寸相同。

一个训练分类器的例子:

同上例,分类器训练的过程用一个批处理文件run2.bat来完成:

cd e:\face\bin

haartraining -data e:\face\data

-vec e:\face\a.vec

-bg e:\face\bg.txt

-npos

-nneg

-w

-h

训练结束后,会在目录data下生成一些子目录,即为训练好的分类器。

注:OpenCv 的某些版本可以将这些目录中的分类器直接转换成xml文件。但在实际的操作中,haartraining程序却好像永远不会停止,而且没有生成xml文件,后来在OpenCV的yahoo论坛上找到一个haarconv的程序,才将分类器转换为xml文件,其中的原因尚待研究。

文章一

原地址:http://www.cnblogs.com/tornadomeet/archive/2012/03/27/2420088.html

总所周知,机器学习前要训练很多数据,一直感觉训练数据是个很神圣的东西,到底怎么训练呢?头脑一直有这么个疑问,但一直没时间去体验。因此最近在学adaboost算法,就要学会怎样训练出一个.xml文件了。方法是相同的,用过一次,以后的训练过程就差不多了。

只是打算进行简单的人脸数据训练,而是在网上下载了yale大学的人脸数据库,由耶鲁大学计算视觉与控制中心创建,包含15位志愿者的165张图片,包含光照,表情和姿态。下载网址为:

http://cvc.yale.edu/projects/yalefaces/yalefaces.html。图片如下所示:

(右下角是我的系统透明主题的青花瓷照片,别惊讶怎么出来的哈…)

Yale大学人脸数据都是bmp格式的,*80像素大小。由于这次的haartraining只是为了学会其过程,再加上这个算法训练的时间非常长,图片不到1000就需要的时间都是以天为单位。所以为了减少训练时间,我们一方面得减少图片的数量,这里我打算用133张正样本图,另外22个张用来做测试,另一方面打算减小图片的尺寸,将80*80的图片统一到尺寸24*24像素大小。

(这里插2个小知识:. 理解图片尺寸的概念。比如说图片的尺寸为80*80代表的是图片的大小为80*,并不是指分辨率,而是说的是80*80像素,即宽度为80个像素,长度也为80个像素。因为一个像素宽在一个显示器件上已经确定了。因此当一副图片被放大时,它的尺寸像素就可能改变,比如变成了100*100像素,因为放大的时候它的长和宽变了。但是其分辨率在放大时并没有变化。另外像素和长度cm的对应关系也得看图形的分辨率,比如通常所说的说1cm=28像素是指在72像素/平方英寸的时候。所以一般所说的数码相机的像素过高的话其实对显示器显示图片清晰度没有太大帮助,像素高只是可以打印出来更大更清晰的照片。

. 在window下如果一副图片,比如说是bmp格式的。我只需把后缀名改为其他的比如jpg。然后右键查看其属性时竟然是jpg格式,并且也能打开,难道真的就是jpg格式的吗?肯定不是,比较bmp和改后的jpg就会发现两者的大小是一样的。最后用matlab命令的imfinfo来查看图片的信息,也还是bmp格式的。说明上面单独改后缀名是一种误导,以后做图像处理的时候一定要小心。)

接下来所要进行的操作就是把这165张图片的尺寸缩小到24*24像素了,当然这里有一个笨方法,就是用图片查看软件(比如说ACDsee)一张一张转换。不过要是图片成千上万那就麻烦了。也不懂有什么批处理的工具没有,有的话大家也可以提出来共享。

所以打算自己写一个小程序来完成这些批处理工作,图片的缩放就用opencv中现有的函数了。写这个小程序的主要目的是练习对文件名的操作,因为以前一直对这些东西没概念,今天练习了下,收获还是有的。

刚刚在上图可以看出,人脸数据库的命名比如1_s1.bmp表示的是第一个人的第一张人脸图。最后调整后的名字改为1_s1n.bmp。

首先在工程文件目录下,建立yale和yale_small_size文件夹,并把165张人脸数据图片拷贝到yale文件夹中。最后通过程序生成的小尺寸图全部放在yale_small_size文件夹中。如下所示:

其程序代码如下:

// change_img_size.cpp : 定义控制台应用程序的入口点。

//

#include "stdafx.h"//这句头文件一定要放在最上面,否则很容易报错

#include "opencv2/imgproc/imgproc.hpp"

#include "opencv2/highgui/highgui.hpp"

#include

#include

using namespace cv;

using namespace std;

#define DST_IMG_WIDTH 24 //需要调整图片后的尺寸宽度

#define SRC_IMG_HEIGH 24 //需要调整图片后的尺寸高度

int main(int argc, char* argv[])

{

Mat src_img;

int i,j;

string src_img_name="yale/",dst_img_name="yale_small_size/";//源文件和目的文件的文件夹名字

char chari[],charj[];//因为人脸数据不是很多,所以下标5足够用

for(i=;i<=;i++)//15个人的人脸数据

{

for(j=;j<=;j++)//每个人的人脸有11种不同的表情

{

itoa(i,chari,);//将变量转换成字符型,此处的chari是字符数组首地址,但是如果定义为char *chari="";则会出现错误,why?

itoa(j,charj,);

src_img_name+=chari;//原图命名格式为,比如第5个人的第6张图,5_s6.bmp

src_img_name+="_s";

src_img_name+=charj;

src_img_name+=".bmp";

src_img=imread(src_img_name,);

Mat dst_img_rsize(DST_IMG_WIDTH,SRC_IMG_HEIGH,src_img.type());

resize(src_img,dst_img_rsize,dst_img_rsize.size(),,,INTER_LINEAR);

dst_img_name+=chari;//转换后图的命名格式为:例上,5_s6n.bmp

dst_img_name+="_s";

dst_img_name+=charj;

dst_img_name+="n.bmp";

imwrite(dst_img_name,dst_img_rsize);

src_img_name="yale/",dst_img_name="yale_small_size/";//每次循环后要重新清0字符数组内的内容,目的文件夹一定要事先建立,否则无效果

}

}

return ;

}

最后生成的归一化后的图片截图如下所示(yale_small_size文件夹内):

好吧,很简单的工作已经完成了,没什么含量。以后有时间打算写个界面出来,可以批处理的调整图片到指定的像素大小,为以后搞视觉的图片前期处理带来便利。

作者:tornadomeet 出处:http://www.cnblogs.com/tornadomeet 欢迎转载或分享,但请务必声明文章出处。 (新浪微博:tornadomeet,欢迎交流!)

文章二

.准备正负样本:

在上一讲http://www.cnblogs.com/tornadomeet/archive/2012/03/27/2420088.html 中,我们已经收集到了训练所用的正样本。下面就开始收集负样本了,负样本要求是:不能包含人脸,且图片大小也不需要归一化到正样本尺寸,只需比正样本尺寸大或者相等即可。建议负样本用灰度图,加快训练速度,且负样本一定不能重复,要增大负样本的差异性。

这里我采用的负样本是用的是weizmann团队http://www.wisdom.weizmann.ac.il/~vision/Seg_Evaluation_DB/dl.html 网站上的图像分割数据库,里面有灰色图和彩色图,这里当然选取灰度图了。

总共用了200幅图片,大小大约在300*200像素,截图如下所示:

可以看出这些200多张图片基本都没有人脸,所以说应该是可以的。

正负样本的图片准备好了,下面就开始制作正负样本的描述文件了。

首先建立好文件夹,把图片拷贝好,如下所示:

Pos_image中放入的是正样本,neg_image放入的是负样本,test_image放入的是测试样本。并将后面要用到的2个工具.exe文件也拷贝过来(在opencv的安装目录C:\Program Files\opencv2.3.1\build\common\x86下)。

.生成正负样本描述文件:

建立正样本的描述文件:

打开cmd窗口,进入上图所在pos_img文件夹内,可以看到此文件夹图片显示如下:

使用命令dir /b >pos_image.txt。如图所示

且用editplus打开该文件,删除最后一行,最后将名字归一化如下所示:

其中的pos_image/是相对路径名,后面紧接着的是文件名,1代表一个文件, 24表示这个文件的2个顶点位置坐标。保存退出即ok!

负样本的描述文件类似,只是不需要考虑其大小位置。

也是进入neg_imgae后在cmd内使用命令dir /b >neg_image.txt,如图所示:

同样删除最后一行文字,且将文件相对路径加入如下所示:

至此,训练数据准备完备了。

.创建vec文件:

在创建vec文件时,需要把pos_image.txt和neg_image.txt两个样本描述文件剪切到上一目录,如图所示:

然后利用opencv_createsamples.exe应用程序在该目录下使用如下cmd命令:

其中的-vec是指定后面输出vec文件的文件名,-info指定正样本描述文件,-bg指定负样本描述文件,-w和-h分别指正样本的宽和高,-num表示正样本的个数。执行完该命令后就会在当前目录下生产一个pos.vec文件了。

.使用opencv_haartraining.exe文件进行训练

首先在当前目录下新建一个xml文件夹用于存放生成的.xml文件。

在当前目录使用cmd命令:

Opcnv_haartraining.exe –data xml –vec pos.vec –bg neg_image.txt –nsplits –sym –w –h –mode all –mem

截图如下:

其中-data为输出xml中间文件的位置,-sym表示训练的目标为垂直对称,-nsplits 1表示使用简单的stump classfier分类。-mem 表示允许使用计算机的1280M内存,-mode all 表示使用haar特征集的种类既有垂直的,又有45度角旋转的。

因为数据量不是很多,不到半个钟头就训练好了。在当前目录下生产了一个xml.xml文件,将其重名名为face_test.xml。

.实验结果:

利用上面训练出来的face_test.xml文件来检测下人脸,首先来一张比较正面的人脸图,用奥巴马的,检测结果如下:

为了看看是否不是特别正的,且有背景干扰的结果,用了lena的图,检测结果如下:

上面说明其效果还是不错的。其测试源码和前面的博客http://www.cnblogs.com/tornadomeet/archive/2012/03/22/2411318.html的代码类似,删减了人眼检测的代码而已,源码如下:

// face_detect.cpp : 定义控制台应用程序的入口点。

//

#include "stdafx.h"

#include "opencv2/objdetect/objdetect.hpp"

#include "opencv2/highgui/highgui.hpp"

#include "opencv2/imgproc/imgproc.hpp"

#include "opencv2/ml/ml.hpp"

#include

#include

using namespace std;

using namespace cv;

void detectAndDraw( Mat& img,

CascadeClassifier& cascade,

double scale);

String cascadeName = "./face_test.xml";//人脸的训练数据

int main( int argc, const char** argv )

{

Mat image;

CascadeClassifier cascade, nestedCascade;//创建级联分类器对象

double scale = 1.3;

// image = imread("obama_gray.bmp",1);

image = imread("lena_gray.jpg",);

namedWindow( "result", );//opencv2.0以后用namedWindow函数会自动销毁窗口

if( !cascade.load( cascadeName ) )//从指定的文件目录中加载级联分类器

{

cerr << "ERROR: Could not load classifier cascade" << endl;

return ;

}

if( !image.empty() )//读取图片数据不能为空

{

detectAndDraw( image, cascade, scale );

waitKey();

}

return ;

}

void detectAndDraw( Mat& img,

CascadeClassifier& cascade,

double scale)

{

int i = ;

double t = ;

vector faces;

const static Scalar colors[] = { CV_RGB(,,),

CV_RGB(,,),

CV_RGB(,,),

CV_RGB(,,),

CV_RGB(,,),

CV_RGB(,,),

CV_RGB(,,),

CV_RGB(,,)} ;//用不同的颜色表示不同的人脸

Mat gray, smallImg( cvRound (img.rows/scale), cvRound(img.cols/scale), CV_8UC1 );//将图片缩小,加快检测速度

cvtColor( img, gray, CV_BGR2GRAY );//因为用的是类haar特征,所以都是基于灰度图像的,这里要转换成灰度图像

resize( gray, smallImg, smallImg.size(), , , INTER_LINEAR );//将尺寸缩小到1/scale,用线性插值

equalizeHist( smallImg, smallImg );//直方图均衡

t = (double)cvGetTickCount();//用来计算算法执行时间

//检测人脸

//detectMultiScale函数中smallImg表示的是要检测的输入图像为smallImg,faces表示检测到的人脸目标序列,1.1表示

//每次图像尺寸减小的比例为1.1,2表示每一个候选矩形需要记录2个邻居,CV_HAAR_SCALE_IMAGE表示使用haar特征,Size(30, 30)

//为目标的最小最大尺寸

cascade.detectMultiScale( smallImg, faces,

1.1, ,

//|CV_HAAR_FIND_BIGGEST_OBJECT

//|CV_HAAR_DO_ROUGH_SEARCH

|CV_HAAR_SCALE_IMAGE

,

Size(, ) );

t = (double)cvGetTickCount() - t;//相减为算法执行的时间

printf( "detection time = %g ms\n", t/((double)cvGetTickFrequency()*.) );

for( vector::const_iterator r = faces.begin(); r != faces.end(); r++, i++ )

{

Mat smallImgROI;

vector nestedObjects;

Point center;

Scalar color = colors[i%];

int radius;

center.x = cvRound((r->x + r->width*0.5)*scale);//还原成原来的大小

center.y = cvRound((r->y + r->height*0.5)*scale);

radius = cvRound((r->width + r->height)*0.25*scale);

circle( img, center, radius, color, , , );

smallImgROI = smallImg(*r);

}

cv::imshow( "result", img );

}

.参考文献:

. http://hi.baidu.com/zdd007007/blog/item/b2e7f026eec9e23f8644f959.html 的博客。

. http://blog.csdn.net/guxj821/article/details/6341239 网友周明才的博客。

文章三

OpenCV训练分类器制作xml文档

OpenCV训练分类器制作xml文档 (2011-08-25 15:50:06) 转载▼ 标签: 杂谈 分类: 学习 我的问题:有了opencv自带的那些xml人脸检测文档,我们就可以用cvLoad( ...

使用OpenCV训练Haar like&plus;Adaboost分类器的常见问题

——使用OpenCV训练Haar like+Adaboost分类器的常见问题 最近使用OpenCV训练Haar like+Adaboost ...

使用OpenCV训练好的级联分类器识别人脸

一.使用OpenCV训练好的级联分类器来识别图像中的人脸 当然还有很多其他的分类器,例如表情识别,鼻子等,具体可在这里下载: OpenCV分类器 import cv2 # 矩形颜色和描边 color ...

【macOS】 在OpenCV下训练Haar特征分类器

本教程基于以下环境 macOS 10.12.6,OpenCV 3.3.0,python 3.6.由于网上基于masOS系统的教程太少,想出一篇相关教程造福大家-本文旨在学习如何在opencv中基于ha ...

【计算机视觉】如何使用opencv自带工具训练人脸检测分类器

前言 使用opencv自带的分类器效果并不是很好,由此想要训练自己的分类器,正好opencv有自带的工具进行训练.本文就对此进行展开. 步骤 1.查找工具文件: 2.准备样本数据: 3.训练分类器: ...

使用opencv训练分类器时,traincascade训练报错:Train dataset for temp stage can not be filled&period;解决方法

opencv分类器训练中,出错一般都是路径出错,例如, 1.opencv_traincascade.exe路径 2.负样本路径文件,neg.dat中的样本前路径是否正确 3.移植到别的电脑并修改完路径 ...

openCV训练程序申请内存不足

openCV训练程序申请内存不足   在用OpenCV训练分类器(特别是训练Adaboost类型的分类器)的时候,当样本的数量特别大的时候,就会出现申请内存不够的情况,很早以前碰到过这样的情况,最近 ...

迁移学习算法之TrAdaBoost ——本质上是在用不同分布的训练数据,训练出一个分类器

迁移学习算法之TrAdaBoost from: https://blog.csdn.net/Augster/article/details/53039489 TradaBoost算法由来已久,具体算法 ...

13 opencv训练器

https://blog.csdn.net/WZZ18191171661/article/details/91305466 https://blog.csdn.net/qq_25352981/arti ...

随机推荐

springMVC的配置文件路径问题

① contextConfigLocationc ...

BizTalk开发系列&lpar;七&rpar; Hello World2

之前根据BizTalk的订阅原理,使用BizTalk管理控制台创建了第一个应用程序 Hello World.但是由于控制台的开发功能有限,绝大多数的BizTalk程序都是在集成开发环境Visual S ...

IntelliJ IDEA 环境配置

0. 下载 jdk 用于 java developer kit  下载地址 见 rj.baidu.com 1. 从百度 网盘下载 ideaIU-2016.2.5.exe 并安装在window上 2. ...

NOR Flash擦写和原理分析 (二)

Nor Flash上电后处于数据读取状态(Reading Array Data).此状态可以进行正常的读.这和读取SDRAM/SRAM/ROM一样.(要是不一样的话,芯片上电后如何从NorFlash中 ...

&lbrack;Elasticsearch&rsqb; 控制相关性 &lpar;一&rpar; - 后面的相关度分值理论计算

从第一章翻译Elasticsearch官方指南Controlling Relevance一章. 控制相关度(Controlling Relevance) 对于仅处理结构化数据(比方日期.数值和字符枚举 ...

Contours 等高线图

1.画等高线 数据集即三维点 (x,y) 和对应的高度值,共有256个点.高度值使用一个 height function f(x,y) 生成. x, y 分别是在区间 [-3,3] 中均匀分布的256 ...

springmvc拦截器说明

一般 我们在spring mvc的配置文件中 这样配置拦截器 & ...

android 控件设置透明度

问题:java文件中引用组件设置透明度:mGuideLayout.getBackground().setAlpha(125); 一直报null 修改办法:对应的布局文件中添加 android:back ...

&lbrack;转&rsqb;&lbrack;C&num;&rsqb;加密解密类

{ public static class Crypter { private static string FDefaultPassword = typeof(Crypter).FullName; p ...

python训练opencb分类器_opencv 训练自己的分类器汇总相关推荐

  1. python训练opencb分类器_垃圾邮件分类.ipynb

    { "cells": [ { "cell_type": "markdown", "metadata": {}, &quo ...

  2. Python口罩识别检测全网最全OpenCV训练分类器具体步骤(以训练口罩检测分类器为例)附分类器和数据集下载地址

    声明 本文仅在CSDN发布,其他均为盗版.请支持正版! 正版链接: https://blog.csdn.net/meenr/article/details/115825671 OpenCV训练口罩检测 ...

  3. Haar特征级联分类器的训练与检测

    Haar特征级联分类器的训练与检测 1. 样本的创建 1.1 准备正样本图片集 1.2 截取目标区域 1.3 创建正样本描述文件vec文件 1.4 准备负样本图片集 1.5 创建负样本描述文件 2. ...

  4. python绘制影像组学训练集、测试集对应的ROC曲线以及瀑布图(rad-score 瀑布图)

    python绘制影像组学训练集.测试集对应的ROC曲线以及瀑布图(rad-score 瀑布图) # 所有数据的瀑布图 tagets_all = df['label'] tagets_all = df. ...

  5. python篮球-基于Python/Java的人工智能篮球训练系统的制作方法

    本发明涉及信息技术领域,尤其涉及一种基于Python/Java的人工智能篮球训练系统. 背景技术: 人工智能的发展已经开始渗透到各行各业.经过发明人的研究和检索,发现作为篮球训练,已经有专利申请.其中 ...

  6. py之textgenrnn:Python利用textgenrnn库实现训练文本生成网络

    py之textgenrnn:Python利用textgenrnn库实现训练文本生成网络 目录 输出结果 实现代码 输出结果 实现代码 #textgenrnn:利用textgenrnn实现训练文本生成网 ...

  7. [Python+sklearn] 拆分数据集为训练和测试子集 sklearn.model_selection.train_test_split()

    Python - sklearn 拆分数据集为训练和测试子集 sklearn.model_selection.train_test_split() 功能: 将数组或矩阵拆分为随机的训练子集和测试子集 ...

  8. OpenCV57:级联分类器的训练

    目的 在本章中,将学习: 级联分类器的训练过程 学习函数: opencv_createsamples opencv_annotation opencv_traincascade opencv_visu ...

  9. python视频人脸检测_OpenCV + python 实现人脸检测(基于照片和视频进行检测)

    OpenCV + python 实现人脸检测(基于照片和视频进行检测) Haar-like 通俗的来讲,就是作为人脸特征即可. Haar特征值反映了图像的灰度变化情况.例如:脸部的一些特征能由矩形特征 ...

最新文章

  1. 张海腾:语音识别实践教程
  2. 什么是DDOS攻击?怎么防御?
  3. 保留关键字 (Transact-SQL) user 也是,哎
  4. python表单提交文件_python3做multipart/form-data上传请求
  5. Binary Tree Non-recursive Traversal
  6. arm-linux-gcc libstdc .so.6,mini2440编译内核:usr/lib/libstdc++.so.6 not found
  7. 装载服务器安装和配置_一站式解决方案
  8. 大数据平台之初体验 | 网易猛犸 | 数据仓库、调度系统、数据质量、离线与实时计算应有尽有。
  9. 聊聊kafka consumer offset lag的监控
  10. 5. 生信技能树——GEO转录组RNA_seq_GSE162550
  11. ODL之VTN详解-Mac Map
  12. Web3.0时代:你在网上创造的一切,真的可以全部归你?
  13. 【Go】Go语言中反射包的实现原理(The Laws of Reflection)
  14. ORA-12514:TNS:监听程序当前无法识别连接描述符中请求的服务
  15. 【论坛】交通需求管理政策与实践——中国城市交通发展论坛第十一次研讨会讨论精选...
  16. 感谢读者朋友和网友对《Spring Boot实战派》的批评指正
  17. 2022-2028全球与中国绿色氢基微电网市场现状及未来发展趋势
  18. 微信小程序转盘demo
  19. 测试内容总结-测试分类
  20. ASCLL和字符串转换

热门文章

  1. ASP.NET使aspx页面能接受HTML,asp的页面传送的文件
  2. CCSP2021分赛
  3. 信号处理与分析-确定性信号的分析
  4. [JSOI2013]快乐的 JYY
  5. 有监督算法和无监督算法的理解
  6. pdf2word(pdf转word)
  7. PDF转换word格式的方法总结
  8. Alientek I.MX6UL Linux-第八章 汇编LED灯实验
  9. 计算机用加法乘法实现除法运算的数学原理
  10. 打印机 KX-MB788CN 佳能