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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? svm.py

?? 使用svm實現(xiàn)了分類和擬合功能 帶有源文件
?? 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

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
韩日精品视频一区| 欧美一区二区三区在线视频| 日韩精品在线一区| 美女高潮久久久| 欧美一区二区啪啪| 精东粉嫩av免费一区二区三区| 91九色02白丝porn| 亚洲国产美国国产综合一区二区| 欧美一区中文字幕| 激情综合五月天| 久久天天做天天爱综合色| 精品夜夜嗨av一区二区三区| 欧美精品一区二区三区蜜桃视频| 久久99精品国产麻豆婷婷洗澡| 日韩免费电影网站| 国产宾馆实践打屁股91| 国产精品婷婷午夜在线观看| 国产成人在线视频免费播放| 中文字幕在线观看不卡视频| 欧美日韩视频在线第一区 | 日本韩国一区二区三区| 亚洲午夜电影网| 日韩精品一区二区三区在线| 国产成人8x视频一区二区| 亚洲私人影院在线观看| 欧美老肥妇做.爰bbww| 日本三级亚洲精品| 中文字幕一区二区三| 69堂成人精品免费视频| 高潮精品一区videoshd| 洋洋av久久久久久久一区| 精品动漫一区二区三区在线观看| 99综合影院在线| 精品无人码麻豆乱码1区2区| 一区二区欧美精品| 国产精品久久久久久亚洲伦| 日韩一区中文字幕| 欧美激情一区二区三区在线| 欧美一区二区三区日韩视频| 91玉足脚交白嫩脚丫在线播放| 日本一不卡视频| 亚洲另类在线制服丝袜| 久久久久久麻豆| 久久亚洲影视婷婷| 久久久亚洲午夜电影| 日韩欧美中文字幕精品| 91精品免费在线观看| 欧美男女性生活在线直播观看| av一二三不卡影片| 成人免费视频一区二区| 成人精品国产福利| 99久久婷婷国产综合精品| 99精品国产99久久久久久白柏| 国产999精品久久| www.日韩av| 色偷偷久久人人79超碰人人澡| 成人激情小说乱人伦| 国产剧情av麻豆香蕉精品| 国产麻豆精品视频| 狠狠色狠狠色综合| 激情深爱一区二区| 另类小说图片综合网| 狠狠色狠狠色综合系列| 国产精品88888| 成人av在线影院| 色综合久久天天| 欧美午夜在线观看| 日韩欧美一级在线播放| 久久精品日韩一区二区三区| 久久久久一区二区三区四区| 久久久91精品国产一区二区三区| 精品国产污网站| 国产精品女主播av| 午夜精品一区在线观看| 国产精品一区二区在线看| www.亚洲精品| 国产精品久久免费看| 婷婷开心激情综合| 成人短视频下载| 555www色欧美视频| 综合久久给合久久狠狠狠97色 | 国产精品国产三级国产普通话99| 自拍偷拍国产亚洲| 免费在线观看一区| 成人午夜在线免费| 欧美日韩国产电影| 亚洲激情图片qvod| 午夜激情一区二区| 99久久国产综合精品色伊| 91精品国产91热久久久做人人 | 中文字幕综合网| 久久精品国产99| 一本色道久久加勒比精品 | 欧美国产日韩a欧美在线观看 | 在线免费观看日本一区| 亚洲欧美综合在线精品| 国内外成人在线视频| 欧美一级久久久| 五月天久久比比资源色| 99精品热视频| 国产精品国产精品国产专区不蜜 | 一区二区三区不卡在线观看| 成人一区二区三区视频在线观看| 欧美成人bangbros| 精品在线播放免费| 日韩欧美亚洲国产另类| 三级亚洲高清视频| 欧美日韩高清一区| 日本伊人精品一区二区三区观看方式| 成人av手机在线观看| 亚洲欧洲综合另类| 欧美日韩久久久久久| 日韩精品一级中文字幕精品视频免费观看 | 免费成人在线网站| 91精品国产综合久久精品| 亚洲精品网站在线观看| 色天使色偷偷av一区二区| 一区二区高清在线| 欧美区视频在线观看| 久久精品国产亚洲高清剧情介绍| 欧美一区二区免费| 国产麻豆午夜三级精品| 最新不卡av在线| 日韩一区国产二区欧美三区| 久久av资源网| 亚洲视频一区二区免费在线观看| 欧洲人成人精品| 国产一区二区调教| 有码一区二区三区| 欧美一级欧美三级| 7777精品伊人久久久大香线蕉经典版下载| 日韩国产精品久久久| 国产精品女主播av| 欧美一区二区免费| 欧美在线啊v一区| 91在线码无精品| 久久99精品久久久久婷婷| 亚洲天堂福利av| 欧美成人精品福利| 中文字幕精品三区| 欧美va日韩va| 欧美高清精品3d| 欧美亚洲一区二区在线观看| 国产精品综合二区| 性做久久久久久| 亚洲制服欧美中文字幕中文字幕| 国产精品久久三| 久久久精品黄色| 日韩美女主播在线视频一区二区三区| 精品一区二区三区免费毛片爱| 一级做a爱片久久| 亚洲视频一二区| 欧美极品另类videosde| 久久久久久久久岛国免费| 久久久不卡网国产精品一区| 成人高清伦理免费影院在线观看| 国产毛片精品国产一区二区三区| 亚洲资源中文字幕| 亚洲午夜av在线| 日韩激情一区二区| 色88888久久久久久影院野外 | 国产精品情趣视频| 国产免费观看久久| 国产精品免费视频一区| 1024精品合集| 日本欧美大码aⅴ在线播放| 日本在线观看不卡视频| 精品在线免费视频| 成人91在线观看| 91视频com| 欧美日韩国产123区| 欧美日韩一区三区| 久久久亚洲国产美女国产盗摄 | 亚洲欧美日韩一区| 日韩av电影免费观看高清完整版 | 成人伦理片在线| 欧美日韩亚洲综合一区| 欧美日韩国产在线观看| 欧美α欧美αv大片| 亚洲欧美日韩人成在线播放| 亚洲国产视频在线| 国内一区二区在线| 成人av在线播放网站| 制服.丝袜.亚洲.另类.中文| 国产视频一区不卡| 一区二区三区成人| 国产成人日日夜夜| 日韩视频免费直播| 亚洲一区在线观看网站| 高清国产午夜精品久久久久久| 色香蕉久久蜜桃| 久久久久久久久久久黄色| 毛片基地黄久久久久久天堂| 狠狠色综合播放一区二区| 欧美精品一二三四| 亚洲精品视频一区| 欧美日韩免费高清一区色橹橹| 成人免费在线播放视频| 波多野结衣欧美| 艳妇臀荡乳欲伦亚洲一区|