albers投影转WGS84坐标格式,读.shp.dbf文件,获取文件字符集工具类。

坐标转换

package com.kero99.geo;

import java.io.IOException;
import java.io.StringReader;
import java.io.StringWriter;

import org.geotools.geojson.geom.GeometryJSON;
import org.geotools.geometry.jts.JTS;
import org.geotools.referencing.CRS;
import org.geotools.referencing.crs.DefaultGeographicCRS;
import org.opengis.geometry.MismatchedDimensionException;
import org.opengis.referencing.FactoryException;
import org.opengis.referencing.crs.CoordinateReferenceSystem;
import org.opengis.referencing.operation.MathTransform;
import org.opengis.referencing.operation.TransformException;

import com.vividsolutions.jts.geom.Geometry;

public class CoordinateUitls {
	/**
	 * WGS84转换albers
	 * @return
	 * @author ygc
	 * @throws IOException 
	 * @throws FactoryException 
	 * @throws TransformException 
	 * @throws MismatchedDimensionException 
	 */
	public static String WGS84ToAlbers(String geometry) throws IOException, FactoryException, MismatchedDimensionException, TransformException {
		GeometryJSON geometryJSON2 = new GeometryJSON(15);
		Geometry geometry2 = geometryJSON2.read(new StringReader(geometry.toString()));

//				com.alibaba.fastjson.JSONObject temp = JSON.parseObject(geometry);
		// 这里是以OGC WKT形式定义的是World Mercator投影,网页地图一般使用该投影
		final String strWKTMercator = 
				"PROJCS[\"World_Mercator\","
				+ "GEOGCS[\"GCS_WGS_1984\"," 
				+ "DATUM[\"WGS_1984\","
				+ "SPHEROID[\"WGS_1984\",6378137,298.257223563]]," 
				+ "PRIMEM[\"Greenwich\",0],"
				+ "UNIT[\"Degree\",0.017453292519943295]]," 
				+ "PROJECTION[\"Albers\"],"
				+ "PARAMETER[\"false_easting\",0]," 
				+ "PARAMETER[\"false_northing\",0],"
				+ "PARAMETER[\"central_meridian\",105.0]," 
				+ "PARAMETER[\"standard_parallel_1\",25.0],"
				+ "PARAMETER[\"standard_parallel_2\",47.0]," 
				+ "PARAMETER[\"latitude_of_origin\",0],"
				+ "UNIT[\"Meter\",1]]";
		/*
		 * CoordinateReferenceSystem mercatroCRS = CRS.parseWKT(strWKTMercator);
		 * CRS.decode("EPSG:3857"); xfa1
		 */
		CoordinateReferenceSystem mercatroCRS = CRS.parseWKT(strWKTMercator);				
		// 做投影转换,将WCG84坐标转换成世界墨卡托投影转 
		MathTransform transform = CRS.findMathTransform(DefaultGeographicCRS.WGS84,mercatroCRS);
		Geometry targetPoint = (Geometry) JTS.transform(geometry2, transform);
		StringWriter writer = new StringWriter();
		
		//	geometryJSON2.write(targetPoint, writer);
			geometryJSON2.write(targetPoint, writer);
//			System.out.println(writer.toString());
			writer.flush();
			writer.close();
			return writer.toString();
	}
	
	/**
	 * albers转WGS84
	 * @return
	 * @author ygc
	 * @throws IOException 
	 * @throws FactoryException 
	 * @throws TransformException 
	 * @throws MismatchedDimensionException 
	 */
	public static String AlbersToWGS84(String geometry) throws IOException, FactoryException, MismatchedDimensionException, TransformException {
		GeometryJSON geometryJSON2 = new GeometryJSON(15);
		Geometry geometry2 = geometryJSON2.read(new StringReader(geometry.toString()));

//				com.alibaba.fastjson.JSONObject temp = JSON.parseObject(geometry);
		// 这里是以OGC WKT形式定义的是World Mercator投影,网页地图一般使用该投影
		final String strWKTMercator = 
				"PROJCS[\"World_Mercator\","
				+ "GEOGCS[\"GCS_WGS_1984\"," 
				+ "DATUM[\"WGS_1984\","
				+ "SPHEROID[\"WGS_1984\",6378137,298.257223563]]," 
				+ "PRIMEM[\"Greenwich\",0],"
				+ "UNIT[\"Degree\",0.017453292519943295]]," 
				+ "PROJECTION[\"Albers\"],"
				+ "PARAMETER[\"false_easting\",0]," 
				+ "PARAMETER[\"false_northing\",0],"
				+ "PARAMETER[\"central_meridian\",105.0]," 
				+ "PARAMETER[\"standard_parallel_1\",25.0],"
				+ "PARAMETER[\"standard_parallel_2\",47.0]," 
				+ "PARAMETER[\"latitude_of_origin\",0],"
				+ "UNIT[\"Meter\",1]]";
		/*
		 * CoordinateReferenceSystem mercatroCRS = CRS.parseWKT(strWKTMercator);
		 * CRS.decode("EPSG:3857"); xfa1
		 */
		CoordinateReferenceSystem mercatroCRS = CRS.parseWKT(strWKTMercator);				
		// 做投影转换,将WCG84坐标转换成世界墨卡托投影转 
		MathTransform transform = CRS.findMathTransform(mercatroCRS,DefaultGeographicCRS.WGS84);
		Geometry targetPoint = (Geometry) JTS.transform(geometry2, transform);
		StringWriter writer = new StringWriter();
		
		//	geometryJSON2.write(targetPoint, writer);
			geometryJSON2.write(targetPoint, writer);
//			System.out.println(writer.toString());
			writer.flush();
			writer.close();
			return writer.toString();
	}
}

 

// 读dbf 读.shp文件  工具类

package com.kero99.utils;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.io.StringWriter;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.nio.charset.Charset;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Stack;
import java.util.TreeMap;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import org.geotools.data.shapefile.ShapefileDataStore;
import org.geotools.data.shapefile.ShapefileDataStoreFactory;
import org.geotools.data.shapefile.dbf.DbaseFileHeader;
import org.geotools.data.shapefile.dbf.DbaseFileReader;
import org.geotools.data.shapefile.files.ShpFiles;
import org.geotools.data.simple.SimpleFeatureCollection;
import org.geotools.data.simple.SimpleFeatureIterator;
import org.geotools.data.simple.SimpleFeatureSource;
import org.geotools.geojson.feature.FeatureJSON;
import org.geotools.geojson.geom.GeometryJSON;
import org.opengis.feature.simple.SimpleFeature;
import org.opengis.feature.type.AttributeDescriptor;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;

public class ShapeUtils {
	/**
	 * 解析.shp 点线面文件
	 * 
	 * @param path
	 * @return
	 * @throws Exception
	 * @author ygc
	 */
	public static Map<String, String> readShapeFileData(String path) throws Exception {
		Map<String, String> map = new HashMap<String, String>();
		try {

			File file = new File(path);
			// String fileName = file.getName();
			ShapefileDataStoreFactory sfdsf = new ShapefileDataStoreFactory();
		
			ShapefileDataStore sfds = (ShapefileDataStore) sfdsf.createDataStore(file.toURI().toURL());
			sfds.setCharset(Charset.forName("GBK"));
			
			SimpleFeatureSource featureSource = sfds.getFeatureSource();

			List<AttributeDescriptor> attrList = sfds.getSchema().getAttributeDescriptors();
			JSONObject pFieldJSON = new JSONObject();
			for (AttributeDescriptor attributeDescriptor : attrList) {
				String pFieldName = attributeDescriptor.getName().toString();
				String pTypeName = attributeDescriptor.getType().getBinding().getSimpleName();
				// System.out.println(attributeDescriptor.getType().getBinding().getName());
				if (pFieldName == "the_geom") {
					map.put("type", pTypeName);
					pFieldName = "Shape";
					pTypeName = "Geometry";
				}

				pFieldJSON.put(pFieldName, getShapeType(pTypeName));

			}
			// System.out.println(pFieldJSON);
			SimpleFeatureCollection feacollection = featureSource.getFeatures();
			SimpleFeatureIterator iterator = feacollection.features();
			GeometryJSON gjson = new GeometryJSON(15);
			FeatureJSON fjson = new FeatureJSON(gjson);
			fjson.setEncodeFeatureCRS(true);
			fjson.setEncodeFeatureCollectionCRS(true);
			StringWriter writer = new StringWriter();
			while (iterator.hasNext()) {
				SimpleFeature sFeature = iterator.next();
				if (writer.toString().isEmpty()) {
					fjson.writeFeature(sFeature, writer);

				} else {
					writer.write(',');
					fjson.writeFeature(sFeature, writer);

				}
			}
			iterator.close();
			writer.flush();
			writer.close();
			sfds.dispose();

			String jsonData = "[" + writer.toString() + "]";
			System.err.println(jsonData + "jsonData");

			JSONObject jsonObject = new JSONObject();
			jsonObject.put("type", "FeatureCollection");
			jsonObject.put("features", JSONArray.fromObject(jsonData));
			map.put("features", jsonObject.toString());
			map.put("fields", pFieldJSON.toString());

			map.put("LayerName", file.getName().replace(".shp", ""));

			map.put("op", "sucess");

			// System.out.println(map);
		} catch (Exception e) {
			// TODO: handle exception
			e.printStackTrace();
			map.put("op", "fail");
		}

		return map;
	}

	public static List<String> readDbfData(String path) {
		List<Map<Object, Object>> dbf = ShapeUtils.readDbfFile(path);
		for (Map<Object, Object> data : dbf) {
			for (Object k : data.keySet()) {
				System.out.println(k + " : " + data.get(k));
			}
		}
		return null;
	}
	
	/**
	 * 解析.dbf
	 * 
	 * @param path
	 * @return
	 * @throws Exception
	 * @author ygc
	 */
	public static List<Map<Object, Object>> readDbfFile(String path) {
		String newPath = path.substring(0, path.lastIndexOf("."))+".dbf";
		List<Map<Object, Object>> list = new ArrayList<Map<Object, Object>>();
		TreeMap<Object, Object> values = null;
		String encode=EncodingDetect.getEncodeType(newPath);
//		String code = null;
//		if(encode.equals("ASCII")) {
//			code="GBK";
//		}
//		if(encode.equals("ISO8859_1")) {
//			code="UTF8";
//		}
		System.out.println(encode);
		DbaseFileReader reader = null;
		try {
			
			reader = new DbaseFileReader(new ShpFiles(path), false, Charset.forName(encode));
		
			DbaseFileHeader header = reader.getHeader();
	
			int numFields = header.getNumFields();
	
			// 迭代读取记录
			while (reader.hasNext()) {
				
				try {
					Object[] entry = reader.readEntry();
					
					values = new TreeMap<Object, Object>();
					for (int i = 0; i < numFields; i++) {
						String title = header.getFieldName(i);
				
						Object value = entry[i];
					
						String	result=DbfTitleCheck.dbfTitleCheck(title);
						values.put(result, value);
					
						 System.err.println(result);
						// System.out.println(title+"="+value);
					}

				} catch (Exception e) {
					e.printStackTrace();
				}
				list.add(values);
			}
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			if (reader != null) {
				// 关闭
				try {
					reader.close();
				} catch (Exception e) {
				}
			}
		}
		return list;
	}
	
	

	
	public static String getShapeType(String type) {
		String pDbFieldType = "";
		switch (type) {
		case "Integer":
			pDbFieldType = "INTEGER";
			break;
		case "Double":
			pDbFieldType = "DOUBLE";
			break;
		case "String":
			pDbFieldType = "VARCHAR";
			break;
		case "Date":
			pDbFieldType = "DATETIME";
			break;
		case "Boolean":
			pDbFieldType = "BOOLEAN";
			break;
		case "Geometry":
			pDbFieldType = "Geometry";
			break;
		default:
			pDbFieldType = "TEXT";
			break;
		}
		return pDbFieldType;
	}

	/**
	 * 解析.shp文件数据完整版
	 * 
	 * @param path
	 * @return
	 * @throws Exception
	 * @author ygc
	 */
	public static List<String> parseShapeData(String path) throws Exception {
		List<String> list = new ArrayList<String>();
		Map<String, String> map = ShapeUtils.readShapeFileData(path);
		String r = JSON.toJSONString(map, SerializerFeature.WriteMapNullValue);
		com.alibaba.fastjson.JSONObject jsonObject = JSON.parseObject(r);
		String item = jsonObject.getString("features");
		com.alibaba.fastjson.JSONObject json = JSON.parseObject(item);
		com.alibaba.fastjson.JSONArray value = json.getJSONArray("features");
		for (int i = 0; i < value.size(); i++) {
			com.alibaba.fastjson.JSONObject listValue = (com.alibaba.fastjson.JSONObject) value.get(i);
			String geometry = listValue.getString("geometry");
			com.alibaba.fastjson.JSONObject temp = JSON.parseObject(geometry);
			// String coordinates = temp.getString("coordinates");

			String coordinates = temp.getString("coordinates").replace("[", "").replace("]", "");

			list.add(coordinates);
		}

		return list;
	}

	/**
	 * albers投影转WGS84坐标格式
	 * 
	 * @param shp
	 * @return
	 * @author ygc
	 */
	public static List<String> albersToWGS84(List<String> shp) {
		List<Double> list1 = null;
		List<String> list2 = new ArrayList<String>();
		String X = null;
		String Y = null;
		for (String value : shp) {
			list1 = new ArrayList<Double>();
			String s[] = value.split(",");
			//解析算法
			for (int i = 0; i < s.length; i++) {
				if (i % 2 == 0) {
					X = s[i];
					double[] temp = GeoUtils.albersToCoordinates(Double.valueOf(X), 0);
					list1.add(temp[0]);
				} else {
					Y = s[i];
					double[] temp = GeoUtils.albersToCoordinates(0, Double.valueOf(Y));
					list1.add(temp[1]);
				}
			}
			list2.add(list1.toString());
		}
		return list2;
	}

	// 投影转换 prj tif img 栅格数据解析
	public static void main(String[] args) throws Exception {
		
		 //String path="E:\\shape文件\\设计图斑\\设计图斑-坐标\\item.shp";
		//gbk
		//String path2 = "E:\\shape文件\\设计图斑\\设计图斑-面状\\设计图斑-面状.shp";
		String path2 = "E:\\shape文件\\图斑\\实施方案_项目区边界.shp";
		//String path2 = "E:\\shape文件\\图斑\\实施方案_线措施.shp";
		List<Map<Object, Object>> dbf=ShapeUtils.readDbfFile(path2);
		System.out.println(dbf);
//		List<String> shp = ShapeUtils.parseShapeData(path2);
//		// List<Map<Object, Object>> dbf=ShapeUtils.readDbfFile(path);
//		List<String> info = ShapeUtils.albersToWGS84(shp);
//		for (String value : info) {
//			System.out.println(value);
//		}
//		List<String> shp = ShapeUtils.parseShapeData(path2);
//		for (String value : shp) {
//			System.out.println(value);
//		}
//		List<String> info=ShapeUtils.albersToWGS84(shp);
//		for (String value : info) {
//			System.out.println(value);
//		}
	
	}

	// for(String value:list2) {
	// System.out.println(value);
	// }
	// String X;
	// String Y;
	//
	// for (int i = 0; i < s.length; i+=2){
	// X=s[i];
	// double[] temp=GeoUtils.albers2ll(Double.valueOf(X),0);
	//
	// }
	// for (int j = 1; j < s.length; j+=2){
	// Y=s[j];
	// double[] temp=GeoUtils.albers2ll(0,Double.valueOf(Y));
	//
	// }
	// list2.addAll(list1);

	//
	// System.out.println(s[]);
	// for(String item: s) {
	//
	//
	// }

	// List<String> Polygon=ShapeUtils.parseShapeData(path);
	// for(String value:Polygon) {
	// System.out.println(value);
	// for(Map<Object, Object> item:dbf) {
	// System.out.println(item.get("图斑编码"));
	// System.out.println(item.get("措施代码"));
	// System.out.println(item.get("措施名称"));
	// System.out.println(item.get("利用现状"));
	// System.out.println(item.get("措施数量"));
	// System.out.println(item.get("坡度"));
	// System.out.println(" ");
	// break;
	// }
	// }

	// String path="E:\\shape文件\\设计图斑\\设计图斑-点状\\设计图斑-点状.dbf";
	// List<Map<Object, Object>> list=ShapeUtils.readDbfFile(path);
	// System.out.println(list);
	// for(Map<Object, Object> item:list) {
	// // System.out.println(item.get("措施代码").toString());
	// System.out.println(item.get("措施名称").toString());
	//
	// // System.out.println(item.get("措施数量").toString());
	// }

	// }
//	/**
//	 * 解析.dbf
//	 * 
//	 * @param path
//	 * @return
//	 * @throws Exception
//	 * @author ygc
//	 */
//	public static List<Map<Object, Object>> readDbfFileValue(String path) {
//		List<Map<Object, Object>> list = new ArrayList<Map<Object, Object>>();
//		Map<Object, Object> values = null;
//		DbaseFileReader reader = null;
//		try {
//			
//			reader = new DbaseFileReader(new ShpFiles(path), false, Charset.forName("GBK"));
//			DbaseFileHeader header = reader.getHeader();
//			int numFields = header.getNumFields();
//			// 迭代读取记录
//			while (reader.hasNext()) {
//				try {
//					Object[] entry = reader.readEntry();
//					values = new LinkedHashMap<Object, Object>();
//					for (int i = 0; i < numFields; i++) {
//						String title = header.getFieldName(i);
//						Object value = entry[i];
//			
//						values.put(title, value);
//					
//						// System.out.println(title+"="+value);
//					}
//
//				} catch (Exception e) {
//					e.printStackTrace();
//				}
//				list.add(values);
//			}
//		} catch (Exception e) {
//			e.printStackTrace();
//		} finally {
//			if (reader != null) {
//				// 关闭
//				try {
//					reader.close();
//				} catch (Exception e) {
//				}
//			}
//		}
//		return list;
//	}
	// public static String GetImageExt(String strImageUrl){
	// String strExtent = "";
	// try {
	// String ImageUrl=strImageUrl.replace("\\", "\\\\");;
	// File ImageFile=new File(ImageUrl);
	// GeoTiffReader reader=new GeoTiffReader(ImageFile);
	// GridCoverage2D coverage = reader.read(null);
	// CoordinateReferenceSystem crs = coverage.getCoordinateReferenceSystem2D();
	// Envelope2D coverageEnvelope = coverage.getEnvelope2D();
	// double coverageMinX = coverageEnvelope.getBounds().getMinX();
	// double coverageMaxX = coverageEnvelope.getBounds().getMaxX();
	// double coverageMinY = coverageEnvelope.getBounds().getMinY();
	// double coverageMaxY = coverageEnvelope.getBounds().getMaxY();
	//
	// } catch (Exception e) {
	// // TODO: handle exception
	// }

}

//投影转换工具 albers投影转WGS84坐标格式

package com.kero99.utils;

public class GeoUtils {

	public static double[] albersToCoordinates(double x,double y){
	    double xd=x;
	    double yd=y;
	    double pi=4*Math.atan(1);
	    double fi0=0*pi/180;
	    double lanbuda0=110*pi/180;
	    double fi1=25*pi/180;
	    double fi2=47*pi/180;
	    double EF=0;
	    double NF=0;
	    double a=6378137;
	    double b=6356752.3142;
	    double e1=Math.sqrt(1-b/a*b/a);
	    double e2=1-e1*e1;
	    double alfa0=e2*(Math.sin(fi0)/(1-e1*e1*Math.sin(fi0)*Math.sin(fi0))-0.5/e1*Math.log((1-e1*Math.sin(fi0))/(1+e1*Math.sin(fi0))));
	    double alfa1=e2*(Math.sin(fi1)/(1-e1*e1*Math.sin(fi1)*Math.sin(fi1))-0.5/e1*Math.log((1-e1*Math.sin(fi1))/(1+e1*Math.sin(fi1))));
	    double alfa2=e2*(Math.sin(fi2)/(1-e1*e1*Math.sin(fi2)*Math.sin(fi2))-0.5/e1*Math.log((1-e1*Math.sin(fi2))/(1+e1*Math.sin(fi2))));
	    double m1=Math.cos(fi1)/Math.sqrt(1-e1*e1*Math.sin(fi1)*Math.sin(fi1));
	    double m2=Math.cos(fi2)/Math.sqrt(1-e1*e1*Math.sin(fi2)*Math.sin(fi2));
	    double n=(m1*m1-m2*m2)/(alfa2-alfa1);
	    double c=m1*m1+n*alfa1;
	    double rou0=a*Math.sqrt(c-n*alfa0)/n;
	    double sita=Math.atan((xd-EF)/(rou0-(yd-NF)));
	    double rou=Math.sqrt(Math.pow((xd-EF),2)+Math.pow((rou0-(yd-NF)),2));
	    double alfa=(c-Math.pow((rou*n/a),2))/n;
	    double beta=Math.asin(alfa/(1-(1-Math.pow(e1,2))/(2*e1)*Math.log((1-e1)/(1+e1))));
	    double lon=lanbuda0+sita/n;
	    double lat=beta+(Math.pow(e1,2)/3+31*Math.pow(e1,4)/180+517*Math.pow(e1,6)/5040)*Math.sin(2*beta)+(23*Math.pow(e1,4)/360+251*Math.pow(e1,6)/3780)*Math.sin(4*beta)+(761*Math.pow(e1,6)/45360)*Math.sin(6*beta);
	    lon=lon*180/pi;
	    lat=lat*180/pi;
	    return new double[]{lon,lat};
	}
	public static void main(String[] args) {
		double X=1591429.5;
		double Y=4843964;
		double[] s=GeoUtils.albersToCoordinates(X, Y);
		System.out.println(" X: "+s[0]+" Y: "+s[1]);
	}
}

//读文件字符集

package com.kero99.utils;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URL;

public class EncodingDetect {
	public static void main(String[] args) {
		String path = "E:\\shape文件\\图斑\\实施方案_项目区边界.dbf";
		String encode=getEncodeType(path);
		System.out.println(encode);
	}
	
	/**
	 * @author ygc
	 * 通过文件读文件字符集类型
	 * @param filePath 文件路径
	 * @return 文件的编码
	 */
	public static String getEncodeType(String filePath){
		BytesEncodingDetect s = new BytesEncodingDetect(); 
		String fileCode = BytesEncodingDetect.javaname[s.detectEncoding(new File(filePath))];
		return fileCode;
	}
	
	public static void readFile(String file, String code) {
 
		BufferedReader fr;
		try {
			String myCode = code!=null&&!"".equals(code) ? code : "UTF8";
			InputStreamReader read = new InputStreamReader(new FileInputStream(
					file), myCode);
 
			fr = new BufferedReader(read);
			String line = null;
			int flag=1;
			// 读取每一行,如果结束了,line会为空
			while ((line = fr.readLine()) != null && line.trim().length() > 0) {
				if(flag==1) {
				    line=line.substring(1);//去掉文件头
				    flag++;
			    }
				System.out.println(line);
			}
			fr.close();
			
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
 
	}
}
 
class BytesEncodingDetect extends Encoding {
	  // Frequency tables to hold the GB, Big5, and EUC-TW character
	  // frequencies
	  int GBFreq[][];
 
	  int GBKFreq[][];
 
	  int Big5Freq[][];
 
	  int Big5PFreq[][];
 
	  int EUC_TWFreq[][];
 
	  int KRFreq[][];
 
	  int JPFreq[][];
 
	  // int UnicodeFreq[94][128];
	  // public static String[] nicename;
	  // public static String[] codings;
	  public boolean debug;
 
	  public BytesEncodingDetect() {
	    super();
	    debug = false;
	    GBFreq = new int[94][94];
	    GBKFreq = new int[126][191];
	    Big5Freq = new int[94][158];
	    Big5PFreq = new int[126][191];
	    EUC_TWFreq = new int[94][94];
	    KRFreq = new int[94][94];
	    JPFreq = new int[94][94];
	    // Initialize the Frequency Table for GB, GBK, Big5, EUC-TW, KR, JP
	    initialize_frequencies();
	  }
 
	  public static void main(String argc[]) {
	    BytesEncodingDetect sinodetector;
	    int result = OTHER;
	    int i;
	    sinodetector = new BytesEncodingDetect();
	    for (i = 0; i < argc.length; i++) {
	      if (argc[i].startsWith("http://") == true) {
	        try {
	          result = sinodetector.detectEncoding(new URL(argc[i]));
	        } catch (Exception e) {
	          System.err.println("Bad URL " + e.toString());
	        }
	      } else if (argc[i].equals("-d")) {
	        sinodetector.debug = true;
	        continue;
	      } else {
	        result = sinodetector.detectEncoding(new File(argc[i]));
	      }
	      System.out.println(nicename[result]);
	    }
	  }
 
	  /**
	   * Function : detectEncoding Aruguments: URL Returns : One of the encodings from the Encoding enumeration (GB2312, HZ, BIG5,
	   * EUC_TW, ASCII, or OTHER) Description: This function looks at the URL contents and assigns it a probability score for each
	   * encoding type. The encoding type with the highest probability is returned.
	   */
	  public int detectEncoding(URL testurl) {
	    byte[] rawtext = new byte[10000];
	    int bytesread = 0, byteoffset = 0;
	    int guess = OTHER;
	    InputStream chinesestream;
	    try {
	      chinesestream = testurl.openStream();
	      while ((bytesread = chinesestream.read(rawtext, byteoffset, rawtext.length - byteoffset)) > 0) {
	        byteoffset += bytesread;
	      }
	      ;
	      chinesestream.close();
	      guess = detectEncoding(rawtext);
	    } catch (Exception e) {
	      System.err.println("Error loading or using URL " + e.toString());
	      guess = -1;
	    }
	    return guess;
	  }
 
	  /**
	   * Function : detectEncoding Aruguments: File Returns : One of the encodings from the Encoding enumeration (GB2312, HZ, BIG5,
	   * EUC_TW, ASCII, or OTHER) Description: This function looks at the file and assigns it a probability score for each encoding
	   * type. The encoding type with the highest probability is returned.
	   */
	  public int detectEncoding(File testfile) {
	    FileInputStream chinesefile;
	    byte[] rawtext;
	    rawtext = new byte[(int) testfile.length()];
	    try {
	      chinesefile = new FileInputStream(testfile);
	      chinesefile.read(rawtext);
	      chinesefile.close();
	    } catch (Exception e) {
	      System.err.println("Error: " + e);
	    }
	    return detectEncoding(rawtext);
	  }
 
	  /**
	   * Function : detectEncoding Aruguments: byte array Returns : One of the encodings from the Encoding enumeration (GB2312, HZ,
	   * BIG5, EUC_TW, ASCII, or OTHER) Description: This function looks at the byte array and assigns it a probability score for
	   * each encoding type. The encoding type with the highest probability is returned.
	   */
	  public int detectEncoding(byte[] rawtext) {
	    int[] scores;
	    int index, maxscore = 0;
	    int encoding_guess = OTHER;
	    scores = new int[TOTALTYPES];
	    // Assign Scores
	    scores[GB2312] = gb2312_probability(rawtext);
	    scores[GBK] = gbk_probability(rawtext);
	    scores[GB18030] = gb18030_probability(rawtext);
	    scores[HZ] = hz_probability(rawtext);
	    scores[BIG5] = big5_probability(rawtext);
	    scores[CNS11643] = euc_tw_probability(rawtext);
	    scores[ISO2022CN] = iso_2022_cn_probability(rawtext);
	    scores[UTF8] = utf8_probability(rawtext);
	    scores[UNICODE] = utf16_probability(rawtext);
	    scores[EUC_KR] = euc_kr_probability(rawtext);
	    scores[CP949] = cp949_probability(rawtext);
	    scores[JOHAB] = 0;
	    scores[ISO2022KR] = iso_2022_kr_probability(rawtext);
	    scores[ASCII] = ascii_probability(rawtext);
	    scores[SJIS] = sjis_probability(rawtext);
	    scores[EUC_JP] = euc_jp_probability(rawtext);
	    scores[ISO2022JP] = iso_2022_jp_probability(rawtext);
	    scores[UNICODET] = 0;
	    scores[UNICODES] = 0;
	    scores[ISO2022CN_GB] = 0;
	    scores[ISO2022CN_CNS] = 0;
	    scores[OTHER] = 0;
	    // Tabulate Scores
	    for (index = 0; index < TOTALTYPES; index++) {
	      if (debug)
	        System.err.println("Encoding " + nicename[index] + " score " + scores[index]);
	      if (scores[index] > maxscore) {
	        encoding_guess = index;
	        maxscore = scores[index];
	      }
	    }
	    // Return OTHER if nothing scored above 50
	    if (maxscore <= 50) {
	      encoding_guess = OTHER;
	    }
	    return encoding_guess;
	  }
 
	  /*
	   * Function: gb2312_probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text
	   * in array uses GB-2312 encoding
	   */
	  int gb2312_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, gbchars = 1;
	    long gbfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xF7 && (byte) 0xA1 <= rawtext[i + 1]
	            && rawtext[i + 1] <= (byte) 0xFE) {
	          gbchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          column = rawtext[i + 1] + 256 - 0xA1;
	          if (GBFreq[row][column] != 0) {
	            gbfreq += GBFreq[row][column];
	          } else if (15 <= row && row < 55) {
	            // In GB high-freq character range
	            gbfreq += 200;
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) gbchars / (float) dbchars);
	    freqval = 50 * ((float) gbfreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  /*
	   * Function: gbk_probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text in
	   * array uses GBK encoding
	   */
	  int gbk_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, gbchars = 1;
	    long gbfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xF7 && // Original GB range
	            (byte) 0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE) {
	          gbchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          column = rawtext[i + 1] + 256 - 0xA1;
	          // System.out.println("original row " + row + " column " + column);
	          if (GBFreq[row][column] != 0) {
	            gbfreq += GBFreq[row][column];
	          } else if (15 <= row && row < 55) {
	            gbfreq += 200;
	          }
	        } else if ((byte) 0x81 <= rawtext[i]
	            && rawtext[i] <= (byte) 0xFE
	            && // Extended GB range
	            (((byte) 0x80 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE) || ((byte) 0x40 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0x7E))) {
	          gbchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0x81;
	          if (0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) {
	            column = rawtext[i + 1] - 0x40;
	          } else {
	            column = rawtext[i + 1] + 256 - 0x40;
	          }
	          // System.out.println("extended row " + row + " column " + column + " rawtext[i] " + rawtext[i]);
	          if (GBKFreq[row][column] != 0) {
	            gbfreq += GBKFreq[row][column];
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) gbchars / (float) dbchars);
	    freqval = 50 * ((float) gbfreq / (float) totalfreq);
	    // For regular GB files, this would give the same score, so I handicap it slightly
	    return (int) (rangeval + freqval) - 1;
	  }
 
	  /*
	   * Function: gb18030_probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text
	   * in array uses GBK encoding
	   */
	  int gb18030_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, gbchars = 1;
	    long gbfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xF7 && // Original GB range
	            i + 1 < rawtextlen && (byte) 0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE) {
	          gbchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          column = rawtext[i + 1] + 256 - 0xA1;
	          // System.out.println("original row " + row + " column " + column);
	          if (GBFreq[row][column] != 0) {
	            gbfreq += GBFreq[row][column];
	          } else if (15 <= row && row < 55) {
	            gbfreq += 200;
	          }
	        } else if ((byte) 0x81 <= rawtext[i] && rawtext[i] <= (byte) 0xFE
	            && // Extended GB range
	            i + 1 < rawtextlen
	            && (((byte) 0x80 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE) || ((byte) 0x40 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0x7E))) {
	          gbchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0x81;
	          if (0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) {
	            column = rawtext[i + 1] - 0x40;
	          } else {
	            column = rawtext[i + 1] + 256 - 0x40;
	          }
	          // System.out.println("extended row " + row + " column " + column + " rawtext[i] " + rawtext[i]);
	          if (GBKFreq[row][column] != 0) {
	            gbfreq += GBKFreq[row][column];
	          }
	        } else if ((byte) 0x81 <= rawtext[i]
	            && rawtext[i] <= (byte) 0xFE
	            && // Extended GB range
	            i + 3 < rawtextlen && (byte) 0x30 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0x39
	            && (byte) 0x81 <= rawtext[i + 2] && rawtext[i + 2] <= (byte) 0xFE && (byte) 0x30 <= rawtext[i + 3]
	            && rawtext[i + 3] <= (byte) 0x39) {
	          gbchars++;
	          /*
	           * totalfreq += 500; row = rawtext[i] + 256 - 0x81; if (0x40 <= rawtext[i+1] && rawtext[i+1] <= 0x7E) { column =
	           * rawtext[i+1] - 0x40; } else { column = rawtext[i+1] + 256 - 0x40; } //System.out.println("extended row " + row + "
	           * column " + column + " rawtext[i] " + rawtext[i]); if (GBKFreq[row][column] != 0) { gbfreq += GBKFreq[row][column]; }
	           */
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) gbchars / (float) dbchars);
	    freqval = 50 * ((float) gbfreq / (float) totalfreq);
	    // For regular GB files, this would give the same score, so I handicap it slightly
	    return (int) (rangeval + freqval) - 1;
	  }
 
	  /*
	   * Function: hz_probability Argument: byte array Returns : number from 0 to 100 representing probability text in array uses HZ
	   * encoding
	   */
	  int hz_probability(byte[] rawtext) {
	    int i, rawtextlen;
	    int hzchars = 0, dbchars = 1;
	    long hzfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int hzstart = 0, hzend = 0;
	    int row, column;
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen; i++) {
	      if (rawtext[i] == '~') {
	        if (rawtext[i + 1] == '{') {
	          hzstart++;
	          i += 2;
	          while (i < rawtextlen - 1) {
	            if (rawtext[i] == 0x0A || rawtext[i] == 0x0D) {
	              break;
	            } else if (rawtext[i] == '~' && rawtext[i + 1] == '}') {
	              hzend++;
	              i++;
	              break;
	            } else if ((0x21 <= rawtext[i] && rawtext[i] <= 0x77) && (0x21 <= rawtext[i + 1] && rawtext[i + 1] <= 0x77)) {
	              hzchars += 2;
	              row = rawtext[i] - 0x21;
	              column = rawtext[i + 1] - 0x21;
	              totalfreq += 500;
	              if (GBFreq[row][column] != 0) {
	                hzfreq += GBFreq[row][column];
	              } else if (15 <= row && row < 55) {
	                hzfreq += 200;
	              }
	            } else if ((0xA1 <= rawtext[i] && rawtext[i] <= 0xF7) && (0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= 0xF7)) {
	              hzchars += 2;
	              row = rawtext[i] + 256 - 0xA1;
	              column = rawtext[i + 1] + 256 - 0xA1;
	              totalfreq += 500;
	              if (GBFreq[row][column] != 0) {
	                hzfreq += GBFreq[row][column];
	              } else if (15 <= row && row < 55) {
	                hzfreq += 200;
	              }
	            }
	            dbchars += 2;
	            i += 2;
	          }
	        } else if (rawtext[i + 1] == '}') {
	          hzend++;
	          i++;
	        } else if (rawtext[i + 1] == '~') {
	          i++;
	        }
	      }
	    }
	    if (hzstart > 4) {
	      rangeval = 50;
	    } else if (hzstart > 1) {
	      rangeval = 41;
	    } else if (hzstart > 0) { // Only 39 in case the sequence happened to occur
	      rangeval = 39; // in otherwise non-Hz text
	    } else {
	      rangeval = 0;
	    }
	    freqval = 50 * ((float) hzfreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  /**
	   * Function: big5_probability Argument: byte array Returns : number from 0 to 100 representing probability text in array uses
	   * Big5 encoding
	   */
	  int big5_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, bfchars = 1;
	    float rangeval = 0, freqval = 0;
	    long bffreq = 0, totalfreq = 1;
	    int row, column;
	    // Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0xA1 <= rawtext[i]
	            && rawtext[i] <= (byte) 0xF9
	            && (((byte) 0x40 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0x7E) || ((byte) 0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE))) {
	          bfchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          if (0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) {
	            column = rawtext[i + 1] - 0x40;
	          } else {
	            column = rawtext[i + 1] + 256 - 0x61;
	          }
	          if (Big5Freq[row][column] != 0) {
	            bffreq += Big5Freq[row][column];
	          } else if (3 <= row && row <= 37) {
	            bffreq += 200;
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) bfchars / (float) dbchars);
	    freqval = 50 * ((float) bffreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  /*
	   * Function: big5plus_probability Argument: pointer to unsigned char array Returns : number from 0 to 100 representing
	   * probability text in array uses Big5+ encoding
	   */
	  int big5plus_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, bfchars = 1;
	    long bffreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 128) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if (0xA1 <= rawtext[i] && rawtext[i] <= 0xF9 && // Original Big5 range
	            ((0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) || (0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= 0xFE))) {
	          bfchars++;
	          totalfreq += 500;
	          row = rawtext[i] - 0xA1;
	          if (0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) {
	            column = rawtext[i + 1] - 0x40;
	          } else {
	            column = rawtext[i + 1] - 0x61;
	          }
	          // System.out.println("original row " + row + " column " + column);
	          if (Big5Freq[row][column] != 0) {
	            bffreq += Big5Freq[row][column];
	          } else if (3 <= row && row < 37) {
	            bffreq += 200;
	          }
	        } else if (0x81 <= rawtext[i] && rawtext[i] <= 0xFE && // Extended Big5 range
	            ((0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) || (0x80 <= rawtext[i + 1] && rawtext[i + 1] <= 0xFE))) {
	          bfchars++;
	          totalfreq += 500;
	          row = rawtext[i] - 0x81;
	          if (0x40 <= rawtext[i + 1] && rawtext[i + 1] <= 0x7E) {
	            column = rawtext[i + 1] - 0x40;
	          } else {
	            column = rawtext[i + 1] - 0x40;
	          }
	          // System.out.println("extended row " + row + " column " + column + " rawtext[i] " + rawtext[i]);
	          if (Big5PFreq[row][column] != 0) {
	            bffreq += Big5PFreq[row][column];
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) bfchars / (float) dbchars);
	    freqval = 50 * ((float) bffreq / (float) totalfreq);
	    // For regular Big5 files, this would give the same score, so I handicap it slightly
	    return (int) (rangeval + freqval) - 1;
	  }
 
	  /*
	   * Function: euc_tw_probability Argument: byte array Returns : number from 0 to 100 representing probability text in array
	   * uses EUC-TW (CNS 11643) encoding
	   */
	  int euc_tw_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, cnschars = 1;
	    long cnsfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Check to see if characters fit into acceptable ranges
	    // and have expected frequency of use
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      if (rawtext[i] >= 0) { // in ASCII range
	        // asciichars++;
	      } else { // high bit set
	        dbchars++;
	        if (i + 3 < rawtextlen && (byte) 0x8E == rawtext[i] && (byte) 0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xB0
	            && (byte) 0xA1 <= rawtext[i + 2] && rawtext[i + 2] <= (byte) 0xFE && (byte) 0xA1 <= rawtext[i + 3]
	            && rawtext[i + 3] <= (byte) 0xFE) { // Planes 1 - 16
	          cnschars++;
	          // System.out.println("plane 2 or above CNS char");
	          // These are all less frequent chars so just ignore freq
	          i += 3;
	        } else if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xFE && // Plane 1
	            (byte) 0xA1 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE) {
	          cnschars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          column = rawtext[i + 1] + 256 - 0xA1;
	          if (EUC_TWFreq[row][column] != 0) {
	            cnsfreq += EUC_TWFreq[row][column];
	          } else if (35 <= row && row <= 92) {
	            cnsfreq += 150;
	          }
	          i++;
	        }
	      }
	    }
	    rangeval = 50 * ((float) cnschars / (float) dbchars);
	    freqval = 50 * ((float) cnsfreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  /*
	   * Function: iso_2022_cn_probability Argument: byte array Returns : number from 0 to 100 representing probability text in
	   * array uses ISO 2022-CN encoding WORKS FOR BASIC CASES, BUT STILL NEEDS MORE WORK
	   */
	  int iso_2022_cn_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, isochars = 1;
	    long isofreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Check to see if characters fit into acceptable ranges
	    // and have expected frequency of use
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      if (rawtext[i] == (byte) 0x1B && i + 3 < rawtextlen) { // Escape char ESC
	        if (rawtext[i + 1] == (byte) 0x24 && rawtext[i + 2] == 0x29 && rawtext[i + 3] == (byte) 0x41) { // GB Escape $ ) A
	          i += 4;
	          while (rawtext[i] != (byte) 0x1B) {
	            dbchars++;
	            if ((0x21 <= rawtext[i] && rawtext[i] <= 0x77) && (0x21 <= rawtext[i + 1] && rawtext[i + 1] <= 0x77)) {
	              isochars++;
	              row = rawtext[i] - 0x21;
	              column = rawtext[i + 1] - 0x21;
	              totalfreq += 500;
	              if (GBFreq[row][column] != 0) {
	                isofreq += GBFreq[row][column];
	              } else if (15 <= row && row < 55) {
	                isofreq += 200;
	              }
	              i++;
	            }
	            i++;
	          }
	        } else if (i + 3 < rawtextlen && rawtext[i + 1] == (byte) 0x24 && rawtext[i + 2] == (byte) 0x29
	            && rawtext[i + 3] == (byte) 0x47) {
	          // CNS Escape $ ) G
	          i += 4;
	          while (rawtext[i] != (byte) 0x1B) {
	            dbchars++;
	            if ((byte) 0x21 <= rawtext[i] && rawtext[i] <= (byte) 0x7E && (byte) 0x21 <= rawtext[i + 1]
	                && rawtext[i + 1] <= (byte) 0x7E) {
	              isochars++;
	              totalfreq += 500;
	              row = rawtext[i] - 0x21;
	              column = rawtext[i + 1] - 0x21;
	              if (EUC_TWFreq[row][column] != 0) {
	                isofreq += EUC_TWFreq[row][column];
	              } else if (35 <= row && row <= 92) {
	                isofreq += 150;
	              }
	              i++;
	            }
	            i++;
	          }
	        }
	        if (rawtext[i] == (byte) 0x1B && i + 2 < rawtextlen && rawtext[i + 1] == (byte) 0x28 && rawtext[i + 2] == (byte) 0x42) { // ASCII:
	          // ESC
	          // ( B
	          i += 2;
	        }
	      }
	    }
	    rangeval = 50 * ((float) isochars / (float) dbchars);
	    freqval = 50 * ((float) isofreq / (float) totalfreq);
	    // System.out.println("isochars dbchars isofreq totalfreq " + isochars + " " + dbchars + " " + isofreq + " " + totalfreq + "
	    // " + rangeval + " " + freqval);
	    return (int) (rangeval + freqval);
	    // return 0;
	  }
 
	  /*
	   * Function: utf8_probability Argument: byte array Returns : number from 0 to 100 representing probability text in array uses
	   * UTF-8 encoding of Unicode
	   */
	  int utf8_probability(byte[] rawtext) {
	    int score = 0;
	    int i, rawtextlen = 0;
	    int goodbytes = 0, asciibytes = 0;
	    // Maybe also use UTF8 Byte Order Mark: EF BB BF
	    // Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen; i++) {
	      if ((rawtext[i] & (byte) 0x7F) == rawtext[i]) { // One byte
	        asciibytes++;
	        // Ignore ASCII, can throw off count
	      } else if (-64 <= rawtext[i] && rawtext[i] <= -33 && // Two bytes
	          i + 1 < rawtextlen && -128 <= rawtext[i + 1] && rawtext[i + 1] <= -65) {
	        goodbytes += 2;
	        i++;
	      } else if (-32 <= rawtext[i] && rawtext[i] <= -17
	          && // Three bytes
	          i + 2 < rawtextlen && -128 <= rawtext[i + 1] && rawtext[i + 1] <= -65 && -128 <= rawtext[i + 2]
	          && rawtext[i + 2] <= -65) {
	        goodbytes += 3;
	        i += 2;
	      }
	    }
	    if (asciibytes == rawtextlen) {
	      return 0;
	    }
	    score = (int) (100 * ((float) goodbytes / (float) (rawtextlen - asciibytes)));
	    // System.out.println("rawtextlen " + rawtextlen + " goodbytes " + goodbytes + " asciibytes " + asciibytes + " score " +
	    // score);
	    // If not above 98, reduce to zero to prevent coincidental matches
	    // Allows for some (few) bad formed sequences
	    if (score > 98) {
	      return score;
	    } else if (score > 95 && goodbytes > 30) {
	      return score;
	    } else {
	      return 0;
	    }
	  }
 
	  /*
	   * Function: utf16_probability Argument: byte array Returns : number from 0 to 100 representing probability text in array uses
	   * UTF-16 encoding of Unicode, guess based on BOM // NOT VERY GENERAL, NEEDS MUCH MORE WORK
	   */
	  int utf16_probability(byte[] rawtext) {
	    // int score = 0;
	    // int i, rawtextlen = 0;
	    // int goodbytes = 0, asciibytes = 0;
	    if (rawtext.length > 1 && ((byte) 0xFE == rawtext[0] && (byte) 0xFF == rawtext[1]) || // Big-endian
	        ((byte) 0xFF == rawtext[0] && (byte) 0xFE == rawtext[1])) { // Little-endian
	      return 100;
	    }
	    return 0;
	    /*
	     * // Check to see if characters fit into acceptable ranges rawtextlen = rawtext.length; for (i = 0; i < rawtextlen; i++) {
	     * if ((rawtext[i] & (byte)0x7F) == rawtext[i]) { // One byte goodbytes += 1; asciibytes++; } else if ((rawtext[i] &
	     * (byte)0xDF) == rawtext[i]) { // Two bytes if (i+1 < rawtextlen && (rawtext[i+1] & (byte)0xBF) == rawtext[i+1]) {
	     * goodbytes += 2; i++; } } else if ((rawtext[i] & (byte)0xEF) == rawtext[i]) { // Three bytes if (i+2 < rawtextlen &&
	     * (rawtext[i+1] & (byte)0xBF) == rawtext[i+1] && (rawtext[i+2] & (byte)0xBF) == rawtext[i+2]) { goodbytes += 3; i+=2; } } }
	     * 
	     * score = (int)(100 * ((float)goodbytes/(float)rawtext.length)); // An all ASCII file is also a good UTF8 file, but I'd
	     * rather it // get identified as ASCII. Can delete following 3 lines otherwise if (goodbytes == asciibytes) { score = 0; } //
	     * If not above 90, reduce to zero to prevent coincidental matches if (score > 90) { return score; } else { return 0; }
	     */
	  }
 
	  /*
	   * Function: ascii_probability Argument: byte array Returns : number from 0 to 100 representing probability text in array uses
	   * all ASCII Description: Sees if array has any characters not in ASCII range, if so, score is reduced
	   */
	  int ascii_probability(byte[] rawtext) {
	    int score = 75;
	    int i, rawtextlen;
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen; i++) {
	      if (rawtext[i] < 0) {
	        score = score - 5;
	      } else if (rawtext[i] == (byte) 0x1B) { // ESC (used by ISO 2022)
	        score = score - 5;
	      }
	      if (score <= 0) {
	        return 0;
	      }
	    }
	    return score;
	  }
 
	  /*
	   * Function: euc_kr__probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text
	   * in array uses EUC-KR encoding
	   */
	  int euc_kr_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, krchars = 1;
	    long krfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xFE && (byte) 0xA1 <= rawtext[i + 1]
	            && rawtext[i + 1] <= (byte) 0xFE) {
	          krchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          column = rawtext[i + 1] + 256 - 0xA1;
	          if (KRFreq[row][column] != 0) {
	            krfreq += KRFreq[row][column];
	          } else if (15 <= row && row < 55) {
	            krfreq += 0;
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) krchars / (float) dbchars);
	    freqval = 50 * ((float) krfreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  /*
	   * Function: cp949__probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text
	   * in array uses Cp949 encoding
	   */
	  int cp949_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, krchars = 1;
	    long krfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0x81 <= rawtext[i]
	            && rawtext[i] <= (byte) 0xFE
	            && ((byte) 0x41 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0x5A || (byte) 0x61 <= rawtext[i + 1]
	                && rawtext[i + 1] <= (byte) 0x7A || (byte) 0x81 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFE)) {
	          krchars++;
	          totalfreq += 500;
	          if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xFE && (byte) 0xA1 <= rawtext[i + 1]
	              && rawtext[i + 1] <= (byte) 0xFE) {
	            row = rawtext[i] + 256 - 0xA1;
	            column = rawtext[i + 1] + 256 - 0xA1;
	            if (KRFreq[row][column] != 0) {
	              krfreq += KRFreq[row][column];
	            }
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) krchars / (float) dbchars);
	    freqval = 50 * ((float) krfreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  int iso_2022_kr_probability(byte[] rawtext) {
	    int i;
	    for (i = 0; i < rawtext.length; i++) {
	      if (i + 3 < rawtext.length && rawtext[i] == 0x1b && (char) rawtext[i + 1] == '$' && (char) rawtext[i + 2] == ')'
	          && (char) rawtext[i + 3] == 'C') {
	        return 100;
	      }
	    }
	    return 0;
	  }
 
	  /*
	   * Function: euc_jp_probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text
	   * in array uses EUC-JP encoding
	   */
	  int euc_jp_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, jpchars = 1;
	    long jpfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xFE && (byte) 0xA1 <= rawtext[i + 1]
	            && rawtext[i + 1] <= (byte) 0xFE) {
	          jpchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256 - 0xA1;
	          column = rawtext[i + 1] + 256 - 0xA1;
	          if (JPFreq[row][column] != 0) {
	            jpfreq += JPFreq[row][column];
	          } else if (15 <= row && row < 55) {
	            jpfreq += 0;
	          }
	        }
	        i++;
	      }
	    }
	    rangeval = 50 * ((float) jpchars / (float) dbchars);
	    freqval = 50 * ((float) jpfreq / (float) totalfreq);
	    return (int) (rangeval + freqval);
	  }
 
	  int iso_2022_jp_probability(byte[] rawtext) {
	    int i;
	    for (i = 0; i < rawtext.length; i++) {
	      if (i + 2 < rawtext.length && rawtext[i] == 0x1b && (char) rawtext[i + 1] == '$' && (char) rawtext[i + 2] == 'B') {
	        return 100;
	      }
	    }
	    return 0;
	  }
 
	  /*
	   * Function: sjis_probability Argument: pointer to byte array Returns : number from 0 to 100 representing probability text in
	   * array uses Shift-JIS encoding
	   */
	  int sjis_probability(byte[] rawtext) {
	    int i, rawtextlen = 0;
	    int dbchars = 1, jpchars = 1;
	    long jpfreq = 0, totalfreq = 1;
	    float rangeval = 0, freqval = 0;
	    int row, column, adjust;
	    // Stage 1: Check to see if characters fit into acceptable ranges
	    rawtextlen = rawtext.length;
	    for (i = 0; i < rawtextlen - 1; i++) {
	      // System.err.println(rawtext[i]);
	      if (rawtext[i] >= 0) {
	        // asciichars++;
	      } else {
	        dbchars++;
	        if (i + 1 < rawtext.length
	            && (((byte) 0x81 <= rawtext[i] && rawtext[i] <= (byte) 0x9F) || ((byte) 0xE0 <= rawtext[i] && rawtext[i] <= (byte) 0xEF))
	            && (((byte) 0x40 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0x7E) || ((byte) 0x80 <= rawtext[i + 1] && rawtext[i + 1] <= (byte) 0xFC))) {
	          jpchars++;
	          totalfreq += 500;
	          row = rawtext[i] + 256;
	          column = rawtext[i + 1] + 256;
	          if (column < 0x9f) {
	            adjust = 1;
	            if (column > 0x7f) {
	              column -= 0x20;
	            } else {
	              column -= 0x19;
	            }
	          } else {
	            adjust = 0;
	            column -= 0x7e;
	          }
	          if (row < 0xa0) {
	            row = ((row - 0x70) << 1) - adjust;
	          } else {
	            row = ((row - 0xb0) << 1) - adjust;
	          }
	          row -= 0x20;
	          column = 0x20;
	          // System.out.println("original row " + row + " column " + column);
	          if (row < JPFreq.length && column < JPFreq[row].length && JPFreq[row][column] != 0) {
	            jpfreq += JPFreq[row][column];
	          }
	          i++;
	        } else if ((byte) 0xA1 <= rawtext[i] && rawtext[i] <= (byte) 0xDF) {
	          // half-width katakana, convert to full-width
	        }
	      }
	    }
	    rangeval = 50 * ((float) jpchars / (float) dbchars);
	    freqval = 50 * ((float) jpfreq / (float) totalfreq);
	    // For regular GB files, this would give the same score, so I handicap it slightly
	    return (int) (rangeval + freqval) - 1;
	  }
 
	  void initialize_frequencies() {
	    int i, j;
	    for (i = 0; i < 94; i++) {
	      for (j = 0; j < 94; j++) {
	        GBFreq[i][j] = 0;
	      }
	    }
	    for (i = 0; i < 126; i++) {
	      for (j = 0; j < 191; j++) {
	        GBKFreq[i][j] = 0;
	      }
	    }
	    for (i = 0; i < 94; i++) {
	      for (j = 0; j < 158; j++) {
	        Big5Freq[i][j] = 0;
	      }
	    }
	    for (i = 0; i < 126; i++) {
	      for (j = 0; j < 191; j++) {
	        Big5PFreq[i][j] = 0;
	      }
	    }
	    for (i = 0; i < 94; i++) {
	      for (j = 0; j < 94; j++) {
	        EUC_TWFreq[i][j] = 0;
	      }
	    }
	    for (i = 0; i < 94; i++) {
	      for (j = 0; j < 94; j++) {
	        JPFreq[i][j] = 0;
	      }
	    }
	    GBFreq[20][35] = 599;
	    GBFreq[49][26] = 598;
	    GBFreq[41][38] = 597;
	    GBFreq[17][26] = 596;
	    GBFreq[32][42] = 595;
	    GBFreq[39][42] = 594;
	    GBFreq[45][49] = 593;
	    GBFreq[51][57] = 592;
	    GBFreq[50][47] = 591;
	    GBFreq[42][90] = 590;
	    GBFreq[52][65] = 589;
	    GBFreq[53][47] = 588;
	    GBFreq[19][82] = 587;
	    GBFreq[31][19] = 586;
	    GBFreq[40][46] = 585;
	    GBFreq[24][89] = 584;
	    GBFreq[23][85] = 583;
	    GBFreq[20][28] = 582;
	    GBFreq[42][20] = 581;
	    GBFreq[34][38] = 580;
	    GBFreq[45][9] = 579;
	    GBFreq[54][50] = 578;
	    GBFreq[25][44] = 577;
	    GBFreq[35][66] = 576;
	    GBFreq[20][55] = 575;
	    GBFreq[18][85] = 574;
	    GBFreq[20][31] = 573;
	    GBFreq[49][17] = 572;
	    GBFreq[41][16] = 571;
	    GBFreq[35][73] = 570;
	    GBFreq[20][34] = 569;
	    GBFreq[29][44] = 568;
	    GBFreq[35][38] = 567;
	    GBFreq[49][9] = 566;
	    GBFreq[46][33] = 565;
	    GBFreq[49][51] = 564;
	    GBFreq[40][89] = 563;
	    GBFreq[26][64] = 562;
	    GBFreq[54][51] = 561;
	    GBFreq[54][36] = 560;
	    GBFreq[39][4] = 559;
	    GBFreq[53][13] = 558;
	    GBFreq[24][92] = 557;
	    GBFreq[27][49] = 556;
	    GBFreq[48][6] = 555;
	    GBFreq[21][51] = 554;
	    GBFreq[30][40] = 553;
	    GBFreq[42][92] = 552;
	    GBFreq[31][78] = 551;
	    GBFreq[25][82] = 550;
	    GBFreq[47][0] = 549;
	    GBFreq[34][19] = 548;
	    GBFreq[47][35] = 547;
	    GBFreq[21][63] = 546;
	    GBFreq[43][75] = 545;
	    GBFreq[21][87] = 544;
	    GBFreq[35][59] = 543;
	    GBFreq[25][34] = 542;
	    GBFreq[21][27] = 541;
	    GBFreq[39][26] = 540;
	    GBFreq[34][26] = 539;
	    GBFreq[39][52] = 538;
	    GBFreq[50][57] = 537;
	    GBFreq[37][79] = 536;
	    GBFreq[26][24] = 535;
	    GBFreq[22][1] = 534;
	    GBFreq[18][40] = 533;
	    GBFreq[41][33] = 532;
	    GBFreq[53][26] = 531;
	    GBFreq[54][86] = 530;
	    GBFreq[20][16] = 529;
	    GBFreq[46][74] = 528;
	    GBFreq[30][19] = 527;
	    GBFreq[45][35] = 526;
	    GBFreq[45][61] = 525;
	    GBFreq[30][9] = 524;
	    GBFreq[41][53] = 523;
	    GBFreq[41][13] = 522;
	    GBFreq[50][34] = 521;
	    GBFreq[53][86] = 520;
	    GBFreq[47][47] = 519;
	    GBFreq[22][28] = 518;
	    GBFreq[50][53] = 517;
	    GBFreq[39][70] = 516;
	    GBFreq[38][15] = 515;
	    GBFreq[42][88] = 514;
	    GBFreq[16][29] = 513;
	    GBFreq[27][90] = 512;
	    GBFreq[29][12] = 511;
	    GBFreq[44][22] = 510;
	    GBFreq[34][69] = 509;
	    GBFreq[24][10] = 508;
	    GBFreq[44][11] = 507;
	    GBFreq[39][92] = 506;
	    GBFreq[49][48] = 505;
	    GBFreq[31][46] = 504;
	    GBFreq[19][50] = 503;
	    GBFreq[21][14] = 502;
	    GBFreq[32][28] = 501;
	    GBFreq[18][3] = 500;
	    GBFreq[53][9] = 499;
	    GBFreq[34][80] = 498;
	    GBFreq[48][88] = 497;
	    GBFreq[46][53] = 496;
	    GBFreq[22][53] = 495;
	    GBFreq[28][10] = 494;
	    GBFreq[44][65] = 493;
	    GBFreq[20][10] = 492;
	    GBFreq[40][76] = 491;
	    GBFreq[47][8] = 490;
	    GBFreq[50][74] = 489;
	    GBFreq[23][62] = 488;
	    GBFreq[49][65] = 487;
	    GBFreq[28][87] = 486;
	    GBFreq[15][48] = 485;
	    GBFreq[22][7] = 484;
	    GBFreq[19][42] = 483;
	    GBFreq[41][20] = 482;
	    GBFreq[26][55] = 481;
	    GBFreq[21][93] = 480;
	    GBFreq[31][76] = 479;
	    GBFreq[34][31] = 478;
	    GBFreq[20][66] = 477;
	    GBFreq[51][33] = 476;
	    GBFreq[34][86] = 475;
	    GBFreq[37][67] = 474;
	    GBFreq[53][53] = 473;
	    GBFreq[40][88] = 472;
	    GBFreq[39][10] = 471;
	    GBFreq[24][3] = 470;
	    GBFreq[27][25] = 469;
	    GBFreq[26][15] = 468;
	    GBFreq[21][88] = 467;
	    GBFreq[52][62] = 466;
	    GBFreq[46][81] = 465;
	    GBFreq[38][72] = 464;
	    GBFreq[17][30] = 463;
	    GBFreq[52][92] = 462;
	    GBFreq[34][90] = 461;
	    GBFreq[21][7] = 460;
	    GBFreq[36][13] = 459;
	    GBFreq[45][41] = 458;
	    GBFreq[32][5] = 457;
	    GBFreq[26][89] = 456;
	    GBFreq[23][87] = 455;
	    GBFreq[20][39] = 454;
	    GBFreq[27][23] = 453;
	    GBFreq[25][59] = 452;
	    GBFreq[49][20] = 451;
	    GBFreq[54][77] = 450;
	    GBFreq[27][67] = 449;
	    GBFreq[47][33] = 448;
	    GBFreq[41][17] = 447;
	    GBFreq[19][81] = 446;
	    GBFreq[16][66] = 445;
	    GBFreq[45][26] = 444;
	    GBFreq[49][81] = 443;
	    GBFreq[53][55] = 442;
	    GBFreq[16][26] = 441;
	    GBFreq[54][62] = 440;
	    GBFreq[20][70] = 439;
	    GBFreq[42][35] = 438;
	    GBFreq[20][57] = 437;
	    GBFreq[34][36] = 436;
	    GBFreq[46][63] = 435;
	    GBFreq[19][45] = 434;
	    GBFreq[21][10] = 433;
	    GBFreq[52][93] = 432;
	    GBFreq[25][2] = 431;
	    GBFreq[30][57] = 430;
	    GBFreq[41][24] = 429;
	    GBFreq[28][43] = 428;
	    GBFreq[45][86] = 427;
	    GBFreq[51][56] = 426;
	    GBFreq[37][28] = 425;
	    GBFreq[52][69] = 424;
	    GBFreq[43][92] = 423;
	    GBFreq[41][31] = 422;
	    GBFreq[37][87] = 421;
	    GBFreq[47][36] = 420;
	    GBFreq[16][16] = 419;
	    GBFreq[40][56] = 418;
	    GBFreq[24][55] = 417;
	    GBFreq[17][1] = 416;
	    GBFreq[35][57] = 415;
	    GBFreq[27][50] = 414;
	    GBFreq[26][14] = 413;
	    GBFreq[50][40] = 412;
	    GBFreq[39][19] = 411;
	    GBFreq[19][89] = 410;
	    GBFreq[29][91] = 409;
	    GBFreq[17][89] = 408;
	    GBFreq[39][74] = 407;
	    GBFreq[46][39] = 406;
	    GBFreq[40][28] = 405;
	    GBFreq[45][68] = 404;
	    GBFreq[43][10] = 403;
	    GBFreq[42][13] = 402;
	    GBFreq[44][81] = 401;
	    GBFreq[41][47] = 400;
	    GBFreq[48][58] = 399;
	    GBFreq[43][68] = 398;
	    GBFreq[16][79] = 397;
	    GBFreq[19][5] = 396;
	    GBFreq[54][59] = 395;
	    GBFreq[17][36] = 394;
	    GBFreq[18][0] = 393;
	    GBFreq[41][5] = 392;
	    GBFreq[41][72] = 391;
	    GBFreq[16][39] = 390;
	    GBFreq[54][0] = 389;
	    GBFreq[51][16] = 388;
	    GBFreq[29][36] = 387;
	    GBFreq[47][5] = 386;
	    GBFreq[47][51] = 385;
	    GBFreq[44][7] = 384;
	    GBFreq[35][30] = 383;
	    GBFreq[26][9] = 382;
	    GBFreq[16][7] = 381;
	    GBFreq[32][1] = 380;
	    GBFreq[33][76] = 379;
	    GBFreq[34][91] = 378;
	    GBFreq[52][36] = 377;
	    GBFreq[26][77] = 376;
	    GBFreq[35][48] = 375;
	    GBFreq[40][80] = 374;
	    GBFreq[41][92] = 373;
	    GBFreq[27][93] = 372;
	    GBFreq[15][17] = 371;
	    GBFreq[16][76] = 370;
	    GBFreq[51][12] = 369;
	    GBFreq[18][20] = 368;
	    GBFreq[15][54] = 367;
	    GBFreq[50][5] = 366;
	    GBFreq[33][22] = 365;
	    GBFreq[37][57] = 364;
	    GBFreq[28][47] = 363;
	    GBFreq[42][31] = 362;
	    GBFreq[18][2] = 361;
	    GBFreq[43][64] = 360;
	    GBFreq[23][47] = 359;
	    GBFreq[28][79] = 358;
	    GBFreq[25][45] = 357;
	    GBFreq[23][91] = 356;
	    GBFreq[22][19] = 355;
	    GBFreq[25][46] = 354;
	    GBFreq[22][36] = 353;
	    GBFreq[54][85] = 352;
	    GBFreq[46][20] = 351;
	    GBFreq[27][37] = 350;
	    GBFreq[26][81] = 349;
	    GBFreq[42][29] = 348;
	    GBFreq[31][90] = 347;
	    GBFreq[41][59] = 346;
	    GBFreq[24][65] = 345;
	    GBFreq[44][84] = 344;
	    GBFreq[24][90] = 343;
	    GBFreq[38][54] = 342;
	    GBFreq[28][70] = 341;
	    GBFreq[27][15] = 340;
	    GBFreq[28][80] = 339;
	    GBFreq[29][8] = 338;
	    GBFreq[45][80] = 337;
	    GBFreq[53][37] = 336;
	    GBFreq[28][65] = 335;
	    GBFreq[23][86] = 334;
	    GBFreq[39][45] = 333;
	    GBFreq[53][32] = 332;
	    GBFreq[38][68] = 331;
	    GBFreq[45][78] = 330;
	    GBFreq[43][7] = 329;
	    GBFreq[46][82] = 328;
	    GBFreq[27][38] = 327;
	    GBFreq[16][62] = 326;
	    GBFreq[24][17] = 325;
	    GBFreq[22][70] = 324;
	    GBFreq[52][28] = 323;
	    GBFreq[23][40] = 322;
	    GBFreq[28][50] = 321;
	    GBFreq[42][91] = 320;
	    GBFreq[47][76] = 319;
	    GBFreq[15][42] = 318;
	    GBFreq[43][55] = 317;
	    GBFreq[29][84] = 316;
	    GBFreq[44][90] = 315;
	    GBFreq[53][16] = 314;
	    GBFreq[22][93] = 313;
	    GBFreq[34][10] = 312;
	    GBFreq[32][53] = 311;
	    GBFreq[43][65] = 310;
	    GBFreq[28][7] = 309;
	    GBFreq[35][46] = 308;
	    GBFreq[21][39] = 307;
	    GBFreq[44][18] = 306;
	    GBFreq[40][10] = 305;
	    GBFreq[54][53] = 304;
	    GBFreq[38][74] = 303;
	    GBFreq[28][26] = 302;
	    GBFreq[15][13] = 301;
	    GBFreq[39][34] = 300;
	    GBFreq[39][46] = 299;
	    GBFreq[42][66] = 298;
	    GBFreq[33][58] = 297;
	    GBFreq[15][56] = 296;
	    GBFreq[18][51] = 295;
	    GBFreq[49][68] = 294;
	    GBFreq[30][37] = 293;
	    GBFreq[51][84] = 292;
	    GBFreq[51][9] = 291;
	    GBFreq[40][70] = 290;
	    GBFreq[41][84] = 289;
	    GBFreq[28][64] = 288;
	    GBFreq[32][88] = 287;
	    GBFreq[24][5] = 286;
	    GBFreq[53][23] = 285;
	    GBFreq[42][27] = 284;
	    GBFreq[22][38] = 283;
	    GBFreq[32][86] = 282;
	    GBFreq[34][30] = 281;
	    GBFreq[38][63] = 280;
	    GBFreq[24][59] = 279;
	    GBFreq[22][81] = 278;
	    GBFreq[32][11] = 277;
	    GBFreq[51][21] = 276;
	    GBFreq[54][41] = 275;
	    GBFreq[21][50] = 274;
	    GBFreq[23][89] = 273;
	    GBFreq[19][87] = 272;
	    GBFreq[26][7] = 271;
	    GBFreq[30][75] = 270;
	    GBFreq[43][84] = 269;
	    GBFreq[51][25] = 268;
	    GBFreq[16][67] = 267;
	    GBFreq[32][9] = 266;
	    GBFreq[48][51] = 265;
	    GBFreq[39][7] = 264;
	    GBFreq[44][88] = 263;
	    GBFreq[52][24] = 262;
	    GBFreq[23][34] = 261;
	    GBFreq[32][75] = 260;
	    GBFreq[19][10] = 259;
	    GBFreq[28][91] = 258;
	    GBFreq[32][83] = 257;
	    GBFreq[25][75] = 256;
	    GBFreq[53][45] = 255;
	    GBFreq[29][85] = 254;
	    GBFreq[53][59] = 253;
	    GBFreq[16][2] = 252;
	    GBFreq[19][78] = 251;
	    GBFreq[15][75] = 250;
	    GBFreq[51][42] = 249;
	    GBFreq[45][67] = 248;
	    GBFreq[15][74] = 247;
	    GBFreq[25][81] = 246;
	    GBFreq[37][62] = 245;
	    GBFreq[16][55] = 244;
	    GBFreq[18][38] = 243;
	    GBFreq[23][23] = 242;
	    GBFreq[38][30] = 241;
	    GBFreq[17][28] = 240;
	    GBFreq[44][73] = 239;
	    GBFreq[23][78] = 238;
	    GBFreq[40][77] = 237;
	    GBFreq[38][87] = 236;
	    GBFreq[27][19] = 235;
	    GBFreq[38][82] = 234;
	    GBFreq[37][22] = 233;
	    GBFreq[41][30] = 232;
	    GBFreq[54][9] = 231;
	    GBFreq[32][30] = 230;
	    GBFreq[30][52] = 229;
	    GBFreq[40][84] = 228;
	    GBFreq[53][57] = 227;
	    GBFreq[27][27] = 226;
	    GBFreq[38][64] = 225;
	    GBFreq[18][43] = 224;
	    GBFreq[23][69] = 223;
	    GBFreq[28][12] = 222;
	    GBFreq[50][78] = 221;
	    GBFreq[50][1] = 220;
	    GBFreq[26][88] = 219;
	    GBFreq[36][40] = 218;
	    GBFreq[33][89] = 217;
	    GBFreq[41][28] = 216;
	    GBFreq[31][77] = 215;
	    GBFreq[46][1] = 214;
	    GBFreq[47][19] = 213;
	    GBFreq[35][55] = 212;
	    GBFreq[41][21] = 211;
	    GBFreq[27][10] = 210;
	    GBFreq[32][77] = 209;
	    GBFreq[26][37] = 208;
	    GBFreq[20][33] = 207;
	    GBFreq[41][52] = 206;
	    GBFreq[32][18] = 205;
	    GBFreq[38][13] = 204;
	    GBFreq[20][18] = 203;
	    GBFreq[20][24] = 202;
	    GBFreq[45][19] = 201;
	    GBFreq[18][53] = 200;
	    /*
	     * GBFreq[39][0] = 199; GBFreq[40][71] = 198; GBFreq[41][27] = 197; GBFreq[15][69] = 196; GBFreq[42][10] = 195;
	     * GBFreq[31][89] = 194; GBFreq[51][28] = 193; GBFreq[41][22] = 192; GBFreq[40][43] = 191; GBFreq[38][6] = 190;
	     * GBFreq[37][11] = 189; GBFreq[39][60] = 188; GBFreq[48][47] = 187; GBFreq[46][80] = 186; GBFreq[52][49] = 185;
	     * GBFreq[50][48] = 184; GBFreq[25][1] = 183; GBFreq[52][29] = 182; GBFreq[24][66] = 181; GBFreq[23][35] = 180;
	     * GBFreq[49][72] = 179; GBFreq[47][45] = 178; GBFreq[45][14] = 177; GBFreq[51][70] = 176; GBFreq[22][30] = 175;
	     * GBFreq[49][83] = 174; GBFreq[26][79] = 173; GBFreq[27][41] = 172; GBFreq[51][81] = 171; GBFreq[41][54] = 170;
	     * GBFreq[20][4] = 169; GBFreq[29][60] = 168; GBFreq[20][27] = 167; GBFreq[50][15] = 166; GBFreq[41][6] = 165;
	     * GBFreq[35][34] = 164; GBFreq[44][87] = 163; GBFreq[46][66] = 162; GBFreq[42][37] = 161; GBFreq[42][24] = 160;
	     * GBFreq[54][7] = 159; GBFreq[41][14] = 158; GBFreq[39][83] = 157; GBFreq[16][87] = 156; GBFreq[20][59] = 155;
	     * GBFreq[42][12] = 154; GBFreq[47][2] = 153; GBFreq[21][32] = 152; GBFreq[53][29] = 151; GBFreq[22][40] = 150;
	     * GBFreq[24][58] = 149; GBFreq[52][88] = 148; GBFreq[29][30] = 147; GBFreq[15][91] = 146; GBFreq[54][72] = 145;
	     * GBFreq[51][75] = 144; GBFreq[33][67] = 143; GBFreq[41][50] = 142; GBFreq[27][34] = 141; GBFreq[46][17] = 140;
	     * GBFreq[31][74] = 139; GBFreq[42][67] = 138; GBFreq[54][87] = 137; GBFreq[27][14] = 136; GBFreq[16][63] = 135;
	     * GBFreq[16][5] = 134; GBFreq[43][23] = 133; GBFreq[23][13] = 132; GBFreq[31][12] = 131; GBFreq[25][57] = 130;
	     * GBFreq[38][49] = 129; GBFreq[42][69] = 128; GBFreq[23][80] = 127; GBFreq[29][0] = 126; GBFreq[28][2] = 125;
	     * GBFreq[28][17] = 124; GBFreq[17][27] = 123; GBFreq[40][16] = 122; GBFreq[45][1] = 121; GBFreq[36][33] = 120;
	     * GBFreq[35][23] = 119; GBFreq[20][86] = 118; GBFreq[29][53] = 117; GBFreq[23][88] = 116; GBFreq[51][87] = 115;
	     * GBFreq[54][27] = 114; GBFreq[44][36] = 113; GBFreq[21][45] = 112; GBFreq[53][52] = 111; GBFreq[31][53] = 110;
	     * GBFreq[38][47] = 109; GBFreq[27][21] = 108; GBFreq[30][42] = 107; GBFreq[29][10] = 106; GBFreq[35][35] = 105;
	     * GBFreq[24][56] = 104; GBFreq[41][29] = 103; GBFreq[18][68] = 102; GBFreq[29][24] = 101; GBFreq[25][84] = 100;
	     * GBFreq[35][47] = 99; GBFreq[29][56] = 98; GBFreq[30][44] = 97; GBFreq[53][3] = 96; GBFreq[30][63] = 95; GBFreq[52][52] =
	     * 94; GBFreq[54][1] = 93; GBFreq[22][48] = 92; GBFreq[54][66] = 91; GBFreq[21][90] = 90; GBFreq[52][47] = 89;
	     * GBFreq[39][25] = 88; GBFreq[39][39] = 87; GBFreq[44][37] = 86; GBFreq[44][76] = 85; GBFreq[46][75] = 84; GBFreq[18][37] =
	     * 83; GBFreq[47][42] = 82; GBFreq[19][92] = 81; GBFreq[51][27] = 80; GBFreq[48][83] = 79; GBFreq[23][70] = 78;
	     * GBFreq[29][9] = 77; GBFreq[33][79] = 76; GBFreq[52][90] = 75; GBFreq[53][6] = 74; GBFreq[24][36] = 73; GBFreq[25][25] =
	     * 72; GBFreq[44][26] = 71; GBFreq[25][36] = 70; GBFreq[29][87] = 69; GBFreq[48][0] = 68; GBFreq[15][40] = 67;
	     * GBFreq[17][45] = 66; GBFreq[30][14] = 65; GBFreq[48][38] = 64; GBFreq[23][19] = 63; GBFreq[40][42] = 62; GBFreq[31][63] =
	     * 61; GBFreq[16][23] = 60; GBFreq[26][21] = 59; GBFreq[32][76] = 58; GBFreq[23][58] = 57; GBFreq[41][37] = 56;
	     * GBFreq[30][43] = 55; GBFreq[47][38] = 54; GBFreq[21][46] = 53; GBFreq[18][33] = 52; GBFreq[52][37] = 51; GBFreq[36][8] =
	     * 50; GBFreq[49][24] = 49; GBFreq[15][66] = 48; GBFreq[35][77] = 47; GBFreq[27][58] = 46; GBFreq[35][51] = 45;
	     * GBFreq[24][69] = 44; GBFreq[20][54] = 43; GBFreq[24][41] = 42; GBFreq[41][0] = 41; GBFreq[33][71] = 40; GBFreq[23][52] =
	     * 39; GBFreq[29][67] = 38; GBFreq[46][51] = 37; GBFreq[46][90] = 36; GBFreq[49][33] = 35; GBFreq[33][28] = 34;
	     * GBFreq[37][86] = 33; GBFreq[39][22] = 32; GBFreq[37][37] = 31; GBFreq[29][62] = 30; GBFreq[29][50] = 29; GBFreq[36][89] =
	     * 28; GBFreq[42][44] = 27; GBFreq[51][82] = 26; GBFreq[28][83] = 25; GBFreq[15][78] = 24; GBFreq[46][62] = 23;
	     * GBFreq[19][69] = 22; GBFreq[51][23] = 21; GBFreq[37][69] = 20; GBFreq[25][5] = 19; GBFreq[51][85] = 18; GBFreq[48][77] =
	     * 17; GBFreq[32][46] = 16; GBFreq[53][60] = 15; GBFreq[28][57] = 14; GBFreq[54][82] = 13; GBFreq[54][15] = 12;
	     * GBFreq[49][54] = 11; GBFreq[53][87] = 10; GBFreq[27][16] = 9; GBFreq[29][34] = 8; GBFreq[20][44] = 7; GBFreq[42][73] = 6;
	     * GBFreq[47][71] = 5; GBFreq[29][37] = 4; GBFreq[25][50] = 3; GBFreq[18][84] = 2; GBFreq[50][45] = 1; GBFreq[48][46] = 0;
	     */
	    // GBFreq[43][89] = -1; GBFreq[54][68] = -2;
	    Big5Freq[9][89] = 600;
	    Big5Freq[11][15] = 599;
	    Big5Freq[3][66] = 598;
	    Big5Freq[6][121] = 597;
	    Big5Freq[3][0] = 596;
	    Big5Freq[5][82] = 595;
	    Big5Freq[3][42] = 594;
	    Big5Freq[5][34] = 593;
	    Big5Freq[3][8] = 592;
	    Big5Freq[3][6] = 591;
	    Big5Freq[3][67] = 590;
	    Big5Freq[7][139] = 589;
	    Big5Freq[23][137] = 588;
	    Big5Freq[12][46] = 587;
	    Big5Freq[4][8] = 586;
	    Big5Freq[4][41] = 585;
	    Big5Freq[18][47] = 584;
	    Big5Freq[12][114] = 583;
	    Big5Freq[6][1] = 582;
	    Big5Freq[22][60] = 581;
	    Big5Freq[5][46] = 580;
	    Big5Freq[11][79] = 579;
	    Big5Freq[3][23] = 578;
	    Big5Freq[7][114] = 577;
	    Big5Freq[29][102] = 576;
	    Big5Freq[19][14] = 575;
	    Big5Freq[4][133] = 574;
	    Big5Freq[3][29] = 573;
	    Big5Freq[4][109] = 572;
	    Big5Freq[14][127] = 571;
	    Big5Freq[5][48] = 570;
	    Big5Freq[13][104] = 569;
	    Big5Freq[3][132] = 568;
	    Big5Freq[26][64] = 567;
	    Big5Freq[7][19] = 566;
	    Big5Freq[4][12] = 565;
	    Big5Freq[11][124] = 564;
	    Big5Freq[7][89] = 563;
	    Big5Freq[15][124] = 562;
	    Big5Freq[4][108] = 561;
	    Big5Freq[19][66] = 560;
	    Big5Freq[3][21] = 559;
	    Big5Freq[24][12] = 558;
	    Big5Freq[28][111] = 557;
	    Big5Freq[12][107] = 556;
	    Big5Freq[3][112] = 555;
	    Big5Freq[8][113] = 554;
	    Big5Freq[5][40] = 553;
	    Big5Freq[26][145] = 552;
	    Big5Freq[3][48] = 551;
	    Big5Freq[3][70] = 550;
	    Big5Freq[22][17] = 549;
	    Big5Freq[16][47] = 548;
	    Big5Freq[3][53] = 547;
	    Big5Freq[4][24] = 546;
	    Big5Freq[32][120] = 545;
	    Big5Freq[24][49] = 544;
	    Big5Freq[24][142] = 543;
	    Big5Freq[18][66] = 542;
	    Big5Freq[29][150] = 541;
	    Big5Freq[5][122] = 540;
	    Big5Freq[5][114] = 539;
	    Big5Freq[3][44] = 538;
	    Big5Freq[10][128] = 537;
	    Big5Freq[15][20] = 536;
	    Big5Freq[13][33] = 535;
	    Big5Freq[14][87] = 534;
	    Big5Freq[3][126] = 533;
	    Big5Freq[4][53] = 532;
	    Big5Freq[4][40] = 531;
	    Big5Freq[9][93] = 530;
	    Big5Freq[15][137] = 529;
	    Big5Freq[10][123] = 528;
	    Big5Freq[4][56] = 527;
	    Big5Freq[5][71] = 526;
	    Big5Freq[10][8] = 525;
	    Big5Freq[5][16] = 524;
	    Big5Freq[5][146] = 523;
	    Big5Freq[18][88] = 522;
	    Big5Freq[24][4] = 521;
	    Big5Freq[20][47] = 520;
	    Big5Freq[5][33] = 519;
	    Big5Freq[9][43] = 518;
	    Big5Freq[20][12] = 517;
	    Big5Freq[20][13] = 516;
	    Big5Freq[5][156] = 515;
	    Big5Freq[22][140] = 514;
	    Big5Freq[8][146] = 513;
	    Big5Freq[21][123] = 512;
	    Big5Freq[4][90] = 511;
	    Big5Freq[5][62] = 510;
	    Big5Freq[17][59] = 509;
	    Big5Freq[10][37] = 508;
	    Big5Freq[18][107] = 507;
	    Big5Freq[14][53] = 506;
	    Big5Freq[22][51] = 505;
	    Big5Freq[8][13] = 504;
	    Big5Freq[5][29] = 503;
	    Big5Freq[9][7] = 502;
	    Big5Freq[22][14] = 501;
	    Big5Freq[8][55] = 500;
	    Big5Freq[33][9] = 499;
	    Big5Freq[16][64] = 498;
	    Big5Freq[7][131] = 497;
	    Big5Freq[34][4] = 496;
	    Big5Freq[7][101] = 495;
	    Big5Freq[11][139] = 494;
	    Big5Freq[3][135] = 493;
	    Big5Freq[7][102] = 492;
	    Big5Freq[17][13] = 491;
	    Big5Freq[3][20] = 490;
	    Big5Freq[27][106] = 489;
	    Big5Freq[5][88] = 488;
	    Big5Freq[6][33] = 487;
	    Big5Freq[5][139] = 486;
	    Big5Freq[6][0] = 485;
	    Big5Freq[17][58] = 484;
	    Big5Freq[5][133] = 483;
	    Big5Freq[9][107] = 482;
	    Big5Freq[23][39] = 481;
	    Big5Freq[5][23] = 480;
	    Big5Freq[3][79] = 479;
	    Big5Freq[32][97] = 478;
	    Big5Freq[3][136] = 477;
	    Big5Freq[4][94] = 476;
	    Big5Freq[21][61] = 475;
	    Big5Freq[23][123] = 474;
	    Big5Freq[26][16] = 473;
	    Big5Freq[24][137] = 472;
	    Big5Freq[22][18] = 471;
	    Big5Freq[5][1] = 470;
	    Big5Freq[20][119] = 469;
	    Big5Freq[3][7] = 468;
	    Big5Freq[10][79] = 467;
	    Big5Freq[15][105] = 466;
	    Big5Freq[3][144] = 465;
	    Big5Freq[12][80] = 464;
	    Big5Freq[15][73] = 463;
	    Big5Freq[3][19] = 462;
	    Big5Freq[8][109] = 461;
	    Big5Freq[3][15] = 460;
	    Big5Freq[31][82] = 459;
	    Big5Freq[3][43] = 458;
	    Big5Freq[25][119] = 457;
	    Big5Freq[16][111] = 456;
	    Big5Freq[7][77] = 455;
	    Big5Freq[3][95] = 454;
	    Big5Freq[24][82] = 453;
	    Big5Freq[7][52] = 452;
	    Big5Freq[9][151] = 451;
	    Big5Freq[3][129] = 450;
	    Big5Freq[5][87] = 449;
	    Big5Freq[3][55] = 448;
	    Big5Freq[8][153] = 447;
	    Big5Freq[4][83] = 446;
	    Big5Freq[3][114] = 445;
	    Big5Freq[23][147] = 444;
	    Big5Freq[15][31] = 443;
	    Big5Freq[3][54] = 442;
	    Big5Freq[11][122] = 441;
	    Big5Freq[4][4] = 440;
	    Big5Freq[34][149] = 439;
	    Big5Freq[3][17] = 438;
	    Big5Freq[21][64] = 437;
	    Big5Freq[26][144] = 436;
	    Big5Freq[4][62] = 435;
	    Big5Freq[8][15] = 434;
	    Big5Freq[35][80] = 433;
	    Big5Freq[7][110] = 432;
	    Big5Freq[23][114] = 431;
	    Big5Freq[3][108] = 430;
	    Big5Freq[3][62] = 429;
	    Big5Freq[21][41] = 428;
	    Big5Freq[15][99] = 427;
	    Big5Freq[5][47] = 426;
	    Big5Freq[4][96] = 425;
	    Big5Freq[20][122] = 424;
	    Big5Freq[5][21] = 423;
	    Big5Freq[4][157] = 422;
	    Big5Freq[16][14] = 421;
	    Big5Freq[3][117] = 420;
	    Big5Freq[7][129] = 419;
	    Big5Freq[4][27] = 418;
	    Big5Freq[5][30] = 417;
	    Big5Freq[22][16] = 416;
	    Big5Freq[5][64] = 415;
	    Big5Freq[17][99] = 414;
	    Big5Freq[17][57] = 413;
	    Big5Freq[8][105] = 412;
	    Big5Freq[5][112] = 411;
	    Big5Freq[20][59] = 410;
	    Big5Freq[6][129] = 409;
	    Big5Freq[18][17] = 408;
	    Big5Freq[3][92] = 407;
	    Big5Freq[28][118] = 406;
	    Big5Freq[3][109] = 405;
	    Big5Freq[31][51] = 404;
	    Big5Freq[13][116] = 403;
	    Big5Freq[6][15] = 402;
	    Big5Freq[36][136] = 401;
	    Big5Freq[12][74] = 400;
	    Big5Freq[20][88] = 399;
	    Big5Freq[36][68] = 398;
	    Big5Freq[3][147] = 397;
	    Big5Freq[15][84] = 396;
	    Big5Freq[16][32] = 395;
	    Big5Freq[16][58] = 394;
	    Big5Freq[7][66] = 393;
	    Big5Freq[23][107] = 392;
	    Big5Freq[9][6] = 391;
	    Big5Freq[12][86] = 390;
	    Big5Freq[23][112] = 389;
	    Big5Freq[37][23] = 388;
	    Big5Freq[3][138] = 387;
	    Big5Freq[20][68] = 386;
	    Big5Freq[15][116] = 385;
	    Big5Freq[18][64] = 384;
	    Big5Freq[12][139] = 383;
	    Big5Freq[11][155] = 382;
	    Big5Freq[4][156] = 381;
	    Big5Freq[12][84] = 380;
	    Big5Freq[18][49] = 379;
	    Big5Freq[25][125] = 378;
	    Big5Freq[25][147] = 377;
	    Big5Freq[15][110] = 376;
	    Big5Freq[19][96] = 375;
	    Big5Freq[30][152] = 374;
	    Big5Freq[6][31] = 373;
	    Big5Freq[27][117] = 372;
	    Big5Freq[3][10] = 371;
	    Big5Freq[6][131] = 370;
	    Big5Freq[13][112] = 369;
	    Big5Freq[36][156] = 368;
	    Big5Freq[4][60] = 367;
	    Big5Freq[15][121] = 366;
	    Big5Freq[4][112] = 365;
	    Big5Freq[30][142] = 364;
	    Big5Freq[23][154] = 363;
	    Big5Freq[27][101] = 362;
	    Big5Freq[9][140] = 361;
	    Big5Freq[3][89] = 360;
	    Big5Freq[18][148] = 359;
	    Big5Freq[4][69] = 358;
	    Big5Freq[16][49] = 357;
	    Big5Freq[6][117] = 356;
	    Big5Freq[36][55] = 355;
	    Big5Freq[5][123] = 354;
	    Big5Freq[4][126] = 353;
	    Big5Freq[4][119] = 352;
	    Big5Freq[9][95] = 351;
	    Big5Freq[5][24] = 350;
	    Big5Freq[16][133] = 349;
	    Big5Freq[10][134] = 348;
	    Big5Freq[26][59] = 347;
	    Big5Freq[6][41] = 346;
	    Big5Freq[6][146] = 345;
	    Big5Freq[19][24] = 344;
	    Big5Freq[5][113] = 343;
	    Big5Freq[10][118] = 342;
	    Big5Freq[34][151] = 341;
	    Big5Freq[9][72] = 340;
	    Big5Freq[31][25] = 339;
	    Big5Freq[18][126] = 338;
	    Big5Freq[18][28] = 337;
	    Big5Freq[4][153] = 336;
	    Big5Freq[3][84] = 335;
	    Big5Freq[21][18] = 334;
	    Big5Freq[25][129] = 333;
	    Big5Freq[6][107] = 332;
	    Big5Freq[12][25] = 331;
	    Big5Freq[17][109] = 330;
	    Big5Freq[7][76] = 329;
	    Big5Freq[15][15] = 328;
	    Big5Freq[4][14] = 327;
	    Big5Freq[23][88] = 326;
	    Big5Freq[18][2] = 325;
	    Big5Freq[6][88] = 324;
	    Big5Freq[16][84] = 323;
	    Big5Freq[12][48] = 322;
	    Big5Freq[7][68] = 321;
	    Big5Freq[5][50] = 320;
	    Big5Freq[13][54] = 319;
	    Big5Freq[7][98] = 318;
	    Big5Freq[11][6] = 317;
	    Big5Freq[9][80] = 316;
	    Big5Freq[16][41] = 315;
	    Big5Freq[7][43] = 314;
	    Big5Freq[28][117] = 313;
	    Big5Freq[3][51] = 312;
	    Big5Freq[7][3] = 311;
	    Big5Freq[20][81] = 310;
	    Big5Freq[4][2] = 309;
	    Big5Freq[11][16] = 308;
	    Big5Freq[10][4] = 307;
	    Big5Freq[10][119] = 306;
	    Big5Freq[6][142] = 305;
	    Big5Freq[18][51] = 304;
	    Big5Freq[8][144] = 303;
	    Big5Freq[10][65] = 302;
	    Big5Freq[11][64] = 301;
	    Big5Freq[11][130] = 300;
	    Big5Freq[9][92] = 299;
	    Big5Freq[18][29] = 298;
	    Big5Freq[18][78] = 297;
	    Big5Freq[18][151] = 296;
	    Big5Freq[33][127] = 295;
	    Big5Freq[35][113] = 294;
	    Big5Freq[10][155] = 293;
	    Big5Freq[3][76] = 292;
	    Big5Freq[36][123] = 291;
	    Big5Freq[13][143] = 290;
	    Big5Freq[5][135] = 289;
	    Big5Freq[23][116] = 288;
	    Big5Freq[6][101] = 287;
	    Big5Freq[14][74] = 286;
	    Big5Freq[7][153] = 285;
	    Big5Freq[3][101] = 284;
	    Big5Freq[9][74] = 283;
	    Big5Freq[3][156] = 282;
	    Big5Freq[4][147] = 281;
	    Big5Freq[9][12] = 280;
	    Big5Freq[18][133] = 279;
	    Big5Freq[4][0] = 278;
	    Big5Freq[7][155] = 277;
	    Big5Freq[9][144] = 276;
	    Big5Freq[23][49] = 275;
	    Big5Freq[5][89] = 274;
	    Big5Freq[10][11] = 273;
	    Big5Freq[3][110] = 272;
	    Big5Freq[3][40] = 271;
	    Big5Freq[29][115] = 270;
	    Big5Freq[9][100] = 269;
	    Big5Freq[21][67] = 268;
	    Big5Freq[23][145] = 267;
	    Big5Freq[10][47] = 266;
	    Big5Freq[4][31] = 265;
	    Big5Freq[4][81] = 264;
	    Big5Freq[22][62] = 263;
	    Big5Freq[4][28] = 262;
	    Big5Freq[27][39] = 261;
	    Big5Freq[27][54] = 260;
	    Big5Freq[32][46] = 259;
	    Big5Freq[4][76] = 258;
	    Big5Freq[26][15] = 257;
	    Big5Freq[12][154] = 256;
	    Big5Freq[9][150] = 255;
	    Big5Freq[15][17] = 254;
	    Big5Freq[5][129] = 253;
	    Big5Freq[10][40] = 252;
	    Big5Freq[13][37] = 251;
	    Big5Freq[31][104] = 250;
	    Big5Freq[3][152] = 249;
	    Big5Freq[5][22] = 248;
	    Big5Freq[8][48] = 247;
	    Big5Freq[4][74] = 246;
	    Big5Freq[6][17] = 245;
	    Big5Freq[30][82] = 244;
	    Big5Freq[4][116] = 243;
	    Big5Freq[16][42] = 242;
	    Big5Freq[5][55] = 241;
	    Big5Freq[4][64] = 240;
	    Big5Freq[14][19] = 239;
	    Big5Freq[35][82] = 238;
	    Big5Freq[30][139] = 237;
	    Big5Freq[26][152] = 236;
	    Big5Freq[32][32] = 235;
	    Big5Freq[21][102] = 234;
	    Big5Freq[10][131] = 233;
	    Big5Freq[9][128] = 232;
	    Big5Freq[3][87] = 231;
	    Big5Freq[4][51] = 230;
	    Big5Freq[10][15] = 229;
	    Big5Freq[4][150] = 228;
	    Big5Freq[7][4] = 227;
	    Big5Freq[7][51] = 226;
	    Big5Freq[7][157] = 225;
	    Big5Freq[4][146] = 224;
	    Big5Freq[4][91] = 223;
	    Big5Freq[7][13] = 222;
	    Big5Freq[17][116] = 221;
	    Big5Freq[23][21] = 220;
	    Big5Freq[5][106] = 219;
	    Big5Freq[14][100] = 218;
	    Big5Freq[10][152] = 217;
	    Big5Freq[14][89] = 216;
	    Big5Freq[6][138] = 215;
	    Big5Freq[12][157] = 214;
	    Big5Freq[10][102] = 213;
	    Big5Freq[19][94] = 212;
	    Big5Freq[7][74] = 211;
	    Big5Freq[18][128] = 210;
	    Big5Freq[27][111] = 209;
	    Big5Freq[11][57] = 208;
	    Big5Freq[3][131] = 207;
	    Big5Freq[30][23] = 206;
	    Big5Freq[30][126] = 205;
	    Big5Freq[4][36] = 204;
	    Big5Freq[26][124] = 203;
	    Big5Freq[4][19] = 202;
	    Big5Freq[9][152] = 201;
	    /*
	     * Big5Freq[5][0] = 200; Big5Freq[26][57] = 199; Big5Freq[13][155] = 198; Big5Freq[3][38] = 197; Big5Freq[9][155] = 196;
	     * Big5Freq[28][53] = 195; Big5Freq[15][71] = 194; Big5Freq[21][95] = 193; Big5Freq[15][112] = 192; Big5Freq[14][138] = 191;
	     * Big5Freq[8][18] = 190; Big5Freq[20][151] = 189; Big5Freq[37][27] = 188; Big5Freq[32][48] = 187; Big5Freq[23][66] = 186;
	     * Big5Freq[9][2] = 185; Big5Freq[13][133] = 184; Big5Freq[7][127] = 183; Big5Freq[3][11] = 182; Big5Freq[12][118] = 181;
	     * Big5Freq[13][101] = 180; Big5Freq[30][153] = 179; Big5Freq[4][65] = 178; Big5Freq[5][25] = 177; Big5Freq[5][140] = 176;
	     * Big5Freq[6][25] = 175; Big5Freq[4][52] = 174; Big5Freq[30][156] = 173; Big5Freq[16][13] = 172; Big5Freq[21][8] = 171;
	     * Big5Freq[19][74] = 170; Big5Freq[15][145] = 169; Big5Freq[9][15] = 168; Big5Freq[13][82] = 167; Big5Freq[26][86] = 166;
	     * Big5Freq[18][52] = 165; Big5Freq[6][109] = 164; Big5Freq[10][99] = 163; Big5Freq[18][101] = 162; Big5Freq[25][49] = 161;
	     * Big5Freq[31][79] = 160; Big5Freq[28][20] = 159; Big5Freq[12][115] = 158; Big5Freq[15][66] = 157; Big5Freq[11][104] = 156;
	     * Big5Freq[23][106] = 155; Big5Freq[34][157] = 154; Big5Freq[32][94] = 153; Big5Freq[29][88] = 152; Big5Freq[10][46] = 151;
	     * Big5Freq[13][118] = 150; Big5Freq[20][37] = 149; Big5Freq[12][30] = 148; Big5Freq[21][4] = 147; Big5Freq[16][33] = 146;
	     * Big5Freq[13][52] = 145; Big5Freq[4][7] = 144; Big5Freq[21][49] = 143; Big5Freq[3][27] = 142; Big5Freq[16][91] = 141;
	     * Big5Freq[5][155] = 140; Big5Freq[29][130] = 139; Big5Freq[3][125] = 138; Big5Freq[14][26] = 137; Big5Freq[15][39] = 136;
	     * Big5Freq[24][110] = 135; Big5Freq[7][141] = 134; Big5Freq[21][15] = 133; Big5Freq[32][104] = 132; Big5Freq[8][31] = 131;
	     * Big5Freq[34][112] = 130; Big5Freq[10][75] = 129; Big5Freq[21][23] = 128; Big5Freq[34][131] = 127; Big5Freq[12][3] = 126;
	     * Big5Freq[10][62] = 125; Big5Freq[9][120] = 124; Big5Freq[32][149] = 123; Big5Freq[8][44] = 122; Big5Freq[24][2] = 121;
	     * Big5Freq[6][148] = 120; Big5Freq[15][103] = 119; Big5Freq[36][54] = 118; Big5Freq[36][134] = 117; Big5Freq[11][7] = 116;
	     * Big5Freq[3][90] = 115; Big5Freq[36][73] = 114; Big5Freq[8][102] = 113; Big5Freq[12][87] = 112; Big5Freq[25][64] = 111;
	     * Big5Freq[9][1] = 110; Big5Freq[24][121] = 109; Big5Freq[5][75] = 108; Big5Freq[17][83] = 107; Big5Freq[18][57] = 106;
	     * Big5Freq[8][95] = 105; Big5Freq[14][36] = 104; Big5Freq[28][113] = 103; Big5Freq[12][56] = 102; Big5Freq[14][61] = 101;
	     * Big5Freq[25][138] = 100; Big5Freq[4][34] = 99; Big5Freq[11][152] = 98; Big5Freq[35][0] = 97; Big5Freq[4][15] = 96;
	     * Big5Freq[8][82] = 95; Big5Freq[20][73] = 94; Big5Freq[25][52] = 93; Big5Freq[24][6] = 92; Big5Freq[21][78] = 91;
	     * Big5Freq[17][32] = 90; Big5Freq[17][91] = 89; Big5Freq[5][76] = 88; Big5Freq[15][60] = 87; Big5Freq[15][150] = 86;
	     * Big5Freq[5][80] = 85; Big5Freq[15][81] = 84; Big5Freq[28][108] = 83; Big5Freq[18][14] = 82; Big5Freq[19][109] = 81;
	     * Big5Freq[28][133] = 80; Big5Freq[21][97] = 79; Big5Freq[5][105] = 78; Big5Freq[18][114] = 77; Big5Freq[16][95] = 76;
	     * Big5Freq[5][51] = 75; Big5Freq[3][148] = 74; Big5Freq[22][102] = 73; Big5Freq[4][123] = 72; Big5Freq[8][88] = 71;
	     * Big5Freq[25][111] = 70; Big5Freq[8][149] = 69; Big5Freq[9][48] = 68; Big5Freq[16][126] = 67; Big5Freq[33][150] = 66;
	     * Big5Freq[9][54] = 65; Big5Freq[29][104] = 64; Big5Freq[3][3] = 63; Big5Freq[11][49] = 62; Big5Freq[24][109] = 61;
	     * Big5Freq[28][116] = 60; Big5Freq[34][113] = 59; Big5Freq[5][3] = 58; Big5Freq[21][106] = 57; Big5Freq[4][98] = 56;
	     * Big5Freq[12][135] = 55; Big5Freq[16][101] = 54; Big5Freq[12][147] = 53; Big5Freq[27][55] = 52; Big5Freq[3][5] = 51;
	     * Big5Freq[11][101] = 50; Big5Freq[16][157] = 49; Big5Freq[22][114] = 48; Big5Freq[18][46] = 47; Big5Freq[4][29] = 46;
	     * Big5Freq[8][103] = 45; Big5Freq[16][151] = 44; Big5Freq[8][29] = 43; Big5Freq[15][114] = 42; Big5Freq[22][70] = 41;
	     * Big5Freq[13][121] = 40; Big5Freq[7][112] = 39; Big5Freq[20][83] = 38; Big5Freq[3][36] = 37; Big5Freq[10][103] = 36;
	     * Big5Freq[3][96] = 35; Big5Freq[21][79] = 34; Big5Freq[25][120] = 33; Big5Freq[29][121] = 32; Big5Freq[23][71] = 31;
	     * Big5Freq[21][22] = 30; Big5Freq[18][89] = 29; Big5Freq[25][104] = 28; Big5Freq[10][124] = 27; Big5Freq[26][4] = 26;
	     * Big5Freq[21][136] = 25; Big5Freq[6][112] = 24; Big5Freq[12][103] = 23; Big5Freq[17][66] = 22; Big5Freq[13][151] = 21;
	     * Big5Freq[33][152] = 20; Big5Freq[11][148] = 19; Big5Freq[13][57] = 18; Big5Freq[13][41] = 17; Big5Freq[7][60] = 16;
	     * Big5Freq[21][29] = 15; Big5Freq[9][157] = 14; Big5Freq[24][95] = 13; Big5Freq[15][148] = 12; Big5Freq[15][122] = 11;
	     * Big5Freq[6][125] = 10; Big5Freq[11][25] = 9; Big5Freq[20][55] = 8; Big5Freq[19][84] = 7; Big5Freq[21][82] = 6;
	     * Big5Freq[24][3] = 5; Big5Freq[13][70] = 4; Big5Freq[6][21] = 3; Big5Freq[21][86] = 2; Big5Freq[12][23] = 1;
	     * Big5Freq[3][85] = 0; EUC_TWFreq[45][90] = 600;
	     */
	    Big5PFreq[41][122] = 600;
	    Big5PFreq[35][0] = 599;
	    Big5PFreq[43][15] = 598;
	    Big5PFreq[35][99] = 597;
	    Big5PFreq[35][6] = 596;
	    Big5PFreq[35][8] = 595;
	    Big5PFreq[38][154] = 594;
	    Big5PFreq[37][34] = 593;
	    Big5PFreq[37][115] = 592;
	    Big5PFreq[36][12] = 591;
	    Big5PFreq[18][77] = 590;
	    Big5PFreq[35][100] = 589;
	    Big5PFreq[35][42] = 588;
	    Big5PFreq[120][75] = 587;
	    Big5PFreq[35][23] = 586;
	    Big5PFreq[13][72] = 585;
	    Big5PFreq[0][67] = 584;
	    Big5PFreq[39][172] = 583;
	    Big5PFreq[22][182] = 582;
	    Big5PFreq[15][186] = 581;
	    Big5PFreq[15][165] = 580;
	    Big5PFreq[35][44] = 579;
	    Big5PFreq[40][13] = 578;
	    Big5PFreq[38][1] = 577;
	    Big5PFreq[37][33] = 576;
	    Big5PFreq[36][24] = 575;
	    Big5PFreq[56][4] = 574;
	    Big5PFreq[35][29] = 573;
	    Big5PFreq[9][96] = 572;
	    Big5PFreq[37][62] = 571;
	    Big5PFreq[48][47] = 570;
	    Big5PFreq[51][14] = 569;
	    Big5PFreq[39][122] = 568;
	    Big5PFreq[44][46] = 567;
	    Big5PFreq[35][21] = 566;
	    Big5PFreq[36][8] = 565;
	    Big5PFreq[36][141] = 564;
	    Big5PFreq[3][81] = 563;
	    Big5PFreq[37][155] = 562;
	    Big5PFreq[42][84] = 561;
	    Big5PFreq[36][40] = 560;
	    Big5PFreq[35][103] = 559;
	    Big5PFreq[11][84] = 558;
	    Big5PFreq[45][33] = 557;
	    Big5PFreq[121][79] = 556;
	    Big5PFreq[2][77] = 555;
	    Big5PFreq[36][41] = 554;
	    Big5PFreq[37][47] = 553;
	    Big5PFreq[39][125] = 552;
	    Big5PFreq[37][26] = 551;
	    Big5PFreq[35][48] = 550;
	    Big5PFreq[35][28] = 549;
	    Big5PFreq[35][159] = 548;
	    Big5PFreq[37][40] = 547;
	    Big5PFreq[35][145] = 546;
	    Big5PFreq[37][147] = 545;
	    Big5PFreq[46][160] = 544;
	    Big5PFreq[37][46] = 543;
	    Big5PFreq[50][99] = 542;
	    Big5PFreq[52][13] = 541;
	    Big5PFreq[10][82] = 540;
	    Big5PFreq[35][169] = 539;
	    Big5PFreq[35][31] = 538;
	    Big5PFreq[47][31] = 537;
	    Big5PFreq[18][79] = 536;
	    Big5PFreq[16][113] = 535;
	    Big5PFreq[37][104] = 534;
	    Big5PFreq[39][134] = 533;
	    Big5PFreq[36][53] = 532;
	    Big5PFreq[38][0] = 531;
	    Big5PFreq[4][86] = 530;
	    Big5PFreq[54][17] = 529;
	    Big5PFreq[43][157] = 528;
	    Big5PFreq[35][165] = 527;
	    Big5PFreq[69][147] = 526;
	    Big5PFreq[117][95] = 525;
	    Big5PFreq[35][162] = 524;
	    Big5PFreq[35][17] = 523;
	    Big5PFreq[36][142] = 522;
	    Big5PFreq[36][4] = 521;
	    Big5PFreq[37][166] = 520;
	    Big5PFreq[35][168] = 519;
	    Big5PFreq[35][19] = 518;
	    Big5PFreq[37][48] = 517;
	    Big5PFreq[42][37] = 516;
	    Big5PFreq[40][146] = 515;
	    Big5PFreq[36][123] = 514;
	    Big5PFreq[22][41] = 513;
	    Big5PFreq[20][119] = 512;
	    Big5PFreq[2][74] = 511;
	    Big5PFreq[44][113] = 510;
	    Big5PFreq[35][125] = 509;
	    Big5PFreq[37][16] = 508;
	    Big5PFreq[35][20] = 507;
	    Big5PFreq[35][55] = 506;
	    Big5PFreq[37][145] = 505;
	    Big5PFreq[0][88] = 504;
	    Big5PFreq[3][94] = 503;
	    Big5PFreq[6][65] = 502;
	    Big5PFreq[26][15] = 501;
	    Big5PFreq[41][126] = 500;
	    Big5PFreq[36][129] = 499;
	    Big5PFreq[31][75] = 498;
	    Big5PFreq[19][61] = 497;
	    Big5PFreq[35][128] = 496;
	    Big5PFreq[29][79] = 495;
	    Big5PFreq[36][62] = 494;
	    Big5PFreq[37][189] = 493;
	    Big5PFreq[39][109] = 492;
	    Big5PFreq[39][135] = 491;
	    Big5PFreq[72][15] = 490;
	    Big5PFreq[47][106] = 489;
	    Big5PFreq[54][14] = 488;
	    Big5PFreq[24][52] = 487;
	    Big5PFreq[38][162] = 486;
	    Big5PFreq[41][43] = 485;
	    Big5PFreq[37][121] = 484;
	    Big5PFreq[14][66] = 483;
	    Big5PFreq[37][30] = 482;
	    Big5PFreq[35][7] = 481;
	    Big5PFreq[49][58] = 480;
	    Big5PFreq[43][188] = 479;
	    Big5PFreq[24][66] = 478;
	    Big5PFreq[35][171] = 477;
	    Big5PFreq[40][186] = 476;
	    Big5PFreq[39][164] = 475;
	    Big5PFreq[78][186] = 474;
	    Big5PFreq[8][72] = 473;
	    Big5PFreq[36][190] = 472;
	    Big5PFreq[35][53] = 471;
	    Big5PFreq[35][54] = 470;
	    Big5PFreq[22][159] = 469;
	    Big5PFreq[35][9] = 468;
	    Big5PFreq[41][140] = 467;
	    Big5PFreq[37][22] = 466;
	    Big5PFreq[48][97] = 465;
	    Big5PFreq[50][97] = 464;
	    Big5PFreq[36][127] = 463;
	    Big5PFreq[37][23] = 462;
	    Big5PFreq[40][55] = 461;
	    Big5PFreq[35][43] = 460;
	    Big5PFreq[26][22] = 459;
	    Big5PFreq[35][15] = 458;
	    Big5PFreq[72][179] = 457;
	    Big5PFreq[20][129] = 456;
	    Big5PFreq[52][101] = 455;
	    Big5PFreq[35][12] = 454;
	    Big5PFreq[42][156] = 453;
	    Big5PFreq[15][157] = 452;
	    Big5PFreq[50][140] = 451;
	    Big5PFreq[26][28] = 450;
	    Big5PFreq[54][51] = 449;
	    Big5PFreq[35][112] = 448;
	    Big5PFreq[36][116] = 447;
	    Big5PFreq[42][11] = 446;
	    Big5PFreq[37][172] = 445;
	    Big5PFreq[37][29] = 444;
	    Big5PFreq[44][107] = 443;
	    Big5PFreq[50][17] = 442;
	    Big5PFreq[39][107] = 441;
	    Big5PFreq[19][109] = 440;
	    Big5PFreq[36][60] = 439;
	    Big5PFreq[49][132] = 438;
	    Big5PFreq[26][16] = 437;
	    Big5PFreq[43][155] = 436;
	    Big5PFreq[37][120] = 435;
	    Big5PFreq[15][159] = 434;
	    Big5PFreq[43][6] = 433;
	    Big5PFreq[45][188] = 432;
	    Big5PFreq[35][38] = 431;
	    Big5PFreq[39][143] = 430;
	    Big5PFreq[48][144] = 429;
	    Big5PFreq[37][168] = 428;
	    Big5PFreq[37][1] = 427;
	    Big5PFreq[36][109] = 426;
	    Big5PFreq[46][53] = 425;
	    Big5PFreq[38][54] = 424;
	    Big5PFreq[36][0] = 423;
	    Big5PFreq[72][33] = 422;
	    Big5PFreq[42][8] = 421;
	    Big5PFreq[36][31] = 420;
	    Big5PFreq[35][150] = 419;
	    Big5PFreq[118][93] = 418;
	    Big5PFreq[37][61] = 417;
	    Big5PFreq[0][85] = 416;
	    Big5PFreq[36][27] = 415;
	    Big5PFreq[35][134] = 414;
	    Big5PFreq[36][145] = 413;
	    Big5PFreq[6][96] = 412;
	    Big5PFreq[36][14] = 411;
	    Big5PFreq[16][36] = 410;
	    Big5PFreq[15][175] = 409;
	    Big5PFreq[35][10] = 408;
	    Big5PFreq[36][189] = 407;
	    Big5PFreq[35][51] = 406;
	    Big5PFreq[35][109] = 405;
	    Big5PFreq[35][147] = 404;
	    Big5PFreq[35][180] = 403;
	    Big5PFreq[72][5] = 402;
	    Big5PFreq[36][107] = 401;
	    Big5PFreq[49][116] = 400;
	    Big5PFreq[73][30] = 399;
	    Big5PFreq[6][90] = 398;
	    Big5PFreq[2][70] = 397;
	    Big5PFreq[17][141] = 396;
	    Big5PFreq[35][62] = 395;
	    Big5PFreq[16][180] = 394;
	    Big5PFreq[4][91] = 393;
	    Big5PFreq[15][171] = 392;
	    Big5PFreq[35][177] = 391;
	    Big5PFreq[37][173] = 390;
	    Big5PFreq[16][121] = 389;
	    Big5PFreq[35][5] = 388;
	    Big5PFreq[46][122] = 387;
	    Big5PFreq[40][138] = 386;
	    Big5PFreq[50][49] = 385;
	    Big5PFreq[36][152] = 384;
	    Big5PFreq[13][43] = 383;
	    Big5PFreq[9][88] = 382;
	    Big5PFreq[36][159] = 381;
	    Big5PFreq[27][62] = 380;
	    Big5PFreq[40][18] = 379;
	    Big5PFreq[17][129] = 378;
	    Big5PFreq[43][97] = 377;
	    Big5PFreq[13][131] = 376;
	    Big5PFreq[46][107] = 375;
	    Big5PFreq[60][64] = 374;
	    Big5PFreq[36][179] = 373;
	    Big5PFreq[37][55] = 372;
	    Big5PFreq[41][173] = 371;
	    Big5PFreq[44][172] = 370;
	    Big5PFreq[23][187] = 369;
	    Big5PFreq[36][149] = 368;
	    Big5PFreq[17][125] = 367;
	    Big5PFreq[55][180] = 366;
	    Big5PFreq[51][129] = 365;
	    Big5PFreq[36][51] = 364;
	    Big5PFreq[37][122] = 363;
	    Big5PFreq[48][32] = 362;
	    Big5PFreq[51][99] = 361;
	    Big5PFreq[54][16] = 360;
	    Big5PFreq[41][183] = 359;
	    Big5PFreq[37][179] = 358;
	    Big5PFreq[38][179] = 357;
	    Big5PFreq[35][143] = 356;
	    Big5PFreq[37][24] = 355;
	    Big5PFreq[40][177] = 354;
	    Big5PFreq[47][117] = 353;
	    Big5PFreq[39][52] = 352;
	    Big5PFreq[22][99] = 351;
	    Big5PFreq[40][142] = 350;
	    Big5PFreq[36][49] = 349;
	    Big5PFreq[38][17] = 348;
	    Big5PFreq[39][188] = 347;
	    Big5PFreq[36][186] = 346;
	    Big5PFreq[35][189] = 345;
	    Big5PFreq[41][7] = 344;
	    Big5PFreq[18][91] = 343;
	    Big5PFreq[43][137] = 342;
	    Big5PFreq[35][142] = 341;
	    Big5PFreq[35][117] = 340;
	    Big5PFreq[39][138] = 339;
	    Big5PFreq[16][59] = 338;
	    Big5PFreq[39][174] = 337;
	    Big5PFreq[55][145] = 336;
	    Big5PFreq[37][21] = 335;
	    Big5PFreq[36][180] = 334;
	    Big5PFreq[37][156] = 333;
	    Big5PFreq[49][13] = 332;
	    Big5PFreq[41][107] = 331;
	    Big5PFreq[36][56] = 330;
	    Big5PFreq[53][8] = 329;
	    Big5PFreq[22][114] = 328;
	    Big5PFreq[5][95] = 327;
	    Big5PFreq[37][0] = 326;
	    Big5PFreq[26][183] = 325;
	    Big5PFreq[22][66] = 324;
	    Big5PFreq[35][58] = 323;
	    Big5PFreq[48][117] = 322;
	    Big5PFreq[36][102] = 321;
	    Big5PFreq[22][122] = 320;
	    Big5PFreq[35][11] = 319;
	    Big5PFreq[46][19] = 318;
	    Big5PFreq[22][49] = 317;
	    Big5PFreq[48][166] = 316;
	    Big5PFreq[41][125] = 315;
	    Big5PFreq[41][1] = 314;
	    Big5PFreq[35][178] = 313;
	    Big5PFreq[41][12] = 312;
	    Big5PFreq[26][167] = 311;
	    Big5PFreq[42][152] = 310;
	    Big5PFreq[42][46] = 309;
	    Big5PFreq[42][151] = 308;
	    Big5PFreq[20][135] = 307;
	    Big5PFreq[37][162] = 306;
	    Big5PFreq[37][50] = 305;
	    Big5PFreq[22][185] = 304;
	    Big5PFreq[36][166] = 303;
	    Big5PFreq[19][40] = 302;
	    Big5PFreq[22][107] = 301;
	    Big5PFreq[22][102] = 300;
	    Big5PFreq[57][162] = 299;
	    Big5PFreq[22][124] = 298;
	    Big5PFreq[37][138] = 297;
	    Big5PFreq[37][25] = 296;
	    Big5PFreq[0][69] = 295;
	    Big5PFreq[43][172] = 294;
	    Big5PFreq[42][167] = 293;
	    Big5PFreq[35][120] = 292;
	    Big5PFreq[41][128] = 291;
	    Big5PFreq[2][88] = 290;
	    Big5PFreq[20][123] = 289;
	    Big5PFreq[35][123] = 288;
	    Big5PFreq[36][28] = 287;
	    Big5PFreq[42][188] = 286;
	    Big5PFreq[42][164] = 285;
	    Big5PFreq[42][4] = 284;
	    Big5PFreq[43][57] = 283;
	    Big5PFreq[39][3] = 282;
	    Big5PFreq[42][3] = 281;
	    Big5PFreq[57][158] = 280;
	    Big5PFreq[35][146] = 279;
	    Big5PFreq[24][54] = 278;
	    Big5PFreq[13][110] = 277;
	    Big5PFreq[23][132] = 276;
	    Big5PFreq[26][102] = 275;
	    Big5PFreq[55][178] = 274;
	    Big5PFreq[17][117] = 273;
	    Big5PFreq[41][161] = 272;
	    Big5PFreq[38][150] = 271;
	    Big5PFreq[10][71] = 270;
	    Big5PFreq[47][60] = 269;
	    Big5PFreq[16][114] = 268;
	    Big5PFreq[21][47] = 267;
	    Big5PFreq[39][101] = 266;
	    Big5PFreq[18][45] = 265;
	    Big5PFreq[40][121] = 264;
	    Big5PFreq[45][41] = 263;
	    Big5PFreq[22][167] = 262;
	    Big5PFreq[26][149] = 261;
	    Big5PFreq[15][189] = 260;
	    Big5PFreq[41][177] = 259;
	    Big5PFreq[46][36] = 258;
	    Big5PFreq[20][40] = 257;
	    Big5PFreq[41][54] = 256;
	    Big5PFreq[3][87] = 255;
	    Big5PFreq[40][16] = 254;
	    Big5PFreq[42][15] = 253;
	    Big5PFreq[11][83] = 252;
	    Big5PFreq[0][94] = 251;
	    Big5PFreq[122][81] = 250;
	    Big5PFreq[41][26] = 249;
	    Big5PFreq[36][34] = 248;
	    Big5PFreq[44][148] = 247;
	    Big5PFreq[35][3] = 246;
	    Big5PFreq[36][114] = 245;
	    Big5PFreq[42][112] = 244;
	    Big5PFreq[35][183] = 243;
	    Big5PFreq[49][73] = 242;
	    Big5PFreq[39][2] = 241;
	    Big5PFreq[38][121] = 240;
	    Big5PFreq[44][114] = 239;
	    Big5PFreq[49][32] = 238;
	    Big5PFreq[1][65] = 237;
	    Big5PFreq[38][25] = 236;
	    Big5PFreq[39][4] = 235;
	    Big5PFreq[42][62] = 234;
	    Big5PFreq[35][40] = 233;
	    Big5PFreq[24][2] = 232;
	    Big5PFreq[53][49] = 231;
	    Big5PFreq[41][133] = 230;
	    Big5PFreq[43][134] = 229;
	    Big5PFreq[3][83] = 228;
	    Big5PFreq[38][158] = 227;
	    Big5PFreq[24][17] = 226;
	    Big5PFreq[52][59] = 225;
	    Big5PFreq[38][41] = 224;
	    Big5PFreq[37][127] = 223;
	    Big5PFreq[22][175] = 222;
	    Big5PFreq[44][30] = 221;
	    Big5PFreq[47][178] = 220;
	    Big5PFreq[43][99] = 219;
	    Big5PFreq[19][4] = 218;
	    Big5PFreq[37][97] = 217;
	    Big5PFreq[38][181] = 216;
	    Big5PFreq[45][103] = 215;
	    Big5PFreq[1][86] = 214;
	    Big5PFreq[40][15] = 213;
	    Big5PFreq[22][136] = 212;
	    Big5PFreq[75][165] = 211;
	    Big5PFreq[36][15] = 210;
	    Big5PFreq[46][80] = 209;
	    Big5PFreq[59][55] = 208;
	    Big5PFreq[37][108] = 207;
	    Big5PFreq[21][109] = 206;
	    Big5PFreq[24][165] = 205;
	    Big5PFreq[79][158] = 204;
	    Big5PFreq[44][139] = 203;
	    Big5PFreq[36][124] = 202;
	    Big5PFreq[42][185] = 201;
	    Big5PFreq[39][186] = 200;
	    Big5PFreq[22][128] = 199;
	    Big5PFreq[40][44] = 198;
	    Big5PFreq[41][105] = 197;
	    Big5PFreq[1][70] = 196;
	    Big5PFreq[1][68] = 195;
	    Big5PFreq[53][22] = 194;
	    Big5PFreq[36][54] = 193;
	    Big5PFreq[47][147] = 192;
	    Big5PFreq[35][36] = 191;
	    Big5PFreq[35][185] = 190;
	    Big5PFreq[45][37] = 189;
	    Big5PFreq[43][163] = 188;
	    Big5PFreq[56][115] = 187;
	    Big5PFreq[38][164] = 186;
	    Big5PFreq[35][141] = 185;
	    Big5PFreq[42][132] = 184;
	    Big5PFreq[46][120] = 183;
	    Big5PFreq[69][142] = 182;
	    Big5PFreq[38][175] = 181;
	    Big5PFreq[22][112] = 180;
	    Big5PFreq[38][142] = 179;
	    Big5PFreq[40][37] = 178;
	    Big5PFreq[37][109] = 177;
	    Big5PFreq[40][144] = 176;
	    Big5PFreq[44][117] = 175;
	    Big5PFreq[35][181] = 174;
	    Big5PFreq[26][105] = 173;
	    Big5PFreq[16][48] = 172;
	    Big5PFreq[44][122] = 171;
	    Big5PFreq[12][86] = 170;
	    Big5PFreq[84][53] = 169;
	    Big5PFreq[17][44] = 168;
	    Big5PFreq[59][54] = 167;
	    Big5PFreq[36][98] = 166;
	    Big5PFreq[45][115] = 165;
	    Big5PFreq[73][9] = 164;
	    Big5PFreq[44][123] = 163;
	    Big5PFreq[37][188] = 162;
	    Big5PFreq[51][117] = 161;
	    Big5PFreq[15][156] = 160;
	    Big5PFreq[36][155] = 159;
	    Big5PFreq[44][25] = 158;
	    Big5PFreq[38][12] = 157;
	    Big5PFreq[38][140] = 156;
	    Big5PFreq[23][4] = 155;
	    Big5PFreq[45][149] = 154;
	    Big5PFreq[22][189] = 153;
	    Big5PFreq[38][147] = 152;
	    Big5PFreq[27][5] = 151;
	    Big5PFreq[22][42] = 150;
	    Big5PFreq[3][68] = 149;
	    Big5PFreq[39][51] = 148;
	    Big5PFreq[36][29] = 147;
	    Big5PFreq[20][108] = 146;
	    Big5PFreq[50][57] = 145;
	    Big5PFreq[55][104] = 144;
	    Big5PFreq[22][46] = 143;
	    Big5PFreq[18][164] = 142;
	    Big5PFreq[50][159] = 141;
	    Big5PFreq[85][131] = 140;
	    Big5PFreq[26][79] = 139;
	    Big5PFreq[38][100] = 138;
	    Big5PFreq[53][112] = 137;
	    Big5PFreq[20][190] = 136;
	    Big5PFreq[14][69] = 135;
	    Big5PFreq[23][11] = 134;
	    Big5PFreq[40][114] = 133;
	    Big5PFreq[40][148] = 132;
	    Big5PFreq[53][130] = 131;
	    Big5PFreq[36][2] = 130;
	    Big5PFreq[66][82] = 129;
	    Big5PFreq[45][166] = 128;
	    Big5PFreq[4][88] = 127;
	    Big5PFreq[16][57] = 126;
	    Big5PFreq[22][116] = 125;
	    Big5PFreq[36][108] = 124;
	    Big5PFreq[13][48] = 123;
	    Big5PFreq[54][12] = 122;
	    Big5PFreq[40][136] = 121;
	    Big5PFreq[36][128] = 120;
	    Big5PFreq[23][6] = 119;
	    Big5PFreq[38][125] = 118;
	    Big5PFreq[45][154] = 117;
	    Big5PFreq[51][127] = 116;
	    Big5PFreq[44][163] = 115;
	    Big5PFreq[16][173] = 114;
	    Big5PFreq[43][49] = 113;
	    Big5PFreq[20][112] = 112;
	    Big5PFreq[15][168] = 111;
	    Big5PFreq[35][129] = 110;
	    Big5PFreq[20][45] = 109;
	    Big5PFreq[38][10] = 108;
	    Big5PFreq[57][171] = 107;
	    Big5PFreq[44][190] = 106;
	    Big5PFreq[40][56] = 105;
	    Big5PFreq[36][156] = 104;
	    Big5PFreq[3][88] = 103;
	    Big5PFreq[50][122] = 102;
	    Big5PFreq[36][7] = 101;
	    Big5PFreq[39][43] = 100;
	    Big5PFreq[15][166] = 99;
	    Big5PFreq[42][136] = 98;
	    Big5PFreq[22][131] = 97;
	    Big5PFreq[44][23] = 96;
	    Big5PFreq[54][147] = 95;
	    Big5PFreq[41][32] = 94;
	    Big5PFreq[23][121] = 93;
	    Big5PFreq[39][108] = 92;
	    Big5PFreq[2][78] = 91;
	    Big5PFreq[40][155] = 90;
	    Big5PFreq[55][51] = 89;
	    Big5PFreq[19][34] = 88;
	    Big5PFreq[48][128] = 87;
	    Big5PFreq[48][159] = 86;
	    Big5PFreq[20][70] = 85;
	    Big5PFreq[34][71] = 84;
	    Big5PFreq[16][31] = 83;
	    Big5PFreq[42][157] = 82;
	    Big5PFreq[20][44] = 81;
	    Big5PFreq[11][92] = 80;
	    Big5PFreq[44][180] = 79;
	    Big5PFreq[84][33] = 78;
	    Big5PFreq[16][116] = 77;
	    Big5PFreq[61][163] = 76;
	    Big5PFreq[35][164] = 75;
	    Big5PFreq[36][42] = 74;
	    Big5PFreq[13][40] = 73;
	    Big5PFreq[43][176] = 72;
	    Big5PFreq[2][66] = 71;
	    Big5PFreq[20][133] = 70;
	    Big5PFreq[36][65] = 69;
	    Big5PFreq[38][33] = 68;
	    Big5PFreq[12][91] = 67;
	    Big5PFreq[36][26] = 66;
	    Big5PFreq[15][174] = 65;
	    Big5PFreq[77][32] = 64;
	    Big5PFreq[16][1] = 63;
	    Big5PFreq[25][86] = 62;
	    Big5PFreq[17][13] = 61;
	    Big5PFreq[5][75] = 60;
	    Big5PFreq[36][52] = 59;
	    Big5PFreq[51][164] = 58;
	    Big5PFreq[12][85] = 57;
	    Big5PFreq[39][168] = 56;
	    Big5PFreq[43][16] = 55;
	    Big5PFreq[40][69] = 54;
	    Big5PFreq[26][108] = 53;
	    Big5PFreq[51][56] = 52;
	    Big5PFreq[16][37] = 51;
	    Big5PFreq[40][29] = 50;
	    Big5PFreq[46][171] = 49;
	    Big5PFreq[40][128] = 48;
	    Big5PFreq[72][114] = 47;
	    Big5PFreq[21][103] = 46;
	    Big5PFreq[22][44] = 45;
	    Big5PFreq[40][115] = 44;
	    Big5PFreq[43][7] = 43;
	    Big5PFreq[43][153] = 42;
	    Big5PFreq[17][20] = 41;
	    Big5PFreq[16][49] = 40;
	    Big5PFreq[36][57] = 39;
	    Big5PFreq[18][38] = 38;
	    Big5PFreq[45][184] = 37;
	    Big5PFreq[37][167] = 36;
	    Big5PFreq[26][106] = 35;
	    Big5PFreq[61][121] = 34;
	    Big5PFreq[89][140] = 33;
	    Big5PFreq[46][61] = 32;
	    Big5PFreq[39][163] = 31;
	    Big5PFreq[40][62] = 30;
	    Big5PFreq[38][165] = 29;
	    Big5PFreq[47][37] = 28;
	    Big5PFreq[18][155] = 27;
	    Big5PFreq[20][33] = 26;
	    Big5PFreq[29][90] = 25;
	    Big5PFreq[20][103] = 24;
	    Big5PFreq[37][51] = 23;
	    Big5PFreq[57][0] = 22;
	    Big5PFreq[40][31] = 21;
	    Big5PFreq[45][32] = 20;
	    Big5PFreq[59][23] = 19;
	    Big5PFreq[18][47] = 18;
	    Big5PFreq[45][134] = 17;
	    Big5PFreq[37][59] = 16;
	    Big5PFreq[21][128] = 15;
	    Big5PFreq[36][106] = 14;
	    Big5PFreq[31][39] = 13;
	    Big5PFreq[40][182] = 12;
	    Big5PFreq[52][155] = 11;
	    Big5PFreq[42][166] = 10;
	    Big5PFreq[35][27] = 9;
	    Big5PFreq[38][3] = 8;
	    Big5PFreq[13][44] = 7;
	    Big5PFreq[58][157] = 6;
	    Big5PFreq[47][51] = 5;
	    Big5PFreq[41][37] = 4;
	    Big5PFreq[41][172] = 3;
	    Big5PFreq[51][165] = 2;
	    Big5PFreq[15][161] = 1;
	    Big5PFreq[24][181] = 0;
	    EUC_TWFreq[48][49] = 599;
	    EUC_TWFreq[35][65] = 598;
	    EUC_TWFreq[41][27] = 597;
	    EUC_TWFreq[35][0] = 596;
	    EUC_TWFreq[39][19] = 595;
	    EUC_TWFreq[35][42] = 594;
	    EUC_TWFreq[38][66] = 593;
	    EUC_TWFreq[35][8] = 592;
	    EUC_TWFreq[35][6] = 591;
	    EUC_TWFreq[35][66] = 590;
	    EUC_TWFreq[43][14] = 589;
	    EUC_TWFreq[69][80] = 588;
	    EUC_TWFreq[50][48] = 587;
	    EUC_TWFreq[36][71] = 586;
	    EUC_TWFreq[37][10] = 585;
	    EUC_TWFreq[60][52] = 584;
	    EUC_TWFreq[51][21] = 583;
	    EUC_TWFreq[40][2] = 582;
	    EUC_TWFreq[67][35] = 581;
	    EUC_TWFreq[38][78] = 580;
	    EUC_TWFreq[49][18] = 579;
	    EUC_TWFreq[35][23] = 578;
	    EUC_TWFreq[42][83] = 577;
	    EUC_TWFreq[79][47] = 576;
	    EUC_TWFreq[61][82] = 575;
	    EUC_TWFreq[38][7] = 574;
	    EUC_TWFreq[35][29] = 573;
	    EUC_TWFreq[37][77] = 572;
	    EUC_TWFreq[54][67] = 571;
	    EUC_TWFreq[38][80] = 570;
	    EUC_TWFreq[52][74] = 569;
	    EUC_TWFreq[36][37] = 568;
	    EUC_TWFreq[74][8] = 567;
	    EUC_TWFreq[41][83] = 566;
	    EUC_TWFreq[36][75] = 565;
	    EUC_TWFreq[49][63] = 564;
	    EUC_TWFreq[42][58] = 563;
	    EUC_TWFreq[56][33] = 562;
	    EUC_TWFreq[37][76] = 561;
	    EUC_TWFreq[62][39] = 560;
	    EUC_TWFreq[35][21] = 559;
	    EUC_TWFreq[70][19] = 558;
	    EUC_TWFreq[77][88] = 557;
	    EUC_TWFreq[51][14] = 556;
	    EUC_TWFreq[36][17] = 555;
	    EUC_TWFreq[44][51] = 554;
	    EUC_TWFreq[38][72] = 553;
	    EUC_TWFreq[74][90] = 552;
	    EUC_TWFreq[35][48] = 551;
	    EUC_TWFreq[35][69] = 550;
	    EUC_TWFreq[66][86] = 549;
	    EUC_TWFreq[57][20] = 548;
	    EUC_TWFreq[35][53] = 547;
	    EUC_TWFreq[36][87] = 546;
	    EUC_TWFreq[84][67] = 545;
	    EUC_TWFreq[70][56] = 544;
	    EUC_TWFreq[71][54] = 543;
	    EUC_TWFreq[60][70] = 542;
	    EUC_TWFreq[80][1] = 541;
	    EUC_TWFreq[39][59] = 540;
	    EUC_TWFreq[39][51] = 539;
	    EUC_TWFreq[35][44] = 538;
	    EUC_TWFreq[48][4] = 537;
	    EUC_TWFreq[55][24] = 536;
	    EUC_TWFreq[52][4] = 535;
	    EUC_TWFreq[54][26] = 534;
	    EUC_TWFreq[36][31] = 533;
	    EUC_TWFreq[37][22] = 532;
	    EUC_TWFreq[37][9] = 531;
	    EUC_TWFreq[46][0] = 530;
	    EUC_TWFreq[56][46] = 529;
	    EUC_TWFreq[47][93] = 528;
	    EUC_TWFreq[37][25] = 527;
	    EUC_TWFreq[39][8] = 526;
	    EUC_TWFreq[46][73] = 525;
	    EUC_TWFreq[38][48] = 524;
	    EUC_TWFreq[39][83] = 523;
	    EUC_TWFreq[60][92] = 522;
	    EUC_TWFreq[70][11] = 521;
	    EUC_TWFreq[63][84] = 520;
	    EUC_TWFreq[38][65] = 519;
	    EUC_TWFreq[45][45] = 518;
	    EUC_TWFreq[63][49] = 517;
	    EUC_TWFreq[63][50] = 516;
	    EUC_TWFreq[39][93] = 515;
	    EUC_TWFreq[68][20] = 514;
	    EUC_TWFreq[44][84] = 513;
	    EUC_TWFreq[66][34] = 512;
	    EUC_TWFreq[37][58] = 511;
	    EUC_TWFreq[39][0] = 510;
	    EUC_TWFreq[59][1] = 509;
	    EUC_TWFreq[47][8] = 508;
	    EUC_TWFreq[61][17] = 507;
	    EUC_TWFreq[53][87] = 506;
	    EUC_TWFreq[67][26] = 505;
	    EUC_TWFreq[43][46] = 504;
	    EUC_TWFreq[38][61] = 503;
	    EUC_TWFreq[45][9] = 502;
	    EUC_TWFreq[66][83] = 501;
	    EUC_TWFreq[43][88] = 500;
	    EUC_TWFreq[85][20] = 499;
	    EUC_TWFreq[57][36] = 498;
	    EUC_TWFreq[43][6] = 497;
	    EUC_TWFreq[86][77] = 496;
	    EUC_TWFreq[42][70] = 495;
	    EUC_TWFreq[49][78] = 494;
	    EUC_TWFreq[36][40] = 493;
	    EUC_TWFreq[42][71] = 492;
	    EUC_TWFreq[58][49] = 491;
	    EUC_TWFreq[35][20] = 490;
	    EUC_TWFreq[76][20] = 489;
	    EUC_TWFreq[39][25] = 488;
	    EUC_TWFreq[40][34] = 487;
	    EUC_TWFreq[39][76] = 486;
	    EUC_TWFreq[40][1] = 485;
	    EUC_TWFreq[59][0] = 484;
	    EUC_TWFreq[39][70] = 483;
	    EUC_TWFreq[46][14] = 482;
	    EUC_TWFreq[68][77] = 481;
	    EUC_TWFreq[38][55] = 480;
	    EUC_TWFreq[35][78] = 479;
	    EUC_TWFreq[84][44] = 478;
	    EUC_TWFreq[36][41] = 477;
	    EUC_TWFreq[37][62] = 476;
	    EUC_TWFreq[65][67] = 475;
	    EUC_TWFreq[69][66] = 474;
	    EUC_TWFreq[73][55] = 473;
	    EUC_TWFreq[71][49] = 472;
	    EUC_TWFreq[66][87] = 471;
	    EUC_TWFreq[38][33] = 470;
	    EUC_TWFreq[64][61] = 469;
	    EUC_TWFreq[35][7] = 468;
	    EUC_TWFreq[47][49] = 467;
	    EUC_TWFreq[56][14] = 466;
	    EUC_TWFreq[36][49] = 465;
	    EUC_TWFreq[50][81] = 464;
	    EUC_TWFreq[55][76] = 463;
	    EUC_TWFreq[35][19] = 462;
	    EUC_TWFreq[44][47] = 461;
	    EUC_TWFreq[35][15] = 460;
	    EUC_TWFreq[82][59] = 459;
	    EUC_TWFreq[35][43] = 458;
	    EUC_TWFreq[73][0] = 457;
	    EUC_TWFreq[57][83] = 456;
	    EUC_TWFreq[42][46] = 455;
	    EUC_TWFreq[36][0] = 454;
	    EUC_TWFreq[70][88] = 453;
	    EUC_TWFreq[42][22] = 452;
	    EUC_TWFreq[46][58] = 451;
	    EUC_TWFreq[36][34] = 450;
	    EUC_TWFreq[39][24] = 449;
	    EUC_TWFreq[35][55] = 448;
	    EUC_TWFreq[44][91] = 447;
	    EUC_TWFreq[37][51] = 446;
	    EUC_TWFreq[36][19] = 445;
	    EUC_TWFreq[69][90] = 444;
	    EUC_TWFreq[55][35] = 443;
	    EUC_TWFreq[35][54] = 442;
	    EUC_TWFreq[49][61] = 441;
	    EUC_TWFreq[36][67] = 440;
	    EUC_TWFreq[88][34] = 439;
	    EUC_TWFreq[35][17] = 438;
	    EUC_TWFreq[65][69] = 437;
	    EUC_TWFreq[74][89] = 436;
	    EUC_TWFreq[37][31] = 435;
	    EUC_TWFreq[43][48] = 434;
	    EUC_TWFreq[89][27] = 433;
	    EUC_TWFreq[42][79] = 432;
	    EUC_TWFreq[69][57] = 431;
	    EUC_TWFreq[36][13] = 430;
	    EUC_TWFreq[35][62] = 429;
	    EUC_TWFreq[65][47] = 428;
	    EUC_TWFreq[56][8] = 427;
	    EUC_TWFreq[38][79] = 426;
	    EUC_TWFreq[37][64] = 425;
	    EUC_TWFreq[64][64] = 424;
	    EUC_TWFreq[38][53] = 423;
	    EUC_TWFreq[38][31] = 422;
	    EUC_TWFreq[56][81] = 421;
	    EUC_TWFreq[36][22] = 420;
	    EUC_TWFreq[43][4] = 419;
	    EUC_TWFreq[36][90] = 418;
	    EUC_TWFreq[38][62] = 417;
	    EUC_TWFreq[66][85] = 416;
	    EUC_TWFreq[39][1] = 415;
	    EUC_TWFreq[59][40] = 414;
	    EUC_TWFreq[58][93] = 413;
	    EUC_TWFreq[44][43] = 412;
	    EUC_TWFreq[39][49] = 411;
	    EUC_TWFreq[64][2] = 410;
	    EUC_TWFreq[41][35] = 409;
	    EUC_TWFreq[60][22] = 408;
	    EUC_TWFreq[35][91] = 407;
	    EUC_TWFreq[78][1] = 406;
	    EUC_TWFreq[36][14] = 405;
	    EUC_TWFreq[82][29] = 404;
	    EUC_TWFreq[52][86] = 403;
	    EUC_TWFreq[40][16] = 402;
	    EUC_TWFreq[91][52] = 401;
	    EUC_TWFreq[50][75] = 400;
	    EUC_TWFreq[64][30] = 399;
	    EUC_TWFreq[90][78] = 398;
	    EUC_TWFreq[36][52] = 397;
	    EUC_TWFreq[55][87] = 396;
	    EUC_TWFreq[57][5] = 395;
	    EUC_TWFreq[57][31] = 394;
	    EUC_TWFreq[42][35] = 393;
	    EUC_TWFreq[69][50] = 392;
	    EUC_TWFreq[45][8] = 391;
	    EUC_TWFreq[50][87] = 390;
	    EUC_TWFreq[69][55] = 389;
	    EUC_TWFreq[92][3] = 388;
	    EUC_TWFreq[36][43] = 387;
	    EUC_TWFreq[64][10] = 386;
	    EUC_TWFreq[56][25] = 385;
	    EUC_TWFreq[60][68] = 384;
	    EUC_TWFreq[51][46] = 383;
	    EUC_TWFreq[50][0] = 382;
	    EUC_TWFreq[38][30] = 381;
	    EUC_TWFreq[50][85] = 380;
	    EUC_TWFreq[60][54] = 379;
	    EUC_TWFreq[73][6] = 378;
	    EUC_TWFreq[73][28] = 377;
	    EUC_TWFreq[56][19] = 376;
	    EUC_TWFreq[62][69] = 375;
	    EUC_TWFreq[81][66] = 374;
	    EUC_TWFreq[40][32] = 373;
	    EUC_TWFreq[76][31] = 372;
	    EUC_TWFreq[35][10] = 371;
	    EUC_TWFreq[41][37] = 370;
	    EUC_TWFreq[52][82] = 369;
	    EUC_TWFreq[91][72] = 368;
	    EUC_TWFreq[37][29] = 367;
	    EUC_TWFreq[56][30] = 366;
	    EUC_TWFreq[37][80] = 365;
	    EUC_TWFreq[81][56] = 364;
	    EUC_TWFreq[70][3] = 363;
	    EUC_TWFreq[76][15] = 362;
	    EUC_TWFreq[46][47] = 361;
	    EUC_TWFreq[35][88] = 360;
	    EUC_TWFreq[61][58] = 359;
	    EUC_TWFreq[37][37] = 358;
	    EUC_TWFreq[57][22] = 357;
	    EUC_TWFreq[41][23] = 356;
	    EUC_TWFreq[90][66] = 355;
	    EUC_TWFreq[39][60] = 354;
	    EUC_TWFreq[38][0] = 353;
	    EUC_TWFreq[37][87] = 352;
	    EUC_TWFreq[46][2] = 351;
	    EUC_TWFreq[38][56] = 350;
	    EUC_TWFreq[58][11] = 349;
	    EUC_TWFreq[48][10] = 348;
	    EUC_TWFreq[74][4] = 347;
	    EUC_TWFreq[40][42] = 346;
	    EUC_TWFreq[41][52] = 345;
	    EUC_TWFreq[61][92] = 344;
	    EUC_TWFreq[39][50] = 343;
	    EUC_TWFreq[47][88] = 342;
	    EUC_TWFreq[88][36] = 341;
	    EUC_TWFreq[45][73] = 340;
	    EUC_TWFreq[82][3] = 339;
	    EUC_TWFreq[61][36] = 338;
	    EUC_TWFreq[60][33] = 337;
	    EUC_TWFreq[38][27] = 336;
	    EUC_TWFreq[35][83] = 335;
	    EUC_TWFreq[65][24] = 334;
	    EUC_TWFreq[73][10] = 333;
	    EUC_TWFreq[41][13] = 332;
	    EUC_TWFreq[50][27] = 331;
	    EUC_TWFreq[59][50] = 330;
	    EUC_TWFreq[42][45] = 329;
	    EUC_TWFreq[55][19] = 328;
	    EUC_TWFreq[36][77] = 327;
	    EUC_TWFreq[69][31] = 326;
	    EUC_TWFreq[60][7] = 325;
	    EUC_TWFreq[40][88] = 324;
	    EUC_TWFreq[57][56] = 323;
	    EUC_TWFreq[50][50] = 322;
	    EUC_TWFreq[42][37] = 321;
	    EUC_TWFreq[38][82] = 320;
	    EUC_TWFreq[52][25] = 319;
	    EUC_TWFreq[42][67] = 318;
	    EUC_TWFreq[48][40] = 317;
	    EUC_TWFreq[45][81] = 316;
	    EUC_TWFreq[57][14] = 315;
	    EUC_TWFreq[42][13] = 314;
	    EUC_TWFreq[78][0] = 313;
	    EUC_TWFreq[35][51] = 312;
	    EUC_TWFreq[41][67] = 311;
	    EUC_TWFreq[64][23] = 310;
	    EUC_TWFreq[36][65] = 309;
	    EUC_TWFreq[48][50] = 308;
	    EUC_TWFreq[46][69] = 307;
	    EUC_TWFreq[47][89] = 306;
	    EUC_TWFreq[41][48] = 305;
	    EUC_TWFreq[60][56] = 304;
	    EUC_TWFreq[44][82] = 303;
	    EUC_TWFreq[47][35] = 302;
	    EUC_TWFreq[49][3] = 301;
	    EUC_TWFreq[49][69] = 300;
	    EUC_TWFreq[45][93] = 299;
	    EUC_TWFreq[60][34] = 298;
	    EUC_TWFreq[60][82] = 297;
	    EUC_TWFreq[61][61] = 296;
	    EUC_TWFreq[86][42] = 295;
	    EUC_TWFreq[89][60] = 294;
	    EUC_TWFreq[48][31] = 293;
	    EUC_TWFreq[35][75] = 292;
	    EUC_TWFreq[91][39] = 291;
	    EUC_TWFreq[53][19] = 290;
	    EUC_TWFreq[39][72] = 289;
	    EUC_TWFreq[69][59] = 288;
	    EUC_TWFreq[41][7] = 287;
	    EUC_TWFreq[54][13] = 286;
	    EUC_TWFreq[43][28] = 285;
	    EUC_TWFreq[36][6] = 284;
	    EUC_TWFreq[45][75] = 283;
	    EUC_TWFreq[36][61] = 282;
	    EUC_TWFreq[38][21] = 281;
	    EUC_TWFreq[45][14] = 280;
	    EUC_TWFreq[61][43] = 279;
	    EUC_TWFreq[36][63] = 278;
	    EUC_TWFreq[43][30] = 277;
	    EUC_TWFreq[46][51] = 276;
	    EUC_TWFreq[68][87] = 275;
	    EUC_TWFreq[39][26] = 274;
	    EUC_TWFreq[46][76] = 273;
	    EUC_TWFreq[36][15] = 272;
	    EUC_TWFreq[35][40] = 271;
	    EUC_TWFreq[79][60] = 270;
	    EUC_TWFreq[46][7] = 269;
	    EUC_TWFreq[65][72] = 268;
	    EUC_TWFreq[69][88] = 267;
	    EUC_TWFreq[47][18] = 266;
	    EUC_TWFreq[37][0] = 265;
	    EUC_TWFreq[37][49] = 264;
	    EUC_TWFreq[67][37] = 263;
	    EUC_TWFreq[36][91] = 262;
	    EUC_TWFreq[75][48] = 261;
	    EUC_TWFreq[75][63] = 260;
	    EUC_TWFreq[83][87] = 259;
	    EUC_TWFreq[37][44] = 258;
	    EUC_TWFreq[73][54] = 257;
	    EUC_TWFreq[51][61] = 256;
	    EUC_TWFreq[46][57] = 255;
	    EUC_TWFreq[55][21] = 254;
	    EUC_TWFreq[39][66] = 253;
	    EUC_TWFreq[47][11] = 252;
	    EUC_TWFreq[52][8] = 251;
	    EUC_TWFreq[82][81] = 250;
	    EUC_TWFreq[36][57] = 249;
	    EUC_TWFreq[38][54] = 248;
	    EUC_TWFreq[43][81] = 247;
	    EUC_TWFreq[37][42] = 246;
	    EUC_TWFreq[40][18] = 245;
	    EUC_TWFreq[80][90] = 244;
	    EUC_TWFreq[37][84] = 243;
	    EUC_TWFreq[57][15] = 242;
	    EUC_TWFreq[38][87] = 241;
	    EUC_TWFreq[37][32] = 240;
	    EUC_TWFreq[53][53] = 239;
	    EUC_TWFreq[89][29] = 238;
	    EUC_TWFreq[81][53] = 237;
	    EUC_TWFreq[75][3] = 236;
	    EUC_TWFreq[83][73] = 235;
	    EUC_TWFreq[66][13] = 234;
	    EUC_TWFreq[48][7] = 233;
	    EUC_TWFreq[46][35] = 232;
	    EUC_TWFreq[35][86] = 231;
	    EUC_TWFreq[37][20] = 230;
	    EUC_TWFreq[46][80] = 229;
	    EUC_TWFreq[38][24] = 228;
	    EUC_TWFreq[41][68] = 227;
	    EUC_TWFreq[42][21] = 226;
	    EUC_TWFreq[43][32] = 225;
	    EUC_TWFreq[38][20] = 224;
	    EUC_TWFreq[37][59] = 223;
	    EUC_TWFreq[41][77] = 222;
	    EUC_TWFreq[59][57] = 221;
	    EUC_TWFreq[68][59] = 220;
	    EUC_TWFreq[39][43] = 219;
	    EUC_TWFreq[54][39] = 218;
	    EUC_TWFreq[48][28] = 217;
	    EUC_TWFreq[54][28] = 216;
	    EUC_TWFreq[41][44] = 215;
	    EUC_TWFreq[51][64] = 214;
	    EUC_TWFreq[47][72] = 213;
	    EUC_TWFreq[62][67] = 212;
	    EUC_TWFreq[42][43] = 211;
	    EUC_TWFreq[61][38] = 210;
	    EUC_TWFreq[76][25] = 209;
	    EUC_TWFreq[48][91] = 208;
	    EUC_TWFreq[36][36] = 207;
	    EUC_TWFreq[80][32] = 206;
	    EUC_TWFreq[81][40] = 205;
	    EUC_TWFreq[37][5] = 204;
	    EUC_TWFreq[74][69] = 203;
	    EUC_TWFreq[36][82] = 202;
	    EUC_TWFreq[46][59] = 201;
	    /*
	     * EUC_TWFreq[38][32] = 200; EUC_TWFreq[74][2] = 199; EUC_TWFreq[53][31] = 198; EUC_TWFreq[35][38] = 197; EUC_TWFreq[46][62] =
	     * 196; EUC_TWFreq[77][31] = 195; EUC_TWFreq[55][74] = 194; EUC_TWFreq[66][6] = 193; EUC_TWFreq[56][21] = 192;
	     * EUC_TWFreq[54][78] = 191; EUC_TWFreq[43][51] = 190; EUC_TWFreq[64][93] = 189; EUC_TWFreq[92][7] = 188; EUC_TWFreq[83][89] =
	     * 187; EUC_TWFreq[69][9] = 186; EUC_TWFreq[45][4] = 185; EUC_TWFreq[53][9] = 184; EUC_TWFreq[43][2] = 183;
	     * EUC_TWFreq[35][11] = 182; EUC_TWFreq[51][25] = 181; EUC_TWFreq[52][71] = 180; EUC_TWFreq[81][67] = 179;
	     * EUC_TWFreq[37][33] = 178; EUC_TWFreq[38][57] = 177; EUC_TWFreq[39][77] = 176; EUC_TWFreq[40][26] = 175;
	     * EUC_TWFreq[37][21] = 174; EUC_TWFreq[81][70] = 173; EUC_TWFreq[56][80] = 172; EUC_TWFreq[65][14] = 171;
	     * EUC_TWFreq[62][47] = 170; EUC_TWFreq[56][54] = 169; EUC_TWFreq[45][17] = 168; EUC_TWFreq[52][52] = 167;
	     * EUC_TWFreq[74][30] = 166; EUC_TWFreq[60][57] = 165; EUC_TWFreq[41][15] = 164; EUC_TWFreq[47][69] = 163;
	     * EUC_TWFreq[61][11] = 162; EUC_TWFreq[72][25] = 161; EUC_TWFreq[82][56] = 160; EUC_TWFreq[76][92] = 159;
	     * EUC_TWFreq[51][22] = 158; EUC_TWFreq[55][69] = 157; EUC_TWFreq[49][43] = 156; EUC_TWFreq[69][49] = 155;
	     * EUC_TWFreq[88][42] = 154; EUC_TWFreq[84][41] = 153; EUC_TWFreq[79][33] = 152; EUC_TWFreq[47][17] = 151;
	     * EUC_TWFreq[52][88] = 150; EUC_TWFreq[63][74] = 149; EUC_TWFreq[50][32] = 148; EUC_TWFreq[65][10] = 147; EUC_TWFreq[57][6] =
	     * 146; EUC_TWFreq[52][23] = 145; EUC_TWFreq[36][70] = 144; EUC_TWFreq[65][55] = 143; EUC_TWFreq[35][27] = 142;
	     * EUC_TWFreq[57][63] = 141; EUC_TWFreq[39][92] = 140; EUC_TWFreq[79][75] = 139; EUC_TWFreq[36][30] = 138;
	     * EUC_TWFreq[53][60] = 137; EUC_TWFreq[55][43] = 136; EUC_TWFreq[71][22] = 135; EUC_TWFreq[43][16] = 134;
	     * EUC_TWFreq[65][21] = 133; EUC_TWFreq[84][51] = 132; EUC_TWFreq[43][64] = 131; EUC_TWFreq[87][91] = 130;
	     * EUC_TWFreq[47][45] = 129; EUC_TWFreq[65][29] = 128; EUC_TWFreq[88][16] = 127; EUC_TWFreq[50][5] = 126; EUC_TWFreq[47][33] =
	     * 125; EUC_TWFreq[46][27] = 124; EUC_TWFreq[85][2] = 123; EUC_TWFreq[43][77] = 122; EUC_TWFreq[70][9] = 121;
	     * EUC_TWFreq[41][54] = 120; EUC_TWFreq[56][12] = 119; EUC_TWFreq[90][65] = 118; EUC_TWFreq[91][50] = 117;
	     * EUC_TWFreq[48][41] = 116; EUC_TWFreq[35][89] = 115; EUC_TWFreq[90][83] = 114; EUC_TWFreq[44][40] = 113;
	     * EUC_TWFreq[50][88] = 112; EUC_TWFreq[72][39] = 111; EUC_TWFreq[45][3] = 110; EUC_TWFreq[71][33] = 109; EUC_TWFreq[39][12] =
	     * 108; EUC_TWFreq[59][24] = 107; EUC_TWFreq[60][62] = 106; EUC_TWFreq[44][33] = 105; EUC_TWFreq[53][70] = 104;
	     * EUC_TWFreq[77][90] = 103; EUC_TWFreq[50][58] = 102; EUC_TWFreq[54][1] = 101; EUC_TWFreq[73][19] = 100; EUC_TWFreq[37][3] =
	     * 99; EUC_TWFreq[49][91] = 98; EUC_TWFreq[88][43] = 97; EUC_TWFreq[36][78] = 96; EUC_TWFreq[44][20] = 95;
	     * EUC_TWFreq[64][15] = 94; EUC_TWFreq[72][28] = 93; EUC_TWFreq[70][13] = 92; EUC_TWFreq[65][83] = 91; EUC_TWFreq[58][68] =
	     * 90; EUC_TWFreq[59][32] = 89; EUC_TWFreq[39][13] = 88; EUC_TWFreq[55][64] = 87; EUC_TWFreq[56][59] = 86;
	     * EUC_TWFreq[39][17] = 85; EUC_TWFreq[55][84] = 84; EUC_TWFreq[77][85] = 83; EUC_TWFreq[60][19] = 82; EUC_TWFreq[62][82] =
	     * 81; EUC_TWFreq[78][16] = 80; EUC_TWFreq[66][8] = 79; EUC_TWFreq[39][42] = 78; EUC_TWFreq[61][24] = 77; EUC_TWFreq[57][67] =
	     * 76; EUC_TWFreq[38][83] = 75; EUC_TWFreq[36][53] = 74; EUC_TWFreq[67][76] = 73; EUC_TWFreq[37][91] = 72;
	     * EUC_TWFreq[44][26] = 71; EUC_TWFreq[72][86] = 70; EUC_TWFreq[44][87] = 69; EUC_TWFreq[45][50] = 68; EUC_TWFreq[58][4] =
	     * 67; EUC_TWFreq[86][65] = 66; EUC_TWFreq[45][56] = 65; EUC_TWFreq[79][49] = 64; EUC_TWFreq[35][3] = 63; EUC_TWFreq[48][83] =
	     * 62; EUC_TWFreq[71][21] = 61; EUC_TWFreq[77][93] = 60; EUC_TWFreq[87][92] = 59; EUC_TWFreq[38][35] = 58;
	     * EUC_TWFreq[66][17] = 57; EUC_TWFreq[37][66] = 56; EUC_TWFreq[51][42] = 55; EUC_TWFreq[57][73] = 54; EUC_TWFreq[51][54] =
	     * 53; EUC_TWFreq[75][64] = 52; EUC_TWFreq[35][5] = 51; EUC_TWFreq[49][40] = 50; EUC_TWFreq[58][35] = 49; EUC_TWFreq[67][88] =
	     * 48; EUC_TWFreq[60][51] = 47; EUC_TWFreq[36][92] = 46; EUC_TWFreq[44][41] = 45; EUC_TWFreq[58][29] = 44;
	     * EUC_TWFreq[43][62] = 43; EUC_TWFreq[56][23] = 42; EUC_TWFreq[67][44] = 41; EUC_TWFreq[52][91] = 40; EUC_TWFreq[42][81] =
	     * 39; EUC_TWFreq[64][25] = 38; EUC_TWFreq[35][36] = 37; EUC_TWFreq[47][73] = 36; EUC_TWFreq[36][1] = 35; EUC_TWFreq[65][84] =
	     * 34; EUC_TWFreq[73][1] = 33; EUC_TWFreq[79][66] = 32; EUC_TWFreq[69][14] = 31; EUC_TWFreq[65][28] = 30; EUC_TWFreq[60][93] =
	     * 29; EUC_TWFreq[72][79] = 28; EUC_TWFreq[48][0] = 27; EUC_TWFreq[73][43] = 26; EUC_TWFreq[66][47] = 25; EUC_TWFreq[41][18] =
	     * 24; EUC_TWFreq[51][10] = 23; EUC_TWFreq[59][7] = 22; EUC_TWFreq[53][27] = 21; EUC_TWFreq[86][67] = 20; EUC_TWFreq[49][87] =
	     * 19; EUC_TWFreq[52][28] = 18; EUC_TWFreq[52][12] = 17; EUC_TWFreq[42][30] = 16; EUC_TWFreq[65][35] = 15;
	     * EUC_TWFreq[46][64] = 14; EUC_TWFreq[71][7] = 13; EUC_TWFreq[56][57] = 12; EUC_TWFreq[56][31] = 11; EUC_TWFreq[41][31] =
	     * 10; EUC_TWFreq[48][59] = 9; EUC_TWFreq[63][92] = 8; EUC_TWFreq[62][57] = 7; EUC_TWFreq[65][87] = 6; EUC_TWFreq[70][10] =
	     * 5; EUC_TWFreq[52][40] = 4; EUC_TWFreq[40][22] = 3; EUC_TWFreq[65][91] = 2; EUC_TWFreq[50][25] = 1; EUC_TWFreq[35][84] =
	     * 0;
	     */
	    GBKFreq[52][132] = 600;
	    GBKFreq[73][135] = 599;
	    GBKFreq[49][123] = 598;
	    GBKFreq[77][146] = 597;
	    GBKFreq[81][123] = 596;
	    GBKFreq[82][144] = 595;
	    GBKFreq[51][179] = 594;
	    GBKFreq[83][154] = 593;
	    GBKFreq[71][139] = 592;
	    GBKFreq[64][139] = 591;
	    GBKFreq[85][144] = 590;
	    GBKFreq[52][125] = 589;
	    GBKFreq[88][25] = 588;
	    GBKFreq[81][106] = 587;
	    GBKFreq[81][148] = 586;
	    GBKFreq[62][137] = 585;
	    GBKFreq[94][0] = 584;
	    GBKFreq[1][64] = 583;
	    GBKFreq[67][163] = 582;
	    GBKFreq[20][190] = 581;
	    GBKFreq[57][131] = 580;
	    GBKFreq[29][169] = 579;
	    GBKFreq[72][143] = 578;
	    GBKFreq[0][173] = 577;
	    GBKFreq[11][23] = 576;
	    GBKFreq[61][141] = 575;
	    GBKFreq[60][123] = 574;
	    GBKFreq[81][114] = 573;
	    GBKFreq[82][131] = 572;
	    GBKFreq[67][156] = 571;
	    GBKFreq[71][167] = 570;
	    GBKFreq[20][50] = 569;
	    GBKFreq[77][132] = 568;
	    GBKFreq[84][38] = 567;
	    GBKFreq[26][29] = 566;
	    GBKFreq[74][187] = 565;
	    GBKFreq[62][116] = 564;
	    GBKFreq[67][135] = 563;
	    GBKFreq[5][86] = 562;
	    GBKFreq[72][186] = 561;
	    GBKFreq[75][161] = 560;
	    GBKFreq[78][130] = 559;
	    GBKFreq[94][30] = 558;
	    GBKFreq[84][72] = 557;
	    GBKFreq[1][67] = 556;
	    GBKFreq[75][172] = 555;
	    GBKFreq[74][185] = 554;
	    GBKFreq[53][160] = 553;
	    GBKFreq[123][14] = 552;
	    GBKFreq[79][97] = 551;
	    GBKFreq[85][110] = 550;
	    GBKFreq[78][171] = 549;
	    GBKFreq[52][131] = 548;
	    GBKFreq[56][100] = 547;
	    GBKFreq[50][182] = 546;
	    GBKFreq[94][64] = 545;
	    GBKFreq[106][74] = 544;
	    GBKFreq[11][102] = 543;
	    GBKFreq[53][124] = 542;
	    GBKFreq[24][3] = 541;
	    GBKFreq[86][148] = 540;
	    GBKFreq[53][184] = 539;
	    GBKFreq[86][147] = 538;
	    GBKFreq[96][161] = 537;
	    GBKFreq[82][77] = 536;
	    GBKFreq[59][146] = 535;
	    GBKFreq[84][126] = 534;
	    GBKFreq[79][132] = 533;
	    GBKFreq[85][123] = 532;
	    GBKFreq[71][101] = 531;
	    GBKFreq[85][106] = 530;
	    GBKFreq[6][184] = 529;
	    GBKFreq[57][156] = 528;
	    GBKFreq[75][104] = 527;
	    GBKFreq[50][137] = 526;
	    GBKFreq[79][133] = 525;
	    GBKFreq[76][108] = 524;
	    GBKFreq[57][142] = 523;
	    GBKFreq[84][130] = 522;
	    GBKFreq[52][128] = 521;
	    GBKFreq[47][44] = 520;
	    GBKFreq[52][152] = 519;
	    GBKFreq[54][104] = 518;
	    GBKFreq[30][47] = 517;
	    GBKFreq[71][123] = 516;
	    GBKFreq[52][107] = 515;
	    GBKFreq[45][84] = 514;
	    GBKFreq[107][118] = 513;
	    GBKFreq[5][161] = 512;
	    GBKFreq[48][126] = 511;
	    GBKFreq[67][170] = 510;
	    GBKFreq[43][6] = 509;
	    GBKFreq[70][112] = 508;
	    GBKFreq[86][174] = 507;
	    GBKFreq[84][166] = 506;
	    GBKFreq[79][130] = 505;
	    GBKFreq[57][141] = 504;
	    GBKFreq[81][178] = 503;
	    GBKFreq[56][187] = 502;
	    GBKFreq[81][162] = 501;
	    GBKFreq[53][104] = 500;
	    GBKFreq[123][35] = 499;
	    GBKFreq[70][169] = 498;
	    GBKFreq[69][164] = 497;
	    GBKFreq[109][61] = 496;
	    GBKFreq[73][130] = 495;
	    GBKFreq[62][134] = 494;
	    GBKFreq[54][125] = 493;
	    GBKFreq[79][105] = 492;
	    GBKFreq[70][165] = 491;
	    GBKFreq[71][189] = 490;
	    GBKFreq[23][147] = 489;
	    GBKFreq[51][139] = 488;
	    GBKFreq[47][137] = 487;
	    GBKFreq[77][123] = 486;
	    GBKFreq[86][183] = 485;
	    GBKFreq[63][173] = 484;
	    GBKFreq[79][144] = 483;
	    GBKFreq[84][159] = 482;
	    GBKFreq[60][91] = 481;
	    GBKFreq[66][187] = 480;
	    GBKFreq[73][114] = 479;
	    GBKFreq[85][56] = 478;
	    GBKFreq[71][149] = 477;
	    GBKFreq[84][189] = 476;
	    GBKFreq[104][31] = 475;
	    GBKFreq[83][82] = 474;
	    GBKFreq[68][35] = 473;
	    GBKFreq[11][77] = 472;
	    GBKFreq[15][155] = 471;
	    GBKFreq[83][153] = 470;
	    GBKFreq[71][1] = 469;
	    GBKFreq[53][190] = 468;
	    GBKFreq[50][135] = 467;
	    GBKFreq[3][147] = 466;
	    GBKFreq[48][136] = 465;
	    GBKFreq[66][166] = 464;
	    GBKFreq[55][159] = 463;
	    GBKFreq[82][150] = 462;
	    GBKFreq[58][178] = 461;
	    GBKFreq[64][102] = 460;
	    GBKFreq[16][106] = 459;
	    GBKFreq[68][110] = 458;
	    GBKFreq[54][14] = 457;
	    GBKFreq[60][140] = 456;
	    GBKFreq[91][71] = 455;
	    GBKFreq[54][150] = 454;
	    GBKFreq[78][177] = 453;
	    GBKFreq[78][117] = 452;
	    GBKFreq[104][12] = 451;
	    GBKFreq[73][150] = 450;
	    GBKFreq[51][142] = 449;
	    GBKFreq[81][145] = 448;
	    GBKFreq[66][183] = 447;
	    GBKFreq[51][178] = 446;
	    GBKFreq[75][107] = 445;
	    GBKFreq[65][119] = 444;
	    GBKFreq[69][176] = 443;
	    GBKFreq[59][122] = 442;
	    GBKFreq[78][160] = 441;
	    GBKFreq[85][183] = 440;
	    GBKFreq[105][16] = 439;
	    GBKFreq[73][110] = 438;
	    GBKFreq[104][39] = 437;
	    GBKFreq[119][16] = 436;
	    GBKFreq[76][162] = 435;
	    GBKFreq[67][152] = 434;
	    GBKFreq[82][24] = 433;
	    GBKFreq[73][121] = 432;
	    GBKFreq[83][83] = 431;
	    GBKFreq[82][145] = 430;
	    GBKFreq[49][133] = 429;
	    GBKFreq[94][13] = 428;
	    GBKFreq[58][139] = 427;
	    GBKFreq[74][189] = 426;
	    GBKFreq[66][177] = 425;
	    GBKFreq[85][184] = 424;
	    GBKFreq[55][183] = 423;
	    GBKFreq[71][107] = 422;
	    GBKFreq[11][98] = 421;
	    GBKFreq[72][153] = 420;
	    GBKFreq[2][137] = 419;
	    GBKFreq[59][147] = 418;
	    GBKFreq[58][152] = 417;
	    GBKFreq[55][144] = 416;
	    GBKFreq[73][125] = 415;
	    GBKFreq[52][154] = 414;
	    GBKFreq[70][178] = 413;
	    GBKFreq[79][148] = 412;
	    GBKFreq[63][143] = 411;
	    GBKFreq[50][140] = 410;
	    GBKFreq[47][145] = 409;
	    GBKFreq[48][123] = 408;
	    GBKFreq[56][107] = 407;
	    GBKFreq[84][83] = 406;
	    GBKFreq[59][112] = 405;
	    GBKFreq[124][72] = 404;
	    GBKFreq[79][99] = 403;
	    GBKFreq[3][37] = 402;
	    GBKFreq[114][55] = 401;
	    GBKFreq[85][152] = 400;
	    GBKFreq[60][47] = 399;
	    GBKFreq[65][96] = 398;
	    GBKFreq[74][110] = 397;
	    GBKFreq[86][182] = 396;
	    GBKFreq[50][99] = 395;
	    GBKFreq[67][186] = 394;
	    GBKFreq[81][74] = 393;
	    GBKFreq[80][37] = 392;
	    GBKFreq[21][60] = 391;
	    GBKFreq[110][12] = 390;
	    GBKFreq[60][162] = 389;
	    GBKFreq[29][115] = 388;
	    GBKFreq[83][130] = 387;
	    GBKFreq[52][136] = 386;
	    GBKFreq[63][114] = 385;
	    GBKFreq[49][127] = 384;
	    GBKFreq[83][109] = 383;
	    GBKFreq[66][128] = 382;
	    GBKFreq[78][136] = 381;
	    GBKFreq[81][180] = 380;
	    GBKFreq[76][104] = 379;
	    GBKFreq[56][156] = 378;
	    GBKFreq[61][23] = 377;
	    GBKFreq[4][30] = 376;
	    GBKFreq[69][154] = 375;
	    GBKFreq[100][37] = 374;
	    GBKFreq[54][177] = 373;
	    GBKFreq[23][119] = 372;
	    GBKFreq[71][171] = 371;
	    GBKFreq[84][146] = 370;
	    GBKFreq[20][184] = 369;
	    GBKFreq[86][76] = 368;
	    GBKFreq[74][132] = 367;
	    GBKFreq[47][97] = 366;
	    GBKFreq[82][137] = 365;
	    GBKFreq[94][56] = 364;
	    GBKFreq[92][30] = 363;
	    GBKFreq[19][117] = 362;
	    GBKFreq[48][173] = 361;
	    GBKFreq[2][136] = 360;
	    GBKFreq[7][182] = 359;
	    GBKFreq[74][188] = 358;
	    GBKFreq[14][132] = 357;
	    GBKFreq[62][172] = 356;
	    GBKFreq[25][39] = 355;
	    GBKFreq[85][129] = 354;
	    GBKFreq[64][98] = 353;
	    GBKFreq[67][127] = 352;
	    GBKFreq[72][167] = 351;
	    GBKFreq[57][143] = 350;
	    GBKFreq[76][187] = 349;
	    GBKFreq[83][181] = 348;
	    GBKFreq[84][10] = 347;
	    GBKFreq[55][166] = 346;
	    GBKFreq[55][188] = 345;
	    GBKFreq[13][151] = 344;
	    GBKFreq[62][124] = 343;
	    GBKFreq[53][136] = 342;
	    GBKFreq[106][57] = 341;
	    GBKFreq[47][166] = 340;
	    GBKFreq[109][30] = 339;
	    GBKFreq[78][114] = 338;
	    GBKFreq[83][19] = 337;
	    GBKFreq[56][162] = 336;
	    GBKFreq[60][177] = 335;
	    GBKFreq[88][9] = 334;
	    GBKFreq[74][163] = 333;
	    GBKFreq[52][156] = 332;
	    GBKFreq[71][180] = 331;
	    GBKFreq[60][57] = 330;
	    GBKFreq[72][173] = 329;
	    GBKFreq[82][91] = 328;
	    GBKFreq[51][186] = 327;
	    GBKFreq[75][86] = 326;
	    GBKFreq[75][78] = 325;
	    GBKFreq[76][170] = 324;
	    GBKFreq[60][147] = 323;
	    GBKFreq[82][75] = 322;
	    GBKFreq[80][148] = 321;
	    GBKFreq[86][150] = 320;
	    GBKFreq[13][95] = 319;
	    GBKFreq[0][11] = 318;
	    GBKFreq[84][190] = 317;
	    GBKFreq[76][166] = 316;
	    GBKFreq[14][72] = 315;
	    GBKFreq[67][144] = 314;
	    GBKFreq[84][44] = 313;
	    GBKFreq[72][125] = 312;
	    GBKFreq[66][127] = 311;
	    GBKFreq[60][25] = 310;
	    GBKFreq[70][146] = 309;
	    GBKFreq[79][135] = 308;
	    GBKFreq[54][135] = 307;
	    GBKFreq[60][104] = 306;
	    GBKFreq[55][132] = 305;
	    GBKFreq[94][2] = 304;
	    GBKFreq[54][133] = 303;
	    GBKFreq[56][190] = 302;
	    GBKFreq[58][174] = 301;
	    GBKFreq[80][144] = 300;
	    GBKFreq[85][113] = 299;
	    /*
	     * GBKFreq[83][15] = 298; GBKFreq[105][80] = 297; GBKFreq[7][179] = 296; GBKFreq[93][4] = 295; GBKFreq[123][40] = 294;
	     * GBKFreq[85][120] = 293; GBKFreq[77][165] = 292; GBKFreq[86][67] = 291; GBKFreq[25][162] = 290; GBKFreq[77][183] = 289;
	     * GBKFreq[83][71] = 288; GBKFreq[78][99] = 287; GBKFreq[72][177] = 286; GBKFreq[71][97] = 285; GBKFreq[58][111] = 284;
	     * GBKFreq[77][175] = 283; GBKFreq[76][181] = 282; GBKFreq[71][142] = 281; GBKFreq[64][150] = 280; GBKFreq[5][142] = 279;
	     * GBKFreq[73][128] = 278; GBKFreq[73][156] = 277; GBKFreq[60][188] = 276; GBKFreq[64][56] = 275; GBKFreq[74][128] = 274;
	     * GBKFreq[48][163] = 273; GBKFreq[54][116] = 272; GBKFreq[73][127] = 271; GBKFreq[16][176] = 270; GBKFreq[62][149] = 269;
	     * GBKFreq[105][96] = 268; GBKFreq[55][186] = 267; GBKFreq[4][51] = 266; GBKFreq[48][113] = 265; GBKFreq[48][152] = 264;
	     * GBKFreq[23][9] = 263; GBKFreq[56][102] = 262; GBKFreq[11][81] = 261; GBKFreq[82][112] = 260; GBKFreq[65][85] = 259;
	     * GBKFreq[69][125] = 258; GBKFreq[68][31] = 257; GBKFreq[5][20] = 256; GBKFreq[60][176] = 255; GBKFreq[82][81] = 254;
	     * GBKFreq[72][107] = 253; GBKFreq[3][52] = 252; GBKFreq[71][157] = 251; GBKFreq[24][46] = 250; GBKFreq[69][108] = 249;
	     * GBKFreq[78][178] = 248; GBKFreq[9][69] = 247; GBKFreq[73][144] = 246; GBKFreq[63][187] = 245; GBKFreq[68][36] = 244;
	     * GBKFreq[47][151] = 243; GBKFreq[14][74] = 242; GBKFreq[47][114] = 241; GBKFreq[80][171] = 240; GBKFreq[75][152] = 239;
	     * GBKFreq[86][40] = 238; GBKFreq[93][43] = 237; GBKFreq[2][50] = 236; GBKFreq[62][66] = 235; GBKFreq[1][183] = 234;
	     * GBKFreq[74][124] = 233; GBKFreq[58][104] = 232; GBKFreq[83][106] = 231; GBKFreq[60][144] = 230; GBKFreq[48][99] = 229;
	     * GBKFreq[54][157] = 228; GBKFreq[70][179] = 227; GBKFreq[61][127] = 226; GBKFreq[57][135] = 225; GBKFreq[59][190] = 224;
	     * GBKFreq[77][116] = 223; GBKFreq[26][17] = 222; GBKFreq[60][13] = 221; GBKFreq[71][38] = 220; GBKFreq[85][177] = 219;
	     * GBKFreq[59][73] = 218; GBKFreq[50][150] = 217; GBKFreq[79][102] = 216; GBKFreq[76][118] = 215; GBKFreq[67][132] = 214;
	     * GBKFreq[73][146] = 213; GBKFreq[83][184] = 212; GBKFreq[86][159] = 211; GBKFreq[95][120] = 210; GBKFreq[23][139] = 209;
	     * GBKFreq[64][183] = 208; GBKFreq[85][103] = 207; GBKFreq[41][90] = 206; GBKFreq[87][72] = 205; GBKFreq[62][104] = 204;
	     * GBKFreq[79][168] = 203; GBKFreq[79][150] = 202; GBKFreq[104][20] = 201; GBKFreq[56][114] = 200; GBKFreq[84][26] = 199;
	     * GBKFreq[57][99] = 198; GBKFreq[62][154] = 197; GBKFreq[47][98] = 196; GBKFreq[61][64] = 195; GBKFreq[112][18] = 194;
	     * GBKFreq[123][19] = 193; GBKFreq[4][98] = 192; GBKFreq[47][163] = 191; GBKFreq[66][188] = 190; GBKFreq[81][85] = 189;
	     * GBKFreq[82][30] = 188; GBKFreq[65][83] = 187; GBKFreq[67][24] = 186; GBKFreq[68][179] = 185; GBKFreq[55][177] = 184;
	     * GBKFreq[2][122] = 183; GBKFreq[47][139] = 182; GBKFreq[79][158] = 181; GBKFreq[64][143] = 180; GBKFreq[100][24] = 179;
	     * GBKFreq[73][103] = 178; GBKFreq[50][148] = 177; GBKFreq[86][97] = 176; GBKFreq[59][116] = 175; GBKFreq[64][173] = 174;
	     * GBKFreq[99][91] = 173; GBKFreq[11][99] = 172; GBKFreq[78][179] = 171; GBKFreq[18][17] = 170; GBKFreq[58][185] = 169;
	     * GBKFreq[47][165] = 168; GBKFreq[67][131] = 167; GBKFreq[94][40] = 166; GBKFreq[74][153] = 165; GBKFreq[79][142] = 164;
	     * GBKFreq[57][98] = 163; GBKFreq[1][164] = 162; GBKFreq[55][168] = 161; GBKFreq[13][141] = 160; GBKFreq[51][31] = 159;
	     * GBKFreq[57][178] = 158; GBKFreq[50][189] = 157; GBKFreq[60][167] = 156; GBKFreq[80][34] = 155; GBKFreq[109][80] = 154;
	     * GBKFreq[85][54] = 153; GBKFreq[69][183] = 152; GBKFreq[67][143] = 151; GBKFreq[47][120] = 150; GBKFreq[45][75] = 149;
	     * GBKFreq[82][98] = 148; GBKFreq[83][22] = 147; GBKFreq[13][103] = 146; GBKFreq[49][174] = 145; GBKFreq[57][181] = 144;
	     * GBKFreq[64][127] = 143; GBKFreq[61][131] = 142; GBKFreq[52][180] = 141; GBKFreq[74][134] = 140; GBKFreq[84][187] = 139;
	     * GBKFreq[81][189] = 138; GBKFreq[47][160] = 137; GBKFreq[66][148] = 136; GBKFreq[7][4] = 135; GBKFreq[85][134] = 134;
	     * GBKFreq[88][13] = 133; GBKFreq[88][80] = 132; GBKFreq[69][166] = 131; GBKFreq[86][18] = 130; GBKFreq[79][141] = 129;
	     * GBKFreq[50][108] = 128; GBKFreq[94][69] = 127; GBKFreq[81][110] = 126; GBKFreq[69][119] = 125; GBKFreq[72][161] = 124;
	     * GBKFreq[106][45] = 123; GBKFreq[73][124] = 122; GBKFreq[94][28] = 121; GBKFreq[63][174] = 120; GBKFreq[3][149] = 119;
	     * GBKFreq[24][160] = 118; GBKFreq[113][94] = 117; GBKFreq[56][138] = 116; GBKFreq[64][185] = 115; GBKFreq[86][56] = 114;
	     * GBKFreq[56][150] = 113; GBKFreq[110][55] = 112; GBKFreq[28][13] = 111; GBKFreq[54][190] = 110; GBKFreq[8][180] = 109;
	     * GBKFreq[73][149] = 108; GBKFreq[80][155] = 107; GBKFreq[83][172] = 106; GBKFreq[67][174] = 105; GBKFreq[64][180] = 104;
	     * GBKFreq[84][46] = 103; GBKFreq[91][74] = 102; GBKFreq[69][134] = 101; GBKFreq[61][107] = 100; GBKFreq[47][171] = 99;
	     * GBKFreq[59][51] = 98; GBKFreq[109][74] = 97; GBKFreq[64][174] = 96; GBKFreq[52][151] = 95; GBKFreq[51][176] = 94;
	     * GBKFreq[80][157] = 93; GBKFreq[94][31] = 92; GBKFreq[79][155] = 91; GBKFreq[72][174] = 90; GBKFreq[69][113] = 89;
	     * GBKFreq[83][167] = 88; GBKFreq[83][122] = 87; GBKFreq[8][178] = 86; GBKFreq[70][186] = 85; GBKFreq[59][153] = 84;
	     * GBKFreq[84][68] = 83; GBKFreq[79][39] = 82; GBKFreq[47][180] = 81; GBKFreq[88][53] = 80; GBKFreq[57][154] = 79;
	     * GBKFreq[47][153] = 78; GBKFreq[3][153] = 77; GBKFreq[76][134] = 76; GBKFreq[51][166] = 75; GBKFreq[58][176] = 74;
	     * GBKFreq[27][138] = 73; GBKFreq[73][126] = 72; GBKFreq[76][185] = 71; GBKFreq[52][186] = 70; GBKFreq[81][151] = 69;
	     * GBKFreq[26][50] = 68; GBKFreq[76][173] = 67; GBKFreq[106][56] = 66; GBKFreq[85][142] = 65; GBKFreq[11][103] = 64;
	     * GBKFreq[69][159] = 63; GBKFreq[53][142] = 62; GBKFreq[7][6] = 61; GBKFreq[84][59] = 60; GBKFreq[86][3] = 59;
	     * GBKFreq[64][144] = 58; GBKFreq[1][187] = 57; GBKFreq[82][128] = 56; GBKFreq[3][66] = 55; GBKFreq[68][133] = 54;
	     * GBKFreq[55][167] = 53; GBKFreq[52][130] = 52; GBKFreq[61][133] = 51; GBKFreq[72][181] = 50; GBKFreq[25][98] = 49;
	     * GBKFreq[84][149] = 48; GBKFreq[91][91] = 47; GBKFreq[47][188] = 46; GBKFreq[68][130] = 45; GBKFreq[22][44] = 44;
	     * GBKFreq[81][121] = 43; GBKFreq[72][140] = 42; GBKFreq[55][133] = 41; GBKFreq[55][185] = 40; GBKFreq[56][105] = 39;
	     * GBKFreq[60][30] = 38; GBKFreq[70][103] = 37; GBKFreq[62][141] = 36; GBKFreq[70][144] = 35; GBKFreq[59][111] = 34;
	     * GBKFreq[54][17] = 33; GBKFreq[18][190] = 32; GBKFreq[65][164] = 31; GBKFreq[83][125] = 30; GBKFreq[61][121] = 29;
	     * GBKFreq[48][13] = 28; GBKFreq[51][189] = 27; GBKFreq[65][68] = 26; GBKFreq[7][0] = 25; GBKFreq[76][188] = 24;
	     * GBKFreq[85][117] = 23; GBKFreq[45][33] = 22; GBKFreq[78][187] = 21; GBKFreq[106][48] = 20; GBKFreq[59][52] = 19;
	     * GBKFreq[86][185] = 18; GBKFreq[84][121] = 17; GBKFreq[82][189] = 16; GBKFreq[68][156] = 15; GBKFreq[55][125] = 14;
	     * GBKFreq[65][175] = 13; GBKFreq[7][140] = 12; GBKFreq[50][106] = 11; GBKFreq[59][124] = 10; GBKFreq[67][115] = 9;
	     * GBKFreq[82][114] = 8; GBKFreq[74][121] = 7; GBKFreq[106][69] = 6; GBKFreq[94][27] = 5; GBKFreq[78][98] = 4;
	     * GBKFreq[85][186] = 3; GBKFreq[108][90] = 2; GBKFreq[62][160] = 1; GBKFreq[60][169] = 0;
	     */
	    KRFreq[31][43] = 600;
	    KRFreq[19][56] = 599;
	    KRFreq[38][46] = 598;
	    KRFreq[3][3] = 597;
	    KRFreq[29][77] = 596;
	    KRFreq[19][33] = 595;
	    KRFreq[30][0] = 594;
	    KRFreq[29][89] = 593;
	    KRFreq[31][26] = 592;
	    KRFreq[31][38] = 591;
	    KRFreq[32][85] = 590;
	    KRFreq[15][0] = 589;
	    KRFreq[16][54] = 588;
	    KRFreq[15][76] = 587;
	    KRFreq[31][25] = 586;
	    KRFreq[23][13] = 585;
	    KRFreq[28][34] = 584;
	    KRFreq[18][9] = 583;
	    KRFreq[29][37] = 582;
	    KRFreq[22][45] = 581;
	    KRFreq[19][46] = 580;
	    KRFreq[16][65] = 579;
	    KRFreq[23][5] = 578;
	    KRFreq[26][70] = 577;
	    KRFreq[31][53] = 576;
	    KRFreq[27][12] = 575;
	    KRFreq[30][67] = 574;
	    KRFreq[31][57] = 573;
	    KRFreq[20][20] = 572;
	    KRFreq[30][31] = 571;
	    KRFreq[20][72] = 570;
	    KRFreq[15][51] = 569;
	    KRFreq[3][8] = 568;
	    KRFreq[32][53] = 567;
	    KRFreq[27][85] = 566;
	    KRFreq[25][23] = 565;
	    KRFreq[15][44] = 564;
	    KRFreq[32][3] = 563;
	    KRFreq[31][68] = 562;
	    KRFreq[30][24] = 561;
	    KRFreq[29][49] = 560;
	    KRFreq[27][49] = 559;
	    KRFreq[23][23] = 558;
	    KRFreq[31][91] = 557;
	    KRFreq[31][46] = 556;
	    KRFreq[19][74] = 555;
	    KRFreq[27][27] = 554;
	    KRFreq[3][17] = 553;
	    KRFreq[20][38] = 552;
	    KRFreq[21][82] = 551;
	    KRFreq[28][25] = 550;
	    KRFreq[32][5] = 549;
	    KRFreq[31][23] = 548;
	    KRFreq[25][45] = 547;
	    KRFreq[32][87] = 546;
	    KRFreq[18][26] = 545;
	    KRFreq[24][10] = 544;
	    KRFreq[26][82] = 543;
	    KRFreq[15][89] = 542;
	    KRFreq[28][36] = 541;
	    KRFreq[28][31] = 540;
	    KRFreq[16][23] = 539;
	    KRFreq[16][77] = 538;
	    KRFreq[19][84] = 537;
	    KRFreq[23][72] = 536;
	    KRFreq[38][48] = 535;
	    KRFreq[23][2] = 534;
	    KRFreq[30][20] = 533;
	    KRFreq[38][47] = 532;
	    KRFreq[39][12] = 531;
	    KRFreq[23][21] = 530;
	    KRFreq[18][17] = 529;
	    KRFreq[30][87] = 528;
	    KRFreq[29][62] = 527;
	    KRFreq[29][87] = 526;
	    KRFreq[34][53] = 525;
	    KRFreq[32][29] = 524;
	    KRFreq[35][0] = 523;
	    KRFreq[24][43] = 522;
	    KRFreq[36][44] = 521;
	    KRFreq[20][30] = 520;
	    KRFreq[39][86] = 519;
	    KRFreq[22][14] = 518;
	    KRFreq[29][39] = 517;
	    KRFreq[28][38] = 516;
	    KRFreq[23][79] = 515;
	    KRFreq[24][56] = 514;
	    KRFreq[29][63] = 513;
	    KRFreq[31][45] = 512;
	    KRFreq[23][26] = 511;
	    KRFreq[15][87] = 510;
	    KRFreq[30][74] = 509;
	    KRFreq[24][69] = 508;
	    KRFreq[20][4] = 507;
	    KRFreq[27][50] = 506;
	    KRFreq[30][75] = 505;
	    KRFreq[24][13] = 504;
	    KRFreq[30][8] = 503;
	    KRFreq[31][6] = 502;
	    KRFreq[25][80] = 501;
	    KRFreq[36][8] = 500;
	    KRFreq[15][18] = 499;
	    KRFreq[39][23] = 498;
	    KRFreq[16][24] = 497;
	    KRFreq[31][89] = 496;
	    KRFreq[15][71] = 495;
	    KRFreq[15][57] = 494;
	    KRFreq[30][11] = 493;
	    KRFreq[15][36] = 492;
	    KRFreq[16][60] = 491;
	    KRFreq[24][45] = 490;
	    KRFreq[37][35] = 489;
	    KRFreq[24][87] = 488;
	    KRFreq[20][45] = 487;
	    KRFreq[31][90] = 486;
	    KRFreq[32][21] = 485;
	    KRFreq[19][70] = 484;
	    KRFreq[24][15] = 483;
	    KRFreq[26][92] = 482;
	    KRFreq[37][13] = 481;
	    KRFreq[39][2] = 480;
	    KRFreq[23][70] = 479;
	    KRFreq[27][25] = 478;
	    KRFreq[15][69] = 477;
	    KRFreq[19][61] = 476;
	    KRFreq[31][58] = 475;
	    KRFreq[24][57] = 474;
	    KRFreq[36][74] = 473;
	    KRFreq[21][6] = 472;
	    KRFreq[30][44] = 471;
	    KRFreq[15][91] = 470;
	    KRFreq[27][16] = 469;
	    KRFreq[29][42] = 468;
	    KRFreq[33][86] = 467;
	    KRFreq[29][41] = 466;
	    KRFreq[20][68] = 465;
	    KRFreq[25][47] = 464;
	    KRFreq[22][0] = 463;
	    KRFreq[18][14] = 462;
	    KRFreq[31][28] = 461;
	    KRFreq[15][2] = 460;
	    KRFreq[23][76] = 459;
	    KRFreq[38][32] = 458;
	    KRFreq[29][82] = 457;
	    KRFreq[21][86] = 456;
	    KRFreq[24][62] = 455;
	    KRFreq[31][64] = 454;
	    KRFreq[38][26] = 453;
	    KRFreq[32][86] = 452;
	    KRFreq[22][32] = 451;
	    KRFreq[19][59] = 450;
	    KRFreq[34][18] = 449;
	    KRFreq[18][54] = 448;
	    KRFreq[38][63] = 447;
	    KRFreq[36][23] = 446;
	    KRFreq[35][35] = 445;
	    KRFreq[32][62] = 444;
	    KRFreq[28][35] = 443;
	    KRFreq[27][13] = 442;
	    KRFreq[31][59] = 441;
	    KRFreq[29][29] = 440;
	    KRFreq[15][64] = 439;
	    KRFreq[26][84] = 438;
	    KRFreq[21][90] = 437;
	    KRFreq[20][24] = 436;
	    KRFreq[16][18] = 435;
	    KRFreq[22][23] = 434;
	    KRFreq[31][14] = 433;
	    KRFreq[15][1] = 432;
	    KRFreq[18][63] = 431;
	    KRFreq[19][10] = 430;
	    KRFreq[25][49] = 429;
	    KRFreq[36][57] = 428;
	    KRFreq[20][22] = 427;
	    KRFreq[15][15] = 426;
	    KRFreq[31][51] = 425;
	    KRFreq[24][60] = 424;
	    KRFreq[31][70] = 423;
	    KRFreq[15][7] = 422;
	    KRFreq[28][40] = 421;
	    KRFreq[18][41] = 420;
	    KRFreq[15][38] = 419;
	    KRFreq[32][0] = 418;
	    KRFreq[19][51] = 417;
	    KRFreq[34][62] = 416;
	    KRFreq[16][27] = 415;
	    KRFreq[20][70] = 414;
	    KRFreq[22][33] = 413;
	    KRFreq[26][73] = 412;
	    KRFreq[20][79] = 411;
	    KRFreq[23][6] = 410;
	    KRFreq[24][85] = 409;
	    KRFreq[38][51] = 408;
	    KRFreq[29][88] = 407;
	    KRFreq[38][55] = 406;
	    KRFreq[32][32] = 405;
	    KRFreq[27][18] = 404;
	    KRFreq[23][87] = 403;
	    KRFreq[35][6] = 402;
	    KRFreq[34][27] = 401;
	    KRFreq[39][35] = 400;
	    KRFreq[30][88] = 399;
	    KRFreq[32][92] = 398;
	    KRFreq[32][49] = 397;
	    KRFreq[24][61] = 396;
	    KRFreq[18][74] = 395;
	    KRFreq[23][77] = 394;
	    KRFreq[23][50] = 393;
	    KRFreq[23][32] = 392;
	    KRFreq[23][36] = 391;
	    KRFreq[38][38] = 390;
	    KRFreq[29][86] = 389;
	    KRFreq[36][15] = 388;
	    KRFreq[31][50] = 387;
	    KRFreq[15][86] = 386;
	    KRFreq[39][13] = 385;
	    KRFreq[34][26] = 384;
	    KRFreq[19][34] = 383;
	    KRFreq[16][3] = 382;
	    KRFreq[26][93] = 381;
	    KRFreq[19][67] = 380;
	    KRFreq[24][72] = 379;
	    KRFreq[29][17] = 378;
	    KRFreq[23][24] = 377;
	    KRFreq[25][19] = 376;
	    KRFreq[18][65] = 375;
	    KRFreq[30][78] = 374;
	    KRFreq[27][52] = 373;
	    KRFreq[22][18] = 372;
	    KRFreq[16][38] = 371;
	    KRFreq[21][26] = 370;
	    KRFreq[34][20] = 369;
	    KRFreq[15][42] = 368;
	    KRFreq[16][71] = 367;
	    KRFreq[17][17] = 366;
	    KRFreq[24][71] = 365;
	    KRFreq[18][84] = 364;
	    KRFreq[15][40] = 363;
	    KRFreq[31][62] = 362;
	    KRFreq[15][8] = 361;
	    KRFreq[16][69] = 360;
	    KRFreq[29][79] = 359;
	    KRFreq[38][91] = 358;
	    KRFreq[31][92] = 357;
	    KRFreq[20][77] = 356;
	    KRFreq[3][16] = 355;
	    KRFreq[27][87] = 354;
	    KRFreq[16][25] = 353;
	    KRFreq[36][33] = 352;
	    KRFreq[37][76] = 351;
	    KRFreq[30][12] = 350;
	    KRFreq[26][75] = 349;
	    KRFreq[25][14] = 348;
	    KRFreq[32][26] = 347;
	    KRFreq[23][22] = 346;
	    KRFreq[20][90] = 345;
	    KRFreq[19][8] = 344;
	    KRFreq[38][41] = 343;
	    KRFreq[34][2] = 342;
	    KRFreq[39][4] = 341;
	    KRFreq[27][89] = 340;
	    KRFreq[28][41] = 339;
	    KRFreq[28][44] = 338;
	    KRFreq[24][92] = 337;
	    KRFreq[34][65] = 336;
	    KRFreq[39][14] = 335;
	    KRFreq[21][38] = 334;
	    KRFreq[19][31] = 333;
	    KRFreq[37][39] = 332;
	    KRFreq[33][41] = 331;
	    KRFreq[38][4] = 330;
	    KRFreq[23][80] = 329;
	    KRFreq[25][24] = 328;
	    KRFreq[37][17] = 327;
	    KRFreq[22][16] = 326;
	    KRFreq[22][46] = 325;
	    KRFreq[33][91] = 324;
	    KRFreq[24][89] = 323;
	    KRFreq[30][52] = 322;
	    KRFreq[29][38] = 321;
	    KRFreq[38][85] = 320;
	    KRFreq[15][12] = 319;
	    KRFreq[27][58] = 318;
	    KRFreq[29][52] = 317;
	    KRFreq[37][38] = 316;
	    KRFreq[34][41] = 315;
	    KRFreq[31][65] = 314;
	    KRFreq[29][53] = 313;
	    KRFreq[22][47] = 312;
	    KRFreq[22][19] = 311;
	    KRFreq[26][0] = 310;
	    KRFreq[37][86] = 309;
	    KRFreq[35][4] = 308;
	    KRFreq[36][54] = 307;
	    KRFreq[20][76] = 306;
	    KRFreq[30][9] = 305;
	    KRFreq[30][33] = 304;
	    KRFreq[23][17] = 303;
	    KRFreq[23][33] = 302;
	    KRFreq[38][52] = 301;
	    KRFreq[15][19] = 300;
	    KRFreq[28][45] = 299;
	    KRFreq[29][78] = 298;
	    KRFreq[23][15] = 297;
	    KRFreq[33][5] = 296;
	    KRFreq[17][40] = 295;
	    KRFreq[30][83] = 294;
	    KRFreq[18][1] = 293;
	    KRFreq[30][81] = 292;
	    KRFreq[19][40] = 291;
	    KRFreq[24][47] = 290;
	    KRFreq[17][56] = 289;
	    KRFreq[39][80] = 288;
	    KRFreq[30][46] = 287;
	    KRFreq[16][61] = 286;
	    KRFreq[26][78] = 285;
	    KRFreq[26][57] = 284;
	    KRFreq[20][46] = 283;
	    KRFreq[25][15] = 282;
	    KRFreq[25][91] = 281;
	    KRFreq[21][83] = 280;
	    KRFreq[30][77] = 279;
	    KRFreq[35][30] = 278;
	    KRFreq[30][34] = 277;
	    KRFreq[20][69] = 276;
	    KRFreq[35][10] = 275;
	    KRFreq[29][70] = 274;
	    KRFreq[22][50] = 273;
	    KRFreq[18][0] = 272;
	    KRFreq[22][64] = 271;
	    KRFreq[38][65] = 270;
	    KRFreq[22][70] = 269;
	    KRFreq[24][58] = 268;
	    KRFreq[19][66] = 267;
	    KRFreq[30][59] = 266;
	    KRFreq[37][14] = 265;
	    KRFreq[16][56] = 264;
	    KRFreq[29][85] = 263;
	    KRFreq[31][15] = 262;
	    KRFreq[36][84] = 261;
	    KRFreq[39][15] = 260;
	    KRFreq[39][90] = 259;
	    KRFreq[18][12] = 258;
	    KRFreq[21][93] = 257;
	    KRFreq[24][66] = 256;
	    KRFreq[27][90] = 255;
	    KRFreq[25][90] = 254;
	    KRFreq[22][24] = 253;
	    KRFreq[36][67] = 252;
	    KRFreq[33][90] = 251;
	    KRFreq[15][60] = 250;
	    KRFreq[23][85] = 249;
	    KRFreq[34][1] = 248;
	    KRFreq[39][37] = 247;
	    KRFreq[21][18] = 246;
	    KRFreq[34][4] = 245;
	    KRFreq[28][33] = 244;
	    KRFreq[15][13] = 243;
	    KRFreq[32][22] = 242;
	    KRFreq[30][76] = 241;
	    KRFreq[20][21] = 240;
	    KRFreq[38][66] = 239;
	    KRFreq[32][55] = 238;
	    KRFreq[32][89] = 237;
	    KRFreq[25][26] = 236;
	    KRFreq[16][80] = 235;
	    KRFreq[15][43] = 234;
	    KRFreq[38][54] = 233;
	    KRFreq[39][68] = 232;
	    KRFreq[22][88] = 231;
	    KRFreq[21][84] = 230;
	    KRFreq[21][17] = 229;
	    KRFreq[20][28] = 228;
	    KRFreq[32][1] = 227;
	    KRFreq[33][87] = 226;
	    KRFreq[38][71] = 225;
	    KRFreq[37][47] = 224;
	    KRFreq[18][77] = 223;
	    KRFreq[37][58] = 222;
	    KRFreq[34][74] = 221;
	    KRFreq[32][54] = 220;
	    KRFreq[27][33] = 219;
	    KRFreq[32][93] = 218;
	    KRFreq[23][51] = 217;
	    KRFreq[20][57] = 216;
	    KRFreq[22][37] = 215;
	    KRFreq[39][10] = 214;
	    KRFreq[39][17] = 213;
	    KRFreq[33][4] = 212;
	    KRFreq[32][84] = 211;
	    KRFreq[34][3] = 210;
	    KRFreq[28][27] = 209;
	    KRFreq[15][79] = 208;
	    KRFreq[34][21] = 207;
	    KRFreq[34][69] = 206;
	    KRFreq[21][62] = 205;
	    KRFreq[36][24] = 204;
	    KRFreq[16][89] = 203;
	    KRFreq[18][48] = 202;
	    KRFreq[38][15] = 201;
	    KRFreq[36][58] = 200;
	    KRFreq[21][56] = 199;
	    KRFreq[34][48] = 198;
	    KRFreq[21][15] = 197;
	    KRFreq[39][3] = 196;
	    KRFreq[16][44] = 195;
	    KRFreq[18][79] = 194;
	    KRFreq[25][13] = 193;
	    KRFreq[29][47] = 192;
	    KRFreq[38][88] = 191;
	    KRFreq[20][71] = 190;
	    KRFreq[16][58] = 189;
	    KRFreq[35][57] = 188;
	    KRFreq[29][30] = 187;
	    KRFreq[29][23] = 186;
	    KRFreq[34][93] = 185;
	    KRFreq[30][85] = 184;
	    KRFreq[15][80] = 183;
	    KRFreq[32][78] = 182;
	    KRFreq[37][82] = 181;
	    KRFreq[22][40] = 180;
	    KRFreq[21][69] = 179;
	    KRFreq[26][85] = 178;
	    KRFreq[31][31] = 177;
	    KRFreq[28][64] = 176;
	    KRFreq[38][13] = 175;
	    KRFreq[25][2] = 174;
	    KRFreq[22][34] = 173;
	    KRFreq[28][28] = 172;
	    KRFreq[24][91] = 171;
	    KRFreq[33][74] = 170;
	    KRFreq[29][40] = 169;
	    KRFreq[15][77] = 168;
	    KRFreq[32][80] = 167;
	    KRFreq[30][41] = 166;
	    KRFreq[23][30] = 165;
	    KRFreq[24][63] = 164;
	    KRFreq[30][53] = 163;
	    KRFreq[39][70] = 162;
	    KRFreq[23][61] = 161;
	    KRFreq[37][27] = 160;
	    KRFreq[16][55] = 159;
	    KRFreq[22][74] = 158;
	    KRFreq[26][50] = 157;
	    KRFreq[16][10] = 156;
	    KRFreq[34][63] = 155;
	    KRFreq[35][14] = 154;
	    KRFreq[17][7] = 153;
	    KRFreq[15][59] = 152;
	    KRFreq[27][23] = 151;
	    KRFreq[18][70] = 150;
	    KRFreq[32][56] = 149;
	    KRFreq[37][87] = 148;
	    KRFreq[17][61] = 147;
	    KRFreq[18][83] = 146;
	    KRFreq[23][86] = 145;
	    KRFreq[17][31] = 144;
	    KRFreq[23][83] = 143;
	    KRFreq[35][2] = 142;
	    KRFreq[18][64] = 141;
	    KRFreq[27][43] = 140;
	    KRFreq[32][42] = 139;
	    KRFreq[25][76] = 138;
	    KRFreq[19][85] = 137;
	    KRFreq[37][81] = 136;
	    KRFreq[38][83] = 135;
	    KRFreq[35][7] = 134;
	    KRFreq[16][51] = 133;
	    KRFreq[27][22] = 132;
	    KRFreq[16][76] = 131;
	    KRFreq[22][4] = 130;
	    KRFreq[38][84] = 129;
	    KRFreq[17][83] = 128;
	    KRFreq[24][46] = 127;
	    KRFreq[33][15] = 126;
	    KRFreq[20][48] = 125;
	    KRFreq[17][30] = 124;
	    KRFreq[30][93] = 123;
	    KRFreq[28][11] = 122;
	    KRFreq[28][30] = 121;
	    KRFreq[15][62] = 120;
	    KRFreq[17][87] = 119;
	    KRFreq[32][81] = 118;
	    KRFreq[23][37] = 117;
	    KRFreq[30][22] = 116;
	    KRFreq[32][66] = 115;
	    KRFreq[33][78] = 114;
	    KRFreq[21][4] = 113;
	    KRFreq[31][17] = 112;
	    KRFreq[39][61] = 111;
	    KRFreq[18][76] = 110;
	    KRFreq[15][85] = 109;
	    KRFreq[31][47] = 108;
	    KRFreq[19][57] = 107;
	    KRFreq[23][55] = 106;
	    KRFreq[27][29] = 105;
	    KRFreq[29][46] = 104;
	    KRFreq[33][0] = 103;
	    KRFreq[16][83] = 102;
	    KRFreq[39][78] = 101;
	    KRFreq[32][77] = 100;
	    KRFreq[36][25] = 99;
	    KRFreq[34][19] = 98;
	    KRFreq[38][49] = 97;
	    KRFreq[19][25] = 96;
	    KRFreq[23][53] = 95;
	    KRFreq[28][43] = 94;
	    KRFreq[31][44] = 93;
	    KRFreq[36][34] = 92;
	    KRFreq[16][34] = 91;
	    KRFreq[35][1] = 90;
	    KRFreq[19][87] = 89;
	    KRFreq[18][53] = 88;
	    KRFreq[29][54] = 87;
	    KRFreq[22][41] = 86;
	    KRFreq[38][18] = 85;
	    KRFreq[22][2] = 84;
	    KRFreq[20][3] = 83;
	    KRFreq[39][69] = 82;
	    KRFreq[30][29] = 81;
	    KRFreq[28][19] = 80;
	    KRFreq[29][90] = 79;
	    KRFreq[17][86] = 78;
	    KRFreq[15][9] = 77;
	    KRFreq[39][73] = 76;
	    KRFreq[15][37] = 75;
	    KRFreq[35][40] = 74;
	    KRFreq[33][77] = 73;
	    KRFreq[27][86] = 72;
	    KRFreq[36][79] = 71;
	    KRFreq[23][18] = 70;
	    KRFreq[34][87] = 69;
	    KRFreq[39][24] = 68;
	    KRFreq[26][8] = 67;
	    KRFreq[33][48] = 66;
	    KRFreq[39][30] = 65;
	    KRFreq[33][28] = 64;
	    KRFreq[16][67] = 63;
	    KRFreq[31][78] = 62;
	    KRFreq[32][23] = 61;
	    KRFreq[24][55] = 60;
	    KRFreq[30][68] = 59;
	    KRFreq[18][60] = 58;
	    KRFreq[15][17] = 57;
	    KRFreq[23][34] = 56;
	    KRFreq[20][49] = 55;
	    KRFreq[15][78] = 54;
	    KRFreq[24][14] = 53;
	    KRFreq[19][41] = 52;
	    KRFreq[31][55] = 51;
	    KRFreq[21][39] = 50;
	    KRFreq[35][9] = 49;
	    KRFreq[30][15] = 48;
	    KRFreq[20][52] = 47;
	    KRFreq[35][71] = 46;
	    KRFreq[20][7] = 45;
	    KRFreq[29][72] = 44;
	    KRFreq[37][77] = 43;
	    KRFreq[22][35] = 42;
	    KRFreq[20][61] = 41;
	    KRFreq[31][60] = 40;
	    KRFreq[20][93] = 39;
	    KRFreq[27][92] = 38;
	    KRFreq[28][16] = 37;
	    KRFreq[36][26] = 36;
	    KRFreq[18][89] = 35;
	    KRFreq[21][63] = 34;
	    KRFreq[22][52] = 33;
	    KRFreq[24][65] = 32;
	    KRFreq[31][8] = 31;
	    KRFreq[31][49] = 30;
	    KRFreq[33][30] = 29;
	    KRFreq[37][15] = 28;
	    KRFreq[18][18] = 27;
	    KRFreq[25][50] = 26;
	    KRFreq[29][20] = 25;
	    KRFreq[35][48] = 24;
	    KRFreq[38][75] = 23;
	    KRFreq[26][83] = 22;
	    KRFreq[21][87] = 21;
	    KRFreq[27][71] = 20;
	    KRFreq[32][91] = 19;
	    KRFreq[25][73] = 18;
	    KRFreq[16][84] = 17;
	    KRFreq[25][31] = 16;
	    KRFreq[17][90] = 15;
	    KRFreq[18][40] = 14;
	    KRFreq[17][77] = 13;
	    KRFreq[17][35] = 12;
	    KRFreq[23][52] = 11;
	    KRFreq[23][35] = 10;
	    KRFreq[16][5] = 9;
	    KRFreq[23][58] = 8;
	    KRFreq[19][60] = 7;
	    KRFreq[30][32] = 6;
	    KRFreq[38][34] = 5;
	    KRFreq[23][4] = 4;
	    KRFreq[23][1] = 3;
	    KRFreq[27][57] = 2;
	    KRFreq[39][38] = 1;
	    KRFreq[32][33] = 0;
	    JPFreq[3][74] = 600;
	    JPFreq[3][45] = 599;
	    JPFreq[3][3] = 598;
	    JPFreq[3][24] = 597;
	    JPFreq[3][30] = 596;
	    JPFreq[3][42] = 595;
	    JPFreq[3][46] = 594;
	    JPFreq[3][39] = 593;
	    JPFreq[3][11] = 592;
	    JPFreq[3][37] = 591;
	    JPFreq[3][38] = 590;
	    JPFreq[3][31] = 589;
	    JPFreq[3][41] = 588;
	    JPFreq[3][5] = 587;
	    JPFreq[3][10] = 586;
	    JPFreq[3][75] = 585;
	    JPFreq[3][65] = 584;
	    JPFreq[3][72] = 583;
	    JPFreq[37][91] = 582;
	    JPFreq[0][27] = 581;
	    JPFreq[3][18] = 580;
	    JPFreq[3][22] = 579;
	    JPFreq[3][61] = 578;
	    JPFreq[3][14] = 577;
	    JPFreq[24][80] = 576;
	    JPFreq[4][82] = 575;
	    JPFreq[17][80] = 574;
	    JPFreq[30][44] = 573;
	    JPFreq[3][73] = 572;
	    JPFreq[3][64] = 571;
	    JPFreq[38][14] = 570;
	    JPFreq[33][70] = 569;
	    JPFreq[3][1] = 568;
	    JPFreq[3][16] = 567;
	    JPFreq[3][35] = 566;
	    JPFreq[3][40] = 565;
	    JPFreq[4][74] = 564;
	    JPFreq[4][24] = 563;
	    JPFreq[42][59] = 562;
	    JPFreq[3][7] = 561;
	    JPFreq[3][71] = 560;
	    JPFreq[3][12] = 559;
	    JPFreq[15][75] = 558;
	    JPFreq[3][20] = 557;
	    JPFreq[4][39] = 556;
	    JPFreq[34][69] = 555;
	    JPFreq[3][28] = 554;
	    JPFreq[35][24] = 553;
	    JPFreq[3][82] = 552;
	    JPFreq[28][47] = 551;
	    JPFreq[3][67] = 550;
	    JPFreq[37][16] = 549;
	    JPFreq[26][93] = 548;
	    JPFreq[4][1] = 547;
	    JPFreq[26][85] = 546;
	    JPFreq[31][14] = 545;
	    JPFreq[4][3] = 544;
	    JPFreq[4][72] = 543;
	    JPFreq[24][51] = 542;
	    JPFreq[27][51] = 541;
	    JPFreq[27][49] = 540;
	    JPFreq[22][77] = 539;
	    JPFreq[27][10] = 538;
	    JPFreq[29][68] = 537;
	    JPFreq[20][35] = 536;
	    JPFreq[41][11] = 535;
	    JPFreq[24][70] = 534;
	    JPFreq[36][61] = 533;
	    JPFreq[31][23] = 532;
	    JPFreq[43][16] = 531;
	    JPFreq[23][68] = 530;
	    JPFreq[32][15] = 529;
	    JPFreq[3][32] = 528;
	    JPFreq[19][53] = 527;
	    JPFreq[40][83] = 526;
	    JPFreq[4][14] = 525;
	    JPFreq[36][9] = 524;
	    JPFreq[4][73] = 523;
	    JPFreq[23][10] = 522;
	    JPFreq[3][63] = 521;
	    JPFreq[39][14] = 520;
	    JPFreq[3][78] = 519;
	    JPFreq[33][47] = 518;
	    JPFreq[21][39] = 517;
	    JPFreq[34][46] = 516;
	    JPFreq[36][75] = 515;
	    JPFreq[41][92] = 514;
	    JPFreq[37][93] = 513;
	    JPFreq[4][34] = 512;
	    JPFreq[15][86] = 511;
	    JPFreq[46][1] = 510;
	    JPFreq[37][65] = 509;
	    JPFreq[3][62] = 508;
	    JPFreq[32][73] = 507;
	    JPFreq[21][65] = 506;
	    JPFreq[29][75] = 505;
	    JPFreq[26][51] = 504;
	    JPFreq[3][34] = 503;
	    JPFreq[4][10] = 502;
	    JPFreq[30][22] = 501;
	    JPFreq[35][73] = 500;
	    JPFreq[17][82] = 499;
	    JPFreq[45][8] = 498;
	    JPFreq[27][73] = 497;
	    JPFreq[18][55] = 496;
	    JPFreq[25][2] = 495;
	    JPFreq[3][26] = 494;
	    JPFreq[45][46] = 493;
	    JPFreq[4][22] = 492;
	    JPFreq[4][40] = 491;
	    JPFreq[18][10] = 490;
	    JPFreq[32][9] = 489;
	    JPFreq[26][49] = 488;
	    JPFreq[3][47] = 487;
	    JPFreq[24][65] = 486;
	    JPFreq[4][76] = 485;
	    JPFreq[43][67] = 484;
	    JPFreq[3][9] = 483;
	    JPFreq[41][37] = 482;
	    JPFreq[33][68] = 481;
	    JPFreq[43][31] = 480;
	    JPFreq[19][55] = 479;
	    JPFreq[4][30] = 478;
	    JPFreq[27][33] = 477;
	    JPFreq[16][62] = 476;
	    JPFreq[36][35] = 475;
	    JPFreq[37][15] = 474;
	    JPFreq[27][70] = 473;
	    JPFreq[22][71] = 472;
	    JPFreq[33][45] = 471;
	    JPFreq[31][78] = 470;
	    JPFreq[43][59] = 469;
	    JPFreq[32][19] = 468;
	    JPFreq[17][28] = 467;
	    JPFreq[40][28] = 466;
	    JPFreq[20][93] = 465;
	    JPFreq[18][15] = 464;
	    JPFreq[4][23] = 463;
	    JPFreq[3][23] = 462;
	    JPFreq[26][64] = 461;
	    JPFreq[44][92] = 460;
	    JPFreq[17][27] = 459;
	    JPFreq[3][56] = 458;
	    JPFreq[25][38] = 457;
	    JPFreq[23][31] = 456;
	    JPFreq[35][43] = 455;
	    JPFreq[4][54] = 454;
	    JPFreq[35][19] = 453;
	    JPFreq[22][47] = 452;
	    JPFreq[42][0] = 451;
	    JPFreq[23][28] = 450;
	    JPFreq[46][33] = 449;
	    JPFreq[36][85] = 448;
	    JPFreq[31][12] = 447;
	    JPFreq[3][76] = 446;
	    JPFreq[4][75] = 445;
	    JPFreq[36][56] = 444;
	    JPFreq[4][64] = 443;
	    JPFreq[25][77] = 442;
	    JPFreq[15][52] = 441;
	    JPFreq[33][73] = 440;
	    JPFreq[3][55] = 439;
	    JPFreq[43][82] = 438;
	    JPFreq[27][82] = 437;
	    JPFreq[20][3] = 436;
	    JPFreq[40][51] = 435;
	    JPFreq[3][17] = 434;
	    JPFreq[27][71] = 433;
	    JPFreq[4][52] = 432;
	    JPFreq[44][48] = 431;
	    JPFreq[27][2] = 430;
	    JPFreq[17][39] = 429;
	    JPFreq[31][8] = 428;
	    JPFreq[44][54] = 427;
	    JPFreq[43][18] = 426;
	    JPFreq[43][77] = 425;
	    JPFreq[4][61] = 424;
	    JPFreq[19][91] = 423;
	    JPFreq[31][13] = 422;
	    JPFreq[44][71] = 421;
	    JPFreq[20][0] = 420;
	    JPFreq[23][87] = 419;
	    JPFreq[21][14] = 418;
	    JPFreq[29][13] = 417;
	    JPFreq[3][58] = 416;
	    JPFreq[26][18] = 415;
	    JPFreq[4][47] = 414;
	    JPFreq[4][18] = 413;
	    JPFreq[3][53] = 412;
	    JPFreq[26][92] = 411;
	    JPFreq[21][7] = 410;
	    JPFreq[4][37] = 409;
	    JPFreq[4][63] = 408;
	    JPFreq[36][51] = 407;
	    JPFreq[4][32] = 406;
	    JPFreq[28][73] = 405;
	    JPFreq[4][50] = 404;
	    JPFreq[41][60] = 403;
	    JPFreq[23][1] = 402;
	    JPFreq[36][92] = 401;
	    JPFreq[15][41] = 400;
	    JPFreq[21][71] = 399;
	    JPFreq[41][30] = 398;
	    JPFreq[32][76] = 397;
	    JPFreq[17][34] = 396;
	    JPFreq[26][15] = 395;
	    JPFreq[26][25] = 394;
	    JPFreq[31][77] = 393;
	    JPFreq[31][3] = 392;
	    JPFreq[46][34] = 391;
	    JPFreq[27][84] = 390;
	    JPFreq[23][8] = 389;
	    JPFreq[16][0] = 388;
	    JPFreq[28][80] = 387;
	    JPFreq[26][54] = 386;
	    JPFreq[33][18] = 385;
	    JPFreq[31][20] = 384;
	    JPFreq[31][62] = 383;
	    JPFreq[30][41] = 382;
	    JPFreq[33][30] = 381;
	    JPFreq[45][45] = 380;
	    JPFreq[37][82] = 379;
	    JPFreq[15][33] = 378;
	    JPFreq[20][12] = 377;
	    JPFreq[18][5] = 376;
	    JPFreq[28][86] = 375;
	    JPFreq[30][19] = 374;
	    JPFreq[42][43] = 373;
	    JPFreq[36][31] = 372;
	    JPFreq[17][93] = 371;
	    JPFreq[4][15] = 370;
	    JPFreq[21][20] = 369;
	    JPFreq[23][21] = 368;
	    JPFreq[28][72] = 367;
	    JPFreq[4][20] = 366;
	    JPFreq[26][55] = 365;
	    JPFreq[21][5] = 364;
	    JPFreq[19][16] = 363;
	    JPFreq[23][64] = 362;
	    JPFreq[40][59] = 361;
	    JPFreq[37][26] = 360;
	    JPFreq[26][56] = 359;
	    JPFreq[4][12] = 358;
	    JPFreq[33][71] = 357;
	    JPFreq[32][39] = 356;
	    JPFreq[38][40] = 355;
	    JPFreq[22][74] = 354;
	    JPFreq[3][25] = 353;
	    JPFreq[15][48] = 352;
	    JPFreq[41][82] = 351;
	    JPFreq[41][9] = 350;
	    JPFreq[25][48] = 349;
	    JPFreq[31][71] = 348;
	    JPFreq[43][29] = 347;
	    JPFreq[26][80] = 346;
	    JPFreq[4][5] = 345;
	    JPFreq[18][71] = 344;
	    JPFreq[29][0] = 343;
	    JPFreq[43][43] = 342;
	    JPFreq[23][81] = 341;
	    JPFreq[4][42] = 340;
	    JPFreq[44][28] = 339;
	    JPFreq[23][93] = 338;
	    JPFreq[17][81] = 337;
	    JPFreq[25][25] = 336;
	    JPFreq[41][23] = 335;
	    JPFreq[34][35] = 334;
	    JPFreq[4][53] = 333;
	    JPFreq[28][36] = 332;
	    JPFreq[4][41] = 331;
	    JPFreq[25][60] = 330;
	    JPFreq[23][20] = 329;
	    JPFreq[3][43] = 328;
	    JPFreq[24][79] = 327;
	    JPFreq[29][41] = 326;
	    JPFreq[30][83] = 325;
	    JPFreq[3][50] = 324;
	    JPFreq[22][18] = 323;
	    JPFreq[18][3] = 322;
	    JPFreq[39][30] = 321;
	    JPFreq[4][28] = 320;
	    JPFreq[21][64] = 319;
	    JPFreq[4][68] = 318;
	    JPFreq[17][71] = 317;
	    JPFreq[27][0] = 316;
	    JPFreq[39][28] = 315;
	    JPFreq[30][13] = 314;
	    JPFreq[36][70] = 313;
	    JPFreq[20][82] = 312;
	    JPFreq[33][38] = 311;
	    JPFreq[44][87] = 310;
	    JPFreq[34][45] = 309;
	    JPFreq[4][26] = 308;
	    JPFreq[24][44] = 307;
	    JPFreq[38][67] = 306;
	    JPFreq[38][6] = 305;
	    JPFreq[30][68] = 304;
	    JPFreq[15][89] = 303;
	    JPFreq[24][93] = 302;
	    JPFreq[40][41] = 301;
	    JPFreq[38][3] = 300;
	    JPFreq[28][23] = 299;
	    JPFreq[26][17] = 298;
	    JPFreq[4][38] = 297;
	    JPFreq[22][78] = 296;
	    JPFreq[15][37] = 295;
	    JPFreq[25][85] = 294;
	    JPFreq[4][9] = 293;
	    JPFreq[4][7] = 292;
	    JPFreq[27][53] = 291;
	    JPFreq[39][29] = 290;
	    JPFreq[41][43] = 289;
	    JPFreq[25][62] = 288;
	    JPFreq[4][48] = 287;
	    JPFreq[28][28] = 286;
	    JPFreq[21][40] = 285;
	    JPFreq[36][73] = 284;
	    JPFreq[26][39] = 283;
	    JPFreq[22][54] = 282;
	    JPFreq[33][5] = 281;
	    JPFreq[19][21] = 280;
	    JPFreq[46][31] = 279;
	    JPFreq[20][64] = 278;
	    JPFreq[26][63] = 277;
	    JPFreq[22][23] = 276;
	    JPFreq[25][81] = 275;
	    JPFreq[4][62] = 274;
	    JPFreq[37][31] = 273;
	    JPFreq[40][52] = 272;
	    JPFreq[29][79] = 271;
	    JPFreq[41][48] = 270;
	    JPFreq[31][57] = 269;
	    JPFreq[32][92] = 268;
	    JPFreq[36][36] = 267;
	    JPFreq[27][7] = 266;
	    JPFreq[35][29] = 265;
	    JPFreq[37][34] = 264;
	    JPFreq[34][42] = 263;
	    JPFreq[27][15] = 262;
	    JPFreq[33][27] = 261;
	    JPFreq[31][38] = 260;
	    JPFreq[19][79] = 259;
	    JPFreq[4][31] = 258;
	    JPFreq[4][66] = 257;
	    JPFreq[17][32] = 256;
	    JPFreq[26][67] = 255;
	    JPFreq[16][30] = 254;
	    JPFreq[26][46] = 253;
	    JPFreq[24][26] = 252;
	    JPFreq[35][10] = 251;
	    JPFreq[18][37] = 250;
	    JPFreq[3][19] = 249;
	    JPFreq[33][69] = 248;
	    JPFreq[31][9] = 247;
	    JPFreq[45][29] = 246;
	    JPFreq[3][15] = 245;
	    JPFreq[18][54] = 244;
	    JPFreq[3][44] = 243;
	    JPFreq[31][29] = 242;
	    JPFreq[18][45] = 241;
	    JPFreq[38][28] = 240;
	    JPFreq[24][12] = 239;
	    JPFreq[35][82] = 238;
	    JPFreq[17][43] = 237;
	    JPFreq[28][9] = 236;
	    JPFreq[23][25] = 235;
	    JPFreq[44][37] = 234;
	    JPFreq[23][75] = 233;
	    JPFreq[23][92] = 232;
	    JPFreq[0][24] = 231;
	    JPFreq[19][74] = 230;
	    JPFreq[45][32] = 229;
	    JPFreq[16][72] = 228;
	    JPFreq[16][93] = 227;
	    JPFreq[45][13] = 226;
	    JPFreq[24][8] = 225;
	    JPFreq[25][47] = 224;
	    JPFreq[28][26] = 223;
	    JPFreq[43][81] = 222;
	    JPFreq[32][71] = 221;
	    JPFreq[18][41] = 220;
	    JPFreq[26][62] = 219;
	    JPFreq[41][24] = 218;
	    JPFreq[40][11] = 217;
	    JPFreq[43][57] = 216;
	    JPFreq[34][53] = 215;
	    JPFreq[20][32] = 214;
	    JPFreq[34][43] = 213;
	    JPFreq[41][91] = 212;
	    JPFreq[29][57] = 211;
	    JPFreq[15][43] = 210;
	    JPFreq[22][89] = 209;
	    JPFreq[33][83] = 208;
	    JPFreq[43][20] = 207;
	    JPFreq[25][58] = 206;
	    JPFreq[30][30] = 205;
	    JPFreq[4][56] = 204;
	    JPFreq[17][64] = 203;
	    JPFreq[23][0] = 202;
	    JPFreq[44][12] = 201;
	    JPFreq[25][37] = 200;
	    JPFreq[35][13] = 199;
	    JPFreq[20][30] = 198;
	    JPFreq[21][84] = 197;
	    JPFreq[29][14] = 196;
	    JPFreq[30][5] = 195;
	    JPFreq[37][2] = 194;
	    JPFreq[4][78] = 193;
	    JPFreq[29][78] = 192;
	    JPFreq[29][84] = 191;
	    JPFreq[32][86] = 190;
	    JPFreq[20][68] = 189;
	    JPFreq[30][39] = 188;
	    JPFreq[15][69] = 187;
	    JPFreq[4][60] = 186;
	    JPFreq[20][61] = 185;
	    JPFreq[41][67] = 184;
	    JPFreq[16][35] = 183;
	    JPFreq[36][57] = 182;
	    JPFreq[39][80] = 181;
	    JPFreq[4][59] = 180;
	    JPFreq[4][44] = 179;
	    JPFreq[40][54] = 178;
	    JPFreq[30][8] = 177;
	    JPFreq[44][30] = 176;
	    JPFreq[31][93] = 175;
	    JPFreq[31][47] = 174;
	    JPFreq[16][70] = 173;
	    JPFreq[21][0] = 172;
	    JPFreq[17][35] = 171;
	    JPFreq[21][67] = 170;
	    JPFreq[44][18] = 169;
	    JPFreq[36][29] = 168;
	    JPFreq[18][67] = 167;
	    JPFreq[24][28] = 166;
	    JPFreq[36][24] = 165;
	    JPFreq[23][5] = 164;
	    JPFreq[31][65] = 163;
	    JPFreq[26][59] = 162;
	    JPFreq[28][2] = 161;
	    JPFreq[39][69] = 160;
	    JPFreq[42][40] = 159;
	    JPFreq[37][80] = 158;
	    JPFreq[15][66] = 157;
	    JPFreq[34][38] = 156;
	    JPFreq[28][48] = 155;
	    JPFreq[37][77] = 154;
	    JPFreq[29][34] = 153;
	    JPFreq[33][12] = 152;
	    JPFreq[4][65] = 151;
	    JPFreq[30][31] = 150;
	    JPFreq[27][92] = 149;
	    JPFreq[4][2] = 148;
	    JPFreq[4][51] = 147;
	    JPFreq[23][77] = 146;
	    JPFreq[4][35] = 145;
	    JPFreq[3][13] = 144;
	    JPFreq[26][26] = 143;
	    JPFreq[44][4] = 142;
	    JPFreq[39][53] = 141;
	    JPFreq[20][11] = 140;
	    JPFreq[40][33] = 139;
	    JPFreq[45][7] = 138;
	    JPFreq[4][70] = 137;
	    JPFreq[3][49] = 136;
	    JPFreq[20][59] = 135;
	    JPFreq[21][12] = 134;
	    JPFreq[33][53] = 133;
	    JPFreq[20][14] = 132;
	    JPFreq[37][18] = 131;
	    JPFreq[18][17] = 130;
	    JPFreq[36][23] = 129;
	    JPFreq[18][57] = 128;
	    JPFreq[26][74] = 127;
	    JPFreq[35][2] = 126;
	    JPFreq[38][58] = 125;
	    JPFreq[34][68] = 124;
	    JPFreq[29][81] = 123;
	    JPFreq[20][69] = 122;
	    JPFreq[39][86] = 121;
	    JPFreq[4][16] = 120;
	    JPFreq[16][49] = 119;
	    JPFreq[15][72] = 118;
	    JPFreq[26][35] = 117;
	    JPFreq[32][14] = 116;
	    JPFreq[40][90] = 115;
	    JPFreq[33][79] = 114;
	    JPFreq[35][4] = 113;
	    JPFreq[23][33] = 112;
	    JPFreq[19][19] = 111;
	    JPFreq[31][41] = 110;
	    JPFreq[44][1] = 109;
	    JPFreq[22][56] = 108;
	    JPFreq[31][27] = 107;
	    JPFreq[32][18] = 106;
	    JPFreq[27][32] = 105;
	    JPFreq[37][39] = 104;
	    JPFreq[42][11] = 103;
	    JPFreq[29][71] = 102;
	    JPFreq[32][58] = 101;
	    JPFreq[46][10] = 100;
	    JPFreq[17][30] = 99;
	    JPFreq[38][15] = 98;
	    JPFreq[29][60] = 97;
	    JPFreq[4][11] = 96;
	    JPFreq[38][31] = 95;
	    JPFreq[40][79] = 94;
	    JPFreq[28][49] = 93;
	    JPFreq[28][84] = 92;
	    JPFreq[26][77] = 91;
	    JPFreq[22][32] = 90;
	    JPFreq[33][17] = 89;
	    JPFreq[23][18] = 88;
	    JPFreq[32][64] = 87;
	    JPFreq[4][6] = 86;
	    JPFreq[33][51] = 85;
	    JPFreq[44][77] = 84;
	    JPFreq[29][5] = 83;
	    JPFreq[46][25] = 82;
	    JPFreq[19][58] = 81;
	    JPFreq[4][46] = 80;
	    JPFreq[15][71] = 79;
	    JPFreq[18][58] = 78;
	    JPFreq[26][45] = 77;
	    JPFreq[45][66] = 76;
	    JPFreq[34][10] = 75;
	    JPFreq[19][37] = 74;
	    JPFreq[33][65] = 73;
	    JPFreq[44][52] = 72;
	    JPFreq[16][38] = 71;
	    JPFreq[36][46] = 70;
	    JPFreq[20][26] = 69;
	    JPFreq[30][37] = 68;
	    JPFreq[4][58] = 67;
	    JPFreq[43][2] = 66;
	    JPFreq[30][18] = 65;
	    JPFreq[19][35] = 64;
	    JPFreq[15][68] = 63;
	    JPFreq[3][36] = 62;
	    JPFreq[35][40] = 61;
	    JPFreq[36][32] = 60;
	    JPFreq[37][14] = 59;
	    JPFreq[17][11] = 58;
	    JPFreq[19][78] = 57;
	    JPFreq[37][11] = 56;
	    JPFreq[28][63] = 55;
	    JPFreq[29][61] = 54;
	    JPFreq[33][3] = 53;
	    JPFreq[41][52] = 52;
	    JPFreq[33][63] = 51;
	    JPFreq[22][41] = 50;
	    JPFreq[4][19] = 49;
	    JPFreq[32][41] = 48;
	    JPFreq[24][4] = 47;
	    JPFreq[31][28] = 46;
	    JPFreq[43][30] = 45;
	    JPFreq[17][3] = 44;
	    JPFreq[43][70] = 43;
	    JPFreq[34][19] = 42;
	    JPFreq[20][77] = 41;
	    JPFreq[18][83] = 40;
	    JPFreq[17][15] = 39;
	    JPFreq[23][61] = 38;
	    JPFreq[40][27] = 37;
	    JPFreq[16][48] = 36;
	    JPFreq[39][78] = 35;
	    JPFreq[41][53] = 34;
	    JPFreq[40][91] = 33;
	    JPFreq[40][72] = 32;
	    JPFreq[18][52] = 31;
	    JPFreq[35][66] = 30;
	    JPFreq[39][93] = 29;
	    JPFreq[19][48] = 28;
	    JPFreq[26][36] = 27;
	    JPFreq[27][25] = 26;
	    JPFreq[42][71] = 25;
	    JPFreq[42][85] = 24;
	    JPFreq[26][48] = 23;
	    JPFreq[28][15] = 22;
	    JPFreq[3][66] = 21;
	    JPFreq[25][24] = 20;
	    JPFreq[27][43] = 19;
	    JPFreq[27][78] = 18;
	    JPFreq[45][43] = 17;
	    JPFreq[27][72] = 16;
	    JPFreq[40][29] = 15;
	    JPFreq[41][0] = 14;
	    JPFreq[19][57] = 13;
	    JPFreq[15][59] = 12;
	    JPFreq[29][29] = 11;
	    JPFreq[4][25] = 10;
	    JPFreq[21][42] = 9;
	    JPFreq[23][35] = 8;
	    JPFreq[33][1] = 7;
	    JPFreq[4][57] = 6;
	    JPFreq[17][60] = 5;
	    JPFreq[25][19] = 4;
	    JPFreq[22][65] = 3;
	    JPFreq[42][29] = 2;
	    JPFreq[27][66] = 1;
	    JPFreq[26][89] = 0;
	  }
	}
 
	class Encoding {
	  // Supported Encoding Types
	  public static int GB2312 = 0;
 
	  public static int GBK = 1;
 
	  public static int GB18030 = 2;
 
	  public static int HZ = 3;
 
	  public static int BIG5 = 4;
 
	  public static int CNS11643 = 5;
 
	  public static int UTF8 = 6;
 
	  public static int UTF8T = 7;
 
	  public static int UTF8S = 8;
 
	  public static int UNICODE = 9;
 
	  public static int UNICODET = 10;
 
	  public static int UNICODES = 11;
 
	  public static int ISO2022CN = 12;
 
	  public static int ISO2022CN_CNS = 13;
 
	  public static int ISO2022CN_GB = 14;
 
	  public static int EUC_KR = 15;
 
	  public static int CP949 = 16;
 
	  public static int ISO2022KR = 17;
 
	  public static int JOHAB = 18;
 
	  public static int SJIS = 19;
 
	  public static int EUC_JP = 20;
 
	  public static int ISO2022JP = 21;
 
	  public static int ASCII = 22;
 
	  public static int OTHER = 23;
 
	  public static int TOTALTYPES = 24;
 
	  public final static int SIMP = 0;
 
	  public final static int TRAD = 1;
 
	  // Names of the encodings as understood by Java
	  public static String[] javaname;
 
	  // Names of the encodings for human viewing
	  public static String[] nicename;
 
	  // Names of charsets as used in charset parameter of HTML Meta tag
	  public static String[] htmlname;
 
	  // Constructor
	  public Encoding() {
	    javaname = new String[TOTALTYPES];
	    nicename = new String[TOTALTYPES];
	    htmlname = new String[TOTALTYPES];
	    // Assign encoding names
	    javaname[GB2312] = "GB2312";
	    javaname[GBK] = "GBK";
	    javaname[GB18030] = "GB18030";
	    javaname[HZ] = "ASCII"; // What to put here? Sun doesn't support HZ
	    javaname[ISO2022CN_GB] = "ISO2022CN_GB";
	    javaname[BIG5] = "BIG5";
	    javaname[CNS11643] = "EUC-TW";
	    javaname[ISO2022CN_CNS] = "ISO2022CN_CNS";
	    javaname[ISO2022CN] = "ISO2022CN";
	    javaname[UTF8] = "UTF-8";
	    javaname[UTF8T] = "UTF-8";
	    javaname[UTF8S] = "UTF-8";
	    javaname[UNICODE] = "Unicode";
	    javaname[UNICODET] = "Unicode";
	    javaname[UNICODES] = "Unicode";
	    javaname[EUC_KR] = "EUC_KR";
	    javaname[CP949] = "MS949";
	    javaname[ISO2022KR] = "ISO2022KR";
	    javaname[JOHAB] = "Johab";
	    javaname[SJIS] = "SJIS";
	    javaname[EUC_JP] = "EUC_JP";
	    javaname[ISO2022JP] = "ISO2022JP";
	    javaname[ASCII] = "ASCII";
	    javaname[OTHER] = "ISO8859_1";
	    // Assign encoding names
	    htmlname[GB2312] = "GB2312";
	    htmlname[GBK] = "GBK";
	    htmlname[GB18030] = "GB18030";
	    htmlname[HZ] = "HZ-GB-2312";
	    htmlname[ISO2022CN_GB] = "ISO-2022-CN-EXT";
	    htmlname[BIG5] = "BIG5";
	    htmlname[CNS11643] = "EUC-TW";
	    htmlname[ISO2022CN_CNS] = "ISO-2022-CN-EXT";
	    htmlname[ISO2022CN] = "ISO-2022-CN";
	    htmlname[UTF8] = "UTF-8";
	    htmlname[UTF8T] = "UTF-8";
	    htmlname[UTF8S] = "UTF-8";
	    htmlname[UNICODE] = "UTF-16";
	    htmlname[UNICODET] = "UTF-16";
	    htmlname[UNICODES] = "UTF-16";
	    htmlname[EUC_KR] = "EUC-KR";
	    htmlname[CP949] = "x-windows-949";
	    htmlname[ISO2022KR] = "ISO-2022-KR";
	    htmlname[JOHAB] = "x-Johab";
	    htmlname[SJIS] = "Shift_JIS";
	    htmlname[EUC_JP] = "EUC-JP";
	    htmlname[ISO2022JP] = "ISO-2022-JP";
	    htmlname[ASCII] = "ASCII";
	    htmlname[OTHER] = "ISO8859-1";
	    // Assign Human readable names
	    nicename[GB2312] = "GB-2312";
	    nicename[GBK] = "GBK";
	    nicename[GB18030] = "GB18030";
	    nicename[HZ] = "HZ";
	    nicename[ISO2022CN_GB] = "ISO2022CN-GB";
	    nicename[BIG5] = "Big5";
	    nicename[CNS11643] = "CNS11643";
	    nicename[ISO2022CN_CNS] = "ISO2022CN-CNS";
	    nicename[ISO2022CN] = "ISO2022 CN";
	    nicename[UTF8] = "UTF-8";
	    nicename[UTF8T] = "UTF-8 (Trad)";
	    nicename[UTF8S] = "UTF-8 (Simp)";
	    nicename[UNICODE] = "Unicode";
	    nicename[UNICODET] = "Unicode (Trad)";
	    nicename[UNICODES] = "Unicode (Simp)";
	    nicename[EUC_KR] = "EUC-KR";
	    nicename[CP949] = "CP949";
	    nicename[ISO2022KR] = "ISO 2022 KR";
	    nicename[JOHAB] = "Johab";
	    nicename[SJIS] = "Shift-JIS";
	    nicename[EUC_JP] = "EUC-JP";
	    nicename[ISO2022JP] = "ISO 2022 JP";
	    nicename[ASCII] = "ASCII";
	    nicename[OTHER] = "OTHER";
	  }
	 
	}

 

转换后结果

### 回答1: krasovsky194alberswgs84是将使用Krasovsky 194椭球体和Albers等面积投影坐标转换为使用WGS84椭球体的坐标系。这种转换需要使用适当的数学公式和参数,以确保精确性和准确性。常见的工具包括GIS软件和在线坐标转换工具。 ### 回答2: Krasovsky1940-Albers投影WGS84坐标系都是用于地图绘制和测量计算的重要工具。Krasovsky1940-Albers投影是基于椭球体Krasovsky1940,其中利用标准纬度和中央经线进行投影WGS84坐标系是根据地球的真实形状建立的,因此它被称为全球定位系统的标准坐标系。 如果需要将Krasovsky1940-Albers投影转换WGS84坐标系,需要使用专门的转换工具。一般来说,这些工具会根据不同的坐标点来获取投影参数和转换参数,包括椭球体的长轴和偏心率以及投影中心的纬度和经度等信息。使用这些参数,就可以将Krasovsky1940-Albers投影转换WGS84坐标系。 需要注意的是,Krasovsky1940-Albers投影WGS84坐标系在地球表面的覆盖范围和精度方面有所不同。因此,转换过程可能会导致少量的误差。因此,在进行测量计算或制图时,应该根据实际情况选择合适的坐标系,并进行适当的校准和误差控制。 总之,将Krasovsky1940-Albers投影转换WGS84坐标系需要使用专门的工具,并且应该注意校准误差和选择合适的坐标系。 ### 回答3: Krasovsky1940 AlbersWGS84是将俄罗斯的Krasovsky1940坐标系中的Albers等面积投影转换WGS84全球卫星定位系统(Global Positioning System)坐标系的过程。需要注意的是,Krasovsky1940 Albers投影是基于等面积原则设计的,即在投影过程中,图形面积保持不变。 在进行Krasovsky1940 AlbersWGS84转换时,需要使用专业的地理信息系统(Geographic Information System)软件工具,比如ArcGIS、QGIS等。首先需要将Krasovsky1940 Albers投影文件导入到GIS软件中,然后将其投影转换WGS84坐标系。具体转换方式如下: 1. 在GIS软件中打开Krasovsky1940 Albers投影文件,选择坐标系并确定投影参数。 2. 将投影文件另存为WGS84坐标系,同时选择数据类型和坐标精度。 3. 完成转换后,通过GIS软件工具查看转换结果,可以在地图上看到投影文件的位置和形状是否符合WGS84坐标系的要求。 总之,Krasovsky1940 AlbersWGS84是俄罗斯地理信息数据和全球卫星定位系统之间的转换过程,需要使用专业的GIS软件工具和相关技术知识进行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南归北隐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值