intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Giáo trình xử lý ảnh y tế Tập 2 P17

Chia sẻ: Cinny Cinny | Ngày: | Loại File: PDF | Số trang:7

96
lượt xem
5
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Vỉ mạch ATI PIB được chia ra làm hai mã nguồn: một bằng Microsoft Assembly cho các chương trình vào ra cơ bản, một bằng Microsoft C cho các chương trình chính (như lấy ra khung ảnh hoặc là sửa lại màu).

Chủ đề:
Lưu

Nội dung Text: Giáo trình xử lý ảnh y tế Tập 2 P17

  1. Vỉ mạch ATI PIB đư ợc chia ra làm hai mã ngu ồn: một bằng Microsoft Assembly cho các chương trình vào ra cơ bản, một bằng Microsoft C cho các chương trình chính (nh ư lấy ra khung ảnh hoặc là sửa lại màu). Mặc dù bạn có thể đưa ra ph ần lớn các chương trình trong chương này mà không cần vỉ mạch lưu giữ khung màu, nhưng để làm cho đầy đủ công việc tôi khuyên bạn nên sử dụng một vỉ mạch có chế độ ít nhất là 512  256. Nó không quá đắt, thậm chí nó rẻ h ơn một số vỉ mạch đen trắng. Tôi sẽ cung cấp cho bạn các ch ương trình con dùng cho loại vỉ mạch này, n ếu bạn có một loại vỉ mạch khác thì không ph ải là khó khăn lắm để viết lại các sửa đổi cho phù hợp. Chương trình mà tôi đưa ra trong chương này đư ợc viết bằng Turbo C. Nó sẽ đòi hỏi phải có một thay đổi nhỏ trên mã nguồn cung cấp cho vỉ mạch ATI, PIBTOOL.C và IMGIO.ASM. Để dịch và liên kết th ành một chương trình (tên là CHROM.C) bạn có thể làm điều n ày thông qua Project trên menu lựa chọn của môi trường phát triển kết hợp hoặc là đánh dòng lệnh DOS : tcc chrom.c pibtool.c imgio.asm Trư ớc khi xử lý, bạn sẽ cần viết một file "custom.h" ch ứa một loạt các chương trình nguồn sử dụng trong hai chương trình IMGIO.ASM và PIBTOOL.C. Danh sách của "custom.h " được cung cấp sau chương trình 11.1. Đặt "custom.h" n ằm ở thư mục con Turbo C. Chương trình cho vỉ mạch PIB đư ợc viết cho kiểu 512  256. Các bạn cũng có thể dùng nó với kiểu 512  512 mà không cần có một sự thay đổi nào. Nếu bạn muốn sử dụng đầy đủ khả năng của kiểu 512  512 thì bạn cần một số thay đ ổi nhỏ. Nếu khả năng tài chính không cho phép bạn có một vỉ mạch như vậy, thì b ạn có thể dùng vỉ mạch VGA thay thế. Bây giờ chúng ta sẽ quay lại với sơ đồ màu CIE. Mã nguồn dùng trong chương trình 11.1 cho hiện lên sơ đồ màu trên một monitor m àu dùng vỉ mạch PIB. Chương trình 11.1 "CHROM.C".Displaying the chromaticity diagram. #include /* Program for displaying the chromaticity diagram using the ATI PIB board, 512x256 version. */ void main() { unsigned i,R,G,B; int xp,yp; 234
  2. float x,y,X,Y,Z,D; InitPIB(); /* Initials the PIB to the internal display mode.*/ SetInDispMode(); /* Sets PIB to the internal Sync display mode and also enables the direct memory access. */ SetScreen(0); /* Display page 0 512x256. */ FillPibRect(0,0,0,511,255,0); /* Clear screen. FillPibRect(color,xl,yl,x2,y2,mode); fills the rectangle area specified by the two corners (xl,yl) and (x2,y2) with color. mode=0 for set the pixel to the value specified. mode=1 for 'exclusive or' the pixel with the value specified. mode=2 for 'and' the pixel with the value specified.*/ for(i=1;i>5; R=(0x7C00 & i)>10; X=2.7690*R+1.7518*G+1.1300*B; Y=R+4.5907*G+0.0601*B; Z=0.0565*G+5.5943*B; D=X+Y+Z ; x=X/D; y=Y/D; xp=(int)(400.0*x+60.0+0.5); yp=(int)(200.0-y*200.0+0.5); PutPixel(&i,xp,yp,0); /* PutpixeI(*vaIue,x,y,mode) */ } } File include "custom.h" chứa các một loạt chương trình con cung cấp bởi ATI. Nếu chưa được cung cấp bởi ATI bạn có thể tự viết lấy các ch ương trình này. Liệt kê cho "custom.h" cung cấp ở dư ới đây. "custom.h" 235
  3. void SetScreen(int); int CaptureFrame(void); void SetInDispMode(void); void SetExtDispMode(void); void SetLiveMode(void); void SetHue(int); void SetContrast(int); void SetSaturation(int); void Bright(int); void SetInterlace(int); void SetMask(unsigned); void SetCamera(int); void SetPIBorEGA(int); void SetBlank(int); void FillPibRect(unsigned,int,int,int,int,int); void WaitEven(void); void WaitOdd(void); int InitPIB(void); int TestRow(int); int WaitVsync(void); void FillPibRow(unsigned,int,int,int,int); void FGetPibRow(char far *,int,int,int); void FPutPibRow(char far *,int,int,int); void GetPibRow(char far *,int,int,`int); void PutPibRow(char far *,int,int,int); unsigned GetPixel(unsigned *,int,int); void PutPixel(unsigned *,int,int,int); void SaveData(unsigned,unsigned,int); void SetBright(int); Biểu đồ màu cho các m àu tính ra b ằng vỉ mạch PIB đ ược giới thiệu ở cuối cuốn sách này. Nếu bạn có phần kiểm tra vật lý của "độ sáng" (ví dụ như College Physic) b ạn sẽ có thể so sánh biểu đồ m àu của kiểm tra vật lý với kết qu ả rút ra từ chương trình 11.1. Nếu hệ thống có khả năng hiện nhiều m àu hơn bạn sẽ có một sơ đồ d ày đặc h ơn. Bây giờ ta sẽ so sánh vỉ mạch PIB với vỉ mạch VGA. Để làm như việc này bạn sẽ phải tính ra một bảng màu có cùng một số mức của đỏ, lục, lam. Nếu các màu chính có 26 = 64 mức trên VGA, bạn có thể chọn các m ức 0, 12, 24, 36, 48, và 60 cho tất cả các m àu đỏ, lục, lam để xác lập ra bảng cân bằng m àu. Vì vậy m à ta có tổng cộng 6  6  6 = 216 màu. Bây giờ đưa 216 màu này vào vỉ mạch VGA. Khi tính 32,680 màu cho chuyển đổi 15 bit/ điểm, bạn nhóm 6 màu lại với nhau, ch ẳng hạn, (R/6)  6 ,...v.v.., ở đây R,G,B là giá trị nguyên. Nếu được biểu diễn ảnh 5 bit màu, b ạn cần nhân kết quả với 2 để chuyển sang dạng 6 bit/màu như trường hợp tương thích với VGA. Biết R,G,B chúng ta có thể tính địa chỉ của bảng m àu dùng 236
  4. Address = (B/6+G+R6) / 2 Mã ch ương trình cho hiện sơ đồ biểu đồ trên VGA như ví dụ trên cho ở chương trình 11.2 Chương trình 11.2 "CHROMVGA.C". Displaying the chromaticity diagram on a VGA card. /* Program for displaying chromaticity diagram using a VGA. The program emulates a video card capable of 15 bits/pixel.*/ #include #include #include #include #include void main() { int xp,yp,l,R,G,B; unsigned i; float x,y,X,Y,Z,D; unsigned char a[648],b[648],display_mode,active_page; int color; char far *farptr; union REGS reg; struct SREGS sreg; clrscr(); /* Generate color palette. We assume 6 bits per color for VGA, and therefore the range will extend from 0 to 63per color. */ l=0 ; for(R=0;R
  5. } /* Get current mode. */ reg.h.ah=0x0F; int86(0x10,&reg,&reg); display_mode=reg.h.al; active_page=reg.h.bh; /* Setting display mode to 32Ox2OO. */ reg.h.ah=0; reg.h.al=0x13; int86(0x10,&reg,&reg); /* Read color palette.*/ reg.h.ah=0x10; reg.h.al=0x17; reg.x.bx=0; reg.x.cx=216; sreg.es=FP_SEG(b); reg.x.dx=FP_OFF(b); int86x(0x10,&reg,&reg,&sreg); /* Setting new color palette. */ reg.h.ah=0x10; reg.h.al=0x12; reg.x.bx=0; reg.x.cx=216; sreg.es=FP_SEG(a); reg.x.dx=FP_OFF(a); int86x(0x10,&reg,&reg,&sreg); for(i=1;i> 5; G=(0x7C00 & i) >> 10; X=2.769*R+1.7518*G+1.1300*B; Y=R+4.5907*G+0.0601*B; Z=0.0565*G+5.5943*B; D=X+Y+Z; x=X/D; y=Y/D; xp=(int)(300.0*x+0.5); yp=(int)(190.0-y*190+0.5); /* Group every 6 colors in red, green and blue,i.e. (R/6)*6, and then multiply by 2 to spread the range from 0 to 63 (6-bits.) */ R=(R/6)*12; G=(G/6)*12; B=(B/6)*12; 238
  6. color=(B/6+G+R*6)/2; /* position in palette. */ reg.h.ah=0x0C; reg.h.al=(char)color; reg.h.bh=0; reg.x.cx=xp; reg.x.dx=yp; int86(0x10,&reg,&reg); } getch(); /* Restore previous color palette. */ reg.h.ah=0x10; reg.h.al=0x12; reg.x.bx=0; reg.x.cx=216; sreg.es=FP_SEG(b); reg.x.dx=FP_OFF(b); int86x(0x10,&reg,&reg,&sreg); /* Restore previous mode and page. */ reg.h.ah=0x00; reg.h.al=display_mode; int86(0x10,&reg,&reg); reg.h.ah=0x05; reg.h.al=active_page; int86(0x10,&reg,&reg); } 11.5 Hiển thị ảnh màu trên hệ thống màu 15 bit và 8 bit Phần sắp tới chúng ta sẽ xây dựng chương trình cho hiển thị ảnh và sửa lại màu, độ sáng ..., trên vỉ mạch PIB. Chương trình cũng bao gồm nén và chứa ảnh trên một file. Sau đó là một chương trình cho hiển thị ảnh màu bằng vỉ mạch VGA. Chương trình 11.3 "DISPPIB.C". To display, freeze, and save an image on the PlB board. /* Program for displaying images in live mode through the PIB board. Through the program you can adjust colors, brightness,etc..You are also given the choices to freeze and save the image to a file. */ #include 239
  7. #include #include #include #include #include #define U_ARROW 0x48 #define D_ARROW 0x50 void main() { int ind,k1,k2,k3,k4,ind2,i; char a; char buff[1024],file_name[30]; FILE *fptro; clrscr(); InitPIB(); SetScreen(0); SetInDispMode(); SetCamera(0); SetInterlace(0); SetLiveMode(); k1=140; k2=126; k3=162; k4=44; SetHue(k1); SetContrast(k2); SetSaturation(k3); SetBright(k4); textattr(WHITE+(BLUE
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
7=>1