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

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

?? grad1.c

?? vc編寫的3D圖形
?? C
?? 第 1 頁 / 共 3 頁
字號:
/******************** GRAD ******************************
  grad.c
  Daniel Geist - Mallinckrodt Institue of Radiology 1987.
   This program reads a set of ct scans for one
   patient. It outputs two sets of files containing predefined 
   views of bone surfaces. One set contains distance values and
   the other gradient values.

   Danny Geist & Mike Vannier

   Contact for further information:
	Michael W. Vannier
	Mallinckrodt Institute of Radiology
	Washington University School of Medicine
	510 South Kingshighway Blvd.
	St. Louis, Mo. 63110 USA

   Ake Wallin has made the following changes - 1988

   -Command line input
   -Threshold of gradient for differencing
   -Views to choose: BO (bottom), TO (top), RL (right lateral),
    LL (left lateral), RE (rear), FR (front), NO (none, just leave distance)
   -Clipping planes: RL (right lateral), LL (lateral left), RE (rear),
    FR (front)
   -Scan of data in "correct" order, assuming:
    object:
    low z - feet, high z - head
    low x - right, high x - left
    low y - back, high y - front
    image:
    low x - left, high x - right
    low y - down, high y - up
		    front
    view BO : right      left
		    back
		    front
    view TO : left       right
		    back
		    head
    view RL : back      front
		    feet
		    head
    view LL : front     back
		    feet
		    head
    view RE : left      right
		    feet
		    head
    view FR : right     left
		    feet
*********************************************************/
#include <stdio.h>
#include <math.h>
#include <ctype.h>

/* some global variables*/
int FIRSTSLICE,LASTSLICE,THRESHOLD,NLINES;
float ZOOM;
char DR;
int  buffer[2][6][256];          /* input buffer */
float fxbuf[5][256],fybuf[5][256]; /* X,Y Views floating buffers */

float huge fzbuf[256][256];        /* Z view floating buffer */
char fnamein[50]="ctbild.000";        /* input file name  */
float GRAD_THRESHOLD = 10.0;
unsigned int   views = 0xFFFF;
int   clipx[2], clipy[2];      /* clipping planes */
int   dispmode;                /* distance and/or gradient */
int   image_or[2];            /* image oriention in x and y */
int   object_or[3];           /* image oriention in x, y and z */
int   header_blocks;          /* number of header blocks in CT's */
char *usestr1 = "Usage: grad [file] [-z] [-f] [-l] [-t] [-d] [-n(g|d)] [-g]";
char *usestr2 = "            [-h] [-v(bo|to|rl|ll|re|fr|no)] [-c(rl|ll|re|fr)]";
char *usestr3 = "            [-i(x(r|l)|y(u|d))] [-o(x(r|l)|y(f|b)|z(h|f))]";

succ(i)   /* (i+1) modolus 3 */
int i;
{
    return(i==2?0:i+1);
}

prev(i)   /* (i-1) modolus 3 */
int i;
{
    return(i==0?2:i-1);
}

/* Set input file - add slice number to extension */
setfilename(filenum)
int filenum;
{
    int i;

    for (i = strlen(fnamein)-1; i > 0; i--)
      if (fnamein[i] == '.') break;
    if (i == 0) {
      printf("CT file names inconsistend!\n");
      exit(1);
    }
    fnamein[++i]=filenum/100+'0';
    fnamein[++i]=(filenum%100)/10+'0';
    fnamein[++i]='0'+filenum%10;
}

/* interpolate from bottom line to top line n-1 lines  */
interpolate(line,bot,top,n)
int line,bot,top,n;
{
    int next,i,j,x,inc;
    inc=top>bot?1:(-1);    /* interpolate backward or forwards ? */
    next=bot+inc;
    for(i=1,j=n-1;i<n;i++,j--){   /* do for each next line of interpolation */
        for(x=0;x<256;x++) buffer[line][next][x]=
            (buffer[line][bot][x]*j+buffer[line][top][x]*i)/n;
        next+=inc;
    }
}

/* midpoint - fraction part of threshold transition distance */ 
float midpoint(b,a)
float b,a;
{
    return( (THRESHOLD-a) / (b-a) );
}

/* get floating point distance values  */
getdistances(xstart,xstop,xdir,
             ystart,ystop,ydir,
             start_slice,end_slice,zdir,
             xbufxstart, xbufxdir, xbufystart, xbufydir,
             ybufxstart, ybufxdir, ybufystart, ybufydir,
             zbufxstart, zbufxdir, zbufystart, zbufydir,
             pass)
int xstart,xstop,xdir,ystart,ystop,ydir,start_slice,end_slice,zdir,pass;
int  xbufxstart, xbufxdir, xbufystart, xbufydir;
int  ybufxstart, ybufxdir, ybufystart, ybufydir;
int  zbufxstart, zbufxdir, zbufystart, zbufydir;
/* also used are global variables: fxbuf, fybuf, fzbuf, buffer,
   ZOOM, DR, image_or, object_or. */
{
    int z,x,y,i,j,start,stop,inc,line,rzoom,inter;
    float remain;
    FILE *fxfloat,*fyfloat,*fzfloat,*fn[2];
    char filename[13];
    int  filegap;
    int  xbfx, ybfx, zbfx, zbfy;

    NLINES=0;         /* number of output lines in X,Y view directions */
    remain=0;         /* remainder of interpolation after roundoff */
    rzoom=ZOOM+0.5;   /* rounded zoom factor */
    /* X view floating output file */
    sprintf(filename,"%c:xdis%d.dat",DR,pass);
    if ((fxfloat=fopen(filename,"wb")) == NULL) {
      printf("Error creating %s!\n", filename);
      exit(1);
    }
    /* Y view floating output file */
    sprintf(filename,"%c:ydis%d.dat",DR,pass);
    if ((fyfloat=fopen(filename,"wb")) == NULL) {
      printf("Error creating %s!\n", filename);
      exit(1);
    }
    for(i=0;i<256;i++)
        for(j=0;j<256;j++)fzbuf[i][j]=256; /* clear Z view buffer */
    
    for(z=start_slice; z!=end_slice; z += zdir){  /* For each Slice */
      /* open next two slice files */
	  setfilename(z);
      if ((fn[0]=fopen(fnamein,"rb")) == NULL) continue;
	for (filegap = zdir; filegap + z != end_slice+zdir; filegap+=zdir) {
          setfilename(z+filegap);
          if ((fn[1]=fopen(fnamein,"rb")) != NULL) break;
	  }
      if (fn[1] == NULL) continue;

      inter=rzoom; /* interpolation factor assumed rounded zoom */
      /* correct interpolation factor according to floating remainder */
      remain+=rzoom-ZOOM;
      if(remain>=1){
        inter-=1;
        remain-=1;
      }
      else if(remain<=(-1)){
        inter+=1;
        remain+=1;
      }

      line=0;               /* current input buffer line */
      for(j=0;j<inter;j++)  /* clear X,Y floating buffers */
	    for(i=0;i<256;i++) fxbuf[j][i]=fybuf[j][i]=256;
      /* set index for zbuf */
      zbfy = zbufystart;
      /* set index for xbuf */
      xbfx = xbufxstart;
      for(y=ystart; y!=ystop; y+=ydir){              /* For each line */
	/* skip to line*/
	for(i=0;i<2;i++)fseek(fn[i],(long)512*(y+header_blocks),SEEK_SET);
        fread(buffer[line][0],1,512,fn[0]);   
        fread(buffer[line][inter],1,512,fn[1]);
        interpolate(line,0,inter,inter); /* interpolate in_between */
	for(i=0;i<inter;i++){   /* For each interpolation line */
          /* set index for zbuf */
	  zbfx = zbufxstart;
          /* set index for ybuf */
          ybfx = ybufxstart;
	  for(x=xstart; x!=xstop; x+=xdir) { /* For each Voxel value */
            /* find threshold transition*/
	    if (buffer[line][i+1][x] >= THRESHOLD) {
              /* if first transition in X direction get floating
	             distance */
              if(fxbuf[i][xbfx]==256.0) fxbuf[i][xbfx]=(x==xstart)?0:
                                    (x-xstart)*xdir-1+
                     midpoint((float)buffer[line][i+1][x],
                            (float)buffer[line][i+1][x-xdir]);

		      /* if first transition in Y direction get floating
                   distance */
              if(fybuf[i][ybfx]==256.0) fybuf[i][ybfx]=(y==ystart)?0:
                    (y-ystart)*ydir-1+
                     midpoint((float)buffer[line][i+1][x],
                              (float)buffer[1-line][i+1][x]);
 
	          /* if first transition in Z direction get floating
                   distance */
              if(fzbuf[zbfy][zbfx]==256.0) fzbuf[zbfy][zbfx]=
                   (i==0) && (buffer[line][i][x]>=THRESHOLD) ?
                    NLINES : NLINES+i+
                    midpoint((float)buffer[line][i+1][x],
                             (float)buffer[line][i][x]);
            }
            /* change index of ybuf and zbuf */
            ybfx += ybufxdir;
	    zbfx += zbufxdir;
	    if ((ybfx < 0 || ybfx > 255) && x+xdir != xstop) {
              printf("Error in index YBFX!\n");
              exit(1);
            }
	    if ((zbfx < 0 || zbfx > 255) && x+xdir != xstop) {
              printf("Error in index ZBFX!\n");
              exit(1);
            }
          }
        }
        line=1-line;  /* change current input buffer line */
        /* update index of xbuf and zbuf */
        xbfx += xbufxdir;
        zbfy += zbufydir;
	if ((zbfy < 0 || zbfy > 255) && y+ydir != ystop) {
          printf("Error in index ZBFY!\n");
          exit(1);
        }
	if ((xbfx < 0 || xbfx > 255) && y+ydir != ystop) {
          printf("Error in index XBFX!\n");
          exit(1);
        }
      }
      NLINES+=inter;           /* increment number of output lines */

      fclose(fn[0]);           /* close slice files */
      fclose(fn[1]);
      /* write output lines to files */
      if (fwrite(fxbuf,1,sizeof(float)*inter*256,fxfloat) <
		inter*256*sizeof(float))
	printf("Error writing to FXBUF!\n");
      if (fwrite(fybuf,1,sizeof(float)*inter*256,fyfloat) <
		inter*256*sizeof(float))
	printf("Error writing to FYBUF!\n");
      printf(" line %d\r", z);
    }
    printf("\n");
    fclose(fxfloat); /* close X,Y floating files */
    fclose(fyfloat);
    /* write Z floating file */
    sprintf(filename,"%c:zdis%d.dat",DR,pass);
    fzfloat=fopen(filename,"wb");
    for(i=0;i<256;i++)fwrite(fzbuf[i],sizeof(float),256,fzfloat);
    fclose(fzfloat);

    /* should we reverse the order of the lines? */
    if (xbufydir < 0) {
      sprintf(filename,"%c:xdis%d.dat",DR,pass);
      fxfloat=fopen(filename,"rb");
      for (line = 0; line < NLINES; line++)
        fread(fzbuf[line], 1, sizeof(float)*256, fxfloat);
      fclose (fxfloat);
      fxfloat=fopen(filename,"wb");
      for (line = 1; line <= NLINES; line++)
        fwrite(fzbuf[NLINES-line], sizeof(float), 256, fxfloat);
      fclose (fxfloat);
    }
    if (ybufydir < 0) {
      sprintf(filename,"%c:ydis%d.dat",DR,pass);
      fyfloat=fopen(filename,"rb");
      for (line = 0; line < NLINES; line++)
        fread(fzbuf[line], 1, sizeof(float)*256, fyfloat);
      fclose (fyfloat);
      fyfloat=fopen(filename,"wb");
      for (line = 1; line <= NLINES; line++)
        fwrite(fzbuf[NLINES-line], sizeof(float), 256, fyfloat);
      fclose (fyfloat);
    }

}

unsigned char grad(y1,y2,z1,z2,y_factor,z_factor)
float y1,y2,z1,z2;
int y_factor,z_factor;
{
    float gx,gy,gz;
    unsigned char gxint;
    /* get z and y components of gradient */
    gz=(z1-z2)/(float) z_factor;
    gy=(y1-y2)/(float) y_factor;
    /*compute gx - normalized x component of gradient */
    gx=1/sqrt(1+gz*gz+gy*gy);
    gxint=255*gx+0.5;      /*scale gx by 256 and round */
    return(gxint);
}

/* get gradient and depth shades for one image line */
doline(lineg,lined,line,prevline,succline,z_factor,fg,fd)
unsigned char lineg[],lined[];  /*output buffers */
int line,prevline,succline;  /* input buffer configuration */
int z_factor; /* for choosing forward, backward or central differences */
FILE *fg,*fd;  /* output files */
{
    int i;
    float y1, y2, z1, z2;
    int factor;
    /* do first pixel in line */
    i = 0;
    if(fxbuf[line][0]==256)lineg[0]=lined[0]=0;
    else{
        if (dispmode & 1)
          lined[0]=255-fxbuf[line][0]; /*distance shade */
        if (dispmode & 2)
          lineg[0]=grad(fxbuf[line][0],fxbuf[line][1],fxbuf[prevline][0],

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美自拍偷拍一区| 欧美性猛交xxxxxx富婆| 7777精品伊人久久久大香线蕉超级流畅| 久久久久久9999| 亚洲电影一区二区| 99久久99久久免费精品蜜臀| 精品区一区二区| 天使萌一区二区三区免费观看| www.久久精品| 久久亚洲免费视频| 日韩国产成人精品| 欧美系列在线观看| 亚洲同性gay激情无套| 国产精品一二一区| 日韩欧美不卡在线观看视频| 亚洲成人一二三| 一本久久a久久精品亚洲| 亚洲国产激情av| 国产精品自拍一区| 欧美电视剧免费观看| 日韩中文字幕一区二区三区| 日本道在线观看一区二区| 欧美国产激情一区二区三区蜜月| 国产在线精品视频| 精品国产1区二区| 麻豆精品一区二区综合av| 欧美久久一二三四区| 亚洲二区在线观看| 欧美最新大片在线看| 亚洲男人电影天堂| 日本黄色一区二区| 亚洲日本护士毛茸茸| 91蜜桃传媒精品久久久一区二区| 国产精品免费aⅴ片在线观看| 国产69精品久久99不卡| 国产视频一区在线播放| 国产黄色精品视频| 国产欧美中文在线| 国产91丝袜在线观看| 国产清纯在线一区二区www| 福利电影一区二区三区| 国产精品日韩精品欧美在线| 成人av网址在线| 中文字幕制服丝袜一区二区三区| yourporn久久国产精品| 国产精品久久久久桃色tv| 91丨porny丨首页| 亚洲精品视频在线| 欧美色综合影院| 日韩不卡一区二区| 欧美成人午夜电影| 国产精品538一区二区在线| 国产喷白浆一区二区三区| www.在线欧美| 亚洲综合色噜噜狠狠| 7777精品伊人久久久大香线蕉超级流畅 | 91在线小视频| 亚洲欧美国产77777| 在线亚洲一区二区| 日韩成人精品在线| 久久久高清一区二区三区| 成人午夜在线视频| 亚洲美女区一区| 欧美日韩精品一二三区| 老汉av免费一区二区三区| 久久天堂av综合合色蜜桃网| 成人性生交大片免费看视频在线 | 国产91丝袜在线播放0| 国产蜜臀av在线一区二区三区| 9久草视频在线视频精品| 亚洲美女电影在线| 欧美一区二区在线视频| 久久精品久久99精品久久| 久久精品亚洲乱码伦伦中文| av午夜精品一区二区三区| 亚洲综合色成人| 日韩欧美二区三区| thepron国产精品| 石原莉奈在线亚洲二区| 国产午夜亚洲精品理论片色戒| 色综合视频在线观看| 青青国产91久久久久久| 欧美国产激情二区三区| 欧美人狂配大交3d怪物一区| 国产激情一区二区三区四区| 亚洲香肠在线观看| 精品黑人一区二区三区久久| 91丝袜美腿高跟国产极品老师 | 麻豆精品久久精品色综合| 日本一区二区动态图| 在线中文字幕不卡| 麻豆精品视频在线观看免费| 综合久久国产九一剧情麻豆| 日韩一区二区三区在线视频| 成人91在线观看| 青娱乐精品视频在线| 中文字幕在线不卡视频| 日韩一区二区三区av| 97久久精品人人做人人爽50路| 青青草原综合久久大伊人精品 | 日韩美女视频在线| 91免费国产在线| 韩国三级在线一区| 亚洲综合视频在线观看| 国产色一区二区| 91麻豆精品国产91久久久资源速度| 国产精品伊人色| 一区二区三区产品免费精品久久75| 欧美videos大乳护士334| 色成年激情久久综合| 国产一区三区三区| 天堂久久一区二区三区| 国产精品电影一区二区三区| 日韩免费视频一区| 精品视频在线免费观看| 成人黄色电影在线| 男女男精品网站| 亚洲国产视频直播| 国产精品久久久久影院亚瑟 | 91精品免费在线观看| 色综合久久99| 成人高清视频免费观看| 国内精品免费在线观看| 午夜欧美电影在线观看| 亚洲另类在线一区| 国产精品护士白丝一区av| 精品国产凹凸成av人网站| 欧美精品xxxxbbbb| 欧美午夜精品久久久久久超碰| 成人av中文字幕| 国产乱码精品一区二区三区五月婷| 秋霞午夜鲁丝一区二区老狼| 亚洲国产视频一区二区| 亚洲色图一区二区三区| 亚洲国产成人在线| 26uuu欧美日本| 欧美大片顶级少妇| 91精品国产综合久久小美女| 欧美视频日韩视频| 在线免费观看视频一区| 色猫猫国产区一区二在线视频| 粉嫩av一区二区三区粉嫩| 国产精品系列在线观看| 狠狠色狠狠色合久久伊人| 久久www免费人成看片高清| 亚洲第四色夜色| 图片区小说区区亚洲影院| 亚洲超碰97人人做人人爱| 亚洲国产日韩av| 午夜精品成人在线视频| 亚洲国产视频直播| 五月激情综合婷婷| 日韩电影在线一区二区| 日韩高清不卡一区| 日本不卡一区二区| 免费成人av在线| 久久精品国产精品亚洲红杏| 久久疯狂做爰流白浆xx| 久久99精品久久久| 国产精品1区2区3区| 成人美女在线视频| 99国内精品久久| 色就色 综合激情| 欧美日韩久久久一区| 4438x亚洲最大成人网| 欧美一区二区三区播放老司机| 欧美日韩久久久久久| 欧美一区永久视频免费观看| 在线播放中文字幕一区| 欧美嫩在线观看| 日韩欧美三级在线| 久久亚洲综合色| 中文字幕的久久| 一区二区三区欧美视频| 亚洲va国产va欧美va观看| 视频一区二区不卡| 国产麻豆精品视频| 成人福利在线看| 欧美午夜理伦三级在线观看| 欧美肥大bbwbbw高潮| 日韩情涩欧美日韩视频| 日韩一区二区三区四区五区六区| 久久这里只有精品6| 亚洲欧洲精品一区二区三区不卡| 亚洲黄一区二区三区| 日韩av电影天堂| 国产福利电影一区二区三区| 97精品国产露脸对白| 欧美日韩一卡二卡| 日韩小视频在线观看专区| 日本一区二区三区国色天香 | 日韩欧美你懂的| 欧美国产精品劲爆| 亚洲天天做日日做天天谢日日欢 | 欧美电影免费观看高清完整版在线 | 国产激情一区二区三区| 91浏览器打开| 91精品国产麻豆国产自产在线| 久久久影视传媒| 亚洲伊人色欲综合网|