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

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

?? merge.c

?? 用于2維的射線追蹤
?? C
字號:
/* * Ray2mesh : software for geophysicists. * Compute various scores attached to the mesh cells, based on geometric   information that rays bring when the traverse the cell. * * Copyright (C) 2003, St閜hane Genaud and Marc Grunberg * * This tool is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#include <sys/types.h>#include <sys/stat.h>#include <unistd.h>#include <sys/mman.h>#ifdef USE_MPI#include <mpi.h>#endif#ifdef USE_ZLIB#include <zlib.h>#endif#include <stdio.h>#include <mesh/mesh.h>#include <mesh/layer.h>#include "ray2mesh.h"#include "r2mfile.h"#include "merge.h"#include "util.h"		/* for get_date_stamp() */#include "memusage.h"#define ROOT 0#define MERGE_DEBUG#ifdef USE_MPI/* check if all transmission occured flawlessly *//* if not, exit                                 */void check_transmission_error(MPI_Status * status_tab, int nb, char *str){	int             i;	int             test;	for (i = 0; i < nb; i++) {		MPI_Test_cancelled(status_tab + i, &test);		if (test == 1) {			fprintf(stderr, "check_transmission_error : [%d] %s", i, str);			MPI_Abort(MPI_COMM_WORLD, 1);			exit(1);		}	}}/* * ************************************************************************* * \brief prepare, send, recv, import in mesh cell data from other processes. * * Each process is assigned a domain which is a vertical mesh slice. * Prepare data cell buffers. This buffer is text formated.   During this process, we scan all domains , each cell is dumped   in the text buffer, then the cell is freed.   1- prepare  buffer and clean  cell_info data in the same time   2- send to other procs the buffer's size   3- recv buffer's size from other procs   4- send the buffer itself to other procs   5- import the buffer received   return: a set of timers:   timers[0] : time to write domain temp files   timers[1] : time to complete receive of all domain sizes after start_time+timers[0]   timers[2] : time to complete send of all domain sizes after start_time+timers[0]   timers[3] : time to emit Irecv for all domains   timers[4] : time to emit Isend for all domains   timers[5] : time to complete Send after Isend emitted   timers[6] : time to complete Recv after Isend emitted   timers[7] : time between start_time_sendrecv and Send+Recv are complete   timers[8] : time after Barrier() -> return from function   timers[9] : time spent for I/O (load_file_to_memory + import_cell_buffer);  ******************************************************************* */double         *send_recv_cell_info(MPI_Comm com, struct cell_info_t **** cell_info,		    struct mesh_t * mesh, char *tmpdir){	MPI_Request    *req_send_tab;	/* array of handler (isend) */	MPI_Request    *req_recv_tab;	/* array of handler (irecv) */	MPI_Status     *status_recv_tab;	/* array of status (irecv)  */	MPI_Status     *status_send_tab;	/* array of status (isend)  */	double         *timers;	double          start_time;	double          start_time_sendrecv;	double          start_time_io;	char           *date_stamp;	int             rank, nbprocs;	int             ireq;	int             tag_size = 1;	/* mpi msg id */	int             tag_buff = 2;	/* mpi msg id */	int             dom;	/* domain ID */	int             buff_size;	/* size txt cell_info buffer */	struct stat     filestat;	struct domain_info_t {	/* domain information */		char            file[256];		char           *buffmap;	/* mmap file buffer */		char           *buff;	/* domain cell info buffer */		int             size_send;	/* buff size */		int             size_recv;	/* buff size */	}              *dominfo;#ifdef USE_ZLIB	char           *zbuf;	int             zbuf_size;#endif	timers = (double *) calloc (10, sizeof(double));   assert(timers);	start_time = MPI_Wtime();	MPI_Comm_rank(com, &rank);	MPI_Comm_size(com, &nbprocs);	fprintf(stdout, "Merge started with proc %d/%d\n", rank, nbprocs);	fflush(stdout);	/* Alloc */	req_send_tab =		(MPI_Request *) calloc(nbprocs - 1, sizeof(MPI_Request));	if (req_send_tab == NULL) {		MPI_Abort(MPI_COMM_WORLD, 1);		exit(1);	}	req_recv_tab =		(MPI_Request *) calloc(nbprocs - 1, sizeof(MPI_Request));	if (req_recv_tab == NULL) {		MPI_Abort(MPI_COMM_WORLD, 1);		exit(1);	}	status_send_tab =		(MPI_Status *) calloc(nbprocs - 1, sizeof(MPI_Status));	if (status_send_tab == NULL) {		MPI_Abort(MPI_COMM_WORLD, 1);		exit(1);	}	status_recv_tab =		(MPI_Status *) calloc(nbprocs - 1, sizeof(MPI_Status));	if (status_recv_tab == NULL) {		MPI_Abort(MPI_COMM_WORLD, 1);		exit(1);	}	dominfo = (struct domain_info_t *)		malloc(nbprocs * sizeof(struct domain_info_t));	if (dominfo == NULL) {		MPI_Abort(MPI_COMM_WORLD, 1);		exit(1);	}	/*****************************************************************************/	/*	 * create data for each domain, save them to disk, and free them from	 * memory	 */	/* Send buffer size                                                          */	/*****************************************************************************/	ireq = 0;	for (dom = 0; dom < nbprocs; dom++) {		dominfo[dom].buffmap = NULL;		dominfo[dom].buff = NULL;		dominfo[dom].size_send = 0;		dominfo[dom].size_recv = 0;		if (dom == rank) {			strcpy(dominfo[dom].file, "");			continue;		}		/* create file with domain cell info and clean the */		/* corresponding cell from memory */#ifdef USE_ZLIB		snprintf(dominfo[dom].file, 256, "%s/p%d-domain-%d.dom.gz", tmpdir, rank,			 dom);#else		snprintf(dominfo[dom].file, 256, "%s/p%d-domain-%d.dom", tmpdir, rank,			 dom);#endif		make_domain_info_file(dominfo[dom].file, cell_info, mesh, dom,				      nbprocs, rank);		stat(dominfo[dom].file, &filestat);		dominfo[dom].size_send = filestat.st_size;#ifdef MERGE_DEBUG		date_stamp = get_date_stamp();		fprintf(stdout,		"*** [process %d] sends size(%d) to [process %d] *** (%s)\n",			rank, dominfo[dom].size_send, dom, date_stamp);		fflush(stdout);		free(date_stamp);#endif		/* send the buffer size to the procs 'dom' which is dedicated */		/* to work on the 'dom' domain */		MPI_Isend(&(dominfo[dom].size_send), 1, MPI_INT, dom, tag_size, com, req_send_tab + ireq);		ireq++;	}   timers[0] = MPI_Wtime() - start_time;	/***************************************/	/* recv buffer's size from other procs */	/***************************************/	ireq = 0;	for (dom = 0; dom < nbprocs; dom++) {		if (dom == rank)			continue;		MPI_Irecv(&(dominfo[dom].size_recv), 1, MPI_INT, dom, tag_size,			  com, req_recv_tab + ireq);		ireq++;	}	/***************************/	/* wait to recv all message */	/***************************/	MPI_Waitall(ireq, req_recv_tab, status_recv_tab);	check_transmission_error(status_recv_tab, ireq, "MPI_Irecv (size)\n");	/* all domain sizes received */	timers[1] = MPI_Wtime() - timers[0] - start_time;#ifdef MERGE_DEBUG	date_stamp = get_date_stamp();	fprintf(stdout,		"*** [process %d] MPI_Irecv domain size from %d other processes ***(%s)\n",		rank, ireq, date_stamp);	fflush(stdout);	free(date_stamp);#endif	/********************************************/	/* wait to be sure that all message is sent */	/********************************************/	MPI_Waitall(ireq, req_send_tab, status_send_tab);	check_transmission_error(status_send_tab, ireq, "MPI_Isend (size)\n");	/* all domain sizes sent */	timers[2] = MPI_Wtime() - timers[1] - start_time;#ifdef MERGE_DEBUG	date_stamp = get_date_stamp();	fprintf(stdout,		"*** [process %d] MPI_Isend domain sizes to all other processes (%d) *** (%s)\n",		rank, ireq, date_stamp);	fflush(stdout);	free(date_stamp);#endif	//MPI_Barrier(com);	/* reset to zero */	/*	 * memset(req_recv_tab, 0, sizeof(MPI_Request)*(nbprocs-1));	 * memset(req_send_tab, 0, sizeof(MPI_Request)*(nbprocs-1));	 */	/* mem info */	fprintf(stdout,		"*** [process %d] starting data exange with MEM=%.2f\n",		rank, get_mem_usage());	fflush(stdout);	/*****************************************************************/	/* recv  buffer must be in a recv wait state before sending data */   /* when buffer are >  40K                                        */	/*****************************************************************/	start_time_sendrecv = MPI_Wtime();	ireq = 0;	for (dom = 0; dom < nbprocs; dom++) {		if (dom == rank)			continue;		/* allocation to recv the buffer */		dominfo[dom].buff = (char *)			malloc(sizeof(char) * dominfo[dom].size_recv);		if (dominfo[dom].buff == NULL) {			fprintf(stderr, "%s : could not allocate %d bytes. Exiting.\n", PACKAGE, dominfo[dom].size_recv);			MPI_Abort(MPI_COMM_WORLD, 1);		}#ifdef MERGE_DEBUG		date_stamp = get_date_stamp();		fprintf(stdout, "*** [process %d] waits buffmap from [process %d] (size = %d) (%s)\n",			rank, dom, dominfo[dom].size_recv, date_stamp);		fflush(stdout);		free(date_stamp);#endif		/* start Irecv data */		MPI_Irecv(dominfo[dom].buff, dominfo[dom].size_recv,			  MPI_UNSIGNED_CHAR, dom, tag_buff, com,			  req_recv_tab + ireq);		ireq++;	}	timers[3] = MPI_Wtime() - start_time_sendrecv;	/* mem info */	fprintf(stdout,		"*** [process %d] all data buffers space to be received are allocated, MEM=%.2f\n",		rank, get_mem_usage());	fflush(stdout);	/****************/	/* send  buffer */	/****************/	ireq = 0;	for (dom = 0; dom < nbprocs; dom++) {		if (dom == rank)			continue;            start_time_io =  MPI_Wtime();		/* load domain cell info to mem and send it */		if ((dominfo[dom].buffmap =		     load_file_to_memory(dominfo[dom].file, &buff_size)) == NULL) {			fprintf(stderr,				"%s : could not load %s to memory (%d bytes). Check free space on disk. Exiting.\n",				PACKAGE, dominfo[dom].file, buff_size);			MPI_Abort(MPI_COMM_WORLD, 1);		}		timers[9] += MPI_Wtime() - start_time_io;#ifdef MERGE_DEBUG		date_stamp = get_date_stamp();		fprintf(stdout,			"*** [process %d] sends buffmap to [process %d] (size = %d/%d) *** (%s)\n",		  rank, dom, buff_size, dominfo[dom].size_send, date_stamp);		fflush(stdout);		free(date_stamp);#endif		MPI_Isend(dominfo[dom].buffmap, dominfo[dom].size_send,			  MPI_UNSIGNED_CHAR, dom, tag_buff, com,			  req_send_tab + ireq);		ireq++;	}	/* all Isend have been emitted */	timers[4] = MPI_Wtime() - timers[3] - start_time_sendrecv;#ifdef MERGE_DEBUG	date_stamp = get_date_stamp();	fprintf(stdout, "*** [process %d] sent all buffmap to all other processes (%d) *** (%s)\n",		rank, ireq, date_stamp);	fflush(stdout);	free(date_stamp);#endif	/* mem info */	fprintf(stdout, "*** [process %d] all data buffers space to be send are allocated, MEM=%.2f\n",		rank, get_mem_usage());	fflush(stdout);	/****************/	/* Manage data */	/***************/	{		int             send_status = 1;		int             recv_status = 1;		int             send_proc_id, recv_proc_id;		MPI_Status      sstatus, rstatus;		while (send_status || recv_status) {			if (send_status) {				/* if data are sent -> clean them */				MPI_Waitany(ireq, req_send_tab, &send_proc_id, &sstatus);				if (send_proc_id == MPI_UNDEFINED) {					send_status = 0;					/* from Isend to sending complete */					timers[5] = MPI_Wtime() - timers[4] - timers[3] - start_time_sendrecv;				} else {					if (send_proc_id >= rank) {						send_proc_id++;					}#ifdef MERGE_DEBUG					date_stamp = get_date_stamp();					fprintf(stdout,						"*** [process %d] MPI_Isend (buffer)   to [process %d] OK *** (%s)\n",					    rank, send_proc_id, date_stamp);					fflush(stdout);					free(date_stamp);#endif					munmap(dominfo[send_proc_id].buffmap, dominfo[send_proc_id].size_send);					unlink(dominfo[send_proc_id].file);					dominfo[send_proc_id].buffmap = NULL;				}			}			if (recv_status) {				/* if data are received -> process them */				MPI_Waitany(ireq, req_recv_tab, &recv_proc_id, &rstatus);				if (recv_proc_id == MPI_UNDEFINED) {					recv_status = 0;					/* from Isend to receiving complete */					timers[6] = MPI_Wtime() - timers[4] - timers[3] - start_time_sendrecv;				} else {					if (recv_proc_id >= rank) {						recv_proc_id++;					}#ifdef MERGE_DEBUG					date_stamp = get_date_stamp();					fprintf(stdout, "*** [process %d] MPI_Irecv (buffer) from [process %d] OK *** (%s)\n",					    rank, recv_proc_id, date_stamp);					fflush(stdout);					free(date_stamp);#endif					start_time_io= MPI_Wtime();#ifdef USE_ZLIB										zbuf = dominfo[recv_proc_id].buff;					zbuf_size = dominfo[recv_proc_id].size_recv;					dominfo[recv_proc_id].buff = decompress_cell_data_gzbuffer(						 cell_info, zbuf, zbuf_size,												   &(dominfo[recv_proc_id].size_recv), rank);					free(zbuf);#endif					import_cell_buffer(cell_info,							   dominfo[recv_proc_id].buff, dominfo[recv_proc_id].size_recv,							   -1, -1,	/* import all layers */							rank, recv_proc_id);					free(dominfo[recv_proc_id].buff);					timers[9] += MPI_Wtime() - start_time_io;					fprintf(stdout,						"*** [process %d] after buffer[%d] importation, MEM=%.2f\n",					   rank, recv_proc_id, get_mem_usage());					fflush(stdout);				}			}		}	}	date_stamp = get_date_stamp();	fprintf(stdout, "*** [process %d] DATA EXCHANGE COMPLETED, MEM=%.2f (%s)\n",		rank, get_mem_usage(), date_stamp);	fflush(stdout);	free(date_stamp);	/******************/	/* cleaning stuff */	/******************/	free(req_send_tab);	free(status_send_tab);	free(req_recv_tab);	free(status_recv_tab);	free(dominfo);	/* from Isend to send/receive complete */	timers[7] = (MPI_Wtime() - start_time_sendrecv);	MPI_Barrier(com);	/* full send_receive operation */	timers[8] = (MPI_Wtime() - start_time);	return (timers);}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久免费观看| 91在线视频官网| 亚洲精品日韩综合观看成人91| 日韩欧美不卡一区| 欧美美女bb生活片| 欧洲一区在线电影| 日本道在线观看一区二区| 91色九色蝌蚪| 不卡一区中文字幕| 91丝袜美腿高跟国产极品老师 | 91精品国产免费| 欧美日韩一二区| 欧美日本乱大交xxxxx| 91久久一区二区| 欧美三级资源在线| 欧美肥妇毛茸茸| 欧美成人精精品一区二区频| 日韩免费视频一区| 日韩精品一区二区三区中文不卡| 91麻豆精品国产无毒不卡在线观看| 欧美日韩一区成人| 精品三级在线看| 中文字幕成人av| 亚洲品质自拍视频| 亚洲不卡一区二区三区| 亚洲国产aⅴ天堂久久| 日韩精品欧美精品| 国产在线播放一区| 国产精品66部| 91麻豆精品在线观看| 欧美日免费三级在线| 精品剧情在线观看| 中文字幕一区二区三区不卡在线| 亚洲综合色成人| 蜜桃一区二区三区在线观看| 国产mv日韩mv欧美| 欧美美女一区二区三区| 国产日韩欧美精品在线| 亚洲国产sm捆绑调教视频| 激情综合五月婷婷| 在线精品视频一区二区| 日韩美女主播在线视频一区二区三区 | 精彩视频一区二区三区| 99久久精品久久久久久清纯| 欧美精品三级在线观看| 日本一区二区在线不卡| 亚洲大尺度视频在线观看| 国产精品一区二区三区99| 色噜噜久久综合| 国产色91在线| 日韩电影在线观看一区| 99久久精品国产观看| 欧美成人精品高清在线播放| 自拍偷自拍亚洲精品播放| 麻豆精品视频在线观看免费| 在线精品视频免费播放| 欧美激情一区二区三区| 美国欧美日韩国产在线播放| 色婷婷综合久久久久中文一区二区| 日韩精品一区二区三区蜜臀| 亚洲影院在线观看| 国产电影精品久久禁18| 日韩欧美国产三级| 日韩主播视频在线| 色偷偷成人一区二区三区91 | av在线这里只有精品| 欧美一级二级在线观看| 亚洲国产一区二区三区青草影视| av在线不卡免费看| 国产欧美日产一区| 国产在线播放一区| 精品国产乱码久久久久久老虎| 午夜精品久久久久久久久久久| jlzzjlzz欧美大全| 中文在线免费一区三区高中清不卡| 另类小说综合欧美亚洲| 欧美精品在线视频| 午夜av一区二区三区| 欧美图区在线视频| 亚洲图片欧美一区| 欧美日韩一级二级| 日本女优在线视频一区二区| 3751色影院一区二区三区| 天天综合网 天天综合色| 欧美日韩中文字幕精品| 午夜免费久久看| 欧美精选午夜久久久乱码6080| 亚洲国产一区视频| 在线电影院国产精品| 日本亚洲三级在线| 日韩一级片在线观看| 国产自产视频一区二区三区| 欧美mv日韩mv亚洲| 国产一区二区电影| 久久久久久久久久久久久夜| 成人av在线电影| 亚洲精品国产品国语在线app| 欧美伊人久久大香线蕉综合69| 亚洲午夜电影在线观看| 日韩一卡二卡三卡四卡| 国产自产视频一区二区三区| 久久久亚洲精华液精华液精华液| 国产一区二区三区黄视频| 中文字幕久久午夜不卡| 欧美图片一区二区三区| 三级欧美在线一区| 久久免费偷拍视频| 99精品久久免费看蜜臀剧情介绍| 亚洲国产精品嫩草影院| 久久亚洲一区二区三区明星换脸| 国产成人av电影| 夜夜操天天操亚洲| 精品人在线二区三区| 成人精品视频.| 香港成人在线视频| 精品99一区二区三区| 91婷婷韩国欧美一区二区| 蜜臀久久99精品久久久久宅男| 国产欧美一区二区精品性| 欧美伊人久久久久久午夜久久久久| 久久精品国产久精国产爱| 亚洲欧洲国产专区| 欧美一区二区三区成人| 成人av网址在线| 麻豆精品精品国产自在97香蕉| 国产精品第13页| 欧美大片日本大片免费观看| 色哟哟一区二区在线观看| 久久精品99久久久| 亚洲午夜在线视频| 国产清纯白嫩初高生在线观看91 | 国产精品久久久一本精品| 欧美绝品在线观看成人午夜影视| 成人激情小说乱人伦| 蜜桃视频在线观看一区| 亚洲精品国产a| 欧美电影影音先锋| 播五月开心婷婷综合| 久久电影网电视剧免费观看| 亚洲一区视频在线观看视频| 中文字幕的久久| 久久亚洲一级片| 日韩午夜在线观看| 欧美日韩综合在线免费观看| 97久久人人超碰| 国产不卡免费视频| 国产一区二区福利| 精品一区二区影视| 日产精品久久久久久久性色| 一区二区三区不卡在线观看| 综合激情成人伊人| 国产亚洲欧美一区在线观看| 26uuu亚洲| 欧美变态凌虐bdsm| 日韩欧美在线网站| 日韩一级片在线播放| 日韩欧美中文一区二区| 欧美日韩精品是欧美日韩精品| 色婷婷av一区二区三区大白胸| 99久久精品国产麻豆演员表| 99久久精品免费| 91麻豆swag| 日本高清不卡aⅴ免费网站| 在线观看av不卡| 欧美丰满嫩嫩电影| 欧美一区二区三区免费在线看| 欧美精品v日韩精品v韩国精品v| 91.麻豆视频| 精品欧美一区二区久久| 亚洲精品一线二线三线| 国产亚洲成年网址在线观看| 国产亚洲成av人在线观看导航 | 国产精品国产三级国产| 国产精品国产精品国产专区不片| 亚洲女同一区二区| 日韩中文字幕一区二区三区| 免费成人av资源网| 国产精品一区2区| 91在线视频播放地址| 在线观看国产精品网站| 91精品在线免费| 国产亚洲成aⅴ人片在线观看 | 欧美日韩色一区| 91麻豆精品91久久久久久清纯| 久久亚洲精品小早川怜子| 国产精品久久久久久久久免费丝袜 | 国产三级欧美三级日产三级99 | 99久久久无码国产精品| 91原创在线视频| 91麻豆精品国产91| 久久精品一区二区三区四区| 国产精品国产三级国产专播品爱网 | 精品福利一区二区三区| 国产精品美女久久久久久| 尤物av一区二区| 久久99国产精品久久| 色欧美日韩亚洲| 精品国产一区a| 亚洲综合在线电影| 国产精品一区二区男女羞羞无遮挡|