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

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

?? heatdis-imn0-pq.c

?? 一個MPI程序
?? C
字號:
/*******************************************************
*****************Title: Heat Distribution Problem******
*****************File: heatdis.c **********************
*****************Author: Sheng Di**********************
*****************Email: sdi@cs.hku.hk******************
*******************************************************/


#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
#include <mpi.h>

#define ITERATIVE_TIMES 100000
#define PRECISION 0.001
#define WORKTAG 11
#define QUITTAG 22
char filename[100];
enum BOOLEAN {FALSE=0,TRUE=1};

void init(int DEVIDE_SIZE_M,int DEVIDE_SIZE_N, double original[][]);
void reduceData(int rowsize, int numprocs, int DEVIDE_SIZE_N, double original[][]);
void doDistribution(int numprocs, int currentRank, int rowsize, int DEVIDE_SIZE_N, double **h,double **g);
//void resetData(int numprocs, int currentRank, int rowsize, double h[][], double g[][]);
void print(int rowsize,int DEVIDE_SIZE_N, double original[][]);
//void printlines(int DEVIDE_SIZE_N, int row1, int row2, double original[][]);
void initializeData2(int procs, int currentRank, int _rowsize_, double **h, double **g);
void print_solution (int M, int N, char *filename, double u[][]);
void allocate_2d_array (int r, int c, double ***a);
void print2(int rowsize,int DEVIDE_SIZE_N,  double **original);
//void copy(int rowsize, double **g,double g0[][]);

/**
* usage: input one argument: DEVIDE_SIZE
*/
int DEVIDE_SIZE_M = 200;
int DEVIDE_SIZE_N = 200;
double starttime, endtime;

int main(int argc, char *argv[])
{
	double **h;
	double **g;
    int myrank, numprocs,i,j;

	double tick;
    int rowsize;
    printf("-");
    if(argc != 7)
	{
		//printf("Usage: input one argument: DEVIDE_SIZE\nmpirun -np [num] -machinefile ~/machines1 [M] [N]\n");
	}
    else
	{
		DEVIDE_SIZE_M = atoi(argv[1]);		
		DEVIDE_SIZE_N = atoi(argv[2]);
	}
    double original[DEVIDE_SIZE_M][DEVIDE_SIZE_N];
    MPI_Init(&argc, &argv);
    MPI_Comm_size(MPI_COMM_WORLD, &numprocs);
    MPI_Comm_rank(MPI_COMM_WORLD, &myrank);/* get the rank */
    fflush(stdout); 

//	printf("num=%d\n",numprocs);
	int tempdata[2];

	tempdata[0] = DEVIDE_SIZE_M;
	tempdata[1] = DEVIDE_SIZE_N;
	MPI_Bcast(tempdata, 2, MPI_INT, 0, MPI_COMM_WORLD);
	DEVIDE_SIZE_M = tempdata[0];
	DEVIDE_SIZE_N = tempdata[1];

	rowsize = DEVIDE_SIZE_M / numprocs;
	//printf("DEVIDE_SIZE=%d\n",DEVIDE_SIZE);
	//printf("numprocs=%d\n",numprocs);
	//printf("rowsize=%d\n",rowsize);
	//printf("DEVIDE_SIZE mod numprocs = %d\n",DEVIDE_SIZE%numprocs);	

	allocate_2d_array(rowsize+2,DEVIDE_SIZE_N,&h);
	allocate_2d_array(rowsize+2,DEVIDE_SIZE_N,&g);

	if(myrank == 0)
	{
		initializeData2(numprocs, myrank , rowsize+2, h , g);
		sprintf(filename, "%s.dat", argv[0]);
		printf("\nProblem size: M=%d,N=%d\n",DEVIDE_SIZE_M,DEVIDE_SIZE_N);
		fflush(stdout);
		MPI_Barrier(MPI_COMM_WORLD);
		starttime = MPI_Wtime();
		//printf("rank: %d, elapsed=%lf\n", myrank,MPI_Wtime()-starttime);
		doDistribution(numprocs, myrank, rowsize, DEVIDE_SIZE_N,h,g);
		/**
		* converge data.
		*/
		reduceData(rowsize, numprocs, DEVIDE_SIZE_N, original);
		for(i = 0;i < rowsize;i++)
			for(j = 0;j <= DEVIDE_SIZE_N - 1; j++)
				original[i][j] = h[i+1][j];
		endtime = MPI_Wtime();
		printf("WTIME=%lf\n", endtime-starttime);
		tick = MPI_Wtick();
		printf("The precision of time is:%lf\n",tick);
		/**
		* print out the result.
		*/
		//print(DEVIDE_SIZE_M, DEVIDE_SIZE_N, original);
		printf("Finished^^\n");
		printf("The heat-distribution result copying... \n");
		print_solution(DEVIDE_SIZE_M,DEVIDE_SIZE_N, filename, original);
	}
	else
	{
		//printf("M=%d,N=%d\n",DEVIDE_SIZE_M,DEVIDE_SIZE_N);
		initializeData2(numprocs, myrank ,  rowsize+2, h , g);
		//printf("rank: %d, elapsed=%lf loc: before barrier.\n", myrank,MPI_Wtime()-starttime);fflush(stdout);
		MPI_Barrier(MPI_COMM_WORLD);
		//printf("rank: %d, elapsed=%lf loc: after barrier.\n", myrank,MPI_Wtime()-starttime);fflush(stdout);
		doDistribution(numprocs, myrank, rowsize, DEVIDE_SIZE_N,h,g);
	}
	MPI_Finalize();	
	return 0;
}

/**
*	Initialize data. (never been used in this program, maybe usable for future^^)
*/
void init(int DEVIDE_SIZE_M, int DEVIDE_SIZE_N, double original[][DEVIDE_SIZE_N])
{
	int i,j;
	for(i = 1;i < DEVIDE_SIZE_M - 1; i++)
		for(j = 1;j < DEVIDE_SIZE_N - 1; j++)
			original[i][j] = 25;
	for(i = 0;i < DEVIDE_SIZE_M; i++)
	{
		original[i][DEVIDE_SIZE_N-1] = 0;
		original[i][0] = 0;
		original[DEVIDE_SIZE_M-1][i] = 0;
		original[0][i] = 1000.0;
	}
}


/**
*  Reduce data by rows
**
**********************/
void reduceData(int rowsize, int numprocs, int DEVIDE_SIZE_N, double original[][DEVIDE_SIZE_N])
{
	MPI_Status status;
	int count;
	int source_ID,i,j;
	double p[rowsize+2][DEVIDE_SIZE_N];
	//printf("====reduceData\n");
	for(count = 1; count <= numprocs - 1; count++ )
	{
		MPI_Recv(&p[0], (rowsize+2)*DEVIDE_SIZE_N, MPI_DOUBLE, MPI_ANY_SOURCE, MPI_ANY_TAG, MPI_COMM_WORLD, &status);
		//printf("reduce data from %d------------------------\n",status.MPI_SOURCE);
		//print(rowsize+2,DEVIDE_SIZE_N,p);
		if(status.MPI_TAG == QUITTAG)
		{
			source_ID = status.MPI_SOURCE;
			for(i = 1; i <= rowsize; i++)
			{
				int rownumber = source_ID * rowsize + i - 1;
				for(j = 0; j < DEVIDE_SIZE_N; j++)
				{
					original[rownumber][j] = p[i][j];
				}
			}
		}			
		else
			printf("EXCEPT ERROR!\n");

	}
}

/**
* distribute data (when running processes)
* assume the DEVIDE_SIZE%numprocs == 0
* currentRank ( from 1 to (numprocs -1))
* Notice: numprocs includes the root process ( whose ID = 0).
* g[][] and h[][] are both of rowsize X DEVIDE_SIZE. rowsize is heigth, DEVIDE_SIZE is width.
* compute from 1 to DEVIDE_SIZE-2. 
* including accelerator-strategy
*/
void doDistribution(int numprocs, int currentRank, int rowsize, int DEVIDE_SIZE_N,double **h,double **g)
{

	MPI_Request req4[4];
	MPI_Request req2[2];
	MPI_Status status2[2];
	MPI_Status status4[4];
	int k,i,j;
	double timestamp;
	int _rowsize_ = rowsize + 2; //include two ghost arrays.
	double p[_rowsize_][DEVIDE_SIZE_N];
	//	printf("====numprocs=%d\n",numprocs);
	//printf("DEVIDE_SIZE=%d-----------------------------------------------------------\n",DEVIDE_SIZE);
	double localerror;
	double globalerror = 0;
	//printf("rank: %d, elapsed=%lf loc: begin doDistribution.\n", currentRank,MPI_Wtime()-starttime);fflush(stdout);
	for(k = 0;k < ITERATIVE_TIMES; k++)
	{
		//timestamp = MPI_Wtime();
		//if(k % 100 == 0 )
		//	printf("for: %d rank: %d, elapsed=%lf\n",k, currentRank,MPI_Wtime()-starttime);fflush(stdout);
		//printf("<<%d>>k=%d,ITERATIVE_TIMES=%d\n",currentRank,k,ITERATIVE_TIMES);
		localerror = 0;
		double time000 = MPI_Wtime();
		if(currentRank == 0)
		{
			MPI_Isend(&g[rowsize][0], DEVIDE_SIZE_N, MPI_DOUBLE, 1, WORKTAG, MPI_COMM_WORLD,&req2[1]);
			MPI_Irecv(&h[rowsize + 1][0], DEVIDE_SIZE_N, MPI_DOUBLE, 1, WORKTAG, MPI_COMM_WORLD, &req2[0]);

			for(i = 2; i <= rowsize; i++)
				for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
				{
					g[i][j] = 0.25*(h[i-1][j]+h[i+1][j]+h[i][j-1]+h[i][j+1]);
					if(localerror < fabs(g[i][j] - h[i][j]))
						localerror = fabs(g[i][j] - h[i][j]);
				}
			for(i = 1; i <= rowsize; i++)
				for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
					h[i][j] = g[i][j];
			//printf("localerror=%lf\n",localerror);
//			printf("for: %d rank: %d(1), ----------compute time=%lf\n",k, currentRank,timestamp2-timestamp);fflush(stdout);
			MPI_Waitall(2,req2,status2);
		}
		else if(currentRank == (numprocs -1))
		{
			MPI_Isend(&g[1][0], DEVIDE_SIZE_N, MPI_DOUBLE, currentRank - 1, WORKTAG, MPI_COMM_WORLD, &req2[0]);
			MPI_Irecv(&h[0][0], DEVIDE_SIZE_N, MPI_DOUBLE, currentRank - 1, WORKTAG, MPI_COMM_WORLD, &req2[1]);
			for(i = 1; i <= rowsize - 1; i++)
				for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
				{
					g[i][j] = 0.25*(h[i-1][j]+h[i+1][j]+h[i][j-1]+h[i][j+1]);
					if(localerror < fabs(g[i][j] - h[i][j]))
						localerror = fabs(g[i][j] - h[i][j]);
				}
			for(i = 1; i <= rowsize; i++)
				for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
					h[i][j] = g[i][j];
			MPI_Waitall(2,req2,status2);

		}
		else // currentRank == 1 ... numprocs - 2
		{
			MPI_Isend(&g[1][0], DEVIDE_SIZE_N, MPI_DOUBLE, currentRank - 1, WORKTAG, MPI_COMM_WORLD, &req4[0]);
			MPI_Isend(&g[rowsize][0], DEVIDE_SIZE_N, MPI_DOUBLE, currentRank + 1, WORKTAG, MPI_COMM_WORLD, &req4[1]);
			MPI_Irecv(&h[0][0], DEVIDE_SIZE_N, MPI_DOUBLE, currentRank - 1, WORKTAG, MPI_COMM_WORLD, &req4[2]);
			MPI_Irecv(&h[rowsize + 1][0], DEVIDE_SIZE_N, MPI_DOUBLE, currentRank + 1, WORKTAG, MPI_COMM_WORLD, &req4[3]);
	
			//compute all elements from the 1st line to the second last line.
			for(i = 1; i <= rowsize; i++)
				for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
				{
					g[i][j] = 0.25*(h[i-1][j]+h[i+1][j]+h[i][j-1]+h[i][j+1]);
					if(localerror < fabs(g[i][j] - h[i][j]))
						localerror = fabs(g[i][j] - h[i][j]);
				}
			for(i = 1; i <= rowsize; i++)
				for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
					h[i][j] = g[i][j];
			MPI_Waitall(4,req4,status4);
		}
		//printf("<>currentRank: %d,localerror:%lf,globalerror:%lf\n",currentRank,localerror,globalerror);
		//double timestamp2 = MPI_Wtime();
		//if(k % 100 == 0 )
		//	printf("for: %d rank: %d(1), compute time=%lf\n",k, currentRank,timestamp2-timestamp);fflush(stdout);
		MPI_Allreduce(&localerror,&globalerror,1,MPI_DOUBLE,MPI_MAX, MPI_COMM_WORLD);  // very weird! why k will be changed?
		//printf("--currentRank: %d, k:%d,globalerror=%lf\n",currentRank, k,globalerror);
		//if(k % 100 == 0 )
		//	printf("for: %d rank: %d(2),     allreduce w-time=%lf\n",k, currentRank,MPI_Wtime()-timestamp2);fflush(stdout);
		if(globalerror < PRECISION)
		{
		//	printf("Rank: %d, execution times: %d\n",currentRank, k);
			break;
		}
	}

	if(currentRank !=0)
	{
		//printf("data from %d------------------------\n",currentRank);
		//print2(rowsize+2,DEVIDE_SIZE_N,h);
		for(i = 0;i<rowsize+2;i++)
			for( j = 0;j<DEVIDE_SIZE_N;j++)
				p[i][j] = h[i][j];
		MPI_Send(&p[0], (rowsize+2)*DEVIDE_SIZE_N, MPI_DOUBLE, 0, QUITTAG, MPI_COMM_WORLD);
	}
}

	/*
	* Initialize data
	* 1000    0    0    0
	* 1000    25   25   0
	* 1000    25   25   0
	* 1000    0     0   0
	*/
void initializeData2(int procs, int currentRank, int _rowsize_, double **h, double **g)
{
	extern int DEVIDE_SIZE_N;
	int i, j;


	for(i = 0; i < _rowsize_; i = i + 1)
	{
		for(j = 0; j < DEVIDE_SIZE_N - 1; j++)
		{
			g[i][j] = h[i][j] = 25.0;
		}
	}

	for(j = 0;j < DEVIDE_SIZE_N;j++)
	{
		g[_rowsize_ - 1][j] = h[_rowsize_ - 1][j] = 25;
	}


	//initialize the 1st line
	if(currentRank == 0)
	{
		for(j = 0;j < DEVIDE_SIZE_N;j++)
		{
			g[1][j] = h[1][j] = 0;
		}
	}
	if(currentRank == procs - 1)
		for(j = 0;j < DEVIDE_SIZE_N;j++)
		{
			g[_rowsize_ - 2][j] = h[_rowsize_ - 2][j] = 0.0;
		}

	for(i = 0;i < _rowsize_;i++)
	{
		g[i][0] = h[i][0] = 1000;
		g[i][DEVIDE_SIZE_N-1] = h[i][DEVIDE_SIZE_N-1] = 0.0;
	}
	g[0][0]=g[_rowsize_-1][0]=h[0][0]=h[_rowsize_-1][0] = 0;
	//printf("initialize data................................\n");
	//print(_rowsize_ ,DEVIDE_SIZE_M,h);
}
/* Print solution to standard output or a file */
void print_solution (int M, int N, char *filename, double u[][DEVIDE_SIZE_N])
{
   int i, j;
   char sep;
   FILE *outfile;
   
   if (!filename) {
      sep = '\t';   /* just for easier view */
      outfile = stdout;
   } else {
      sep = '\n';   /* for gnuplot format */
      outfile = fopen(filename,"w");
      if (outfile == NULL) {
         printf("Can't open output file.");
         exit(-1);
      }
   }

   /* Print the solution array */
   for (i = 0; i < M; i++) {
      for (j = 0; j < N; j++) 
         fprintf (outfile, "%6.2f%c", u[i][j], sep);
      fprintf(outfile, "\n"); /* Empty line for gnuplot */
   }
   if (outfile != stdout)
      fclose(outfile);
   
#ifdef INTERACTIVE
   /* Copy to another data file for gnuplot to plot */
   if (outfile != stdout) {
      char tempname[100];              /* Temp file name for gnuplot */
      char cmd[1024];                  /* System command buffer */
      sprintf(tempname, "jacobi.dat");
      sprintf(cmd, "cp %s %s", filename, tempname);
      system(cmd);
   }
#endif
}

/* Allocate two-dimensional array. */
void allocate_2d_array (int r, int c, double ***a)
{
   double *storage;
   int     i;
   storage = (double *) malloc (r * c * sizeof(double));
   *a = (double **) malloc (r * sizeof(double *));
   for (i = 0; i < r; i++)
      (*a)[i] = &storage[i * c];
}

void print(int rowsize,int DEVIDE_SIZE_N,  double original[][DEVIDE_SIZE_N])
{
	int i,j;
//	printf("print result.\n");
	for(i = 0; i < rowsize; i ++)
	{		
		for(j = 0; j < DEVIDE_SIZE_N; j++)
		{
			printf("%10.4f", original[i][j]);
		}
		printf("\n");
	}
	fflush(stdout);
}
void print2(int rowsize,int DEVIDE_SIZE_N,  double **original)
{
	int i,j;
//	printf("print result.\n");
	for(i = 0; i < rowsize; i ++)
	{		
		for(j = 0; j < DEVIDE_SIZE_N; j++)
		{
			printf("%10.4f", original[i][j]);
		}
		printf("\n");
	}
	fflush(stdout);
}
/*
void printlines(int DEVIDE_SIZE_N, int row1, int row2, double original[][DEVIDE_SIZE_N])
{
	int i,j;
	fflush(stdout);
	for(i = row1; i <= row2; i ++)
	{		
		for(j = 0; j < DEVIDE_SIZE_N; j++)
		{
			printf("%10.4f", original[i][j]);
		}
		printf("\n");
	}
	fflush(stdout);
}
*/
	/*
	* Initialize data
	* 1000 1000 1000 1000
	*   0    25   25   0
	*   0    25   25   0
	*   0    0     0   0
	*/
/*
void initializeData(int procs, int currentRank, int _rowsize_, double h[][DEVIDE_SIZE_N], double g[][DEVIDE_SIZE_N])
{
	extern int DEVIDE_SIZE_N;
	int i, j;

	//init the last line
	for(i = 0;i < _rowsize_;i++)
		g[i][0] = h[i][0] = g[i][DEVIDE_SIZE_N-1] = h[i][DEVIDE_SIZE_N-1] = 0.0;
	for(j = 0;j < DEVIDE_SIZE_N;j++)
	{
		g[_rowsize_ - 1][j] = h[_rowsize_ - 1][j] = 25;
	}

	// init 1 ~ rowsize lines
	for(i = 1; i < _rowsize_ - 1; i = i + 1)
	{
		for(j = 1; j < DEVIDE_SIZE_N - 1; j++)
		{
			g[i][j] = h[i][j] = 25.0;
		}
	}
	//initialize the 1st line
	if(currentRank == 0)
	{
		for(j = 0;j < DEVIDE_SIZE_N;j++)
		{
			g[1][j] = h[1][j] = 1000.0;
		}
	}
	else // currentRank != 1
		for(j = 0;j < DEVIDE_SIZE_N;j++)
		{
			g[0][j] = h[0][j] = 25.0;
		}
	
	if(currentRank == procs - 1)
		for(j = 0;j < DEVIDE_SIZE_N;j++)
		{
			g[_rowsize_ - 2][j] = h[_rowsize_ - 2][j] = 0.0;
		}
}
*/


/**
*	copy g data to g0
*	**g    g0[][]
*/
/*
void copy(int rowsize, double **g,double g0[][DEVIDE_SIZE_N])
{
	int i,j;
	for(i = 0; i < rowsize;i++)
		for(j = 0; j < DEVIDE_SIZE_N;j++)
		{
			g0[i+1][j] = g[i][j];
		}
}
*/

/**
* print out the result
*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲品质自拍视频| 国产欧美中文在线| 日本aⅴ免费视频一区二区三区 | 日韩黄色小视频| 7777精品久久久大香线蕉| 秋霞午夜鲁丝一区二区老狼| 日韩丝袜美女视频| 韩国欧美国产1区| 国产精品天美传媒| 91久久精品网| 欧美aa在线视频| 国产校园另类小说区| 丰满白嫩尤物一区二区| 亚洲男人天堂av| 3d动漫精品啪啪1区2区免费| 美女被吸乳得到大胸91| 久久久美女艺术照精彩视频福利播放| 国产成人三级在线观看| 中文字幕亚洲成人| 制服丝袜在线91| 国产盗摄一区二区| 亚洲影院理伦片| 中日韩av电影| 亚洲乱码日产精品bd| 国产一区二区主播在线| 粉嫩久久99精品久久久久久夜| 欧美一区二区三区四区五区| 26uuu色噜噜精品一区| 亚洲欧美国产三级| 国产乱子伦视频一区二区三区| www.欧美.com| 久久免费视频一区| 丝袜亚洲另类欧美| 99精品久久只有精品| 在线播放欧美女士性生活| 中文字幕国产一区| 精品制服美女丁香| 色系网站成人免费| 亚洲欧洲精品成人久久奇米网| av动漫一区二区| caoporn国产一区二区| 欧美成人a∨高清免费观看| 日日噜噜夜夜狠狠视频欧美人 | 日韩一级完整毛片| 国产福利精品一区| 日韩精品乱码av一区二区| 国产精品网站在线| 欧美成人乱码一区二区三区| 色综合一个色综合| 国产主播一区二区三区| 欧美日韩三级在线| 另类欧美日韩国产在线| 不卡电影一区二区三区| 国产精品欧美一区二区三区| 91免费看视频| 日韩一区二区免费视频| 老司机免费视频一区二区| 国产视频911| 极品少妇xxxx偷拍精品少妇| 欧美日韩久久一区| av影院午夜一区| 国产成人综合网| 老汉av免费一区二区三区 | 日本欧美一区二区三区| 亚洲免费毛片网站| 中文在线一区二区| 日本一区二区三区视频视频| 欧美r级在线观看| 69av一区二区三区| 8x8x8国产精品| 欧美人妇做爰xxxⅹ性高电影 | 日韩精品中午字幕| 欧美日韩精品综合在线| 在线观看视频一区二区| 欧洲亚洲国产日韩| 欧美自拍偷拍午夜视频| 在线视频国内自拍亚洲视频| 色狠狠综合天天综合综合| 91色视频在线| 91久久人澡人人添人人爽欧美 | 国产剧情一区二区| 亚洲男人的天堂一区二区| 亚洲国产精品天堂| 日本一区二区三区国色天香 | 欧美精品自拍偷拍| 国产欧美一区二区三区鸳鸯浴 | 欧美日韩美少妇| 欧美日韩国产a| 欧美久久一二区| 欧美老年两性高潮| 日韩三级电影网址| 精品日韩99亚洲| 久久影院视频免费| 国产精品美女一区二区三区| 国产精品看片你懂得| 国产精品国产三级国产普通话蜜臀| 欧美国产精品专区| 一区二区三区在线看| 亚洲高清免费在线| 免费在线视频一区| 国产精品12区| 91麻豆福利精品推荐| 欧美日韩国产在线观看| 欧美大片一区二区| 国产精品成人一区二区艾草| 亚洲曰韩产成在线| 国产综合色视频| 99久久免费视频.com| 欧美日韩精品一区二区| 精品国产第一区二区三区观看体验| 国产亚洲综合色| 一区二区三区四区五区视频在线观看| 亚洲电影第三页| 国产最新精品精品你懂的| 91视频.com| 日韩精品一区二| 亚洲日本一区二区| 美女看a上一区| 91浏览器在线视频| www国产亚洲精品久久麻豆| 亚洲精品国产a久久久久久| 日韩av一级电影| 菠萝蜜视频在线观看一区| 欧美一区二区三区小说| 国产精品传媒入口麻豆| 美国十次了思思久久精品导航| 99久久久无码国产精品| 欧美一区二区视频观看视频| 国产精品美女久久久久aⅴ国产馆| 亚洲福利视频导航| 成人国产亚洲欧美成人综合网| 综合久久久久久| 免费精品视频最新在线| 色哟哟一区二区| 国产亚洲精品免费| 日本成人在线看| 色菇凉天天综合网| 欧美激情综合五月色丁香小说| 日韩精品亚洲一区| 日本丶国产丶欧美色综合| 国产色一区二区| 蜜桃传媒麻豆第一区在线观看| 色婷婷av一区二区三区gif| 久久久久久电影| 麻豆91在线观看| 7777女厕盗摄久久久| 伊人色综合久久天天| 从欧美一区二区三区| 精品国产成人在线影院| 日韩精品色哟哟| 欧美日韩极品在线观看一区| 亚洲三级理论片| 95精品视频在线| 国产精品久久99| 成人国产精品免费网站| 国产婷婷色一区二区三区在线| 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美少妇一区二区| 亚洲一区二区三区精品在线| 91在线观看免费视频| 国产精品久久久久久久裸模| 国产99一区视频免费| 国产日韩精品一区二区浪潮av| 蜜臀久久99精品久久久画质超高清| 欧美体内she精高潮| 亚洲一二三专区| 欧美日韩在线播放| 婷婷丁香激情综合| 宅男在线国产精品| 日韩av一区二区三区四区| 日韩一区二区三区免费看 | 精品国产伦理网| 国产一区二区免费视频| 久久久久久一二三区| 国产精品538一区二区在线| 国产日韩av一区| va亚洲va日韩不卡在线观看| 中文字幕亚洲电影| 欧美综合亚洲图片综合区| 亚洲成人中文在线| 欧美一区二区三区四区五区| 寂寞少妇一区二区三区| 国产亚洲精品7777| av一区二区三区四区| 亚洲已满18点击进入久久| 欧美高清www午色夜在线视频| 五月激情综合网| 日韩欧美成人午夜| 粉嫩一区二区三区在线看| 亚洲欧美激情小说另类| 欧美巨大另类极品videosbest | 成人听书哪个软件好| 亚洲色图丝袜美腿| 欧美日韩激情在线| 麻豆91在线播放免费| 国产精品你懂的在线欣赏| 91久久人澡人人添人人爽欧美| 天天影视涩香欲综合网| 精品国产sm最大网站| 不卡的av网站|