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

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

?? svm.py

?? 馬克斯普朗克提供的機器學習程序包
?? PY
字號:
import svmcfrom svmc import C_SVC, NU_SVC, ONE_CLASS, EPSILON_SVR, NU_SVRfrom svmc import LINEAR, POLY, RBF, SIGMOIDfrom 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():			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一区二区三区免费野_久草精品视频
日韩精品1区2区3区| 依依成人精品视频| 国模套图日韩精品一区二区| 日韩欧美成人一区| 国产尤物一区二区在线| 日本一区二区电影| 色哟哟亚洲精品| 奇米影视一区二区三区小说| 2023国产精品视频| 99久久精品国产一区二区三区| 亚洲欧美经典视频| 在线播放视频一区| 国内精品伊人久久久久av一坑| 国产精品理伦片| 欧美日韩一区二区电影| 久久精品av麻豆的观看方式| 国产精品狼人久久影院观看方式| 色婷婷av一区二区三区之一色屋| 偷拍与自拍一区| 国产日韩欧美制服另类| 欧美在线视频不卡| 狠狠久久亚洲欧美| 亚洲天堂av一区| 91精品国产黑色紧身裤美女| 国产成人综合在线播放| 亚洲一区二区精品视频| 日韩精品专区在线| 91精彩视频在线观看| 精品一区二区三区欧美| 亚洲视频一二三| 日韩精品一区二区三区中文精品| av在线一区二区| 日本中文字幕一区二区视频 | 成人aaaa免费全部观看| 亚洲高清不卡在线| 久久女同性恋中文字幕| 欧美性生活影院| 成人黄色网址在线观看| 蜜桃av噜噜一区| 一区二区日韩av| 国产精品私房写真福利视频| 91精品国产综合久久香蕉的特点 | 国产精品久久久久久久久久免费看 | 国产mv日韩mv欧美| 日韩精品五月天| 亚洲女子a中天字幕| 久久久久久久性| 日韩欧美亚洲国产另类| 欧美私模裸体表演在线观看| 成人国产免费视频| 久久国产尿小便嘘嘘尿| 午夜电影网一区| 日韩美女啊v在线免费观看| 亚洲精品一区二区三区香蕉| 欧美乱妇一区二区三区不卡视频| www.66久久| 国产999精品久久久久久| 精品一区二区日韩| 美女视频网站久久| 天天综合网天天综合色 | 亚洲激情图片小说视频| 亚洲国产精品高清| 亚洲精品一区二区三区福利| 777午夜精品免费视频| 91国偷自产一区二区使用方法| 成人av片在线观看| 国产乱码一区二区三区| 久久精品国产77777蜜臀| 男男视频亚洲欧美| 日本特黄久久久高潮| 午夜国产精品影院在线观看| 午夜精品一区二区三区电影天堂 | 亚洲天堂2014| 国产精品青草综合久久久久99| 久久久久9999亚洲精品| 久久蜜桃香蕉精品一区二区三区| 精品国产乱子伦一区| 日韩写真欧美这视频| 日韩欧美久久一区| 日韩精品中午字幕| 精品sm在线观看| 久久久99精品免费观看不卡| 国产欧美日韩亚州综合| 国产精品久久久爽爽爽麻豆色哟哟 | 日韩一区二区三区三四区视频在线观看| 在线亚洲高清视频| 欧美色综合网站| 欧美日韩另类一区| 69久久99精品久久久久婷婷 | 久久九九久精品国产免费直播| 久久日韩粉嫩一区二区三区| 久久久久久久久蜜桃| 国产精品视频免费| 亚洲人一二三区| 亚洲国产日韩精品| 轻轻草成人在线| 国产盗摄视频一区二区三区| 9人人澡人人爽人人精品| 色老头久久综合| 欧美一区二区三区在线电影 | 国产精品激情偷乱一区二区∴| 亚洲人被黑人高潮完整版| 亚洲国产婷婷综合在线精品| 美女看a上一区| 成人精品视频一区二区三区 | 欧美性色欧美a在线播放| 日韩一区二区三区电影在线观看| 久久奇米777| 亚洲狠狠爱一区二区三区| 精久久久久久久久久久| 99精品视频中文字幕| 51精品国自产在线| 国产日韩在线不卡| 亚洲小说欧美激情另类| 国产成人免费高清| 欧美色网一区二区| 久久久久久久久久美女| 亚洲黄色av一区| 国产一区二区三区综合| 在线免费观看一区| 久久久久国产精品麻豆ai换脸 | 亚洲成人午夜电影| 国产黄色91视频| 欧美日韩中文另类| 中文字幕在线一区| 精品制服美女久久| 欧美性三三影院| 国产精品欧美经典| 久久福利视频一区二区| 欧美三级一区二区| 中文字幕一区二区日韩精品绯色| 日本中文字幕一区| 日本黄色一区二区| 国产午夜精品福利| 日韩精品一二三区| 欧美亚洲愉拍一区二区| 国产精品免费视频一区| 精品一区二区免费视频| 91精品国产一区二区三区| 亚洲欧美日韩在线不卡| 国产成人亚洲精品青草天美 | 国产拍揄自揄精品视频麻豆| 免费观看一级欧美片| 在线视频你懂得一区| 亚洲欧洲日韩女同| 国产成人av一区二区三区在线 | 久久久精品一品道一区| 秋霞影院一区二区| 8v天堂国产在线一区二区| 亚洲综合在线电影| 99免费精品视频| 欧美高清在线一区| 国产**成人网毛片九色| 精品成人免费观看| 九九**精品视频免费播放| 欧美一区二区精品久久911| 性久久久久久久久久久久| 91浏览器打开| 亚洲欧洲制服丝袜| 成人h动漫精品一区二| 国产精品剧情在线亚洲| 成人伦理片在线| 成人欧美一区二区三区1314 | 婷婷久久综合九色综合绿巨人| 欧美私模裸体表演在线观看| 亚洲午夜免费福利视频| 欧美三级电影一区| 午夜伦欧美伦电影理论片| 欧美精品乱码久久久久久| 天堂蜜桃91精品| 日韩欧美一区在线| 美女高潮久久久| 亚洲精品一区二区三区福利 | 欧美色欧美亚洲另类二区| 亚洲成人动漫在线免费观看| 欧美日韩不卡一区二区| 老司机精品视频一区二区三区| 日韩欧美第一区| 国产一区二区在线视频| 国产欧美日韩另类视频免费观看| 成人午夜精品在线| 亚洲精品亚洲人成人网在线播放| 一本色道**综合亚洲精品蜜桃冫| 亚洲尤物在线视频观看| 欧美久久一区二区| 精品一区二区免费在线观看| 欧美国产精品v| 色婷婷久久久亚洲一区二区三区| 一区二区三区四区激情| 欧美疯狂做受xxxx富婆| 国内精品自线一区二区三区视频| 国产精品乱码一区二区三区软件| 一本一道久久a久久精品| 亚洲一区二区三区在线| 精品免费视频.| 99久久99久久免费精品蜜臀| 午夜精品免费在线观看| 亚洲精品一区二区三区蜜桃下载 | 欧美日本国产视频| 国产传媒久久文化传媒|