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

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

?? grad.c

?? 3DMEDLIB - 三維醫學圖像開發源程序庫及范例
?? C
字號:
/*********************** grad.c **************************************

	  3-D Reconstruction of Medical Images

	Three Dimensional Reconstruction Of Medical
	Images from Serial Slices - CT, MRI, Ultrasound


   These programs process a set of slices images (scans) for one
   patient. It outputs two sets of files containing nine predefined
   views of bony surfaces. One set contains distance values and
   the other gradient values.

   The distance values are used as 3-D spatial topographic surface
   coordinate maps for geometrical analysis of the scanned object.

   The gradient values are used for rendering the surface maps on
   CRT displays for subjective viewing where perception of small
   surface details is important.

	Daniel Geist, B.S.
	Michael W. Vannier, M.D.

	Mallinckrodt Institute of Radiology
	Washington University School of Medicine
	510 S. Kingshighway Blvd.
	St. Louis, Mo. 63110

	These programs may be copied and used freely for non-commercial
	purposes by developers with inclusion of this notice.


********************************************************************/
#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="ctbild.000";        /* input file name  */

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;
{
    fnamein[7]=filenum/100+'0';
    fnamein[8]=(filenum%100)/10+'0';
    fnamein[9]='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 floting point distance values  */
getdistances(xstart,xstop,xdir,ystart,ystop,ydir,start_slice,zdir,pass)
int xstart,xstop,xdir,ystart,ystop,ydir,start_slice,zdir,pass;
{
    int z,x,y,i,j,start,stop,inc,line,rzoom,inter;
    float remain;
    FILE *fxfloat,*fyfloat,*fzfloat,*fn[2];
    char filename[13];
    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 */
    sprintf(filename,"%c:xdis%d.dat",DR,pass);
    fxfloat=fopen(filename,"wb");    /* X view floating output file */
    sprintf(filename,"%c:ydis%d.dat",DR,pass);
    fyfloat=fopen(filename,"wb");    /* Y view floating output file */
    for(i=0;i<256;i++)
        for(j=0;j<256;j++)fzbuf[i][j]=256; /* clear Z view buffer */
    for(z=0;z<(LASTSLICE-FIRSTSLICE);z++){  /* For each Slice */
        for(i=0;i<2;i++){               /* open next two slice files */
            setfilename(start_slice+(z+i)*zdir);
            fn[i]=fopen(fnamein,"rb");
        } 
        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;
        for(y=ystart;y!=ystop;y+=ydir){              /* For each line */
            for(i=0;i<2;i++)fseek(fn[i],(long)512*(y+1),SEEK_SET); /* skip to line*/
            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 interplation line */
                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][y]==256.0) fxbuf[i][y]=(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][x]==256.0) fybuf[i][x]=(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[y][x]==256.0) fzbuf[y][x]=
                            (z==0) && (buffer[line][0][x]>=THRESHOLD)?0:NLINES+i+
                            midpoint((float)buffer[line][i+1][x],
                        (float)buffer[line][i][x]);
                    }
            }
            line=1-line;  /* change current input buffer line */
        }
        NLINES+=inter;           /* increment number of output lines */

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

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)/y_factor;
    gy=(y1-y2)/z_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;
    /* do first pixel in line */
    if(fxbuf[line][0]==256)lineg[0]=lined[0]=0;
    else{
        lined[0]=255-fxbuf[line][0]; /*distance shade */
        lineg[0]=grad(fxbuf[line][0],fxbuf[line][1],fxbuf[prevline][0],
        fxbuf[succline][0],1,z_factor);
    }
    /* do rest of pixels inside line */
    for(i=1;i<255;i++) if(fxbuf[line][i]==256)lineg[i]=lined[i]=0;
    else{
        lined[i]=255-fxbuf[line][i]; /*distance shade */
        lineg[i]=grad(fxbuf[line][i-1],fxbuf[line][i+1],fxbuf[prevline][i],
        fxbuf[succline][i],2,z_factor);
    }
    /* do last pixel in line */
    if(fxbuf[line][255]==256)lineg[255]=lined[255]=0;
    else{
        lined[255]=255-fxbuf[line][255]; /*distance shade */
        lineg[255]=grad(fxbuf[line][255],fxbuf[line][254],fxbuf[prevline][255],
        fxbuf[succline][255],1,z_factor);
    }
    fwrite(lineg,1,256,fg); /* write to output files */
    fwrite(lined,1,256,fd);
}

/* create an gradient and distance shaded view */
doviews(namedis,nameg,named,nlines)
char *namedis,*nameg,*named; /* floating file , gradiet and distance files*/
int nlines;                  /* number of lines in image */
{
    FILE *fg,*fd,*ffloat;
    int z,i,j,k,midline;
    char lined[256],lineg[256]; /* gradient and distance value buffers */
    midline=1;                  /* middle line in input buffer */
    fd=fopen(named,"wb");       /* open output and input files */
    fg=fopen(nameg,"wb");
    ffloat=fopen(namedis,"rb");
    fread(fxbuf,1,3072,ffloat); /* read first three floating lines */
    /* do first line */
    doline(lineg,lined,0,0,1,1,fg,fd);
    /* do rest of lines */
    for(z=0;z<(nlines-2);z++){      /*for each inside line */
        doline(lineg,lined,midline,prev(midline),succ(midline),2,fg,fd);
        fread(fxbuf[prev(midline)],1,1024,ffloat); /*read next floating line */
        midline=succ(midline);
    }
    /* do last line */
    doline(lineg,lined,midline,prev(midline),midline,1,fg,fd);
    fclose(fg);  /* close all files */
    fclose(fd);
    fclose(ffloat);
}

/**********************************************************/
/**** MAIN ***** MAIN ***** MAIN ***** MAIN ***** MAIN ****/
/**********************************************************/
main()
{   char filename[13];
    FILE *par;
    /* first get some parameters from user */
    printf("Enter Zoom factor: ");
    scanf("%f",&ZOOM);
    printf("Enter starting scan number: ");
    scanf("%d",&FIRSTSLICE);
    printf("Enter ending scan number: ");
    scanf("%d",&LASTSLICE);
    printf("Enter Threshold value: ");
    scanf("%d",&THRESHOLD);
    THRESHOLD+=1024;
    DR=0;
    while(!DR){
        printf("Enter temporary drive: ");
        DR=getchar();
        if(!isalpha(DR)) DR=0;
    } 

 /* get floating distance values (first pass over data)*/
    printf("starting forward pass on data\n");
    getdistances(0,256,1,0,256,1,FIRSTSLICE,1,1);
    /* create images */
    printf("doing bottom (Z) views\n");
    sprintf(filename,"%c:zdis%d.dat",DR,1);
    doviews(filename,"gbo.out","dbo.out",256);
    printf("doing right lateral (X) views\n");
    sprintf(filename,"%c:xdis%d.dat",DR,1);
    doviews(filename,"grl.out","drl.out",NLINES);
    printf("doing rear (Y) views\n");
    sprintf(filename,"%c:ydis%d.dat",DR,1);
    doviews(filename,"gre.out","dre.out",NLINES);

 /* get floating distance values (second pass over data)*/
    printf("starting backward pass on dat\n");
    getdistances(255,-1,-1,255,-1,-1,LASTSLICE,-1,2);
    /* create images */
    printf("doing top (Z) views\n");
    sprintf(filename,"%c:zdis%d.dat",DR,2);
    doviews(filename,"gto.out","dto.out",256);
    printf("doing left lateral (X) views\n");
    sprintf(filename,"%c:xdis%d.dat",DR,2);
    doviews(filename,"gll.out","dll.out",NLINES);
    printf("doing front (Y) views\n");
    sprintf(filename,"%c:ydis%d.dat",DR,2);
    doviews(filename,"gfr.out","dfr.out",NLINES);
    printf("number of lines = %d\n",NLINES);

    /* write temporary drive and number of lines */ 
    par=fopen("param.dat","wb");
    fprintf(par,"%c %d",DR,NLINES);
    fclose(par);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美精品午睡沙发| 久久国产精品区| 韩国精品在线观看| 91豆麻精品91久久久久久| 欧美大胆人体bbbb| 亚洲影院理伦片| 成人a区在线观看| 欧美大尺度电影在线| 亚洲电影视频在线| av资源网一区| 久久久91精品国产一区二区三区| 午夜精品久久久久久久| 99re视频这里只有精品| 亚洲精品一区二区三区影院| 亚洲成人一区在线| 91精品91久久久中77777| 国产婷婷色一区二区三区在线| 日本一不卡视频| 日韩一级片在线播放| 亚洲一区二区欧美激情| 91啪亚洲精品| 一区二区三区中文在线| 99久久国产综合精品色伊| 国产精品色噜噜| 丁香一区二区三区| 国产日韩亚洲欧美综合| 韩国毛片一区二区三区| 26uuu亚洲综合色| 国内精品国产三级国产a久久| 91麻豆精品国产91| 日韩在线观看一区二区| 欧美精品少妇一区二区三区| 亚洲影院理伦片| 欧美群妇大交群的观看方式| 婷婷久久综合九色综合伊人色| 91美女蜜桃在线| 亚洲大片一区二区三区| 欧美曰成人黄网| 青草国产精品久久久久久| 7777精品伊人久久久大香线蕉完整版 | 三级久久三级久久| 欧美日韩专区在线| 日韩电影免费在线看| 精品国产亚洲在线| 国产精一品亚洲二区在线视频| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 一区二区三区四区激情| 色哟哟国产精品免费观看| 亚洲成a人v欧美综合天堂下载| 欧美日韩在线一区二区| 美女一区二区久久| 久久久www成人免费无遮挡大片| 国产传媒日韩欧美成人| 日韩美女视频一区二区| 在线欧美小视频| 蜜桃av一区二区三区电影| 国产欧美一区二区在线观看| 91色九色蝌蚪| 蜜桃视频一区二区三区在线观看| 久久婷婷国产综合精品青草 | 麻豆成人av在线| 国产日韩欧美制服另类| 色婷婷久久久久swag精品| 视频一区在线播放| 日本一区二区三区在线观看| 色综合天天综合狠狠| 蜜臀99久久精品久久久久久软件| 国产欧美一区二区三区在线看蜜臀 | 久久―日本道色综合久久| 色综合久久久网| 老司机精品视频一区二区三区| 久久久91精品国产一区二区三区| 91精品国产91久久久久久一区二区 | 视频一区二区三区入口| 久久奇米777| 717成人午夜免费福利电影| 成人黄页在线观看| 日韩高清在线电影| 中文字幕一区二区不卡| 日韩一区二区三区四区五区六区 | 亚洲天堂免费在线观看视频| 日韩欧美123| 欧美网站一区二区| 成人性色生活片| 免费在线观看视频一区| 一区二区在线免费| 欧美激情中文字幕| 日韩一级二级三级| 在线观看不卡一区| 99久久综合色| 国产成人免费9x9x人网站视频| 婷婷夜色潮精品综合在线| 亚洲精品免费在线观看| 国产午夜精品美女毛片视频| 日韩一区二区电影在线| 欧美老女人第四色| 欧美日韩午夜影院| 色综合欧美在线| 99天天综合性| 成人性生交大合| 高清成人免费视频| 国产一区二区免费视频| 蜜桃av一区二区在线观看| 天天亚洲美女在线视频| 亚洲午夜羞羞片| 亚洲毛片av在线| 最新不卡av在线| 日韩美女视频一区二区 | av在线这里只有精品| 久久99国产精品久久| 美女一区二区三区| 精品一区二区免费在线观看| 日韩中文字幕区一区有砖一区 | 精品1区2区在线观看| 日韩无一区二区| 日韩一区二区视频| 欧美成va人片在线观看| 日韩一区二区三区电影在线观看| 欧美日韩久久久久久| 制服丝袜一区二区三区| 91精品欧美一区二区三区综合在| 91精品国产综合久久香蕉麻豆 | 欧美三级在线看| 欧美日韩一级片在线观看| 欧美精品1区2区| 日韩一区二区视频| 国产日韩欧美在线一区| 国产精品天天摸av网| 国产精品视频你懂的| 亚洲婷婷综合久久一本伊一区| 亚洲精品国产品国语在线app| 亚洲一区二区三区中文字幕| 午夜精品123| 国产盗摄一区二区| 一本到不卡精品视频在线观看| 欧美亚洲国产一区二区三区 | 欧美日韩免费不卡视频一区二区三区| 在线观看亚洲a| 欧美一二三区在线| 国产欧美精品一区| 一区二区三区色| 蜜臀久久久久久久| www.日韩在线| 欧美午夜精品一区| 久久久久九九视频| 一区二区三区欧美亚洲| 久久精品国产成人一区二区三区| 国产成人在线视频播放| 欧美色爱综合网| 国产清纯白嫩初高生在线观看91 | voyeur盗摄精品| 欧美日韩三级视频| 国产丝袜欧美中文另类| 亚洲国产三级在线| 国产91在线看| 欧美狂野另类xxxxoooo| 中文一区在线播放| 日韩高清在线不卡| 91色.com| 久久综合九色综合欧美亚洲| 一区二区三区四区激情| 国产精品综合一区二区| 欧美综合色免费| 精品日韩在线观看| 亚洲精品国产精华液| 欧美国产一区视频在线观看| 亚洲综合偷拍欧美一区色| 韩日av一区二区| 色呦呦一区二区三区| 国产午夜精品一区二区 | 亚洲视频小说图片| 亚洲欧美另类久久久精品| 亚洲福利视频一区二区| 久久成人综合网| 国产jizzjizz一区二区| 91原创在线视频| 欧美日韩一级二级| 欧美精品一区视频| 一区二区中文字幕在线| 五月婷婷激情综合网| 九九热在线视频观看这里只有精品| 国产成人精品免费| 91国偷自产一区二区开放时间| 欧美精品在线观看一区二区| 国产亚洲婷婷免费| 亚洲精品视频免费看| 韩国成人福利片在线播放| 99久久精品国产观看| 欧美一二区视频| 一区二区在线电影| 精品亚洲免费视频| 欧美丝袜丝nylons| 国产精品午夜免费| 麻豆精品视频在线观看免费| 91在线精品一区二区三区| 欧美大片免费久久精品三p | 美女精品一区二区| 色婷婷国产精品| 久久久久久久久蜜桃| 午夜在线成人av|