⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 charsequence2charngrams.java

📁 这是一个matlab的java实现。里面有许多内容。请大家慢慢捉摸。
💻 JAVA
字号:
/* Copyright (C) 2002 Univ. of Massachusetts Amherst, Computer Science Dept.   This file is part of "MALLET" (MAchine Learning for LanguagE Toolkit).   http://www.cs.umass.edu/~mccallum/mallet   This software is provided under the terms of the Common Public License,   version 1.0, as published by http://www.opensource.org.  For further   information, see the file `LICENSE' included with this distribution. *//**    @author Andrew McCallum <a href="mailto:mccallum@cs.umass.edu">mccallum@cs.umass.edu</a> */package edu.umass.cs.mallet.base.pipe;import edu.umass.cs.mallet.base.types.TokenSequence;import edu.umass.cs.mallet.base.types.Instance;import java.io.*;/** * Transform a character sequence into a token sequence of character N grams. *    @author Andrew McCallum <a href="mailto:mccallum@cs.umass.edu">mccallum@cs.umass.edu</a> */public class CharSequence2CharNGrams extends Pipe implements Serializable{	int n;	boolean distinguishBorders = false;	static char startBorderChar = '>';	static char endBorderChar = '<';	public CharSequence2CharNGrams (int n, boolean distinguishBorders)	{		this.n = n;		this.distinguishBorders = distinguishBorders;	}	protected String[] ngramify (CharSequence s)	{		if (distinguishBorders)			s = new StringBuffer().append(startBorderChar).append(s).append(endBorderChar).toString();		int count = s.length() - n;		String[] ngrams = new String[count];		for (int i = 0; i < count; i++)			ngrams[i] = s.subSequence (i, i+n).toString();		return ngrams;	}	public Instance pipe (Instance carrier)	{		if (carrier.getData() instanceof CharSequence)			carrier.setData(new TokenSequence (ngramify ((CharSequence)carrier.getData())));		else if (carrier.getData() instanceof TokenSequence) {			TokenSequence ts = (TokenSequence) carrier.getData();			TokenSequence ret = new TokenSequence ();			for (int i = 0; i < ts.size(); i++)				ret.add (ngramify (ts.getToken(i).getText()));			carrier.setData(ret);		} else			throw new IllegalArgumentException ("Unhandled type "+carrier.getData().getClass());		return carrier;	}	// Serialization 		private static final long serialVersionUID = 1;	private static final int CURRENT_SERIAL_VERSION = 0;		private void writeObject (ObjectOutputStream out) throws IOException {		out.writeInt (CURRENT_SERIAL_VERSION);		out.writeInt(n);		out.writeBoolean(distinguishBorders);	}		private void readObject (ObjectInputStream in) throws IOException, ClassNotFoundException {		int version = in.readInt ();		n = in.readInt();		distinguishBorders = in.readBoolean();	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -