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

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

?? svm.py

?? 一種應用廣泛的分類算法
?? 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' : 40,	'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一区二区三区免费野_久草精品视频
懂色av中文一区二区三区| 日韩精品一区二区在线| 欧美一区二区精品在线| 国产精品国产三级国产aⅴ无密码| 亚洲成av人影院| 成人18精品视频| 日韩视频国产视频| 午夜国产精品影院在线观看| av一二三不卡影片| 26uuu久久天堂性欧美| 亚洲人成伊人成综合网小说| 国产乱子伦一区二区三区国色天香| av动漫一区二区| 亚洲国产成人一区二区三区| 久久av中文字幕片| 欧美日韩国产综合一区二区 | 91精品国产色综合久久ai换脸| 成人免费在线播放视频| 国产一区二区福利| 日韩一区二区免费视频| 日本欧美加勒比视频| 欧美四级电影在线观看| 亚洲激情五月婷婷| 色偷偷久久一区二区三区| 国产亚洲一二三区| 精品一区二区综合| 欧美v日韩v国产v| 卡一卡二国产精品 | 国产精品麻豆久久久| 韩国一区二区视频| 久久综合九色综合欧美亚洲| 蜜臀av一区二区| 精品久久久久久综合日本欧美| 免费久久99精品国产| 日韩亚洲欧美中文三级| 精品综合免费视频观看| 久久久久国产精品人| 成人一区在线观看| 亚洲丝袜制服诱惑| 欧美午夜免费电影| 日本不卡一二三| 欧美大肚乱孕交hd孕妇| 久久69国产一区二区蜜臀| 久久在线免费观看| 丁香啪啪综合成人亚洲小说| 国产精品久久久久久一区二区三区| 成人性生交大片免费看中文网站| 国产精品第13页| 欧美三级资源在线| 看片网站欧美日韩| 国产精品另类一区| 色综合久久久久| 午夜伦理一区二区| 久久久久久一二三区| av不卡在线播放| 午夜精品福利一区二区三区蜜桃| 日韩视频在线一区二区| 成年人午夜久久久| 午夜精品一区二区三区免费视频 | 不卡的看片网站| 一区二区三区高清不卡| 91精品在线麻豆| 成人毛片在线观看| 亚洲综合在线第一页| 精品捆绑美女sm三区| 一本久道中文字幕精品亚洲嫩| 视频一区二区中文字幕| 久久久.com| 欧美熟乱第一页| 国产乱码精品1区2区3区| 一区二区三区资源| 久久免费电影网| 在线观看91视频| 国产成人在线视频免费播放| 亚洲综合网站在线观看| 国产视频一区二区在线| 欧美疯狂性受xxxxx喷水图片| 成人一区二区三区中文字幕| 日本不卡视频一二三区| 亚洲视频免费在线观看| 7777精品伊人久久久大香线蕉最新版| 国产成人午夜精品5599| 天堂av在线一区| 亚洲色图20p| 亚洲精品一区二区三区蜜桃下载| 色88888久久久久久影院按摩| 国产aⅴ综合色| 久久国产精品区| 亚洲不卡av一区二区三区| 国产精品乱码久久久久久| 精品久久国产97色综合| 欧美二区在线观看| 91国产视频在线观看| 成人午夜私人影院| 国产酒店精品激情| 美女诱惑一区二区| 亚洲成人午夜电影| 亚洲黄色免费电影| 亚洲欧美日本在线| 国产精品久久久久影院亚瑟| 国产婷婷色一区二区三区四区 | 99久久综合色| 国产麻豆精品在线| 国产美女精品一区二区三区| 日韩成人免费电影| 视频一区视频二区中文| 亚洲成人动漫精品| 偷偷要91色婷婷| 日精品一区二区三区| 午夜视频在线观看一区二区| 亚洲成av人片一区二区| 亚洲国产sm捆绑调教视频| 亚洲国产精品久久久男人的天堂| 亚洲欧美日韩国产成人精品影院 | 欧美性视频一区二区三区| 91在线云播放| 一本久久a久久免费精品不卡| 一本久道中文字幕精品亚洲嫩| 99精品国产99久久久久久白柏| av不卡在线观看| 欧美亚洲丝袜传媒另类| 欧美日韩免费观看一区三区| 欧美日韩精品免费观看视频| 欧美一区二区视频在线观看2020 | 91精品国产入口| 日韩精品一区国产麻豆| 久久久国产一区二区三区四区小说 | 五月婷婷久久综合| 日韩精品免费视频人成| 久久99精品久久久久久久久久久久| 久久91精品国产91久久小草| 国产黄色精品网站| 一本色道亚洲精品aⅴ| 欧美日韩精品一区视频| 日韩女优视频免费观看| 久久久午夜精品| 日韩美女久久久| 日韩精品电影一区亚洲| 韩国精品在线观看| 成a人片亚洲日本久久| 欧美日韩在线免费视频| 日韩美女视频在线| 国产精品久久久久一区 | 一区二区三区日韩| 免费在线看一区| av资源站一区| 51久久夜色精品国产麻豆| 久久久久国产精品麻豆ai换脸 | 91精品国产综合久久久蜜臀粉嫩| 日韩精品最新网址| 亚洲美女免费视频| 另类欧美日韩国产在线| 99re这里只有精品首页| 精品国产亚洲一区二区三区在线观看| 国产视频一区不卡| 日韩黄色小视频| 成人丝袜高跟foot| 在线综合+亚洲+欧美中文字幕| 国产日韩亚洲欧美综合| 亚洲成av人片在线观看无码| 懂色av一区二区三区蜜臀| 欧美三级视频在线| 国产精品国产三级国产aⅴ中文 | 国产日韩欧美不卡在线| 亚洲国产精品久久久久秋霞影院| 国产99精品在线观看| 欧美精品丝袜中出| 亚洲天堂免费在线观看视频| 美女性感视频久久| 欧美日韩免费一区二区三区| 中文字幕综合网| 国产盗摄女厕一区二区三区| 3751色影院一区二区三区| 日韩一区在线看| 国产 欧美在线| 久久夜色精品国产噜噜av| 日本美女一区二区三区| 欧美亚洲一区二区在线| ...xxx性欧美| 国产成人午夜精品5599| 欧美精品一区二区三区蜜臀| 免费亚洲电影在线| 欧美高清视频不卡网| 一级女性全黄久久生活片免费| www.亚洲色图| 国产精品不卡在线观看| 丰满放荡岳乱妇91ww| 久久久影院官网| 精品伊人久久久久7777人| 欧美一级一区二区| 午夜视频一区二区三区| 欧美日韩国产欧美日美国产精品| 一区二区三区丝袜| 欧美亚洲日本国产| 亚洲国产三级在线| 欧美性欧美巨大黑白大战| 亚洲男人天堂av| 色偷偷久久人人79超碰人人澡| 亚洲欧洲日韩一区二区三区| 91丨porny丨国产|