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

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

?? convo.c

?? 卷積程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
/****************************************************************
 *	Functions for file output.
 ****/

#include "conv.h"

/****************************************************************
 *	Center a string according to the column width.
 ****/
char       *
CenterStr(short int Wid,
	  char *InStr,
	  char *OutStr)
{
  size_t      nspaces;
  /* number of spaces to be filled before InStr. */

  nspaces = (Wid - strlen(InStr)) / 2;
  if (nspaces < 0)
    nspaces = 0;

  strcpy(OutStr, "");
  while (nspaces--)
    strcat(OutStr, " ");

  strcat(OutStr, InStr);

  return (OutStr);
}

/****************************************************************
 *	Print some messages before starting simulation.  e.g. author,
 *	address, program version, year.
 ****/
#define COLWIDTH 80
void 
ShowVersion(void)
{
  char        str[STRLEN];

  puts("");
  CenterStr(COLWIDTH, "Convolution of MCML Simulation Data", str); puts(str);
  CenterStr(COLWIDTH, "Version 1.1, 1994", str); puts(str);
  puts("");

  CenterStr(COLWIDTH, "Lihong Wang, Ph.D.", str); puts(str);
  CenterStr(COLWIDTH, "Biomedical Engineering Program", str); puts(str);
  CenterStr(COLWIDTH, "3120 TAMU, Texas A&M University", str); puts(str);
  CenterStr(COLWIDTH, "College Station, TX 77843-3120", str); puts(str);
  CenterStr(COLWIDTH, "Email: LWang@tamu.edu", str); puts(str);
  CenterStr(COLWIDTH, "URL: http://oilab.tamu.edu", str); puts(str);
  puts("");

  CenterStr(COLWIDTH, "Steven L. Jacques, Ph.D.", str); puts(str);
  CenterStr(COLWIDTH, "Oregon Medical Laser Center", str); puts(str);
  CenterStr(COLWIDTH, "Providence/St. Vincent Hospital", str); puts(str);
  CenterStr(COLWIDTH, "9205 SW Barnes Rd., Portland, OR 97225", str); puts(str);
  CenterStr(COLWIDTH, "Email: sjacques@ece.ogi.edu", str); puts(str);
  CenterStr(COLWIDTH, "URL: http://omlc.ogi.edu/staff/jacques.html", str); 
  puts(str);
  puts("");

  CenterStr(COLWIDTH, 
  "Please cite the following article in your publications:", str); puts(str);
  CenterStr(COLWIDTH, 
  "L.-H. Wang, S. L. Jacques, and L.-Q. Zheng, ", str); puts(str);
  CenterStr(COLWIDTH, 
  "CONV - Convolution for responses to a finite diameter photon beam", str); 
  puts(str);
  CenterStr(COLWIDTH, 
  "incident on multi-layered tissues, Computer Methods and Programs in", str); 
  puts(str);
  CenterStr(COLWIDTH, 
  "Biomedicine 54, 141-150 (1997).", str); puts(str);
}
#undef COLWIDTH

/****************************************************************
 *	Open a file for output with extension Ext.  If file exists,
 *	ask whether to overwrite or append or change filename.
 *
 *	Return file pointer, which could be NULL.
 *	Return the full filename as Ext.
 ****/
FILE       *
GetWriteFile(char *Ext)
{
  FILE       *file;
  char        fname[STRLEN], fmode[STRLEN];

  do {
    printf("Enter output filename with extension .%s (or . to quit): ", Ext);
    gets(fname);
    if (strlen(fname) == 1 && fname[0] == '.') {
      fmode[0] = 'q';
      break;
    } else
      fmode[0] = 'w';

    if ((file = fopen(fname, "r")) != NULL) {	/* file exists. */
      printf("File %s exists, %s",
	     fname, "w=overwrite, a=append, n=new filename, q=quit: ");
      do
	gets(fmode);
      while (!strlen(fmode));	/* avoid null line. */
      fclose(file);
    }
  } while (fmode[0] != 'w' && fmode[0] != 'a' && fmode[0] != 'q');

  if (fmode[0] != 'q')
    file = fopen(fname, fmode);
  else
    file = NULL;

  strcpy(Ext, fname);
  return (file);		/* could be NULL. */
}

/****************************************************************
 *	Return the index to the layer, where iz is in.
 *
 *	Use the center of box.
 ****/
short 
IzToLayer(short Iz,
	  InputStruct * In_Ptr)
{
  short       i = 1;		/* index to layer. */
  short       num_layers = In_Ptr->num_layers;
  double      dz = In_Ptr->dz;

  while ((Iz + 0.5) * dz >= In_Ptr->layerspecs[i].z1
	 && i < num_layers)
    i++;

  return (i);
}

/****************************************************************
 *	Write the input parameter for Monte Carlo simulation program
 *	in such a format that it can be read directly back.
 ****/
void 
WriteInParm(InputStruct * In_Ptr)
{
  short       i;
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "InP");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "1.1\t# file version.\n");
  fprintf(file, "1\t# number of runs.\n\n");
  fprintf(file, "temp.out\tA\t\t#output filename.\n");

  fprintf(file, "%ld \t\t\t# No. of photons.\n",
	  In_Ptr->num_photons);

  fprintf(file, "%G\t%G\t\t# dz, dr.\n", In_Ptr->dz, In_Ptr->dr);
  fprintf(file, "%hd\t%hd\t%hd\t# No. of dz, dr, da.\n\n",
	  In_Ptr->nz, In_Ptr->nr, In_Ptr->na);

  fprintf(file, "%hd\t\t\t\t\t# Number of layers.\n",
	  In_Ptr->num_layers);
  fprintf(file,
	  "#n\tmua\tmus\tg\td\t# One line for each layer.\n");
  fprintf(file, "%G\t\t\t\t\t# n for medium above.\n",
	  In_Ptr->layerspecs[0].n);
  for (i = 1; i <= In_Ptr->num_layers; i++) {
    LayerStruct s;
    s = In_Ptr->layerspecs[i];
    fprintf(file, "%G\t%G\t%G\t%G\t%G\t# layer %hd\n",
	    s.n, s.mua, s.mus, s.g, s.z1 - s.z0, i);
  }
  fprintf(file, "%G\t\t\t\t\t# n for medium below.\n\n",
	  In_Ptr->layerspecs[i].n);

  fclose(file);
}

/****************************************************************
 *	Write reflectance, absorption, transmission.
 ****/
void 
WriteRAT(OutStruct * Out_Ptr)
{
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "RAT");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file,			/* flag. */
	  "RAT #Reflectance, absorption, transmission.\n");
  fprintf(file, "%-12.4G \t#Specular reflectance.\n",
	  Out_Ptr->Rsp);
  fprintf(file, "%-12.4G \t#Diffuse reflectance.\n",
	  Out_Ptr->Rd);
  fprintf(file, "%-12.4G \t#Absorption.\n",
	  Out_Ptr->A);
  fprintf(file, "%-12.4G \t#Transmission.\n",
	  Out_Ptr->Tt);

  fprintf(file, "\n");

  fclose(file);
}

/****************************************************************
 *	Write absorption as a function of layer.
 *	2 numbers each line: layer, A[layer].
 ****/
void 
WriteA_layer(short Num_Layers,
	     double *A_l)
{
  short       i;
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "Al");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "layer\t%-s[-]\n", fname);
  for (i = 1; i <= Num_Layers; i++)
    fprintf(file, "%-4hd\t%-12.4G\n", i, A_l[i]);

  fclose(file);
}

/****************************************************************
 *	2 numbers each line: z, A[z].
 ****/
void 
WriteA_z(InputStruct * In_Ptr, double *A_z)
{
  short       nz = In_Ptr->nz;
  double      dz = In_Ptr->dz;
  short       iz;
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "Az");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "%-12s\t%-s[1/cm]\n", "z[cm]", fname);
  for (iz = 0; iz < nz; iz++)
    fprintf(file, "%-12.4E\t%-12.4E\n", (iz + 0.5) * dz, A_z[iz]);

  fclose(file);
}

/****************************************************************
 *	3 numbers each line: r, z, A[r][z].
 ****/
void 
WriteA_rz(InputStruct * In_Ptr,
	  double **A_rz)
{
  short       ir, iz, nz = In_Ptr->nz, nr = In_Ptr->nr;
  double      r, z, dr = In_Ptr->dr, dz = In_Ptr->dz;
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "Arz");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "%-12s\t%-12s\t%-s[1/cm3]\n", "r[cm]", "z[cm]", fname);
  for (ir = 0; ir < nr; ir++) {
    r = (ir + 0.5) * dr;
    for (iz = 0; iz < nz; iz++) {
      z = (iz + 0.5) * dz;
      fprintf(file, "%-12.4E\t%-12.4E\t%-12.4E\n",
	      r, z, A_rz[ir][iz]);
    }
  }

  fclose(file);
}

/****************************************************************
 *	2 numbers each line: z, F[z].
 ****/
void 
WriteF_z(InputStruct * In_Ptr,
	 double *A_z)
{
  FILE       *file;
  short       iz, nz = In_Ptr->nz;
  double      mua, dz = In_Ptr->dz;
  char        fname[STRLEN];

  strcpy(fname, "Fz");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "%-12s\t%-s[-]\n", "z[cm]", fname);
  for (iz = 0; iz < nz; iz++) {
    mua = In_Ptr->layerspecs[IzToLayer(iz, In_Ptr)].mua;
    if (mua > 0.0)
      fprintf(file, "%-12.4E\t%-12.4E\n", (iz + 0.5) * dz,
	      A_z[iz] / mua);
    else
      fprintf(file, "%-12.4E\t%-12.4E\n", (iz + 0.5) * dz, 0.0);
  }

  fclose(file);
}

/****************************************************************
 *	3 numbers each line: r, z, F[r][z].
 ****/
void 
WriteF_rz(InputStruct * In_Ptr,
	  double **A_rz)
{
  FILE       *file;
  short       ir, iz, nz = In_Ptr->nz, nr = In_Ptr->nr;
  double      mua, r, z, dr = In_Ptr->dr, dz = In_Ptr->dz;
  char        fname[STRLEN];

  strcpy(fname, "Frz");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "%-12s\t%-12s\t%-s[1/cm2]\n",
	  "r[cm]", "z[cm]", fname);
  for (ir = 0; ir < nr; ir++) {
    r = (ir + 0.5) * dr;
    for (iz = 0; iz < nz; iz++) {
      z = (iz + 0.5) * dz;
      mua = In_Ptr->layerspecs[IzToLayer(iz, In_Ptr)].mua;
      if (mua > 0.0)
	fprintf(file, "%-12.4E\t%-12.4E\t%-12.4E\n",
		r, z, A_rz[ir][iz] / mua);
      else
	fprintf(file, "%-12.4E\t%-12.4E\t%-12.4E\n", r, z, 0.0);
    }
  }

  fclose(file);
}

/****************************************************************
 *	3 numbers each line: r, a, Rd[r][a].
 ****/
void 
WriteRd_ra(InputStruct * In_Ptr,
	   double **Rd_ra)
{
  short       ir, ia, nr = In_Ptr->nr, na = In_Ptr->na;
  double      r, a, dr = In_Ptr->dr, da = In_Ptr->da;
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "Rra");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "%-12s\t%-12s\t%-s[1/(cm2sr)]\n",
	  "r[cm]", "a[rad]", fname);
  for (ir = 0; ir < nr; ir++) {
    r = (ir + 0.5) * dr;
    for (ia = 0; ia < na; ia++) {
      a = (ia + 0.5) * da;
      fprintf(file, "%-12.4E\t%-12.4E\t%-12.4E\n",
	      r, a, Rd_ra[ir][ia]);
    }
  }

  fclose(file);
}

/****
 *	2 numbers each line: r, Rd[r]
 ****/
void 
WriteRd_r(InputStruct * In_Ptr,
	  double *Rd_r)
{
  short       ir, nr = In_Ptr->nr;
  double      dr = In_Ptr->dr;
  FILE       *file;
  char        fname[STRLEN];

  strcpy(fname, "Rr");
  file = GetWriteFile(fname);
  if (file == NULL)
    return;

  fprintf(file, "%-12s\t%-s[1/cm2]\n", "r[cm]", fname);
  for (ir = 0; ir < nr; ir++)
    fprintf(file, "%-12.4E\t%-12.4E\n", (ir + 0.5) * dr,
	    Rd_r[ir]);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区三区视频在线| 亚洲一区二区三区国产| 亚洲色图丝袜美腿| 美女久久久精品| 91网站视频在线观看| 欧美一卡二卡在线| 亚洲精品一卡二卡| 成人性生交大合| 欧美夫妻性生活| 一区在线播放视频| 经典三级视频一区| 91精品国产品国语在线不卡| 综合色天天鬼久久鬼色| 久久97超碰国产精品超碰| 欧美性三三影院| 中文字幕一区二区三区av| 国精产品一区一区三区mba桃花| 欧洲av在线精品| 亚洲欧洲成人av每日更新| 国产在线视频不卡二| 日韩欧美在线网站| 免费在线看成人av| 欧美日韩亚洲综合一区二区三区| 亚洲人午夜精品天堂一二香蕉| 国产毛片精品一区| 精品国产青草久久久久福利| 石原莉奈在线亚洲三区| 精品视频在线看| 亚洲乱码国产乱码精品精的特点 | 成人99免费视频| 日韩你懂的电影在线观看| 日产欧产美韩系列久久99| 欧美日韩高清在线| 日韩在线a电影| 在线综合亚洲欧美在线视频| 日本v片在线高清不卡在线观看| 欧美日韩专区在线| 丝袜脚交一区二区| 欧美老肥妇做.爰bbww视频| 五月天久久比比资源色| 欧美久久久久久蜜桃| 日韩国产高清影视| 91精品一区二区三区久久久久久| 婷婷久久综合九色国产成人| 5858s免费视频成人| 美日韩黄色大片| 欧美精品一区二区三区视频| 国产精品123区| 中文字幕一区二区三区乱码在线| 91美女视频网站| 亚洲成人第一页| 日韩精品一区二区三区在线| 久久成人综合网| 中文字幕av不卡| 日本精品一级二级| 婷婷丁香激情综合| 26uuu国产在线精品一区二区| 国产成人aaa| 亚洲免费伊人电影| 在线电影院国产精品| 国产一区二区三区在线观看免费视频 | 欧美日韩中字一区| 狠狠色伊人亚洲综合成人| 中文字幕乱码亚洲精品一区| 色女孩综合影院| 蜜桃在线一区二区三区| 国产日韩综合av| 欧洲日韩一区二区三区| 国产真实乱偷精品视频免| 亚洲天堂免费在线观看视频| 91精品国产福利| 成人天堂资源www在线| 亚洲国产视频a| 国产三级精品在线| 欧美喷水一区二区| 成人国产精品免费网站| 三级亚洲高清视频| 中文字幕亚洲区| 日韩欧美中文字幕制服| 91豆麻精品91久久久久久| 国产在线精品国自产拍免费| 亚洲一线二线三线久久久| 久久精品欧美日韩精品| 欧美日韩视频在线观看一区二区三区 | 成人欧美一区二区三区小说| 91麻豆精品国产91久久久| youjizz国产精品| 久久激五月天综合精品| 亚洲自拍都市欧美小说| 国产肉丝袜一区二区| 日韩欧美国产一区在线观看| 欧美午夜精品电影| 99精品视频中文字幕| 蜜臀av亚洲一区中文字幕| 一区二区三区中文在线| 国产女人aaa级久久久级| 欧美大片日本大片免费观看| 精品视频一区 二区 三区| 色综合久久天天综合网| 国产一区久久久| 美女网站一区二区| 午夜天堂影视香蕉久久| 亚洲精品日韩专区silk| 国产精品热久久久久夜色精品三区 | 成人av资源站| 国产成人在线观看| 久久99国产精品免费网站| 日韩综合一区二区| 亚洲成人动漫av| 亚洲成av人片观看| 亚洲在线中文字幕| 亚洲精品乱码久久久久久黑人| 国产精品蜜臀av| 国产精品护士白丝一区av| 国产偷国产偷精品高清尤物| 日韩欧美一级精品久久| 91精品国产欧美一区二区18| 欧美男女性生活在线直播观看 | 成人夜色视频网站在线观看| 国产一区二区影院| 国产在线一区二区综合免费视频| 另类调教123区 | 精品久久久久香蕉网| 日韩欧美一区二区免费| 久久综合九色欧美综合狠狠| 久久亚洲一级片| 中文字幕精品一区二区精品绿巨人 | 国产美女精品一区二区三区| 久久99精品国产91久久来源| 国内精品在线播放| 国产精品香蕉一区二区三区| 顶级嫩模精品视频在线看| 成人免费视频视频在线观看免费| 国产成人免费高清| 91视频一区二区| 欧美熟乱第一页| 日韩欧美国产一区二区在线播放| 欧美成人精品高清在线播放| 国产亚洲欧美日韩俺去了| 国产精品每日更新| 亚洲韩国一区二区三区| 奇米精品一区二区三区在线观看一 | 日韩欧美第一区| 国产欧美一区二区精品性色| 亚洲男同1069视频| 丝袜亚洲另类欧美| 久久99国产精品麻豆| 91偷拍与自偷拍精品| 欧美亚男人的天堂| 精品捆绑美女sm三区| 国产精品国产三级国产普通话蜜臀 | 国产精品污污网站在线观看| 亚洲综合色成人| 狠狠色丁香婷婷综合| 欧美最猛黑人xxxxx猛交| 欧美一区二区私人影院日本| 国产精品色婷婷| 秋霞电影网一区二区| 成人美女视频在线看| 欧美日韩不卡视频| 国产欧美一二三区| 亚洲成a人在线观看| 国产成a人无v码亚洲福利| 欧美日韩国产影片| 国产精品沙发午睡系列990531| 日韩国产在线观看| 色综合天天天天做夜夜夜夜做| 欧美一二三四在线| 一区二区三区资源| 懂色av中文一区二区三区| 91精品国产免费| 亚洲美女电影在线| 国产大陆精品国产| 欧美大片在线观看一区二区| 亚洲综合久久久久| 成人免费va视频| 亚洲精品一区二区三区精华液| 亚洲一区二区在线视频| 成人一区二区视频| 精品国产乱码久久久久久夜甘婷婷 | 欧美写真视频网站| ●精品国产综合乱码久久久久| 国内精品久久久久影院色| 91麻豆精品久久久久蜜臀 | 91麻豆免费视频| 国产视频一区在线观看| 精品中文字幕一区二区小辣椒| 欧美日韩一区二区三区四区五区 | av不卡免费电影| 日本一二三不卡| 国产精品一区二区久久精品爱涩| 欧美精品乱人伦久久久久久| 亚洲香肠在线观看| 91香蕉视频mp4| 亚洲黄色av一区| 一本色道**综合亚洲精品蜜桃冫| 中文字幕不卡在线观看| 福利一区二区在线| 中文字幕av不卡| 成人免费电影视频|