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

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

?? neuquant.java

?? JAVA 寫的的 GIF 圖像編碼器
?? JAVA
字號:
/* NeuQuant Neural-Net Quantization Algorithm
 * ------------------------------------------
 *
 * Copyright (c) 1994 Anthony Dekker
 *
 * NEUQUANT Neural-Net quantization algorithm by Anthony Dekker, 1994.
 * See "Kohonen neural networks for optimal colour quantization"
 * in "Network: Computation in Neural Systems" Vol. 5 (1994) pp 351-367.
 * for a discussion of the algorithm.
 *
 * Any party obtaining a copy of these files from the author, directly or
 * indirectly, is granted, free of charge, a full and unrestricted irrevocable,
 * world-wide, paid up, royalty-free, nonexclusive right and license to deal
 * in this software and documentation files (the "Software"), including without
 * limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons who receive
 * copies from any such party to do so, with the only requirement being
 * that this copyright notice remain intact.
 */

// Ported to Java 12/00 K Weiner

public class NeuQuant {

	protected static final int netsize = 256; /* number of colours used */

	/* four primes near 500 - assume no image has a length so large */
	/* that it is divisible by all four primes */
	protected static final int prime1 = 499;
	protected static final int prime2 = 491;
	protected static final int prime3 = 487;
	protected static final int prime4 = 503;

	protected static final int minpicturebytes = (3 * prime4);
	/* minimum size for input image */

	/* Program Skeleton
	   ----------------
	   [select samplefac in range 1..30]
	   [read image from input file]
	   pic = (unsigned char*) malloc(3*width*height);
	   initnet(pic,3*width*height,samplefac);
	   learn();
	   unbiasnet();
	   [write output image header, using writecolourmap(f)]
	   inxbuild();
	   write output image using inxsearch(b,g,r)      */

	/* Network Definitions
	   ------------------- */

	protected static final int maxnetpos = (netsize - 1);
	protected static final int netbiasshift = 4; /* bias for colour values */
	protected static final int ncycles = 100; /* no. of learning cycles */

	/* defs for freq and bias */
	protected static final int intbiasshift = 16; /* bias for fractions */
	protected static final int intbias = (((int) 1) << intbiasshift);
	protected static final int gammashift = 10; /* gamma = 1024 */
	protected static final int gamma = (((int) 1) << gammashift);
	protected static final int betashift = 10;
	protected static final int beta = (intbias >> betashift); /* beta = 1/1024 */
	protected static final int betagamma =
		(intbias << (gammashift - betashift));

	/* defs for decreasing radius factor */
	protected static final int initrad = (netsize >> 3); /* for 256 cols, radius starts */
	protected static final int radiusbiasshift = 6; /* at 32.0 biased by 6 bits */
	protected static final int radiusbias = (((int) 1) << radiusbiasshift);
	protected static final int initradius = (initrad * radiusbias); /* and decreases by a */
	protected static final int radiusdec = 30; /* factor of 1/30 each cycle */

	/* defs for decreasing alpha factor */
	protected static final int alphabiasshift = 10; /* alpha starts at 1.0 */
	protected static final int initalpha = (((int) 1) << alphabiasshift);

	protected int alphadec; /* biased by 10 bits */

	/* radbias and alpharadbias used for radpower calculation */
	protected static final int radbiasshift = 8;
	protected static final int radbias = (((int) 1) << radbiasshift);
	protected static final int alpharadbshift = (alphabiasshift + radbiasshift);
	protected static final int alpharadbias = (((int) 1) << alpharadbshift);

	/* Types and Global Variables
	-------------------------- */

	protected byte[] thepicture; /* the input image itself */
	protected int lengthcount; /* lengthcount = H*W*3 */

	protected int samplefac; /* sampling factor 1..30 */

	//   typedef int pixel[4];                /* BGRc */
	protected int[][] network; /* the network itself - [netsize][4] */

	protected int[] netindex = new int[256];
	/* for network lookup - really 256 */

	protected int[] bias = new int[netsize];
	/* bias and freq arrays for learning */
	protected int[] freq = new int[netsize];
	protected int[] radpower = new int[initrad];
	/* radpower for precomputation */

	/* Initialise network in range (0,0,0) to (255,255,255) and set parameters
	   ----------------------------------------------------------------------- */
	public NeuQuant(byte[] thepic, int len, int sample) {

		int i;
		int[] p;

		thepicture = thepic;
		lengthcount = len;
		samplefac = sample;

		network = new int[netsize][];
		for (i = 0; i < netsize; i++) {
			network[i] = new int[4];
			p = network[i];
			p[0] = p[1] = p[2] = (i << (netbiasshift + 8)) / netsize;
			freq[i] = intbias / netsize; /* 1/netsize */
			bias[i] = 0;
		}
	}
	
	public byte[] colorMap() {
		byte[] map = new byte[3 * netsize];
		int[] index = new int[netsize];
		for (int i = 0; i < netsize; i++)
			index[network[i][3]] = i;
		int k = 0;
		for (int i = 0; i < netsize; i++) {
			int j = index[i];
			map[k++] = (byte) (network[j][0]);
			map[k++] = (byte) (network[j][1]);
			map[k++] = (byte) (network[j][2]);
		}
		return map;
	}
	
	/* Insertion sort of network and building of netindex[0..255] (to do after unbias)
	   ------------------------------------------------------------------------------- */
	public void inxbuild() {

		int i, j, smallpos, smallval;
		int[] p;
		int[] q;
		int previouscol, startpos;

		previouscol = 0;
		startpos = 0;
		for (i = 0; i < netsize; i++) {
			p = network[i];
			smallpos = i;
			smallval = p[1]; /* index on g */
			/* find smallest in i..netsize-1 */
			for (j = i + 1; j < netsize; j++) {
				q = network[j];
				if (q[1] < smallval) { /* index on g */
					smallpos = j;
					smallval = q[1]; /* index on g */
				}
			}
			q = network[smallpos];
			/* swap p (i) and q (smallpos) entries */
			if (i != smallpos) {
				j = q[0];
				q[0] = p[0];
				p[0] = j;
				j = q[1];
				q[1] = p[1];
				p[1] = j;
				j = q[2];
				q[2] = p[2];
				p[2] = j;
				j = q[3];
				q[3] = p[3];
				p[3] = j;
			}
			/* smallval entry is now in position i */
			if (smallval != previouscol) {
				netindex[previouscol] = (startpos + i) >> 1;
				for (j = previouscol + 1; j < smallval; j++)
					netindex[j] = i;
				previouscol = smallval;
				startpos = i;
			}
		}
		netindex[previouscol] = (startpos + maxnetpos) >> 1;
		for (j = previouscol + 1; j < 256; j++)
			netindex[j] = maxnetpos; /* really 256 */
	}
	
	/* Main Learning Loop
	   ------------------ */
	public void learn() {

		int i, j, b, g, r;
		int radius, rad, alpha, step, delta, samplepixels;
		byte[] p;
		int pix, lim;

		if (lengthcount < minpicturebytes)
			samplefac = 1;
		alphadec = 30 + ((samplefac - 1) / 3);
		p = thepicture;
		pix = 0;
		lim = lengthcount;
		samplepixels = lengthcount / (3 * samplefac);
		delta = samplepixels / ncycles;
		alpha = initalpha;
		radius = initradius;

		rad = radius >> radiusbiasshift;
		if (rad <= 1)
			rad = 0;
		for (i = 0; i < rad; i++)
			radpower[i] =
				alpha * (((rad * rad - i * i) * radbias) / (rad * rad));

		//fprintf(stderr,"beginning 1D learning: initial radius=%d\n", rad);

		if (lengthcount < minpicturebytes)
			step = 3;
		else if ((lengthcount % prime1) != 0)
			step = 3 * prime1;
		else {
			if ((lengthcount % prime2) != 0)
				step = 3 * prime2;
			else {
				if ((lengthcount % prime3) != 0)
					step = 3 * prime3;
				else
					step = 3 * prime4;
			}
		}

		i = 0;
		while (i < samplepixels) {
			b = (p[pix + 0] & 0xff) << netbiasshift;
			g = (p[pix + 1] & 0xff) << netbiasshift;
			r = (p[pix + 2] & 0xff) << netbiasshift;
			j = contest(b, g, r);

			altersingle(alpha, j, b, g, r);
			if (rad != 0)
				alterneigh(rad, j, b, g, r); /* alter neighbours */

			pix += step;
			if (pix >= lim)
				pix -= lengthcount;

			i++;
			if (delta == 0)
				delta = 1;
			if (i % delta == 0) {
				alpha -= alpha / alphadec;
				radius -= radius / radiusdec;
				rad = radius >> radiusbiasshift;
				if (rad <= 1)
					rad = 0;
				for (j = 0; j < rad; j++)
					radpower[j] =
						alpha * (((rad * rad - j * j) * radbias) / (rad * rad));
			}
		}
		//fprintf(stderr,"finished 1D learning: final alpha=%f !\n",((float)alpha)/initalpha);
	}
	
	/* Search for BGR values 0..255 (after net is unbiased) and return colour index
	   ---------------------------------------------------------------------------- */
	public int map(int b, int g, int r) {

		int i, j, dist, a, bestd;
		int[] p;
		int best;

		bestd = 1000; /* biggest possible dist is 256*3 */
		best = -1;
		i = netindex[g]; /* index on g */
		j = i - 1; /* start at netindex[g] and work outwards */

		while ((i < netsize) || (j >= 0)) {
			if (i < netsize) {
				p = network[i];
				dist = p[1] - g; /* inx key */
				if (dist >= bestd)
					i = netsize; /* stop iter */
				else {
					i++;
					if (dist < 0)
						dist = -dist;
					a = p[0] - b;
					if (a < 0)
						a = -a;
					dist += a;
					if (dist < bestd) {
						a = p[2] - r;
						if (a < 0)
							a = -a;
						dist += a;
						if (dist < bestd) {
							bestd = dist;
							best = p[3];
						}
					}
				}
			}
			if (j >= 0) {
				p = network[j];
				dist = g - p[1]; /* inx key - reverse dif */
				if (dist >= bestd)
					j = -1; /* stop iter */
				else {
					j--;
					if (dist < 0)
						dist = -dist;
					a = p[0] - b;
					if (a < 0)
						a = -a;
					dist += a;
					if (dist < bestd) {
						a = p[2] - r;
						if (a < 0)
							a = -a;
						dist += a;
						if (dist < bestd) {
							bestd = dist;
							best = p[3];
						}
					}
				}
			}
		}
		return (best);
	}
	public byte[] process() {
		learn();
		unbiasnet();
		inxbuild();
		return colorMap();
	}
	
	/* Unbias network to give byte values 0..255 and record position i to prepare for sort
	   ----------------------------------------------------------------------------------- */
	public void unbiasnet() {

		int i, j;

		for (i = 0; i < netsize; i++) {
			network[i][0] >>= netbiasshift;
			network[i][1] >>= netbiasshift;
			network[i][2] >>= netbiasshift;
			network[i][3] = i; /* record colour no */
		}
	}
	
	/* Move adjacent neurons by precomputed alpha*(1-((i-j)^2/[r]^2)) in radpower[|i-j|]
	   --------------------------------------------------------------------------------- */
	protected void alterneigh(int rad, int i, int b, int g, int r) {

		int j, k, lo, hi, a, m;
		int[] p;

		lo = i - rad;
		if (lo < -1)
			lo = -1;
		hi = i + rad;
		if (hi > netsize)
			hi = netsize;

		j = i + 1;
		k = i - 1;
		m = 1;
		while ((j < hi) || (k > lo)) {
			a = radpower[m++];
			if (j < hi) {
				p = network[j++];
				try {
					p[0] -= (a * (p[0] - b)) / alpharadbias;
					p[1] -= (a * (p[1] - g)) / alpharadbias;
					p[2] -= (a * (p[2] - r)) / alpharadbias;
				} catch (Exception e) {
				} // prevents 1.3 miscompilation
			}
			if (k > lo) {
				p = network[k--];
				try {
					p[0] -= (a * (p[0] - b)) / alpharadbias;
					p[1] -= (a * (p[1] - g)) / alpharadbias;
					p[2] -= (a * (p[2] - r)) / alpharadbias;
				} catch (Exception e) {
				}
			}
		}
	}
	
	/* Move neuron i towards biased (b,g,r) by factor alpha
	   ---------------------------------------------------- */
	protected void altersingle(int alpha, int i, int b, int g, int r) {

		/* alter hit neuron */
		int[] n = network[i];
		n[0] -= (alpha * (n[0] - b)) / initalpha;
		n[1] -= (alpha * (n[1] - g)) / initalpha;
		n[2] -= (alpha * (n[2] - r)) / initalpha;
	}
	
	/* Search for biased BGR values
	   ---------------------------- */
	protected int contest(int b, int g, int r) {

		/* finds closest neuron (min dist) and updates freq */
		/* finds best neuron (min dist-bias) and returns position */
		/* for frequently chosen neurons, freq[i] is high and bias[i] is negative */
		/* bias[i] = gamma*((1/netsize)-freq[i]) */

		int i, dist, a, biasdist, betafreq;
		int bestpos, bestbiaspos, bestd, bestbiasd;
		int[] n;

		bestd = ~(((int) 1) << 31);
		bestbiasd = bestd;
		bestpos = -1;
		bestbiaspos = bestpos;

		for (i = 0; i < netsize; i++) {
			n = network[i];
			dist = n[0] - b;
			if (dist < 0)
				dist = -dist;
			a = n[1] - g;
			if (a < 0)
				a = -a;
			dist += a;
			a = n[2] - r;
			if (a < 0)
				a = -a;
			dist += a;
			if (dist < bestd) {
				bestd = dist;
				bestpos = i;
			}
			biasdist = dist - ((bias[i]) >> (intbiasshift - netbiasshift));
			if (biasdist < bestbiasd) {
				bestbiasd = biasdist;
				bestbiaspos = i;
			}
			betafreq = (freq[i] >> betashift);
			freq[i] -= betafreq;
			bias[i] += (betafreq << gammashift);
		}
		freq[bestpos] += beta;
		bias[bestpos] -= betagamma;
		return (bestbiaspos);
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆91免费观看| 青椒成人免费视频| 国产精品天干天干在观线| 欧美一区二区三区视频在线观看| 欧美在线观看禁18| 欧美性三三影院| 欧美在线一二三四区| 欧美三级电影网站| 欧美精品在线一区二区| 欧美乱熟臀69xxxxxx| 678五月天丁香亚洲综合网| 欧美人xxxx| 欧美成人精精品一区二区频| 日韩欧美一区在线| 国产网红主播福利一区二区| 国产精品三级av| 亚洲精品一二三四区| 性做久久久久久久免费看| 丝袜美腿亚洲一区二区图片| 久久精品国产成人一区二区三区| 久88久久88久久久| 国产成人日日夜夜| 色综合中文字幕国产 | 亚洲激情在线激情| 亚洲一区二区在线免费看| 偷拍一区二区三区四区| 免费看黄色91| 成人免费视频一区| 一本久久精品一区二区| 欧美一区二区不卡视频| 久久先锋影音av| 18成人在线观看| 日精品一区二区三区| 国产一二三精品| 欧美自拍偷拍一区| 亚洲精品一区二区三区蜜桃下载 | 精品国产不卡一区二区三区| 亚洲国产精品国自产拍av| 亚洲影视在线观看| 麻豆精品久久久| 97se狠狠狠综合亚洲狠狠| 欧美老人xxxx18| 中文字幕视频一区二区三区久| 亚洲高清久久久| 成人激情免费网站| 欧美一区二区三区免费观看视频| 久久人人爽人人爽| 五月综合激情婷婷六月色窝| 色综合久久综合网欧美综合网| 欧美日韩国产精选| 亚洲欧美精品午睡沙发| 激情综合一区二区三区| 欧美性猛交xxxx乱大交退制版| √…a在线天堂一区| 日韩av电影免费观看高清完整版 | 麻豆精品视频在线观看视频| 91在线视频免费观看| 精品1区2区在线观看| 天天影视涩香欲综合网| 91麻豆国产在线观看| 欧美国产日韩一二三区| 九色porny丨国产精品| 欧美片网站yy| 一区二区三区免费网站| 99久久精品国产一区| 国产无一区二区| 国产精品一区二区久久不卡| 日韩一本二本av| 日韩制服丝袜先锋影音| 欧美色爱综合网| 亚洲一卡二卡三卡四卡| 一本一本大道香蕉久在线精品| 日本一区二区成人在线| 国产69精品久久久久777| 日韩免费高清电影| 麻豆精品国产91久久久久久 | 久久国产精品色| 日韩一区二区不卡| 美国毛片一区二区| 欧美一级高清大全免费观看| 美女免费视频一区二区| 精品久久久久久久久久久久久久久 | 波多野结衣在线aⅴ中文字幕不卡| 日韩欧美亚洲国产精品字幕久久久| 亚洲国产精品一区二区www| 欧美日韩国产乱码电影| 水野朝阳av一区二区三区| 91精品国产aⅴ一区二区| 日本vs亚洲vs韩国一区三区 | 综合欧美一区二区三区| 色婷婷精品久久二区二区蜜臂av | 日本aⅴ免费视频一区二区三区| 欧美日高清视频| 久久精品国产99国产精品| 久久综合九色综合97婷婷女人| 粉嫩绯色av一区二区在线观看| 亚洲免费毛片网站| 4438成人网| 成人一区二区三区在线观看| 国产精品传媒入口麻豆| 欧美午夜理伦三级在线观看| 蜜臀久久99精品久久久久久9 | 亚洲欧美一区二区三区孕妇| 在线观看一区不卡| 久久精品久久综合| 国产精品理论片在线观看| 欧美日韩一卡二卡三卡| 国产精品自拍毛片| 亚洲自拍偷拍网站| 久久久久久久久久久黄色| 91麻豆国产自产在线观看| 久久国产精品色婷婷| 一级精品视频在线观看宜春院| 日韩欧美一区二区久久婷婷| 成人不卡免费av| 日韩成人免费看| 最新国产成人在线观看| 日韩一区和二区| 在线亚洲人成电影网站色www| 精品一区二区三区影院在线午夜| 亚洲另类中文字| 国产午夜精品一区二区三区视频 | 亚洲黄色av一区| 久久精品在这里| 欧美一级在线视频| 日本乱码高清不卡字幕| 国产一区二区0| 丝袜美腿亚洲综合| 亚洲天堂成人在线观看| 久久婷婷色综合| 欧美成人一区二区三区片免费| 日本福利一区二区| 99精品在线观看视频| 国产成人av电影在线| 久久99日本精品| 日韩精品免费专区| 亚洲一区二区三区激情| 亚洲欧美偷拍另类a∨色屁股| 国产性色一区二区| 亚洲精品在线免费播放| 日韩欧美中文字幕一区| 9191成人精品久久| 欧美日韩中文字幕一区| 色琪琪一区二区三区亚洲区| 99国产精品国产精品久久| 国产乱子伦一区二区三区国色天香| 日韩一区欧美二区| 午夜av电影一区| 图片区小说区国产精品视频| 亚洲国产你懂的| 天天操天天色综合| 婷婷一区二区三区| 亚洲成人激情社区| 日韩高清不卡一区二区三区| 亚洲成a人片综合在线| 亚洲国产三级在线| 天堂资源在线中文精品| 亚洲成av人片观看| 日韩国产精品久久久久久亚洲| 首页国产欧美日韩丝袜| 日本成人在线看| 精品亚洲aⅴ乱码一区二区三区| 九九九精品视频| 国内欧美视频一区二区| 国产 日韩 欧美大片| 99re8在线精品视频免费播放| 色妹子一区二区| 欧美精品久久一区| 精品欧美久久久| 日本一区二区三区四区 | 亚洲成人免费电影| 蜜臂av日日欢夜夜爽一区| 国产一区二区三区免费在线观看 | 欧美日韩亚洲综合在线| 欧美肥大bbwbbw高潮| 精品国产一区二区三区久久久蜜月| 久久久午夜电影| 亚洲欧美韩国综合色| 亚洲成人免费电影| 狠狠色丁香久久婷婷综| 99麻豆久久久国产精品免费 | 亚洲三级在线免费观看| 一区二区三区毛片| 麻豆freexxxx性91精品| 高清成人免费视频| 欧美日韩国产精选| 欧美激情一区在线观看| 午夜免费久久看| 成人黄色小视频| 这里是久久伊人| 最新热久久免费视频| 久久成人免费网站| 91黄色免费网站| 国产色一区二区| 日韩精品久久久久久| 丁香亚洲综合激情啪啪综合| 欧美日韩一区二区三区视频| 中文一区二区在线观看| 日本不卡视频在线观看| 99久久久国产精品免费蜜臀|