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

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

?? sumskipnan.cpp

?? matlab數字信號處理工具箱
?? CPP
字號:
//-------------------------------------------------------------------
#pragma hdrstop
//-------------------------------------------------------------------
//   C-MEX implementation of SUMSKIPNAN - this function is part of the NaN-toolbox. 
//
//   This program 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; either version 2 of the License, or
//   (at your option) any later version.
//
//   This program 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.
//
//   You should have received a copy of the GNU General Public License
//   along with this program; if not, write to the Free Software
//   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
//
//
// sumskipnan: sums all non-NaN values
//
// Input:
// - array to sum
// - dimension to sum (1=columns; 2=rows; doesn't work for dim>2!!)
//
// Output:
// - sums
// - count of valid elements (optional)
// - sums of squares (optional)
// - sums of squares of squares (optional)
//
// Author:  Patrick Houweling (phouweling@yahoo.com)
// Version: 1.0
// Date:    17 september 2003
//
// modified:
//   Alois Schloegl <a.schloegl@ieee.org>    
// 	$Revision: 1.1 $
// 	$Id: sumskipnan.cpp,v 1.1 2003/10/31 18:13:28 schloegl Exp $
//
//-------------------------------------------------------------------
//#include <stdlib>
#include <math.h>
#include "mex.h"
//-------------------------------------------------------------------
void mexFunction(int POutputCount,  mxArray* POutput[], int PInputCount, const mxArray *PInputs[])
{
    	const int	*SZ;	    
    	double* 	LInput;
    	double* 	LInputI;
    	double* 	LOutputSum;
    	double* 	LOutputSumI;
    	double* 	LOutputCount;
    	double* 	LOutputSum2;
    	double* 	LOutputSum4;
    	double  	x, x2;
    	unsigned long   LCount, LCountI;
    	double  	LSum, LSum2, LSum4;

    	unsigned	DIM = 0; 
    	unsigned long	D1, D2, D3; 	// NN; 	//  	
    	unsigned    	ND, ND2;	// number of dimensions: input, output
    	unsigned long	ix1, ix2;	// index to input and output

    	unsigned    	j, k, l;	// running indices 
    	int 		*SZ2;		// size of output 	    


	// check for proper number of input and output arguments
	if ((PInputCount <= 0) || (PInputCount > 2))
	        mexErrMsgTxt("SumSkipNan.MEX requires 1 or 2 arguments.");
	if (POutputCount > 4)
	        mexErrMsgTxt("SumSkipNan.MEX has 1 to 4 output arguments.");

	// get 1st argument
	if(mxIsDouble(PInputs[0]))
		LInput  = mxGetPr(PInputs[0]);
	else 	
		mexErrMsgTxt("First argument must be DOUBLE.");

	if(mxIsLogical(PInputs[0]))
		LInput  = mxGetLogicals(PInputs[0]);
	else if(mxIsNumeric(PInputs[0]))
		LInput  = mxGetPr(PInputs[0]);
	else if(mxIsSparse(PInputs[0]))
		LInput  = mxGetPr(PInputs[0]);
	else if(mxIsInt8(PInputs[0]))
		LInput  = (char *)mxGetData(PInputs[0]);
	else if(mxIsUint8(PInputs[0]))
		LInput  = (unsigned char *)mxGetData(PInputs[0]);
	else if(mxIsInt16(PInputs[0]))
		LInput  = (int *)mxGetData(PInputs[0]);
	else if(mxIsUint16(PInputs[0]))
		LInput  = (unsigned int *)mxGetData(PInputs[0]);
	else if(mxIsInt32(PInputs[0]))
		LInput  = (long *)mxGetData(PInputs[0]);
	else if(mxIsUint32(PInputs[0]))
		LInput  = (unsigned long *)mxGetData(PInputs[0]);
	else
		mexErrMsgTxt("First argument must be NUMERIC.");

	if(mxIsComplex(PInputs[0]))
		LInputI = mxGetPi(PInputs[0]);
	if(mxIsComplex(PInputs[0]) & (POutputCount > 3))
	        mexErrMsgTxt("More than 3 output arguments only supported for REAL data ");

    	// get 2nd argument
    	if  (PInputCount == 2){
 	       	switch (mxGetNumberOfElements(PInputs[1])) {
		case 0: x = 0.0; 		// accept empty element
			break;
		case 1: x = (mxIsNumeric(PInputs[1]) ? mxGetScalar(PInputs[1]) : -1.0); 
			break;
		default:x = -1.0;		// invalid 
		}
		if ((x < 0) || (x > 65535) || (x != floor(x))) 
			mexErrMsgTxt("Error SUMSKIPNAN.MEX: DIM-argument must be a positive integer scalar");

		DIM = (unsigned)floor(x);	
	}

	// get size 
    	ND = mxGetNumberOfDimensions(PInputs[0]);	
    	// NN = mxGetNumberOfElements(PInputs[0]);
    	SZ = mxGetDimensions(PInputs[0]);		

	// if DIM==0 (undefined), look for first dimension with more than 1 element. 
	for (k = 0; (DIM < 1) && (k < ND); k++) 
		if (SZ[k]>1) DIM = k+1;
	
	if (DIM < 1) DIM=1;		// in case DIM is still undefined 

	ND2 = (ND>DIM ? ND : DIM);	// number of dimensions of output 

	SZ2 = (int*)mxCalloc(ND2, sizeof(int)); // allocate memory for output size

	for (j=0; j<ND; j++)		// copy size of input;  
		SZ2[j] = SZ[j]; 	
	for (j=ND; j<ND2; j++)		// in case DIM > ND, add extra elements 1 
		SZ2[j] = 1; 	

    	for (j=0, D1=1; j<DIM-1; D1=D1*SZ2[j++]); 	// D1 is the number of elements between two elements along dimension  DIM  
	D2 = SZ2[DIM-1];		// D2 contains the size along dimension DIM 	
    	for (j=DIM, D3=1;  j<ND; D3=D3*SZ2[j++]); 	// D3 is the number of blocks containing D1*D2 elements 

	SZ2[DIM-1] = 1;		// size of output is same as size of input but SZ(DIM)=1;

	    // create outputs
	#define TYP mxDOUBLE_CLASS

	if(mxIsComplex(PInputs[0]))
	{	POutput[0] = mxCreateNumericArray(ND2, SZ2, TYP, mxCOMPLEX);
		LOutputSum = mxGetPr(POutput[0]);
		LOutputSumI= mxGetPi(POutput[0]);
    	}
	else 
	{	POutput[0] = mxCreateNumericArray(ND2, SZ2, TYP, mxREAL);
		LOutputSum = mxGetPr(POutput[0]);
    	}

    	if (POutputCount >= 2){
		POutput[1] = mxCreateNumericArray(ND2, SZ2, TYP, mxREAL);
        	LOutputCount = mxGetPr(POutput[1]);
    	}
    	if (POutputCount >= 3){
		POutput[2] = mxCreateNumericArray(ND2, SZ2, TYP, mxREAL);
        	LOutputSum2  = mxGetPr(POutput[2]);
    	}
    	if (POutputCount >= 4){
		POutput[3] = mxCreateNumericArray(ND2, SZ2, TYP, mxREAL);
        	LOutputSum4  = mxGetPr(POutput[3]);
    	}

	mxFree(SZ2);

	// OUTER LOOP: along dimensions > DIM
	for (l = 0; l<D3; l++) 	
    	{
		ix2 =   l*D1;	// index for output 
		ix1 = ix2*D2;	// index for input 

		// Inner LOOP: along dimensions < DIM
		for (k = 0; k<D1; k++, ix1++, ix2++) 	
		{
		        LCount = 0;
			LSum   = 0.0;
			LSum2  = 0.0;
			LSum4  = 0.0;
	        	    		
			// LOOP  along dimension DIM
	    		for (j=0; j<D2; j++) 	
			{
				x = LInput[ix1 + j*D1];
        	        	if (!mxIsNaN(x))
				{
					LCount++; 
					LSum += x; 
					x2 = x*x;
					LSum2 += x2; 
					LSum4 += x2*x2; 
				}
			}
			LOutputSum[ix2] = LSum;
            		if (POutputCount >= 2)
                		LOutputCount[ix2] = (double)LCount;
            		if (POutputCount >= 3)
                		LOutputSum2[ix2] = LSum2;
            		if (POutputCount >= 4)
                		LOutputSum4[ix2] = LSum4;

			if(mxIsComplex(PInputs[0]))
			{
				LSum = 0.0;	
	    			LCountI = 0;
				LSum2  = 0.0;
				for (j=0; j<D2; j++) 	
				{
					x = LInputI[ix1 + j*D1];
        	        		if (!mxIsNaN(x))
					{
						LCountI++; 
						LSum  += x; 
						LSum2 += x*x; 
					}
				}
				LOutputSumI[ix2] = LSum;
				if (LCount != LCountI)
			            	mexErrMsgTxt("Number of NaNs is different for REAL and IMAG part");
	            		if (POutputCount >= 3)
        	        		LOutputSum2[ix2] += LSum2;
			}
		}
	}
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看国产日韩| 久久久欧美精品sm网站| 欧美大胆一级视频| 亚洲欧美一区二区三区国产精品 | 国产91色综合久久免费分享| 日本韩国一区二区三区视频| 久久久久久亚洲综合影院红桃| 一区二区三区日韩欧美精品| 国产精品18久久久久久vr | 国产一区二区不卡老阿姨| 色狠狠一区二区三区香蕉| 一区二区高清视频在线观看| 国产一区二区导航在线播放| 在线成人免费视频| 亚洲欧美一区二区三区极速播放| 国产成人免费在线观看| 日韩免费在线观看| 性久久久久久久| 色一区在线观看| 国产精品久久久久影院亚瑟| 国产精品69毛片高清亚洲| 欧美电影精品一区二区| 午夜精品久久久久久久久久久| 成人av在线播放网址| 久久久精品免费观看| 久久国产精品99久久久久久老狼| 欧美午夜一区二区三区| 亚洲另类春色国产| 色综合久久综合网欧美综合网| 国产欧美精品一区二区三区四区| 国产一区二区三区免费看| www国产亚洲精品久久麻豆| 久久国产三级精品| 久久久亚洲国产美女国产盗摄 | 欧美本精品男人aⅴ天堂| 香蕉成人伊视频在线观看| 欧美性大战久久| 亚洲一区二区欧美日韩| 欧美高清视频在线高清观看mv色露露十八| 一区二区三区欧美亚洲| 欧美在线你懂得| 天堂一区二区在线| 日韩亚洲欧美成人一区| 久久国产成人午夜av影院| 国产亚洲一区二区在线观看| 国产乱码精品一品二品| 中文字幕第一区二区| 91小视频在线观看| 午夜免费久久看| 日韩精品一区二区在线观看| 国产精品主播直播| 亚洲欧洲三级电影| 欧美三级电影在线看| 久久99深爱久久99精品| 国产精品视频一二三| 欧美亚洲一区二区在线观看| 日韩综合在线视频| 久久精品人人做人人综合| 97精品国产97久久久久久久久久久久 | 久久精品国产色蜜蜜麻豆| 精品国产sm最大网站免费看| 成人av影院在线| 午夜精品福利一区二区蜜股av| 精品99一区二区| 色综合久久天天| 日韩av不卡一区二区| 国产视频911| 欧美性受极品xxxx喷水| 精品一区二区三区在线播放| 亚洲欧美日韩一区二区| 精品欧美久久久| 色综合婷婷久久| 久久99精品久久久久久久久久久久| 国产三级精品在线| 91精品久久久久久久99蜜桃| 成人美女视频在线观看18| 日韩国产精品久久久| 亚洲欧洲色图综合| 久久伊99综合婷婷久久伊| 欧美在线不卡视频| 国产麻豆精品一区二区| 午夜精品久久久久久久99樱桃| 国产欧美中文在线| 欧美一区二区三区在线电影| 色综合 综合色| 国产一区二区在线观看免费| 亚洲成人黄色小说| 亚洲人成网站色在线观看| 国产亚洲人成网站| 日韩欧美国产1| 欧美怡红院视频| 波多野结衣亚洲一区| 激情五月播播久久久精品| 亚洲成人午夜影院| 一区二区三区在线视频免费| 国产欧美日韩亚州综合| 欧美成人激情免费网| 欧美日韩在线三级| 91小视频在线| 99精品视频一区二区三区| 国产a级毛片一区| 久久国产麻豆精品| 免费国产亚洲视频| 日韩精品久久久久久| 一区二区三区91| 夜夜嗨av一区二区三区网页| 国产精品萝li| 国产精品丝袜一区| 中文字幕成人网| 中文久久乱码一区二区| 亚洲国产精品激情在线观看| 久久精品一区蜜桃臀影院| 久久久噜噜噜久噜久久综合| 久久亚洲精精品中文字幕早川悠里 | 色婷婷av一区二区三区软件| 成人国产精品免费网站| 成人av集中营| 97se亚洲国产综合自在线| 91一区二区三区在线观看| 91麻豆文化传媒在线观看| 91免费看片在线观看| 91福利视频在线| 欧美放荡的少妇| 日韩一区二区三区视频| 精品国产乱子伦一区| 26uuu精品一区二区三区四区在线| 精品人伦一区二区色婷婷| 欧美精品一区二区三区在线播放| 久久女同精品一区二区| 国产亚洲综合在线| 亚洲欧洲成人av每日更新| 一区二区三区四区蜜桃| 日韩av一二三| 国产一区久久久| 91在线视频18| 69堂精品视频| 久久久久久久久久久电影| 日韩毛片高清在线播放| 亚洲成av人片一区二区三区| 美日韩黄色大片| 丰满少妇在线播放bd日韩电影| 99国产麻豆精品| 欧美一区二区视频网站| 欧美激情在线看| 亚洲成av人片| 国产精品 欧美精品| 欧洲精品视频在线观看| 日韩精品一区二区三区蜜臀 | 一区二区三区欧美| 日本视频在线一区| 国产 欧美在线| 欧美亚洲日本国产| 久久久久9999亚洲精品| 亚洲色图制服诱惑 | 一区二区视频在线| 日本不卡免费在线视频| 风间由美一区二区三区在线观看| 91福利社在线观看| 精品国产乱码91久久久久久网站| 国产精品久久久久影院老司| 免费一区二区视频| 色综合久久久久久久| 欧美精品一区二区三区蜜桃 | 国产麻豆精品在线观看| 欧美日韩在线一区二区| 国产精品久久久久aaaa| 麻豆免费精品视频| 色综合久久中文字幕| 国产欧美一区二区三区沐欲| 婷婷国产在线综合| 91免费在线播放| 欧美国产成人在线| 国产中文一区二区三区| 9191成人精品久久| 综合色天天鬼久久鬼色| 紧缚奴在线一区二区三区| 欧美日韩视频在线一区二区| 日精品一区二区三区| 日本道精品一区二区三区| 日本一区二区不卡视频| 国产精品香蕉一区二区三区| 日韩精品一区二区在线| 秋霞午夜鲁丝一区二区老狼| 在线观看日产精品| 亚洲免费在线看| 北条麻妃国产九九精品视频| 国产日本欧洲亚洲| 精品一区在线看| 精品不卡在线视频| 美女www一区二区| 欧美一区二区三级| 首页国产欧美久久| 欧美日韩午夜在线| 丝袜诱惑亚洲看片| 欧美精品欧美精品系列| 视频在线观看一区| 日韩手机在线导航| 久久99九九99精品| 久久久99免费| 成人av网站大全|