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

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

?? fits_tmln.cpp

?? 本源碼是一個用于衛星數據處理的程序
?? CPP
字號:

#include <stdio.h>
#include "stdafx.h"
#include "ccsds_pro.h"
#include "fits_tmln.h"
/********此文件中函數前都有詳細說明,函數中具體實現參照fits_asf.cpp中的注釋******/

/*****************************************************
** 函數名: LoadTMLN
** 輸入: hxmtfile, s
**        hxmtfile    --- 文件名結構 
**        s           --- 存放多個容器的結構體
** 輸出: 
**           函數執行成功返回0
** 調用說明:	
**			strUTC2time() .......把年月日是時分秒格式的時間字符串轉換成對應的秒	
**			close_fits_tmln()....關閉fits文件
**			get_fits_filename()..取得fits文件名和保存路徑
**          open_fits_tmln() ....生成fits文件并在fits肉中寫入關鍵字
**			write_fits_tmln() ...寫fits文件
** 功能描述:輸入一個TIMELINE文件,把文件中的每行數據的各個字段讀入結構體中,并生成fits文件,然后寫入fits文件中
****************************************************************************************/
int LoadTMLN( const hxmt_file_t *hxmtfile , struct sci_intern *s )
{
	FILE *fp = NULL;
	char *buffer = NULL;
	fitsfile *fptr = NULL;
	int modetype;
	std::string fits_name;
	if( !hxmtfile || (fp = fopen(hxmtfile->filename.c_str(), "r")) == NULL  )
		return -1;
	
	hxmt_file_t hxmt = *hxmtfile;
	std::string prev_fitsname;
	
	if( (buffer = (char *)malloc(FREAD_BUFFER_SIZE)) == NULL )	{
		fclose(fp); close_fits_tmln( fptr );
		return -ERROR_NOT_ENOUGH_MEMORY;
	}

	while( fgets(buffer, FREAD_BUFFER_SIZE, fp) )
	{
		TMLN_t tmln;
		char *p = NULL;
		if( (p = strchr(buffer, '\t')) == NULL )			continue;
		sscanf( buffer, "%d", &tmln.cir );

		char* temp = ++p;
		strUTC2time( temp, &tmln.time );

		if( (p = strchr( p, '\t')) == NULL )	continue;
	    temp = ++p;
		if( (p = strchr( p, '\t')) == NULL )	continue;
		*p = '\0';
		tmln.event = temp;

		sscanf( ++p, "%d", &tmln.param );

		hxmt.start.time = tmln.time.time;
		hxmt.start.usec = tmln.time.usec;
		{
			std::string new_fitsname;
			std::string pathname;			
			get_fits_filename( &hxmt, new_fitsname, pathname, modetype, fits_name);
			if( new_fitsname != prev_fitsname ) {
				prev_fitsname = new_fitsname;
				close_fits_tmln( fptr );
				fptr = NULL;
				if( 0 != open_fits_tmln( &hxmt, &fptr) ) {
					fclose( fp ); 
					free( buffer );
					return -3;
				}
			}
		}
		
		write_fits_tmln( fptr, &tmln, 1 );
	}
	
	free( buffer );
	close_fits_tmln( fptr );
	fclose( fp );

	return 0;	
}

/*****************************************************
** 函數名: open_fits_tmln
** 輸入: hxmtfile, 
**        hxmtfile    --- 文件名結構 
** 輸出: *fptr
**        *fptr       ---
** 調用說明:	
**			get_fits_filename() .......得到文件名和保存路徑以及模式
**			DirExist1()         .......判斷路徑是否存在
**			CreateFilePath()    .......創建一個新路徑
**			time2strUTC_fitshead() ....秒時間轉換成對應的年月日時分秒格式的字符串
** 功能描述: 輸入一個TIMELINE文件,生成fits文件,并寫入fits頭中的關鍵字,通過fptr返回生成fits文件的結構
****************************************************************************************/
int open_fits_tmln( const hxmt_file_t *hxmtfile, fitsfile **fptr )
{
	fitsfile *fp;
	int status = 0;
	std::string filename;
	std::string pathname;
	int modetype;
	std::string fits_name;
	if( get_fits_filename(hxmtfile, filename, pathname, modetype, fits_name) )
		return -1;
	{
		extern std::string product_dest_dir;
		std::string path = product_dest_dir + pathname + "\\";
		if( !DirExist1(path.c_str()) )		{
			extern FILE *arch_filep;
			pathname += "\n";
			fwrite(pathname.c_str(), sizeof(char), pathname.length(), arch_filep);
		}
		
	}
	if( !CreateFilePath(filename.c_str()) )
		return -2;
	if( fits_open_file(&fp, filename.c_str(), READWRITE, &status) )
	{
		status = 0;
		if( fits_create_file(&fp, filename.c_str(), &status) )
			return status;

		if( fits_create_img(fp,  BYTE_IMG, 0, NULL, &status) )
			return status;
		timespec_t t;
		time( &t.time );
		t.usec = 0;
		char buf[40];
		time2strUTC( buf, sizeof(buf), &t );
		if ( fits_update_key(fp, TSTRING , "DATE_CRT", buf, "FITS file creation date", &status) )
			 return status; 
		if ( fits_update_key(fp, TSTRING , "TELESCOP", "HXMT", "Telescope or mission name", &status) )
			 return status;
		if ( fits_update_key(fp, TSTRING , "ORIGIN", "HDPS", "Origin of FITS file", &status) )
			 return status;
		if ( fits_update_key(fp, TSTRING , "TIME_SYS", "UTC", "", &status) )
			 return status;
		if ( fits_update_key(fp, TSTRING , "EPOCH", buf, "2006-10-10T01:39:00.000000Z", &status) )                                                                                                                                   
			 return status;

		status = 0;
		int tfields   = 4;       /* table will have 4 columns */
		long nrows    = 0;
		char extname[] = "TIMELINE_Binary";           /* extension name */
		char *ttype[] = { "REVLUT", "TIME", "EVENT", "PARAM" };
		char *tform[] = { "1J",  "27A", "24A", "1J" };
		char *tunit[] = { "\0", "\0", "\0", "\0" };
		if ( fits_create_tbl( fp, BINARY_TBL, nrows, tfields, ttype, tform,	tunit, extname, &status) ) {
			fits_close_file( fp, &status );
			return status;
		}
	}
	
	*fptr = fp;
	return 0;
}
/*****************************************************
** 函數名: write_fits_tmln
** 輸入: fptr, tmln,n
**        hxmtfile    --- 文件名結構 
**        tmln          --- TIMELINE數據結構
**		  n           ---
** 輸出: 
**        函數執行成功返回0
** 調用說明:	
**			time2strUTC_fitshead() ....秒時間轉換成對應的年月日時分秒格式的字符串
** 功能描述: 輸入先前生成的fits文件結構和TIMELINE數據,把文件中數據寫入fits文件中
****************************************************************************************/
int write_fits_tmln( fitsfile *fptr, const TMLN_t *tmln, int n )
{
	if( fptr == NULL )
		return -1;

	int status = 0;
	unsigned int nrows = 0;
	int hdutype;
    if ( fits_movabs_hdu(fptr, 2, &hdutype, &status) ) 
		 return status;
	if( fits_read_key(fptr, TINT, "NAXIS2", &nrows, NULL, &status) )
		return status;

//	for( int i = 0; i < n; i++, nrows++ )
	{
		if (fits_insert_rows(fptr, nrows, 1, &status))
			  return status;
    
		int firstrow = nrows + 1;
		int firstelem = 1;

		void *var[1];
	
		status = 0;
		
		fits_write_col(fptr, TINT, 1, firstrow, firstelem, n, (void *)&tmln->cir, &status);
		char strUTC[40];
		time2strUTC_fitshead( strUTC, sizeof(strUTC), &tmln->time );
		var[0] = (void *)strUTC;
		fits_write_col(fptr, TSTRING, 2, firstrow, firstelem, n, var, &status);
		var[0] = (void *)tmln->event.c_str();
		fits_write_col(fptr, TSTRING, 3, firstrow, firstelem, n, var, &status);
		fits_write_col(fptr, TINT, 4, firstrow, firstelem, n, (void *)&tmln->param, &status);
		
	}
	return 0;
}

int close_fits_tmln( fitsfile *fptr )//此函數用于關閉
{
	int status = 0;
	if( fits_close_file( fptr, &status) )
		return status;
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av电影免费在线播放| 夜夜嗨av一区二区三区中文字幕 | 国产精品18久久久| 青椒成人免费视频| 日韩成人dvd| 日产国产高清一区二区三区| 亚洲电影中文字幕在线观看| 亚洲在线视频网站| 亚洲一本大道在线| 无码av免费一区二区三区试看| 亚洲综合一区二区精品导航| 依依成人精品视频| 亚洲国产精品视频| 秋霞电影网一区二区| 韩日av一区二区| av在线不卡网| 色噜噜偷拍精品综合在线| 精品视频色一区| 日韩欧美一级精品久久| 久久综合九色欧美综合狠狠 | 中文av一区特黄| 亚洲图片另类小说| 亚洲一区二区黄色| 美女一区二区视频| 成+人+亚洲+综合天堂| 色一情一乱一乱一91av| 制服丝袜中文字幕一区| 久久久久9999亚洲精品| 亚洲欧洲综合另类| 日本欧美久久久久免费播放网| 国产一区二区三区综合| 91在线小视频| 91精品国产一区二区三区蜜臀| 26uuu国产一区二区三区| 亚洲三级在线免费观看| 日本欧美久久久久免费播放网| 精品亚洲国内自在自线福利| 99视频有精品| 精品福利一二区| 一区二区三区加勒比av| 国产在线精品一区二区三区不卡| 99久久精品国产观看| 在线成人小视频| 国产精品久久精品日日| 蜜臀国产一区二区三区在线播放| 成人一区二区三区| 欧美一区二区三区人| 自拍偷拍亚洲综合| 国产露脸91国语对白| 欧美写真视频网站| 综合色天天鬼久久鬼色| 国产综合色视频| 538在线一区二区精品国产| 国产精品成人在线观看| 极品美女销魂一区二区三区| 欧美日韩一卡二卡三卡 | 久草在线在线精品观看| 在线观看免费视频综合| 国产精品乱码久久久久久| 青青草伊人久久| 欧美日韩你懂得| 亚洲日本电影在线| www.在线欧美| 亚洲国产高清不卡| 国产99久久久国产精品潘金网站| 欧美一区二区精品| 日本va欧美va欧美va精品| 欧美午夜精品电影| 亚洲国产精品久久一线不卡| av成人免费在线| 国产精品第一页第二页第三页| 国产一区二区三区在线观看免费| 欧美videossexotv100| 美女网站在线免费欧美精品| 欧美一区二区三级| 日本成人中文字幕| 日韩视频在线你懂得| 日本不卡123| 久久久久国产精品麻豆ai换脸| 另类欧美日韩国产在线| 欧美成人aa大片| 国产精品原创巨作av| 精品99一区二区| 国产91丝袜在线观看| 国产精品免费久久| 99久久99久久免费精品蜜臀| 亚洲精品视频免费看| 精品视频1区2区3区| 麻豆91精品91久久久的内涵| 精品国精品国产| 国产伦精一区二区三区| 国产夜色精品一区二区av| voyeur盗摄精品| 亚洲va韩国va欧美va精品| 宅男在线国产精品| 国产在线一区二区| 亚洲欧美区自拍先锋| 欧美亚洲自拍偷拍| 狠狠色丁香久久婷婷综| 亚洲日本在线a| 日韩视频在线一区二区| 国产99久久久国产精品免费看| 亚洲欧美日韩一区二区三区在线观看| 欧美亚洲精品一区| 国产一区二区女| 一区二区三区在线免费观看| 欧美一级二级在线观看| 国产乱码精品一区二区三区av | 亚洲国产一区视频| 精品国产一区久久| 色狠狠一区二区| 精品一区二区久久| 亚洲欧美乱综合| 久久久国产精品不卡| 色哟哟一区二区在线观看 | 中文字幕日韩一区| 欧美剧情片在线观看| 国产精品99久久久久久似苏梦涵| 一区二区三区日韩欧美| 久久久www免费人成精品| 欧美系列一区二区| www.视频一区| 久草热8精品视频在线观看| 亚洲伦理在线免费看| 久久久久久久国产精品影院| 欧美日韩激情一区二区| 成人动漫中文字幕| 国产麻豆视频一区二区| 五月婷婷久久丁香| 亚洲另类色综合网站| 久久久高清一区二区三区| 欧美一区二区免费| 欧美三级午夜理伦三级中视频| 国产白丝精品91爽爽久久| 麻豆精品在线看| 五月天亚洲婷婷| 亚洲国产一区二区视频| 亚洲少妇最新在线视频| 亚洲国产电影在线观看| 精品国产免费人成电影在线观看四季 | www.日韩av| 国产成人免费在线观看不卡| 黄色成人免费在线| 久久精品国产秦先生| 日本欧美久久久久免费播放网| 亚洲成a人片综合在线| 亚洲一区二区成人在线观看| 一区二区三区在线不卡| 国产精品成人一区二区艾草 | 中文字幕高清一区| 欧美国产一区在线| 国产欧美一区二区精品性| 26uuu另类欧美| 亚洲人成网站影音先锋播放| 国产欧美视频一区二区| 国产欧美日韩在线| 国产精品不卡一区| 亚洲色图在线视频| 亚洲欧美另类综合偷拍| 亚洲黄色av一区| 婷婷成人激情在线网| 日韩中文字幕一区二区三区| 偷拍亚洲欧洲综合| 精品一区二区三区视频在线观看| 韩国精品在线观看| 成人午夜视频网站| 色综合天天天天做夜夜夜夜做| 91视频免费观看| 91精品久久久久久久99蜜桃| 91精品国产美女浴室洗澡无遮挡| 91精品国产欧美一区二区18| 欧美不卡激情三级在线观看| 国产丝袜在线精品| 亚洲免费观看高清完整版在线 | 日韩精品免费视频人成| 日韩成人精品在线观看| 国产精品资源站在线| 99久久久久免费精品国产| 在线视频一区二区三| 日韩一区二区麻豆国产| 久久久久国产精品麻豆| 日韩一区在线免费观看| 亚洲电影在线播放| 国产毛片精品国产一区二区三区| 91丝袜呻吟高潮美腿白嫩在线观看| 91国产成人在线| 2欧美一区二区三区在线观看视频| 国产人久久人人人人爽| 亚洲一区欧美一区| 国产精品一区二区视频| 色88888久久久久久影院按摩| 欧美高清精品3d| 国产精品美女久久久久久2018| 午夜电影网亚洲视频| 高清久久久久久| 911国产精品| 1区2区3区欧美| 久久成人精品无人区| 色综合久久久久久久久| 久久女同性恋中文字幕|