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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? clustering.cpp

?? 一個(gè)聚類算法
?? CPP
字號(hào):
///////////////////////////////////////////////////////////////////////
// File Name:		Clustering.cpp
// File Function:	1. Maximun clustering algorithm
//					2. LBG (k-Mean) clustering algorithm
//
//				Developed by:Zheng Yefeng
//			(c)copyright to Tsinghua THOCR Lab, 2001
//					All Right Reserved
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "ImageObj.h"
#include "Clustering.h"
#include "math.h"

/******************************************************************************
/*	Name:		LBGCluster
/*	Function:	Clustering input vectors using LBG algorithm
/*				Using Euclidean distance
/*	Parameter:	X -- Input vecters
/*				N -- Number of input vectors
/*				Y -- Clustering result
/*				M -- Number of clustering center
/*	Return:		0 -- Correct
/*				1 -- Error
/*
/******************************************************************************/
int LBGCluster(VQ_VECTOR *X, int N, VQ_CENTER *Y, int M)
{
	if(N<M)			 return -1;
	int		L=1000, m=1, nCenter, i, j, k;
	int		nDimension = X[0].nDimension;
	double  D0, D;
	struct  VQ_CENTERINFO
	{
		double*	  Data;
		int		  nDimension;
		double*   SumData;
		int		  Num;
	};
	VQ_CENTERINFO	*Center = (VQ_CENTERINFO*)malloc(M*sizeof(VQ_CENTERINFO));
	if(Center == NULL)		return -1;
	double			*Distance = (double*)malloc(N*sizeof(double));
	if(Distance == NULL)	return -1;

	for( i=0; i<M; i++)
	{
		Center[i].nDimension = nDimension;
		Center[i].Data = (double*)malloc(sizeof(double)*nDimension);
		Center[i].SumData = (double*)malloc(sizeof(double)*nDimension);
		if( Center[i].Data == NULL || Center[i].SumData == NULL )
		{
			AfxMessageBox( "Memory used up!" );
			return -1;
		}
		for( j=0; j<nDimension; j++ )
		{
			Center[i].Data[j] = X[i*N/M].Data[j];
			Center[i].SumData[j] = 0;
		}
		Center[i].Num = 0;
	}

	D0=1;         D=1e+10;	
	while(m<L && fabs(D0-D)/D0>1e-5)
	{
		for(i=0; i<M; i++)
		{
			for( j=0;	j<nDimension; j++ )
				Center[i].SumData[j] = 0;
			Center[i].Num = 0;
		}
		D0 = D;			D = 0;		m++;
		for(i=0; i<N; i++)
		{
			Distance[i] = 1e+10;
			for(int j=0; j<M; j++)
			{
				double  Dist = 0;
				for( j=0; j<nDimension; j++ )
					Dist += (X[i].Data[k]-Center[j].Data[k])*(X[i].Data[k]-Center[j].Data[k]);
				if(  Dist < Distance[i])
				{			
					nCenter = j;
					Distance[i] = Dist;
				}
			}
			X[i].nCluster = nCenter;
			for( k=0; k<nDimension; k++ )
				Center[nCenter].SumData[k] += X[i].Data[k];
			Center[nCenter].Num++;
			D += Distance[i];
		}
		for(i=0; i<M; i++)
		{
			if(Center[i].Num != 0)
				for( k=0; k<nDimension; k++ )
					Center[i].Data[k] = Center[i].SumData[k]/Center[i].Num;
			else
			{	
				int MaxNum=0;
				for( k=1; k<M; k++)
					MaxNum = Center[i].Num > Center[MaxNum].Num ? i: MaxNum;
				int   Num = Center[MaxNum].Num/2;
				for( k=0; k<nDimension; k++ )
					Center[MaxNum].SumData[k] = 0;
				Center[MaxNum].Num = 0;
				for(k=0; k<N; k++)
				{	
					if(X[k].nCluster != MaxNum)		continue;
					if(Center[i].Num < Num)
					{   
						X[k].nCluster = i;
						for( m=0; m<nDimension; m++)
							Center[i].SumData[m] += X[k].Data[m];
						Center[i].Num++;
					}
					else
					{
						for( m=0; m<nDimension; m++ )
							Center[MaxNum].SumData[m] += X[k].Data[m];
						Center[MaxNum].Num++;
					}
				}
				for( m=0; m<nDimension; m++ )
					Center[i].Data[m] = Center[i].SumData[m] / Center[i].Num;
				if(MaxNum < i)
					for( m=0; m<nDimension; m++ )
						Center[MaxNum].Data[m] = Center[MaxNum].SumData[m] / Center[MaxNum].Num;
			}
		}
	}
	for(i=0; i<M; i++)
	{
		for( m=0; m<nDimension; m++ )
			Y[i].Data[m] = Center[i].Data[m];
		Y[i].Num = Center[i].Num;
	}
	for( i=0; i<M; i++ )
	{
		free( Center[i].Data );
		free( Center[i].SumData );
	}
	free(Center);
	free(Distance);
	return 0;
}

/******************************************************************************
/*	Name:		LBGClusterCor
/*	Function:	Clustering input vectors using LBG algorithm
/*				Using correlation distance
/*	Parameter:	X -- Input vecters
/*				N -- Number of input vectors
/*				Y -- Clustering result
/*				M -- Number of clustering center
/*	Return:		0 -- Correct
/*				1 -- Error
/*
/******************************************************************************/
int LBGClusterCor(VQ_VECTOR *X, int N, VQ_CENTER *Y, int M)
{
	if(N<M)			 return -1;
	int		L=1000, m=1, nCenter, i, j, k;
	int		nDimension = X[0].nDimension;
	double  SumCor0, SumCor;
	struct  VQ_CENTERINFO
	{
		double*	  Data;
		int		  nDimension;
		double*   SumData;
		int		  Num;
	};
	VQ_CENTERINFO	*Center = (VQ_CENTERINFO*)malloc(M*sizeof(VQ_CENTERINFO));
	if(Center == NULL)		return -1;
	double			*Correlation = (double*)malloc(N*sizeof(double));
	if(Correlation == NULL)	return -1;

	for( i=0; i<M; i++)
	{
		Center[i].nDimension = nDimension;
		Center[i].Data = (double*)malloc(sizeof(double)*nDimension);
		Center[i].SumData = (double*)malloc(sizeof(double)*nDimension);
		if( Center[i].Data == NULL || Center[i].SumData == NULL )
		{
			AfxMessageBox( "Memory used up!" );
			return -1;
		}	
		for( j=0; j<nDimension; j++ )
		{
			Center[i].Data[j] = X[i*N/M].Data[j];
			Center[i].SumData[j] = 0;
		}
		Center[i].Num = 0;
	}

	SumCor0=0.001;         SumCor=0.1;	
	while(m<L && fabs(SumCor0-SumCor)/SumCor0>1e-20)
	{
		for(i=0; i<M; i++)
		{
			for( j=0;	j<nDimension; j++ )
				Center[i].SumData[j] = 0;
			Center[i].Num = 0;
		}
		SumCor0 = SumCor;			SumCor = 0;		m++;
		for(i=0; i<N; i++)
		{
			Correlation[i] = 0;
			for(int j=0; j<M; j++)
			{
				double  Cor = GetCorrelation( X[i].Data, Center[j].Data, nDimension);
				if(  Cor > Correlation[i])
				{			
					nCenter = j;
					Correlation[i] = Cor;
				}
			}
			X[i].nCluster = nCenter;
			for( k=0; k<nDimension; k++ )
				Center[nCenter].SumData[k] += X[i].Data[k];
			Center[nCenter].Num++;
			SumCor += Correlation[i];
		}
		for(i=0; i<M; i++)
		{
			if(Center[i].Num != 0)
				for( k=0; k<nDimension; k++ )
					Center[i].Data[k] = Center[i].SumData[k]/Center[i].Num;
			else
			{	
				int MaxNum=0;
				for( k=1; k<M; k++)
					MaxNum = Center[i].Num > Center[MaxNum].Num ? i: MaxNum;
				int   Num = Center[MaxNum].Num/2;
				for( k=0; k<nDimension; k++ )
					Center[MaxNum].SumData[k] = 0;
				Center[MaxNum].Num = 0;
				for(k=0; k<N; k++)
				{	
					if(X[k].nCluster != MaxNum)		continue;
					if(Center[i].Num < Num)
					{   
						X[k].nCluster = i;
						for( m=0; m<nDimension; m++)
							Center[i].SumData[m] += X[k].Data[m];
						Center[i].Num++;
					}
					else
					{
						for( m=0; m<nDimension; m++ )
							Center[MaxNum].SumData[m] += X[k].Data[m];
						Center[MaxNum].Num++;
					}
				}
				for( m=0; m<nDimension; m++ )
					Center[i].Data[m] = Center[i].SumData[m] / Center[i].Num;
				if(MaxNum < i)
					for( m=0; m<nDimension; m++ )
						Center[MaxNum].Data[m] = Center[MaxNum].SumData[m] / Center[MaxNum].Num;
			}
		}
	}
	for(i=0; i<M; i++)
	{
		for( m=0; m<nDimension; m++ )
			Y[i].Data[m] = Center[i].Data[m];
		Y[i].Num = Center[i].Num;
	}
	for( i=0; i<M; i++ )
	{
		free( Center[i].Data );
		free( Center[i].SumData );
	}
	free(Center);
	free(Correlation);
	return 0;
}

/*********************************************************************
/*	Name:		GetCorrelation
/*	Function:	Calculate correlation of two vectors
/*	Parameter:	X -- Vector one
/*				Y -- Vector two
/*				nDimension -- Dimension of the vectors
/*	Return:		Correlation of two vectors
/*	
/*********************************************************************/
double	GetCorrelation( double* X, double*	Y, int nDimension )
{
	double	Correlation=0, DX=0, DY=0;
	for(int i=0; i<nDimension; i++ )
	{
		Correlation += X[i]*Y[i];
		DX += X[i]*X[i];
		DY += Y[i]*Y[i];
	}
	return  Correlation/sqrt( DX*DY );
}

/******************************************************************************
/*	Name:		MaxCluster
/*	Function:	Clustering input vectors using Maximum algorithm
/*	Parameter:	X -- Input vecters
/*				N -- Number of input vectors
/*				Y -- Clustering result
/*				M -- Number of clustering center
/*	Return:		0 -- Correct
/*				1 -- Error
/*
/******************************************************************************/
int MaxCluster(VQ_VECTOR *X, int N, VQ_CENTER *Y, int M)
{
	if(N<M)			 return -1;
	int		m=1;
	struct  VQ_CENTERINFO
	{
		double*	  Data;
		int		  nDimension;
		double*   SumData;
		int		  Num;
	};
	VQ_CENTERINFO	*Center = (VQ_CENTERINFO*)malloc(M*sizeof(VQ_CENTERINFO));
	if(Center == NULL)		return -1;
	double			*Distance = (double*)malloc(N*sizeof(double));
	if(Distance == NULL)	return -1;

	int		nDimension = X[0].nDimension;
	int		i, j, k;
	for(i=0; i<M; i++)
	{
		for( k=0; k<nDimension; k++ )
			Center[i].SumData[k] = 0;
		Center[i].Num = 0;
	}
	double*	SumData = (double*)malloc(sizeof(double)*nDimension);
	for( k=0; k<nDimension; k++ )
		SumData[k]= 0;
	for(i=0; i<N; i++)
		for( k=0; k<nDimension; k++ )
			SumData[k] += X[i].Data[k];	
	for( k=0; k<nDimension; k++ )
		SumData[k]	/= N;	
	
	int  l=0;
	double L=0, Dist;
	for(i=0; i<N; i++)
	{
		Dist = 0;
		for( k=0; k<nDimension; k++ )
			Dist += (X[i].Data[k]-SumData[k])*(X[i].Data[k]-SumData[k]);
		if(Dist > L)
		{
			L = Dist;
			l = i;
		}
	}
	for( k=0; k<nDimension; k++ )
		Center[0].Data[k] = X[l].Data[k];
	for(m=1; m<M; m++)
	{
		double  MaxMinDist = -1;
		int		MaxMin = -1;
		for( j=0; j<N; j++)
		{
			double MinDist = 1e+10;
			for(int k=0; k<m; k++)
			{
				Dist = 0;
				for( k=0; k<nDimension; k++ )
					Dist += (X[j].Data[k] - Center[k].Data[k])*(X[j].Data[k] - Center[k].Data[k]);
				MinDist = min(Dist , MinDist);
			}
			if(MinDist > MaxMinDist)
			{
				MaxMinDist = MinDist;
				MaxMin  = j;
			}
		}
		for( k=0; k<nDimension; k++ )
			Center[m].Data[k] = X[MaxMin].Data[k];
	}
	for(i=0; i<N; i++)
	{	int		Min = -1;
		double  MinDist = 1e+10;
		for(m=0; m<M; m++)
		{
			Dist = 0;
			for( k=0; k<nDimension; k++ )
				Dist += (X[i].Data[k] - Center[m].Data[k])*(X[i].Data[k] - Center[m].Data[k]);
			if(Dist < MinDist)
			{
				MinDist = Dist;
				Min = m;
			}
		}
		X[i].nCluster = Min;
		if(Min<0 || Min>=M)
			return -1;
		for( k=0; k<nDimension; k++ )
			Center[Min].SumData[k] += X[i].Data[k];
		Center[Min].Num++;
	}
	for(m=0; m<M; m++)
		for( k=0; k<nDimension; k++ )
			Center[m].Data[k] = Center[m].SumData[k] / Center[m].Num;
	for(i=0; i<M; i++)
	{
		for( k=0; k<nDimension; k++ )
			Y[i].Data[k] = Center[i].Data[k];
		Y[i].Num = Center[i].Num;
	}
	free( SumData );
	for( i=0; i<M; i++ )
	{
		free( Center[i].Data );
		free( Center[i].SumData );
	}
	free(Center);
	free(Distance);
	return 0;
}

/******************************************************************************
/*	Name:		DumpCluster
/*	Function:	Dump the clustering result to an image file for debugging
/*	Parameter:	FileName -- Dump image file name
/*				w -- Image width
/*				h -- Image height
/*				X -- Input vecters
/*				N -- Number of input vectors
/*				Y -- Clustering result
/*				M -- Number of clustering center
/*	Return:		0 -- Correct
/*				1 -- Error
/*
/******************************************************************************/
int DumpCluster(CString FileName, int w, int h, VQ_VECTOR *X, int N, VQ_CENTER *Y, int M)
{
    int i ;
    w = (w+31)/32*32 ;
    int ImgSize = w/8*h ;
    CBitmap bmp, *pOldBMP ;
	CBrush	*pBrush = new CBrush(RGB(0, 0, 0));
	
    if ( bmp.CreateBitmap ( w, h, 1, 1, NULL ) )
    {
        CDC dc ;
        dc.CreateCompatibleDC ( &CClientDC( AfxGetMainWnd() ) ) ;
        if ( (pOldBMP=dc.SelectObject(&bmp)) != NULL )
        {
            BYTE *p = (BYTE *)malloc(ImgSize) ;
            if ( p )
            {
                memset ( p, 255, ImgSize ) ;
                bmp.SetBitmapBits( ImgSize, p ) ;
                free ( p ) ;

				CString  str;
				for(i=0; i<M; i++)
				{
					dc.FillRect( CRect((int)Y[i].Data[0]-4, (int)Y[i].Data[1]-4, (int)Y[i].Data[0]+4, (int)Y[i].Data[1]+4 ), pBrush);
					str.Format("C%d", i);
					if(i>=10)
						dc.TextOut( (int)Y[i].Data[0]-8, (int)Y[i].Data[1]-8, str, 3);
					else
						dc.TextOut( (int)Y[i].Data[0]-8, (int)Y[i].Data[1]-8, str, 2);
				}
				for(i=0; i<N; i++)
				{
					str.Format("%d", X[i].nCluster);
					dc.FillRect( CRect((int)X[i].Data[0]-4, (int)X[i].Data[1]-4, (int)X[i].Data[0]+4, (int)X[i].Data[1]), pBrush); 
					dc.TextOut( (int)X[i].Data[0], (int)X[i].Data[1]-6,str, 1);
				}
				CImage DIB ;
                if ( DIB.Initialize(dc.GetSafeHdc(),bmp) )
                {
                    dc.SelectObject ( pOldBMP ) ;
                    DIB.Write (FileName) ;
                }
            }
        }
    }
	delete pBrush;
    return 0 ;
}

/******************************************************************************
/*	Name:		DumpClusterData
/*	Function:	Dump clustering result to a text file for debugging
/*	Parameter:	FileName -- Dump text file name
/*				X -- Input vecters
/*				N -- Number of input vectors
/*				Y -- Clustering result
/*				M -- Number of clustering center
/*	Return:		0 -- Correct
/*				1 -- Error
/*
/******************************************************************************/
int DumpClusterData(CString FileName, VQ_VECTOR *X, int N, VQ_CENTER *Y, int M)
{
	int		i, j, k;
	int		nDimension = X[0].nDimension;
	FILE *fp = fopen(FileName, "wt");
	for( i=0; i<M; i++)
	{
		fprintf(fp, "Center%02d: ", i);
		for(  k=0; k<nDimension; k++ )
			fprintf( fp, "%5.1f ", Y[i].Data[k] );
		fprintf( fp, "Num=%03d\n", Y[i].Num);
		for( j=0; j<N; j++)
		{	if(X[j].nCluster != i)		continue;
			double Distance = 0;
			for( k=0; k<nDimension; k++)
				Distance += (X[j].Data[k]- Y[i].Data[k])*(X[j].Data[k]-Y[i].Data[k]);
			Distance = sqrt( Distance );
			for( k=0; k<nDimension; k++ )
				fprintf(fp, "  %03d  ", (int)X[j].Data[k] );
			fprintf( fp, " D=%5.1f\n", Distance);
		}
	}
	fclose(fp);
	return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av一区二区三区四区| 中文字幕乱码日本亚洲一区二区| 欧美在线观看视频在线| 懂色中文一区二区在线播放| 国产精品123| 成人免费视频视频| 国产a精品视频| a级精品国产片在线观看| 粉嫩久久99精品久久久久久夜| 福利一区二区在线| 成人激情黄色小说| 99精品欧美一区二区蜜桃免费| 粗大黑人巨茎大战欧美成人| 99免费精品在线观看| 色av综合在线| 欧美一区二区私人影院日本| 91精品国产丝袜白色高跟鞋| 欧美成人激情免费网| 久久久三级国产网站| 国产精品无码永久免费888| 中文字幕欧美日本乱码一线二线| 国产盗摄一区二区| 成人久久久精品乱码一区二区三区| 91丨porny丨户外露出| 欧美三级电影精品| 日韩欧美国产系列| 久久伊人中文字幕| 一区免费观看视频| 亚洲第一福利一区| 精品一区二区三区免费观看| 成人自拍视频在线观看| 日本精品视频一区二区三区| 这里只有精品免费| 国产精品美女久久久久久| 亚洲欧美日韩小说| 捆绑紧缚一区二区三区视频| 成人v精品蜜桃久久一区| 欧美三级午夜理伦三级中视频| 欧美成人一级视频| 亚洲视频资源在线| 日韩高清不卡一区| 成人激情校园春色| 91精品国产高清一区二区三区| 国产日产欧美一区| 亚洲国产另类av| 国产麻豆精品theporn| 色综合天天综合给合国产| 91精品国产综合久久久久久久| 国产亚洲成年网址在线观看| 亚洲电影一区二区| 成人黄色网址在线观看| 欧美日韩视频第一区| 久久久综合激的五月天| 一区二区不卡在线播放| 国产乱码一区二区三区| 欧美亚洲日本一区| 国产人妖乱国产精品人妖| 婷婷夜色潮精品综合在线| 成人国产亚洲欧美成人综合网| 欧美一级片在线看| 亚洲激情在线播放| 国产精品系列在线观看| 欧美精品 日韩| 亚洲日本在线天堂| 国产成人在线网站| 日韩精品一区在线观看| 亚洲一区二区av电影| 国产91在线观看| 日韩美女主播在线视频一区二区三区| 亚洲日本电影在线| 国产伦精品一区二区三区免费| 欧美挠脚心视频网站| 亚洲视频在线观看三级| 国产黑丝在线一区二区三区| 51精品视频一区二区三区| 亚洲欧美另类图片小说| 国产成人在线视频播放| 欧美精品一区视频| 免费观看一级特黄欧美大片| 在线日韩一区二区| 日韩毛片视频在线看| 国产99精品国产| xnxx国产精品| 青青草原综合久久大伊人精品优势 | 国产精品久久久久精k8| 久久精品国产亚洲一区二区三区| 欧美日韩日日骚| 亚洲视频免费观看| 99久久精品国产毛片| 欧美激情一区二区三区在线| 国产一区二区调教| 精品国产污网站| 久草这里只有精品视频| 日韩一区二区三区视频| 日韩av电影免费观看高清完整版 | 在线一区二区视频| 中文字幕一区二区三区蜜月 | 91行情网站电视在线观看高清版| 中文字幕在线不卡一区 | 久久久久国产免费免费| 麻豆精品在线看| 日韩欧美一区在线| 免费成人在线影院| 日韩免费视频一区| 精品午夜久久福利影院| 精品少妇一区二区三区| 韩国v欧美v日本v亚洲v| 欧美精品一区二区三区一线天视频 | 中文字幕高清不卡| 国产成人aaaa| 中文字幕色av一区二区三区| 91一区二区三区在线观看| 亚洲人123区| 在线观看欧美黄色| 首页国产欧美久久| 欧美mv日韩mv| 成人一区二区三区| 日韩一区在线免费观看| 欧美亚洲精品一区| 日韩国产精品91| 欧美大黄免费观看| 国产成人精品亚洲777人妖| 中文字幕一区免费在线观看| 欧美午夜一区二区三区免费大片| 亚洲成人动漫在线免费观看| 欧美精品久久天天躁| 久久精品国产久精国产爱| 国产视频一区二区三区在线观看| 99精品在线免费| 亚洲第一电影网| 2019国产精品| 91在线国产福利| 婷婷开心激情综合| 久久久精品国产免费观看同学| 成人app在线观看| 午夜精品久久久久| 国产人久久人人人人爽| 在线亚洲高清视频| 久久国产生活片100| 中文字幕日本乱码精品影院| 欧美伦理影视网| 国产精品一区在线观看乱码| 亚洲欧美欧美一区二区三区| 欧美一区二区三区影视| 粉嫩绯色av一区二区在线观看| 亚洲福利视频导航| 国产人成亚洲第一网站在线播放 | 色婷婷国产精品综合在线观看| 日本午夜一区二区| 中文字幕在线观看一区二区| 欧美一区日韩一区| 成人va在线观看| 美美哒免费高清在线观看视频一区二区 | 天使萌一区二区三区免费观看| 久久夜色精品国产噜噜av| 91蜜桃婷婷狠狠久久综合9色| 蜜臀91精品一区二区三区| 亚洲人成小说网站色在线 | 婷婷中文字幕一区三区| 中国色在线观看另类| 欧美一区二区视频网站| 99精品视频一区二区| 激情丁香综合五月| 亚洲国产精品一区二区尤物区| 国产亚洲精品超碰| 在线综合亚洲欧美在线视频| youjizz国产精品| 九色porny丨国产精品| 亚洲一区二区三区四区的| 国产欧美日韩精品一区| 在线不卡的av| 色综合视频一区二区三区高清| 国产曰批免费观看久久久| 亚洲6080在线| 亚洲精品国产无套在线观| 国产亚洲欧美日韩俺去了| 日韩一卡二卡三卡四卡| 欧美亚洲国产一卡| 99视频一区二区| 国产精品2024| 久久99热99| 日韩极品在线观看| 一个色在线综合| 亚洲视频一二区| 国产精品午夜在线观看| 久久网站热最新地址| 日韩视频一区二区在线观看| 欧美综合视频在线观看| 99久精品国产| 99精品在线免费| 91在线观看成人| 99久久免费国产| a亚洲天堂av| 99re8在线精品视频免费播放| 国产精品一区二区视频| 国产乱人伦精品一区二区在线观看 | 日韩电影在线看| 亚洲成人av电影在线| 亚洲韩国一区二区三区| 亚洲与欧洲av电影|