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

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

?? kepi.c

?? c源碼
?? C
字號:
/* Read and interpolate de118i ephemeris.  */#include "kep.h"/* Define this or not in the makefile.  Use kepjpl.c when not defined.  */#if SSYSTEM/* Interpolator degree */#define NINTERP 12/* Include constants for appropriate ephemeris */#include "de118i.h"/* long rec0 = 0L; *//* long recsiz = 584L; */double JDi, JDb;extern double au;  /* Kilometers per au */extern double emrat; /* Earth/Moon mass ratio *//* System header files required for I/O.   Define IBMPC, etc. 1 or 0 in kep.h.  */#ifdef _MSC_VER#if _MSC_VER >= 1000#include <stdlib.h>#endif#include <sys\types.h>#include <sys\stat.h>#include <fcntl.h>#include <io.h>#endif#if UNIX#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <unistd.h>#endif#ifndef O_BINARY#define O_BINARY 0#endifextern double pearthb[];static long bcnt = 0;extern struct orbit earth;extern double coseps, sineps, J2000;int defd = 0;extern int defd;extern char defile[];double zatan2(), asin(), sqrt();/* heliocentric velocity of given object (geocentric, if moon) */double pobjb[3];double pobjh[3];double vobjb[3];double vobjh[3];double psunb[3];double vsunb[3];int kepjpl(J, e, rect, polar)double J, rect[], polar[];struct orbit *e;{double JD, ratio, x, y, z;double pm[3], vm[3];int nobj, i;floop:/* Open up the ephemeris file.  */if( defd <= 0 )	{	if( defd < 0 )		{		printf( "Enter DE file name ? " );		gets( &defile[0] );		}	defd = open( &defile[0], O_BINARY | O_RDONLY, S_IREAD );	if( defd <= 0 )		{		printf( "Can't find DE file <%s>\n", &defile[0] );		defd = -1;		goto floop;		}	printf( "Opened %s\n", &defile[0] );/* rec0 is assumed initialized properly in de245.h or de200.h or de102.h */	bcnt = rec0;	lseek( defd, bcnt, SEEK_SET );	read( defd, &JDb, 8 );/* The number of days covered by one record is the difference between   the dates on two adjacent records.  */	lseek( defd, bcnt+recsiz, SEEK_SET );	read( defd, &JDi, 8 );	JDi -= JDb;/*#if DEBUG*/#if 1	printf( "First date in file = %.8E\n", JDb );#endif	}nobj = objnum;if( nobj == 3 )	nobj = 10;	/* moon */if( nobj == 0 )	nobj = 3;	/* sun */JD = tdb(J);/* Sun */#if DEBUGprintf( "psunb, vsunb\n" );#endifif( jpl( JD, 11, psunb, vsunb ) )	{	printf( "Error, DE file boundary violation\n" );	exit(0);	}if( (e == &earth) || (nobj == 3) || (nobj == 10) )	{/* Moon, geocentric */#if DEBUG	printf( "pgmoon, vgmoon\n" );#endif	jpl( JD, 10, pm, vm );	if( e != &earth )		{		for( i=0; i<3; i++ )			{			vobjb[i] = vm[i];			pobjb[i] = pm[i];			vobjh[i] = vm[i];			pobjh[i] = pm[i];			}		goto output;		}/* Earth-Moon barycenter */#if DEBUG	printf( "pemb, vemb\n" );#endif	jpl( JD, 3, pobjb, vobjb );/* Heliocentric EMB */	for( i=0; i<3; i++ )		{		pobjh[i] = pobjb[i] - psunb[i];		vobjh[i] = vobjb[i] - vsunb[i];		}/* Heliocentric Earth */	ratio = 1.0/(emrat+1.0);	for( i=0; i<3; i++ )		{		pobjh[i] = pobjh[i] - ratio * pm[i];		vobjh[i] = vobjh[i] - ratio * vm[i];		}/* Earth position and velocity re solar system barycenter */#if DEBUG	printf( "barycentric earth = pemb - pgmoon/(1+emratio)\n" );#endif	for( i=0; i<3; i++ )		{		pearthb[i] = pobjh[i] + psunb[i];		vearth[i] = vobjh[i] + vsunb[i];		}	jvearth = JD;	}else	{/* Selected object, not Earth or Moon */#if DEBUG	printf( "pobjb, vobjb\n" );#endif	jpl( JD, nobj, pobjb, vobjb );	for( i=0; i<3; i++ )		{		pobjh[i] = pobjb[i] - psunb[i];		vobjh[i] = vobjb[i] - vsunb[i];		}#if DEBUG	printf( "pobjb-psunb\n" );	prvec(pobjh);	prvec(vobjh); /* heliocentric velocity */#endif	}output:/* Write out the heliocentric object coordinates */for( i=0; i<3; i++ )	rect[i] = pobjh[i];epsiln(J2000);x = pobjh[0];y = pobjh[1];z = pobjh[2];/* radius distance */ratio = x*x + y*y + z*z;polar[2] = sqrt(ratio);/* Convert from equatorial to ecliptic coordinates */ratio  =  coseps * y  +  sineps * z;z  = -sineps * y  +  coseps * z;y = ratio;/* convert from rectangular to polar */polar[0] = zatan2( x, y );polar[1] = asin( z/polar[2] );return(0);}#if DEBUGvoid prvec( vec )double vec[];{int k;for( k=0; k<3; k++ )	printf( "%17.9E ", vec[k] );printf( "\n" );}#endif#define DOUBLE doublevoid divdif();DOUBLE difpol();int jpl( JD, iobj, p, v )double JD;int iobj;double p[], v[];{int i, k;long recno;double JD0, x, t;double rec[73];double pcofs[NINTERP+2], vcofs[NINTERP+2];double pdiffs[NINTERP+2], vdiffs[NINTERP+2];/*iobj -= 1;*//* First record number later than requested date.  */x = ((JD - JDb) / JDi) + 1.0;recno = (long) x;JD0 = JDb + (double )recno * JDi;bcnt = (recno - NINTERP) * recsiz + rec0;#if DEBUGprintf( "recno = %ld, bcnt = %ld\n", recno, bcnt );#endift = (JD - JD0)/JDi; /* time scaled to fraction of subrecord */for( k=0; k<3; k++ )	{	  lseek( defd, bcnt, SEEK_SET );	  for( i=0; i<=NINTERP; i++ )	    {	      if( read( defd, rec, (int) recsiz ) != (int) recsiz )		return(-1);	      vcofs[i] = rec[6*iobj + 2*k + 1];	      pcofs[i] = rec[6*iobj + 2*k + 2];	    }	  divdif (vcofs, NINTERP, vdiffs);	  divdif (pcofs, NINTERP, pdiffs);	  p[k] = difpol (pdiffs, NINTERP, t);	  v[k] = difpol (vdiffs, NINTERP, t);	}/* The last record read should have the date JD0.  */if( rec[0] != JD0 )  printf("Record has wrong date %.16e.\n", rec[0]);#if DEBUGprvec(p);prvec(v);#endifreturn(0);}/* Interpolation routines taken from de118i.  */#define DOUBLE double#define One 1.0/* Compute zeroth through kth backward differences * of the data in the input array */void divdif(vec , k, diffn)DOUBLE vec[]; /* input array of k+1 data items */DOUBLE *diffn; /* output array of ith differences */int k;{DOUBLE diftbl[NINTERP+1];DOUBLE *p, *q;DOUBLE y;int i, o;/* Copy the given data (zeroth difference) into temp array */p = diftbl;q = vec;for( i=0; i<=k; i++ )	*p++ = *q++;/* On the first outer loop, k-1 first differences are calculated. * These overwrite the original data in the temp array. */o = k;for( o=k; o>0; o-- )	{	p = diftbl;	q = p;	for( i=0; i<o; i++ )		{		y = *p++;		*q++ = *p - y;		}	*diffn++ = *p; /* copy out the last (undifferenced) item */#if DEBUG	printf( "%.5e ", *p );#endif	}#if DEBUG	printf( "%.5e\n", *(q-1) );#endif*diffn++ = *(q-1);}/* Update array of differences, given new data value. * diffn is an array of k+1 differences, starting with the * zeroth difference (the previous original data value). */void dupdate( diffn, k, f )register DOUBLE *diffn;  /* input and output array of differences */int k; /* max order of differences */DOUBLE f; /* new data point (zeroth difference) */{DOUBLE new, old;int i;new = f;for( i=0; i<k; i++ )	{	old = *diffn;	*diffn++ = new;#if DEBUG	printf( "%.5e ", new );#endif	new = new - old;	}#if DEBUG	printf( "%.5e\n", new );#endif*diffn++ = new;}/* Evaluate the interpolating polynomial * *              (x - x ) *                    n    1 * P(x) = f  +  --------  D f   +  ... *         n       h         n * *     (x - x )(x - x   )...(x - x     ) *           n       n-1          n+2-k    k-1 *  +  ---------------------------------  D    f *                   k-1                        n *                  h     (k-1)! * * *         j *  where D denotes the jth backward difference, see dupdate(), and * *  f   =   f( x , y(x ) )  is the interpolated derivative y'(x ) . *   n          n     n                                        n * * The subroutine argument t is linearly scaled so that t = 1.0 * will evaluate the polynomial at x = x_n + h, * t = 0.0 corresponds to x = x_n, etc. */DOUBLE difpol( diffn, k, t )DOUBLE *diffn;int k; /* differences go up to order k-1 */DOUBLE t; /* scaled argument */{DOUBLE f, fac, s, u;int i;f = *diffn++; /* the zeroth difference = nth data point */u = One;/*s = x/h - n;*//*s = One; */	/* to evaluate the polynomial at x = xn + h */s = t;fac = One;for( i=1; i<k; i++ )	{	if( s == 0 )		break;	u *= s / fac;	f += u  *  (*diffn++);	fac += One;	s += One;	}return( f );}#endif  /* SSYSTEM */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久综合av免费| 2023国产一二三区日本精品2022| 在线精品视频小说1| 色综合久久中文综合久久牛| 在线观看日产精品| 欧美成人一级视频| 国产性天天综合网| 中文字幕一区二区视频| 亚洲va中文字幕| 狠狠色伊人亚洲综合成人| 国产一区二区三区四| 色老综合老女人久久久| 日韩一级黄色片| 亚洲日本在线观看| 蜜臀av一区二区在线免费观看| 国产一区二区三区高清播放| 在线视频你懂得一区二区三区| 久久精品一区二区| 日韩电影在线观看一区| 一本大道综合伊人精品热热| 精品久久久久香蕉网| 亚洲成人资源在线| 成人精品鲁一区一区二区| 欧美精品乱码久久久久久| 国产精品日日摸夜夜摸av| 看电视剧不卡顿的网站| 欧美少妇性性性| 自拍偷拍国产亚洲| 国产999精品久久久久久绿帽| 日韩一区二区三区在线观看 | 婷婷久久综合九色国产成人| 色综合视频在线观看| 国产精品天美传媒沈樵| 精品一区二区三区免费毛片爱| 欧美日韩一区二区在线观看 | 国产精品18久久久久久久网站| 欧美日韩不卡一区二区| 一区二区三区中文字幕| 久久综合九色综合久久久精品综合| 奇米在线7777在线精品| 这里只有精品视频在线观看| 亚洲国产成人tv| 欧美日韩在线精品一区二区三区激情 | 日韩久久免费av| 日本欧洲一区二区| 久久只精品国产| 日韩国产欧美在线观看| 日韩一区二区中文字幕| 国产在线看一区| 国产精品无码永久免费888| 91网页版在线| 一区二区三区在线播放| 欧美影院一区二区三区| 日日欢夜夜爽一区| 欧美成人在线直播| 国产精品一区二区不卡| 国产精品超碰97尤物18| 欧美日韩一区二区电影| 免费在线成人网| 国产亚洲成aⅴ人片在线观看 | 91精品国产综合久久久蜜臀图片| 九色综合国产一区二区三区| 国产精品灌醉下药二区| 欧洲在线/亚洲| 国内精品视频666| 亚洲精品日产精品乱码不卡| 日韩欧美色电影| 在线免费观看日本欧美| 黑人精品欧美一区二区蜜桃| 亚洲色图视频网| 欧美电影免费观看完整版| 99re成人精品视频| 久久精品久久精品| 亚洲精品第一国产综合野| 久久日韩粉嫩一区二区三区| 欧美精品在线视频| 91在线视频免费观看| 国模娜娜一区二区三区| 日韩精品福利网| 一区二区欧美在线观看| 欧美韩日一区二区三区四区| 日韩欧美一区二区免费| 欧美日韩专区在线| 99国产精品久久久久久久久久久| 国产一区二区三区综合| 日本欧美大码aⅴ在线播放| 一区二区三区精品在线观看| 国产精品毛片久久久久久久| 久久蜜桃av一区精品变态类天堂| 日韩一级片在线观看| 日韩一区二区三区免费看| 色噜噜狠狠成人中文综合| 色视频欧美一区二区三区| 91麻豆6部合集magnet| 丁香五精品蜜臀久久久久99网站| 九九**精品视频免费播放| 美女视频黄久久| 久久精品国内一区二区三区| 精品一区二区三区免费播放| 国产精品伊人色| 一本大道久久a久久精二百| 一本色道久久综合亚洲91| 波多野结衣的一区二区三区| 91丝袜高跟美女视频| 色婷婷综合久久久久中文一区二区 | 亚洲视频在线观看三级| 一区二区三区影院| 日韩 欧美一区二区三区| 秋霞电影网一区二区| 国产美女精品人人做人人爽| 日韩一区二区三区在线视频| 久久精品综合网| 玉足女爽爽91| 免费视频一区二区| 懂色av一区二区三区蜜臀| 91理论电影在线观看| 日韩午夜电影在线观看| 国产精品久久福利| 婷婷综合五月天| 成人午夜av电影| 91精品国产91综合久久蜜臀| 国产午夜精品一区二区三区视频 | 国产精品一级在线| 欧美在线观看视频一区二区三区| 欧美一区二区三区日韩视频| 国产精品大尺度| 美女网站视频久久| 91亚洲精华国产精华精华液| 欧美va亚洲va| 亚洲一区二区综合| 国产福利一区二区三区视频| 欧美卡1卡2卡| 亚洲欧美偷拍卡通变态| 国产剧情一区在线| 精品国产亚洲在线| 亚洲国产日韩综合久久精品| 成人app网站| 精品国产一区二区三区四区四 | 91一区二区在线| 国产精品久久久久影院| 久久99热国产| 日韩一区二区三区免费观看| 亚洲一区二区三区中文字幕 | 欧美丰满高潮xxxx喷水动漫| 亚洲一区二区欧美| 97se亚洲国产综合自在线不卡 | 中文字幕一区二区视频| 国产99一区视频免费| 国产免费久久精品| 国产在线麻豆精品观看| 欧美一区二区免费视频| 天堂资源在线中文精品| 欧美日韩激情一区二区三区| 一区二区在线观看视频| 91精品福利视频| 亚洲777理论| 91精品国产福利在线观看| 麻豆精品在线播放| 日韩一区二区视频| 激情丁香综合五月| 国产欧美一区二区精品性色超碰| 不卡一卡二卡三乱码免费网站| 亚洲图片欧美激情| 色婷婷综合激情| 日韩电影一区二区三区四区| 久久色在线视频| www.亚洲国产| 日韩精品五月天| 日本一区二区三区久久久久久久久不 | 99精品欧美一区二区三区综合在线| 亚洲黄色av一区| 欧美一区二区三区视频在线观看| 国产乱人伦偷精品视频不卡| 中文字幕综合网| 日韩欧美色电影| 91搞黄在线观看| 久久精品国产精品青草| 亚洲日穴在线视频| 精品久久久影院| 欧美日韩国产片| 97精品国产露脸对白| 精品一区免费av| 一区二区三区中文在线观看| 久久综合色之久久综合| 欧美日韩一级二级三级| 成人黄色在线视频| 理论片日本一区| 亚洲一级二级三级| 亚洲欧洲av另类| 国产精品全国免费观看高清 | 亚洲精品在线观看网站| 欧美性一二三区| 99久久国产综合精品麻豆| 国产不卡在线视频| 久久se精品一区二区| 日韩在线卡一卡二| 亚洲乱码日产精品bd| 国产精品久久久久久久久久免费看| 日韩天堂在线观看| 在线不卡中文字幕播放|