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

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

?? dofprocessing.cs

?? Image Fusion Techniues
?? CS
字號:
// Waveblend - complex dualtree based image fusion// (C) Copyright 2004 -- Sebastian Nowozin <nowozin@cs.tu-berlin.de>//// This file is part of Waveblend.//// Waveblend is free software; you can redistribute it and/or modify// it under the terms of the GNU General Public License as published// by the Free Software Foundation; version 2 of the License.//// Waveblend is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the// GNU General Public License for more details.//// The license is included with the distribution in the file 'LICENSE'.///* DOFProcessing.cs - Extended Depth of Focus processing algorithms * * algorithms based on the short descriptions in the research paper * "Extended depth-of-focus for multi-channel microscopy images: a complex * wavelet approach" by Brigitte Forster, Dimitri Van De Ville, Jesse Berent, * Daniel Sage, Michael Unser. * * Available online at http://bigwww.epfl.ch/preprints/forster0401p.html * * NOTICE: so far, only real processing has been implemented, because of * outstanding bugs in the complex wavelet transform algorithm. The algorithm * in this file would require no internal changes (except C# type changes), * though. Do not compare the depth-of-focus fusion performance of this * program with the ones presented in the research paper, as this algorithm is * not as powerful yet. * * (C) Copyright 2004 -- Sebastian Nowozin (nowozin@cs.tu-berlin.de) */using System;using System.Collections;public classDOFProcessing{	WaveletProcessing wp = new WaveletProcessing ();	IWaveletDTCW wave1rst = new Farras10CFirst ();	IWaveletDTCW wave = new KingsburyQC10 ();	int currentCount = 0;	ArrayList originals = new ArrayList ();	public ArrayList Originals {		get {			return (originals);		}	}	int scales = -1;	int dimension = -1;	Dualtree2dComplex[] dt = null;	// All images have to have the same dimension.	int xDim = -1;	int yDim = -1;	public DOFProcessing ()	{	}	public DOFProcessing (int scales)	{		this.scales = scales;	}	public ImageMap ProduceImage ()	{		double[,] restored = wp.DualtreeTransform2dComplexInverse (wave1rst, wave, dt);		ImageMap fused = new ImageMap (restored);		fused = fused.ShrinkCanvas (xDim, yDim);		return (fused);	}	// Fuse one image into the overall image	// Return the number of wavelet coefficients replaced	public int FuseOne (string filename)	{		DisplayImage pic = new DisplayImage (filename);		ImageMap map = pic.ConvertToImageMap			(new DisplayImage.CanonicalPixelConverter ());		return (FuseOne (map));	}	public int FuseOne (ImageMap map)	{		currentCount += 1;		originals.Add (map);		if ((xDim != -1 && xDim != map.XDim) || (yDim != -1 && yDim != map.YDim)) {			throw (new ArgumentException (String.Format				("Image files have to be of the same dimension, required: {0}x{1}, found: {2}x{3}",				xDim, yDim, map.XDim, map.YDim)));		}		if (dt == null) {			int smaller = map.XDim < map.YDim ? map.XDim : map.YDim;			int larger = map.XDim > map.YDim ? map.XDim : map.YDim;			int wavelen = wave1rst.SupportSize > wave.SupportSize ?				wave1rst.SupportSize : wave.SupportSize;			// Get the largest scale we could do.			int wscales = 0;			while ((1 << wscales) < wavelen)				wscales += 1;			scales = 0;			while ((1 << scales) < larger)				scales += 1;			dimension = 1 << scales;			scales -= wscales;			if (scales <= 0) {				throw (new ArgumentException (String.Format					("Input too small: size {0} is below wavelet length {1}.",					smaller, wavelen)));			}			xDim = map.XDim;			yDim = map.YDim;			Console.WriteLine ("Images are ({0}x{1}), upscaled to ({2}x{3}), using {4} scales.",				xDim, yDim, dimension, dimension, scales);		}		ImageMap upscaled = map.EnlargeCanvas (dimension, dimension);		// Forward transform		Dualtree2dComplex[] dimage = wp.DualtreeTransform2dComplex (wave1rst, wave,			upscaled.ValueArray, scales);		if (dt == null) {			dt = dimage;			return (-1);		}		// "The largest absolute value of the coefficients in the subbands		// will correspond to sharper brightness changes and therefore to the		// most salient features. A good integration rule consists in		// selecting the slice with the largest absolute value of the wavelet		// coefficients at each point." (Forster, see top of this file).		//		// It is however, not quite clear if each subband should be treated		// independently, or one slice dominates all subbands. Later in the		// paper, a "Subband consistency" check is introduced, from which I		// deduce that most likely each subband shall be treated		// independently.		int replaced = 0;		Console.WriteLine ("Merging image coefficients...");		for (int treeNumber = 0 ; treeNumber < 2 ; ++treeNumber) {			Dualtree2dComplex treeNew = dimage[treeNumber];			Dualtree2dComplex treeBase = dt[treeNumber];			int tLevel = 0;			while (treeNew != null) {				int subReplaced = SalienceComplexLevel (treeBase, treeNew);				Console.WriteLine ("    tree {0} level {1}, replaced {2} coefficients",					treeNumber, tLevel, subReplaced);				replaced += subReplaced;				treeNew = treeNew.Next;				treeBase = treeBase.Next;				tLevel += 1;			}		}		Console.WriteLine ("=> TOTAL replaced {0} coefficients", replaced);		return (replaced);	}	private int SalienceComplexLevel (Dualtree2dComplex treeBase,		Dualtree2dComplex treeNew)	{		int replaced = 0;		for (int band = 0 ; band < 3 ; ++band) {			Dualtree2dComplex.ComplexArray baseBand = treeBase[band];			Dualtree2dComplex.ComplexArray newBand = treeNew[band];			for (int y = 0 ; y < baseBand.GetLength (0) ; ++y) {				for (int x = 0 ; x < baseBand.GetLength (1) ; ++x) {					double absNewBand = Math.Sqrt (						Math.Pow (newBand[y, x, 0], 2.0) +						Math.Pow (newBand[y, x, 1], 2.0));					double absBaseBand = Math.Sqrt (						Math.Pow (baseBand[y, x, 0], 2.0) +						Math.Pow (baseBand[y, x, 1], 2.0));					if (absNewBand > absBaseBand) {						baseBand[y, x, 0] = newBand[y, x, 0];						baseBand[y, x, 1] = newBand[y, x, 1];						replaced += 1;					}				}			}		}		return (replaced);	}	private int ChooseSalient (ImageMap p, ImageMap c)	{		int replaced = 0;		for (int y = 0 ; y < p.YDim ; ++y) {			for (int x = 0 ; x < p.XDim ; ++x) {				if (Math.Abs (c[x, y]) > Math.Abs (p[x, y])) {					p[x, y] = c[x, y];					replaced += 1;				}			}		}		return (replaced);	}}public classMultiClipping{	public static int[,] ClippingMap (ArrayList originals, ImageMap fused)	{		ImageMap input = (ImageMap) originals[0];		int maxX = input.XDim;		int maxY = input.YDim;		int[,] top = new int[maxY, maxX];		for (int y = 0 ; y < maxY ; ++y) {			for (int x = 0 ; x < maxX ; ++x) {				double minDiff = Double.MaxValue;				// Find the minimum delta original				for (int n = 0 ; n < originals.Count ; ++n) {					ImageMap map = (ImageMap) originals[n];					double diff = Math.Abs (map[x, y] - fused[x, y]);					if (diff < minDiff) {						minDiff = diff;						top[y, x] = n;					}				}			}		}		return (top);	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av电影免费观看高清完整版在线观看 | 国产精品女人毛片| 亚洲制服丝袜av| 国产伦精品一区二区三区免费迷| 欧美亚洲一区二区三区四区| 国产日产欧美精品一区二区三区| 亚洲3atv精品一区二区三区| 成人97人人超碰人人99| 久久这里只有精品6| 亚洲国产婷婷综合在线精品| 成人黄色av网站在线| 日韩限制级电影在线观看| 亚洲女厕所小便bbb| 国产综合色产在线精品 | 国产99久久精品| 日韩欧美国产综合一区 | 亚洲欧美一区二区在线观看| 国产乱子伦一区二区三区国色天香 | 亚洲精品成人悠悠色影视| 国产精品香蕉一区二区三区| 日韩免费观看高清完整版在线观看| 一级女性全黄久久生活片免费| 国产99久久久精品| 国产女同互慰高潮91漫画| 国产一区二区三区黄视频 | 欧美女孩性生活视频| 一区二区三区色| 91丨porny丨户外露出| 国产精品午夜电影| 成人永久aaa| 久久五月婷婷丁香社区| 另类人妖一区二区av| 精品久久久久久久一区二区蜜臀| 性做久久久久久免费观看欧美| 色婷婷久久一区二区三区麻豆| 1区2区3区精品视频| 天天免费综合色| 欧美一区二区三区视频在线| 日本aⅴ精品一区二区三区| 日韩一区二区三区在线| 麻豆91精品91久久久的内涵| 日韩欧美高清一区| 精品无人码麻豆乱码1区2区| 久久久一区二区| 国产成人精品影院| 成人免费一区二区三区在线观看| 一本到三区不卡视频| 亚洲永久精品大片| 欧美一区二区三区系列电影| 寂寞少妇一区二区三区| 国产嫩草影院久久久久| 91香蕉国产在线观看软件| 亚洲欧洲综合另类在线| 欧美日韩黄色一区二区| 精品一区二区三区欧美| 欧美极品xxx| 欧美日韩在线免费视频| 久久精品国产亚洲aⅴ| 久久久不卡网国产精品二区| 不卡av免费在线观看| 午夜视频在线观看一区二区三区| 日韩免费一区二区三区在线播放| 国产又黄又大久久| 专区另类欧美日韩| 欧美一区二区视频在线观看2020| 国产精品系列在线播放| 亚洲一二三四久久| 精品美女在线播放| 99精品热视频| 久久er精品视频| 一区二区在线观看视频在线观看| 日韩欧美国产综合| 色呦呦国产精品| 久久国产精品72免费观看| 亚洲欧美日韩国产中文在线| 日韩视频免费观看高清在线视频| a在线欧美一区| 蜜桃91丨九色丨蝌蚪91桃色| 中文字幕中文字幕一区| 日韩欧美不卡在线观看视频| jizz一区二区| 国产制服丝袜一区| 亚洲成av人片在线观看| 国产精品午夜电影| 欧美xxxxx牲另类人与| 99久久精品免费| 国产真实乱子伦精品视频| 亚洲国产精品久久人人爱| 欧美国产日韩在线观看| 欧美成人精品二区三区99精品| 91美女在线看| 不卡视频一二三四| 国产在线不卡一区| 另类调教123区| 视频一区欧美日韩| 亚洲一区日韩精品中文字幕| 国产精品视频一二三| 日韩美女主播在线视频一区二区三区| 欧洲精品在线观看| 99v久久综合狠狠综合久久| 国产精品一区免费视频| 紧缚捆绑精品一区二区| 另类欧美日韩国产在线| 天涯成人国产亚洲精品一区av| 亚洲色图欧美激情| 国产精品国产三级国产三级人妇| 亚洲精品一区在线观看| 欧美一级黄色大片| 337p亚洲精品色噜噜噜| 555夜色666亚洲国产免| 精品视频一区二区三区免费| 91福利视频网站| 欧洲色大大久久| 欧美三级韩国三级日本三斤 | 91精品啪在线观看国产60岁| 欧美日韩一区二区欧美激情| 欧美中文字幕一二三区视频| 色婷婷久久综合| 欧美专区日韩专区| 欧洲一区二区av| 8v天堂国产在线一区二区| 欧美一区二视频| 日韩欧美一级特黄在线播放| 日韩一区二区免费在线电影| 欧美一卡二卡三卡| 欧美电影免费观看完整版| 26uuu欧美日本| 亚洲国产精品成人久久综合一区| 国产欧美日韩一区二区三区在线观看| 日本一区免费视频| 亚洲免费伊人电影| 石原莉奈在线亚洲三区| 欧美aⅴ一区二区三区视频| 麻豆精品新av中文字幕| 国产在线不卡视频| 99re这里只有精品首页| 欧美主播一区二区三区美女| 日韩一区二区三区在线| 日本一区二区成人| 亚洲精品国产精华液| 日本亚洲一区二区| 国产成人精品亚洲777人妖| 99国产欧美久久久精品| 欧美日本国产一区| 2017欧美狠狠色| 亚洲狠狠丁香婷婷综合久久久| 性感美女久久精品| 国产精品一二三四五| 99国产精品国产精品久久| 在线播放日韩导航| 国产三级精品视频| 亚洲欧美另类图片小说| 日本人妖一区二区| eeuss国产一区二区三区| 欧美高清一级片在线| 国产视频一区在线播放| 亚洲激情校园春色| 久久国产尿小便嘘嘘| 97精品超碰一区二区三区| 91麻豆精品国产91| 中文字幕中文字幕一区二区| 日韩成人免费电影| 99久久精品久久久久久清纯| 日韩免费福利电影在线观看| 亚洲欧美偷拍卡通变态| 极品瑜伽女神91| 欧美三片在线视频观看| 国产精品超碰97尤物18| 韩国理伦片一区二区三区在线播放 | 国产1区2区3区精品美女| 欧美日韩国产精选| 国产精品美女久久久久aⅴ | 久久久影视传媒| 午夜久久电影网| 色诱亚洲精品久久久久久| 久久色在线视频| 免费观看在线综合| 在线欧美小视频| 国产精品久久久久一区| 国产美女精品一区二区三区| 777a∨成人精品桃花网| 亚洲精品欧美二区三区中文字幕| 国产成人a级片| 精品日韩99亚洲| 日韩av中文字幕一区二区 | www.成人在线| 国产三级三级三级精品8ⅰ区| 理论电影国产精品| 欧美一区国产二区| 日本在线不卡视频| 欧美绝品在线观看成人午夜影视| 亚洲日本成人在线观看| 高清成人在线观看| 日韩精品专区在线| 久久99国产乱子伦精品免费| 欧美一区二区久久久| 香蕉成人伊视频在线观看| 欧美日韩精品一二三区| 天天色天天操综合| 日韩视频中午一区|