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

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

?? tfidfmeasure.cs

?? 文本相似度計(jì)算(tfidf),可用文本分類以及文本信息處理
?? CS
字號(hào):
/*
 * tf/idf implementation 
 * Author: Thanh Dao, thanh.dao@gmx.net
 */
using System;
using System.Collections;


namespace ServiceRanking
{
	/// <summary>
	/// Summary description for TF_IDFLib.
	/// </summary>
	public class TFIDFMeasure
	{
		private string[] _docs;
		private string[][] _ngramDoc;
		private int _numDocs=0;
		private int _numTerms=0;
		private ArrayList _terms;
		private int[][] _termFreq;
		private float[][] _termWeight;
		private int[] _maxTermFreq;
		private int[] _docFreq;


		public class TermVector
		{		
			public static float ComputeCosineSimilarity(float[] vector1, float[] vector2)
			{
				if (vector1.Length != vector2.Length)				
					throw new Exception("DIFER LENGTH");
				

				float denom=(VectorLength(vector1) * VectorLength(vector2));
				if (denom == 0F)				
					return 0F;				
				else				
					return (InnerProduct(vector1, vector2) / denom);
				
			}

			public static float InnerProduct(float[] vector1, float[] vector2)
			{
			
				if (vector1.Length != vector2.Length)
					throw new Exception("DIFFER LENGTH ARE NOT ALLOWED");
				
			
				float result=0F;
				for (int i=0; i < vector1.Length; i++)				
					result += vector1[i] * vector2[i];
				
				return result;
			}
		
			public static float VectorLength(float[] vector)
			{			
				float sum=0.0F;
				for (int i=0; i < vector.Length; i++)				
					sum=sum + (vector[i] * vector[i]);
						
				return (float)Math.Sqrt(sum);
			}

		}

		private IDictionary _wordsIndex=new Hashtable() ;

		public TFIDFMeasure(string[] documents)
		{
			_docs=documents;
			_numDocs=documents.Length ;
			MyInit();
		}

		private void GeneratNgramText()
		{
			
		}

		private ArrayList GenerateTerms(string[] docs)
		{
			ArrayList uniques=new ArrayList() ;
			_ngramDoc=new string[_numDocs][] ;
			for (int i=0; i < docs.Length ; i++)
			{
				Tokeniser tokenizer=new Tokeniser() ;
				string[] words=tokenizer.Partition(docs[i]);			

				for (int j=0; j < words.Length ; j++)
					if (!uniques.Contains(words[j]) )				
						uniques.Add(words[j]) ;
								
			}
			return uniques;
		}
		


		private static object AddElement(IDictionary collection, object key, object newValue)
		{
			object element=collection[key];
			collection[key]=newValue;
			return element;
		}

		private int GetTermIndex(string term)
		{
			object index=_wordsIndex[term];
			if (index == null) return -1;
			return (int) index;
		}

		private void MyInit()
		{
			_terms=GenerateTerms (_docs );
			_numTerms=_terms.Count ;

			_maxTermFreq=new int[_numDocs] ;
			_docFreq=new int[_numTerms] ;
			_termFreq =new int[_numTerms][] ;
			_termWeight=new float[_numTerms][] ;

			for(int i=0; i < _terms.Count ; i++)			
			{
				_termWeight[i]=new float[_numDocs] ;
				_termFreq[i]=new int[_numDocs] ;

				AddElement(_wordsIndex, _terms[i], i);			
			}
			
			GenerateTermFrequency ();
			GenerateTermWeight();			
				
		}
		
		private float Log(float num)
		{
			return (float) Math.Log(num) ;//log2
		}

		private void GenerateTermFrequency()
		{
			for(int i=0; i < _numDocs  ; i++)
			{								
				string curDoc=_docs[i];
				IDictionary freq=GetWordFrequency(curDoc);
				IDictionaryEnumerator enums=freq.GetEnumerator() ;
				_maxTermFreq[i]=int.MinValue ;
				while (enums.MoveNext())
				{
					string word=(string)enums.Key;
					int wordFreq=(int)enums.Value ;
					int termIndex=GetTermIndex(word);

					_termFreq [termIndex][i]=wordFreq;
					_docFreq[termIndex] ++;

					if (wordFreq > _maxTermFreq[i]) _maxTermFreq[i]=wordFreq;					
				}
			}
		}
		

		private void GenerateTermWeight()
		{			
			for(int i=0; i < _numTerms   ; i++)
			{
				for(int j=0; j < _numDocs ; j++)				
					_termWeight[i][j]=ComputeTermWeight (i, j);				
			}
		}

		private float GetTermFrequency(int term, int doc)
		{			
			int freq=_termFreq [term][doc];
			int maxfreq=_maxTermFreq[doc];			
			
			return ( (float) freq/(float)maxfreq );
		}

		private float GetInverseDocumentFrequency(int term)
		{
			int df=_docFreq[term];
			return Log((float) (_numDocs) / (float) df );
		}

		private float ComputeTermWeight(int term, int doc)
		{
			float tf=GetTermFrequency (term, doc);
			float idf=GetInverseDocumentFrequency(term);
			return tf * idf;
		}
		
		private  float[] GetTermVector(int doc)
		{
			float[] w=new float[_numTerms] ;
			for (int i=0; i < _numTerms; i++)											
				w[i]=_termWeight[i][doc];
			
				
			return w;
		}

		public float GetSimilarity(int doc_i, int doc_j)
		{
			float[] vector1=GetTermVector (doc_i);
			float[] vector2=GetTermVector (doc_j);

			return TermVector.ComputeCosineSimilarity(vector1, vector2) ;

		}
		
		private IDictionary GetWordFrequency(string input)
		{
			string convertedInput=input.ToLower() ;
					
			Tokeniser tokenizer=new Tokeniser() ;
			String[] words=tokenizer.Partition(convertedInput);			
			Array.Sort(words);
			
			String[] distinctWords=GetDistinctWords(words);
						
			IDictionary result=new Hashtable();
			for (int i=0; i < distinctWords.Length; i++)
			{
				object tmp;
				tmp=CountWords(distinctWords[i], words);
				result[distinctWords[i]]=tmp;
				
			}
			
			return result;
		}				
				
		private string[] GetDistinctWords(String[] input)
		{				
			if (input == null)			
				return new string[0];			
			else
			{
				ArrayList list=new ArrayList() ;
				
				for (int i=0; i < input.Length; i++)
					if (!list.Contains(input[i])) // N-GRAM SIMILARITY?				
						list.Add(input[i]);
				
				return Tokeniser.ArrayListToArray(list) ;
			}
		}
		

		
		private int CountWords(string word, string[] words)
		{
			int itemIdx=Array.BinarySearch(words, word);
			
			if (itemIdx > 0)			
				while (itemIdx > 0 && words[itemIdx].Equals(word))				
					itemIdx--;				
						
			int count=0;
			while (itemIdx < words.Length && itemIdx >= 0)
			{
				if (words[itemIdx].Equals(word)) count++;				
				
				itemIdx++;
				if (itemIdx < words.Length)				
					if (!words[itemIdx].Equals(word)) break;					
				
			}
			
			return count;
		}				
	}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人一区二区三区片免费| 亚洲一区二区欧美日韩| 91麻豆精品国产无毒不卡在线观看| 国产电影精品久久禁18| 国产成人av资源| 成人免费三级在线| 99re热这里只有精品免费视频| jizz一区二区| 91久久免费观看| 欧美久久一区二区| 欧美一区二区免费观在线| 欧美v国产在线一区二区三区| 精品国产免费一区二区三区四区 | 亚洲bt欧美bt精品777| 亚洲一区二区不卡免费| 午夜久久久影院| 激情综合色综合久久| 国产99精品视频| 一本色道综合亚洲| 欧美视频在线一区二区三区| 91精品国产综合久久香蕉的特点| 欧美日本一道本在线视频| 欧美一二三区在线观看| 性久久久久久久久久久久| 久久免费午夜影院| 中文字幕一区二区三区蜜月| 亚洲欧美精品午睡沙发| 午夜精品久久久久影视| 国产呦萝稀缺另类资源| 色综合一个色综合亚洲| 日韩午夜激情av| 国产精品天天看| 午夜激情综合网| 国产精品一区一区三区| 欧美性色黄大片手机版| 久久精品无码一区二区三区| 一区二区成人在线观看| 国产精品一级二级三级| 在线视频一区二区免费| 久久久精品天堂| 视频一区欧美日韩| 国产99久久久国产精品潘金网站| 欧美日韩一本到| 国产欧美一区二区三区鸳鸯浴| 亚洲国产一区二区在线播放| 国精品**一区二区三区在线蜜桃| 成人h动漫精品一区二区| 91论坛在线播放| 久久一二三国产| 午夜精品福利久久久| 99久久er热在这里只有精品15| 在线电影院国产精品| 中文字幕亚洲不卡| 国产一区亚洲一区| 欧美高清性hdvideosex| 欧美韩日一区二区三区四区| 轻轻草成人在线| 欧美日本精品一区二区三区| 综合亚洲深深色噜噜狠狠网站| 狠狠久久亚洲欧美| 欧美乱妇15p| 亚洲色图欧美激情| 国产不卡在线一区| 久久女同互慰一区二区三区| 日本一区中文字幕| 欧美日韩精品一区二区三区蜜桃 | 精品视频1区2区| 亚洲精品日韩综合观看成人91| 大桥未久av一区二区三区中文| 欧美精品一区二区三区在线播放| 日韩激情一二三区| 7799精品视频| 蜜臀av一区二区在线观看| 欧美精品在欧美一区二区少妇| 亚洲成av人片在线| 欧美日韩久久久久久| 亚洲成av人片一区二区梦乃| 色狠狠av一区二区三区| 一区二区三区四区在线播放 | 亚洲成国产人片在线观看| 色视频一区二区| 欧美日韩日本视频| 一区二区三区在线视频免费观看 | 欧美成人aa大片| 久久电影国产免费久久电影| 日韩欧美卡一卡二| 国产自产2019最新不卡| 国产午夜亚洲精品理论片色戒 | 亚洲资源中文字幕| 欧美疯狂做受xxxx富婆| 日本少妇一区二区| 久久麻豆一区二区| 91丝袜美女网| 日韩精品乱码免费| 国产一区二区三区精品欧美日韩一区二区三区 | 91麻豆精东视频| 成人免费小视频| 在线免费精品视频| 亚洲电影一级片| 日韩欧美一级片| 国产精品一区二区果冻传媒| 亚洲国产精品二十页| 波多野结衣在线一区| 亚洲一区在线播放| 欧美一区二区三区思思人 | 国产蜜臀97一区二区三区| caoporn国产精品| 欧美日韩精品欧美日韩精品一综合| 视频在线观看一区| 国产日韩成人精品| 欧美在线视频日韩| 国产综合色视频| 亚洲黄色在线视频| 精品国产免费久久| 91免费观看视频| 国产一区三区三区| 亚洲一区二区三区视频在线播放 | 久久久久久99精品| 欧美视频在线观看一区| 国产一区二区三区久久悠悠色av| 亚洲日本韩国一区| 精品国产伦一区二区三区免费| 色婷婷国产精品久久包臀| 美女高潮久久久| 亚洲愉拍自拍另类高清精品| 久久婷婷国产综合国色天香| 欧美日韩一本到| 97精品久久久午夜一区二区三区 | 国产美女视频一区| 亚洲电影你懂得| 亚洲精品视频观看| 国产欧美中文在线| 欧美视频一区二区在线观看| 国产在线精品免费| 日韩精品91亚洲二区在线观看| 国产色综合一区| 日韩欧美123| 91麻豆精品国产自产在线观看一区| 高清beeg欧美| 国产成都精品91一区二区三| 午夜电影一区二区| 亚洲最新视频在线观看| 日韩理论片中文av| 国产精品国产三级国产普通话蜜臀| 欧美一区午夜视频在线观看| 在线视频一区二区三| 色婷婷亚洲婷婷| 日本高清视频一区二区| 99久久精品国产一区| 国产在线播放一区二区三区| 免费看欧美女人艹b| 视频一区免费在线观看| 日韩二区三区四区| 美日韩一级片在线观看| 午夜精品爽啪视频| 日本女优在线视频一区二区| 天堂av在线一区| 老司机精品视频一区二区三区| 蜜臀国产一区二区三区在线播放| 五月婷婷综合激情| 日韩成人一级大片| 久久66热re国产| 粉嫩一区二区三区性色av| av不卡免费电影| 色综合久久中文综合久久97| 欧美亚洲国产怡红院影院| 欧美色中文字幕| 精品日韩99亚洲| 久久久久久免费网| 成人免费视频在线观看| 亚洲亚洲人成综合网络| 蜜臀久久99精品久久久久久9| 久久精品国产久精国产爱| 国产风韵犹存在线视精品| 色老汉一区二区三区| 91精品婷婷国产综合久久竹菊| 日韩精品中文字幕一区二区三区 | 亚洲高清不卡在线| 蜜臀av性久久久久蜜臀av麻豆| 国产一区二区三区香蕉| 91在线精品秘密一区二区| 7777精品伊人久久久大香线蕉完整版| 91精品国产综合久久香蕉的特点 | 欧美亚洲图片小说| 欧美一级欧美三级| 国产精品无码永久免费888| 亚洲一区二区三区四区的| 激情综合网激情| 欧洲视频一区二区| 久久色.com| 亚洲高清免费在线| 国产成人自拍网| 宅男在线国产精品| 日韩毛片高清在线播放| 国内精品视频666| 成人av电影在线观看| 日韩西西人体444www| 亚洲人精品一区| 国产在线视频一区二区三区| 欧美三级午夜理伦三级中视频|