亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? svm.py

?? SVM的源碼
?? PY
字號:
import svmcfrom svmc import C_SVC, NU_SVC, ONE_CLASS, EPSILON_SVR, NU_SVRfrom svmc import LINEAR, POLY, RBF, SIGMOID, PRECOMPUTEDfrom math import exp, fabsdef _int_array(seq):	size = len(seq)	array = svmc.new_int(size)	i = 0	for item in seq:		svmc.int_setitem(array,i,item)		i = i + 1	return arraydef _double_array(seq):	size = len(seq)	array = svmc.new_double(size)	i = 0	for item in seq:		svmc.double_setitem(array,i,item)		i = i + 1	return arraydef _free_int_array(x):	if x != 'NULL' and x != None:		svmc.delete_int(x)def _free_double_array(x):	if x != 'NULL' and x != None:		svmc.delete_double(x)def _int_array_to_list(x,n):	return map(svmc.int_getitem,[x]*n,range(n))def _double_array_to_list(x,n):	return map(svmc.double_getitem,[x]*n,range(n))class svm_parameter:		# default values	default_parameters = {	'svm_type' : C_SVC,	'kernel_type' : RBF,	'degree' : 3,	'gamma' : 0,		# 1/k	'coef0' : 0,	'nu' : 0.5,	'cache_size' : 100,	'C' : 1,	'eps' : 1e-3,	'p' : 0.1,	'shrinking' : 1,	'nr_weight' : 0,	'weight_label' : [],	'weight' : [],	'probability' : 0	}	def __init__(self,**kw):		self.__dict__['param'] = svmc.new_svm_parameter()		for attr,val in self.default_parameters.items():			setattr(self,attr,val)		for attr,val in kw.items():			setattr(self,attr,val)	def __getattr__(self,attr):		get_func = getattr(svmc,'svm_parameter_%s_get' % (attr))		return get_func(self.param)	def __setattr__(self,attr,val):		if attr == 'weight_label':			self.__dict__['weight_label_len'] = len(val)			val = _int_array(val)			_free_int_array(self.weight_label)		elif attr == 'weight':			self.__dict__['weight_len'] = len(val)			val = _double_array(val)			_free_double_array(self.weight)		set_func = getattr(svmc,'svm_parameter_%s_set' % (attr))		set_func(self.param,val)	def __repr__(self):		ret = '<svm_parameter:'		for name in dir(svmc):			if name[:len('svm_parameter_')] == 'svm_parameter_' and name[-len('_set'):] == '_set':				attr = name[len('svm_parameter_'):-len('_set')]				if attr == 'weight_label':					ret = ret+' weight_label = %s,' % _int_array_to_list(self.weight_label,self.weight_label_len)				elif attr == 'weight':					ret = ret+' weight = %s,' % _double_array_to_list(self.weight,self.weight_len)				else:					ret = ret+' %s = %s,' % (attr,getattr(self,attr))		return ret+'>'	def __del__(self):		_free_int_array(self.weight_label)		_free_double_array(self.weight)		svmc.delete_svm_parameter(self.param)def _convert_to_svm_node_array(x):	""" convert a sequence or mapping to an svm_node array """	import operator	# Find non zero elements	iter_range = []	if type(x) == dict:		for k, v in x.iteritems():# all zeros kept due to the precomputed kernel; no good solution yet#			if v != 0:				iter_range.append( k )	elif operator.isSequenceType(x):		for j in range(len(x)):#			if x[j] != 0:				iter_range.append( j )	else:		raise TypeError,"data must be a mapping or a sequence"	iter_range.sort()	data = svmc.svm_node_array(len(iter_range)+1)	svmc.svm_node_array_set(data,len(iter_range),-1,0)	j = 0	for k in iter_range:		svmc.svm_node_array_set(data,j,k,x[k])		j = j + 1	return dataclass svm_problem:	def __init__(self,y,x):		assert len(y) == len(x)		self.prob = prob = svmc.new_svm_problem()		self.size = size = len(y)		self.y_array = y_array = svmc.new_double(size)		for i in range(size):			svmc.double_setitem(y_array,i,y[i])		self.x_matrix = x_matrix = svmc.svm_node_matrix(size)		self.data = []		self.maxlen = 0;		for i in range(size):			data = _convert_to_svm_node_array(x[i])			self.data.append(data);			svmc.svm_node_matrix_set(x_matrix,i,data)			if type(x[i]) == dict:				if (len(x[i]) > 0):					self.maxlen = max(self.maxlen,max(x[i].keys()))			else:				self.maxlen = max(self.maxlen,len(x[i]))		svmc.svm_problem_l_set(prob,size)		svmc.svm_problem_y_set(prob,y_array)		svmc.svm_problem_x_set(prob,x_matrix)	def __repr__(self):		return "<svm_problem: size = %s>" % (self.size)	def __del__(self):		svmc.delete_svm_problem(self.prob)		svmc.delete_double(self.y_array)		for i in range(self.size):			svmc.svm_node_array_destroy(self.data[i])		svmc.svm_node_matrix_destroy(self.x_matrix)class svm_model:	def __init__(self,arg1,arg2=None):		if arg2 == None:			# create model from file			filename = arg1			self.model = svmc.svm_load_model(filename)		else:			# create model from problem and parameter			prob,param = arg1,arg2			self.prob = prob			if param.gamma == 0:				param.gamma = 1.0/prob.maxlen			msg = svmc.svm_check_parameter(prob.prob,param.param)			if msg: raise ValueError, msg			self.model = svmc.svm_train(prob.prob,param.param)		#setup some classwide variables		self.nr_class = svmc.svm_get_nr_class(self.model)		self.svm_type = svmc.svm_get_svm_type(self.model)		#create labels(classes)		intarr = svmc.new_int(self.nr_class)		svmc.svm_get_labels(self.model,intarr)		self.labels = _int_array_to_list(intarr, self.nr_class)		svmc.delete_int(intarr)		#check if valid probability model		self.probability = svmc.svm_check_probability_model(self.model)	def predict(self,x):		data = _convert_to_svm_node_array(x)		ret = svmc.svm_predict(self.model,data)		svmc.svm_node_array_destroy(data)		return ret	def get_nr_class(self):		return self.nr_class	def get_labels(self):		if self.svm_type == NU_SVR or self.svm_type == EPSILON_SVR or self.svm_type == ONE_CLASS:			raise TypeError, "Unable to get label from a SVR/ONE_CLASS model"		return self.labels			def predict_values_raw(self,x):		#convert x into svm_node, allocate a double array for return		n = self.nr_class*(self.nr_class-1)//2		data = _convert_to_svm_node_array(x)		dblarr = svmc.new_double(n)		svmc.svm_predict_values(self.model, data, dblarr)		ret = _double_array_to_list(dblarr, n)		svmc.delete_double(dblarr)		svmc.svm_node_array_destroy(data)		return ret	def predict_values(self,x):		v=self.predict_values_raw(x)		if self.svm_type == NU_SVR or self.svm_type == EPSILON_SVR or self.svm_type == ONE_CLASS:			return v[0]		else: #self.svm_type == C_SVC or self.svm_type == NU_SVC			count = 0			d = {}			for i in range(len(self.labels)):				for j in range(i+1, len(self.labels)):					d[self.labels[i],self.labels[j]] = v[count]					d[self.labels[j],self.labels[i]] = -v[count]					count += 1			return  d	def predict_probability(self,x):		#c code will do nothing on wrong type, so we have to check ourself		if self.svm_type == NU_SVR or self.svm_type == EPSILON_SVR:			raise TypeError, "call get_svr_probability or get_svr_pdf for probability output of regression"		elif self.svm_type == ONE_CLASS:			raise TypeError, "probability not supported yet for one-class problem"		#only C_SVC,NU_SVC goes in		if not self.probability:			raise TypeError, "model does not support probabiliy estimates"		#convert x into svm_node, alloc a double array to receive probabilities		data = _convert_to_svm_node_array(x)		dblarr = svmc.new_double(self.nr_class)		pred = svmc.svm_predict_probability(self.model, data, dblarr)		pv = _double_array_to_list(dblarr, self.nr_class)		svmc.delete_double(dblarr)		svmc.svm_node_array_destroy(data)		p = {}		for i in range(len(self.labels)):			p[self.labels[i]] = pv[i]		return pred, p		def get_svr_probability(self):		#leave the Error checking to svm.cpp code		ret = svmc.svm_get_svr_probability(self.model)		if ret == 0:			raise TypeError, "not a regression model or probability information not available"		return ret	def get_svr_pdf(self):		#get_svr_probability will handle error checking		sigma = self.get_svr_probability()		return lambda z: exp(-fabs(z)/sigma)/(2*sigma)	def save(self,filename):		svmc.svm_save_model(filename,self.model)	def __del__(self):		svmc.svm_destroy_model(self.model)def cross_validation(prob, param, fold):	if param.gamma == 0:		param.gamma = 1.0/prob.maxlen	dblarr = svmc.new_double(prob.size)	svmc.svm_cross_validation(prob.prob, param.param, fold, dblarr)	ret = _double_array_to_list(dblarr, prob.size)	svmc.delete_double(dblarr)	return ret

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲男人都懂的| 国产精品亲子乱子伦xxxx裸| 国产成人精品www牛牛影视| 亚洲色图色小说| 精品国产免费人成在线观看| 色综合久久天天| 国产一区二区在线免费观看| 亚洲综合一区二区精品导航| 国产丝袜美腿一区二区三区| 欧美色视频在线观看| www.99精品| 精品一区二区三区蜜桃| 亚洲国产精品嫩草影院| 成人欧美一区二区三区白人 | 成人福利视频在线| 麻豆精品视频在线观看免费| 亚洲美女屁股眼交| 中文字幕成人av| 亚洲精品一区二区三区99| 欧美日韩国产乱码电影| 91麻豆高清视频| 成人午夜激情影院| 国产很黄免费观看久久| 美女视频免费一区| 日韩精品一二三四| 亚洲第一主播视频| 亚洲一二三区不卡| 亚洲精品水蜜桃| 日韩精品电影在线观看| 一区二区三区在线不卡| 中文字幕亚洲在| 国产精品久久久爽爽爽麻豆色哟哟| 26uuu成人网一区二区三区| 欧美一区二区三区四区五区| 欧美精品乱码久久久久久| 精品视频在线免费| 欧美日韩免费在线视频| 欧美亚洲国产一区二区三区va| 91色porny| 色综合久久天天综合网| 欧美午夜片在线观看| 欧洲一区二区三区免费视频| 在线观看免费一区| 日本电影欧美片| 欧美网站一区二区| 欧美日韩激情一区二区三区| 欧美二区乱c少妇| 日韩一级在线观看| 久久亚洲影视婷婷| 久久久久久久久99精品| 欧美国产一区在线| 自拍偷拍国产亚洲| 亚洲夂夂婷婷色拍ww47| 日韩国产欧美三级| 久久精品国产亚洲一区二区三区| 久久精品99国产国产精| 国产制服丝袜一区| 成人综合日日夜夜| 在线观看一区不卡| 欧美日韩三级一区| 欧美v亚洲v综合ⅴ国产v| 欧美精品一区二区三区蜜臀| 欧美极品aⅴ影院| 亚洲特黄一级片| 亚洲成人精品影院| 久久99精品国产.久久久久| 国产露脸91国语对白| 99精品欧美一区| 欧美亚洲一区二区三区四区| 欧美精品粉嫩高潮一区二区| 欧美videos大乳护士334| 国产夜色精品一区二区av| 有码一区二区三区| 天天综合日日夜夜精品| 国产麻豆日韩欧美久久| 91蝌蚪porny九色| 日韩丝袜美女视频| 中文字幕不卡一区| 五月天激情综合| 国产高清精品网站| 欧美亚洲国产一区二区三区| 26uuu精品一区二区| 樱桃视频在线观看一区| 丁香婷婷深情五月亚洲| 欧美在线看片a免费观看| 精品粉嫩超白一线天av| 亚洲欧美偷拍卡通变态| 青青草97国产精品免费观看无弹窗版| 国产精品亚洲专一区二区三区 | 69久久99精品久久久久婷婷| 久久久久综合网| 亚洲444eee在线观看| 国产精品1区二区.| 欧美精品在线观看播放| 亚洲国产高清在线| 蜜桃精品在线观看| 色老综合老女人久久久| 精品国产乱码久久| 日日夜夜精品视频天天综合网| 成人精品一区二区三区四区 | 国产亚洲综合性久久久影院| 亚洲国产视频a| 盗摄精品av一区二区三区| 91精品国产麻豆| 亚洲精品免费一二三区| 国产精品91xxx| 日韩免费高清av| 午夜精品久久久久| 91麻豆国产精品久久| 亚洲国产经典视频| 国产一区免费电影| 精品国产一区久久| 爽好久久久欧美精品| 色婷婷久久久亚洲一区二区三区| 久久精品欧美一区二区三区不卡| 美洲天堂一区二卡三卡四卡视频 | 欧美日韩在线播放一区| 亚洲欧洲日韩av| 国产成人av自拍| 久久久亚洲国产美女国产盗摄 | 国产a级毛片一区| 日韩女优毛片在线| 视频精品一区二区| 精品视频一区 二区 三区| 自拍偷拍欧美激情| 91亚洲国产成人精品一区二三| 久久综合久久综合久久综合| 喷水一区二区三区| 欧美高清激情brazzers| 亚洲国产毛片aaaaa无费看| 一本久道中文字幕精品亚洲嫩| 亚洲一区二区不卡免费| 91在线精品秘密一区二区| 国产清纯在线一区二区www| 国产精品自拍网站| 久久久www免费人成精品| 国产在线精品一区二区不卡了 | 亚洲精品国产无天堂网2021| 99久久国产综合精品麻豆 | 青青草国产成人99久久| 日韩一级免费观看| 免费高清在线一区| 精品国产一区二区三区久久影院| 蜜桃av一区二区三区电影| 精品免费视频.| 国产一区二区精品久久91| 久久综合一区二区| www.亚洲色图| 一区二区三区中文字幕电影| 91官网在线观看| 污片在线观看一区二区| 日韩美女主播在线视频一区二区三区| 蜜桃在线一区二区三区| 久久久不卡影院| 99精品视频一区二区| 亚洲精品午夜久久久| 69成人精品免费视频| 精品亚洲aⅴ乱码一区二区三区| 精品剧情v国产在线观看在线| 国产精品羞羞答答xxdd| 中文字幕永久在线不卡| 欧美熟乱第一页| 美腿丝袜在线亚洲一区| 欧美国产一区在线| 欧美性xxxxx极品少妇| 免费看黄色91| 国产日韩欧美制服另类| 色综合色综合色综合| 日本亚洲三级在线| 日本一区免费视频| 一本久久a久久精品亚洲| 免费成人深夜小野草| 国产欧美va欧美不卡在线| 日本高清不卡在线观看| 日韩经典一区二区| 国产女同性恋一区二区| 欧美在线色视频| 激情文学综合网| 一区二区在线免费观看| 日韩女优电影在线观看| 972aa.com艺术欧美| 免费的国产精品| 亚洲人成精品久久久久| 日韩欧美成人激情| 色天天综合色天天久久| 国产尤物一区二区在线| 一区二区三区欧美亚洲| 精品成人一区二区三区| 欧洲国产伦久久久久久久| 国内成人自拍视频| 亚洲综合免费观看高清完整版| 久久综合久久综合久久| 欧美日韩在线三区| 欧美午夜在线观看| 国产成人欧美日韩在线电影| 午夜精彩视频在线观看不卡| 成人欧美一区二区三区白人| 日韩精品一区二区三区老鸭窝| 色综合久久久久久久久久久| 精品写真视频在线观看|