Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 75 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
75
Dung lượng
2,23 MB
Nội dung
i ĐẠI HỌC THÁI NGUYÊN TRƯỜNG ĐẠI HỌC CÔNG NGHỆ THÔNG TIN VÀ TRUYỀN THÔNG NGUYỄN QUỐC HƯNG lu an n va tn to p ie gh NỘI SUY ẢNH TRONG d oa nl w HỖ TRỢ CHẨN ĐOÁN HÌNH ẢNH nf va an lu z at nh oi lm ul LUẬN VĂN THẠC SĨ KHOA HỌC MÁY TÍNH z m co l gm @ an Lu Thái Nguyên - 2017 n va ac th si ii LỜI CAM ĐOAN Sau trình làm luận văn, với nội dung đề tài “Nội suy ảnh hỗ trợ chẩn đốn hình ảnh”, có nhiều khó khăn việc sưu tầm tài liệu, làm luận văn, đến luận văn tơi hồn thành với giúp đỡ, bảo tận tình PGS.TS Đỗ Năng Tồn, thầy giáo, cô giáo khoa công nghệ thông tin trường Đại học Công nghệ thông tin truyền thông – Đại học Thái Nguyên Tôi xin cam đoan toàn nội dung luận văn tự sưu tầm, lu tra cứu thông tin mạng, số sách tham khảo xếp, an hoàn thiện cho phù hợp với nội dung yêu cầu đề tài va n Nếu sai tơi xin hồn tồn chịu trách nhiệm to gh tn Thái Nguyên, ngày 10 tháng năm 2017 p ie Người cam đoan d oa nl w nf va an lu Nguyễn Quốc Hưng z at nh oi lm ul z m co l gm @ an Lu n va ac th si iii LỜI CẢM ƠN Trong q trình thực luận văn, tơi nhận nhiều hướng dẫn, giúp đỡ nhiệt tình thầy cơ, gia đình, bạn bè Trước tiên, tơi xin bày tỏ lịng biết ơn sâu sắc tới thầy giáo hướng dẫn PGS.TS Đỗ Năng Toàn Trong suốt hai năm qua, nhận giúp đỡ, động viên đặc biệt hướng dẫn tận tình thầy giúp tơi nắm rõ mục tiêu định hướng nghiên cứu luận văn Tôi xin gửi lời cảm ơn chân thành tới thầy giáo, cô giáo lu khoa công nghệ thông tin trường đại học CNTT&TT – Đại học Thái an Nguyên trang bị cho thêm kiến thức quý giá suốt quãng thời gian va n học tập tai trường to gh tn Cuối cùng, với tình cảm sâu sắc nhất, tơi xin chân thành gửi tới p ie gia đình bạn bè, người bên, động viên, chia sẻ với tơi mặt giúp tơi hồn thành khóa học oa nl w Thái Nguyên, ngày 10 tháng năm 2017 Học viên d nf va an lu lm ul z at nh oi Nguyễn Quốc Hưng z m co l gm @ an Lu n va ac th si iv MỤC LỤC LỜI CAM ĐOAN i LỜI CẢM ƠN iii MỤC LỤC iv DANH MỤC TỪ VIẾT TẮT vi DANH MỤC BẢNG BIỂU vii DANH MỤC HÌNH ẢNH viii MỞ ĐẦU lu CHƯƠNG 1: KHÁI QUÁT VỀ ẢNH Y TẾ VÀ BÀI TOÁN NỘI SUY ẢNH an TRONG HỖ TRỢ CHẨN ĐỐN HÌNH ẢNH va n 1.1 Khái quát ảnh y tế 1.1.2 Chuẩn ảnh y tế DICOM ie gh tn to 1.1.1 Giới thiệu ảnh y tế p 1.2 Bài toán nội suy ảnh hỗ trợ chẩn đốn hình ảnh 13 nl w 1.2.1 Khái niệm nội suy ảnh 13 oa 1.2.2 Hướng tiếp cận 16 d 1.2.3 Ứng dụng 18 lu nf va an CHƯƠNG 2: MỘT SỐ KỸ THUẬT NỘI SUY ẢNH TRONG HỖ TRỢ CHẨN ĐỐN HÌNH ẢNH 19 lm ul 2.1 Kỹ thuật nội suy điểm ảnh láng giềng gần 19 z at nh oi 2.1.1 Giới thiệu 19 2.1.2 Phương pháp 20 2.2 Kỹ thuật nội suy lát cắt dựa cải tiến phép hợp biến dạng cong 24 z gm @ 2.2.1 Giới thiệu 24 2.2.2 Phương pháp 26 l co 2.3 Kỹ thuật nội suy tuyến tính 30 m 2.3.1 Giới thiệu 30 an Lu 2.3.2 Phương pháp 30 n va ac th si v 2.4 Kỹ thuật nội suy song tuyến 34 2.4.1 Giới thiệu 34 2.4.2 Phương pháp 34 CHƯƠNG 3: CHƯƠNG TRÌNH THỬ NGHIỆM 38 3.1 Bài toán 1: Nội suy sinh lát cắt trung gian 38 3.1.1 Phát biểu toán 38 3.1.2 Phân tích chương trình 39 3.1.3 Các bước triển khai 40 3.1.4 Kết chương trình thử nghiệm 44 lu an 3.2 Bài toán 2: Dựng lát cắt theo chiều dọc (hoặc chiều ngang) 46 va 3.2.1 Phát biểu toán 46 n 3.2.2 Phân tích chương trình 46 gh tn to 3.2.3 Các bước triển khai 47 p ie 3.2.4 Kết chương trình thử nghiệm 50 KẾT LUẬN 52 oa nl w TÀI LIỆU THAM KHẢO 53 PHỤ LỤC 55 d nf va an lu z at nh oi lm ul z m co l gm @ an Lu n va ac th si vi DANH MỤC TỪ VIẾT TẮT lu an n va American College of Radiologist CCD Charge Coupled Device CT Computer Tomography DICOM Digital Imaging and Communications in Medicine IOD Information Object Definition MPR Multi Planar Reformat MRI Magentic Resonance Imaging NEMA National Electrical Manufacturers Association OSI Open Systems Interconnection PACS Picture archiving and communication system SOP Service Object Pair p ie gh tn to ACR d oa nl w nf va an lu z at nh oi lm ul z m co l gm @ an Lu n va ac th si vii DANH MỤC BẢNG BIỂU Bảng 1.1: Các khái niệm DICOM Bảng 1.2: Quy ước thứ tự xuất byte file DICOM 12 lu an n va p ie gh tn to d oa nl w nf va an lu z at nh oi lm ul z m co l gm @ an Lu n va ac th si viii DANH MỤC HÌNH ẢNH Hình 1.1: DICOM mơ hình tham chiếu OSI Hình 1.2: Thơng tin file DICOM Hình 1.3: Một số trường ảnh DICOM Hình 1.4: Cấu trúc file DICOM Hình 1.5: Cấu tạo Data Set Hình 2.1: Minh họa kỹ thuật nội suy điểm ảnh láng giềng gần 19 Hình 2.2: Kỹ thuật nội suy điểm ảnh láng giềng gần không gian lu chiều 21 an Hình 2.3: Kết kỹ thuật nội suy điểm ảnh láng giềng gần va n không gian chiều 22 gh tn to Hình 2.4: Ứng dụng kỹ thuật nội suy điểm ảnh láng giềng gần p ie chẩn đoán bệnh lác mắt 23 Hình 2.5: Minh họa kỹ thuật nội suy lát cắt dựa cải tiến phép hợp biến nl w dạng cong 25 d oa Hình 2.6: Ứng dụng kỹ thuật nội suy lát cắt dựa cải tiến phép hợp biến an lu dạng cong 29 nf va Hình 2.7: Minh họa kỹ thuật nội suy tuyến tính theo phương pháp lặp 30 lm ul Hình 2.8: Minh họa kỹ thuật nội suy tuyến tính theo đường thẳng 31 z at nh oi Hình 2.9: Ứng dụng kỹ thuật nội suy tuyến tính xoay ảnh MRI 33 Hình 2.10: Ứng dụng kỹ thuật nội suy tuyến tính sinh lát cắt trung gian 33 Hình 2.11: Minh họa kỹ thuật nội suy song tuyến 34 z Hình 2.12: Ứng dụng kỹ thuật nội suy song tuyến 37 gm @ Hình 3.1: Hai lát cắt liên tiếp lát cắt trung gian 38 l co Hình 3.2: Hai lát cắt đầu vào chương trình thử nghiệm 44 m Hình 3.3: Kết chương trình thử nghiệm 44 an Lu Hình 3.4: Giao diện chương trình thử nghiệm 45 n va ac th si ix Hình 3.5: Thơng tin bệnh nhân chương trình thử nghiệm 45 Hình 3.6: Giao diện chương trình thử nghiệm 50 Hình 3.7: Thơng tin bệnh nhân chương trình thử nghiệm 50 Hình 3.8: Dựng lát cắt với MPR (1) 51 Hình 3.9: Dựng lát cắt với MPR (2) 51 Hình 3.10: Dựng lát cắt với MPR (3) 51 lu an n va p ie gh tn to d oa nl w nf va an lu z at nh oi lm ul z m co l gm @ an Lu n va ac th si MỞ ĐẦU Trong năm gần công nghệ thông tin phát triển với tốc độ chóng mặt phần cứng phần mềm Sự phát triển công nghệ thông tin thúc đẩy phát triển nhiều lĩnh vực khác xã hội y học, giáo dục, giải trí, kinh tế, … Sự phát triển phần cứng phương diện thu nhận, hiển thị, với tốc độ xử lý mở nhiều hướng cho phát triển phần mềm, đặt biệt lĩnh vực xử lý ảnh Nội suy ảnh chủ đề biến đến rộng rãi lĩnh vực xử lý ảnh lu có nhiều nghiên cứu chủ đề này, đặc biệt nội suy ảnh an phát triển mạnh mẽ xử lý ảnh y – sinh học Trong lĩnh vực y tế, xử lý va n ảnh ứng dụng cách rộng rãi đem lại nhiều kết khả quan gh tn to Mặt khác cịn hứa hẹn tương lai tươi sáng, với phát triển Trong y học, chẩn đốn hình ảnh phương pháp chẩn đốn cho p ie cơng nghệ sinh học nl w phép người bác sĩ quan sát hình ảnh phận thể bệnh d oa nhân cách trực quan nhất, từ đưa chẩn đốn xác bệnh an lu lý để có biện pháp điều trị hiệu Hình ảnh tái cấu trúc thiết bị nf va xuất lát cắt hai chiều khơng gian cần chẩn đốn Các thiết bị lm ul chẩn đốn đo lường hình ảnh y học phát triển nhằm mục đích z at nh oi tái lại hình ảnh bên thể bệnh nhân, phân biệt phận phát tổn thương, từ giúp ích nhiều cho q trình chẩn đốn bệnh Là kỹ sư cơng tác bệnh viên đa khoa tỉnh Ninh Bình, z hết em muốn tìm hiểu đóng góp phần cơng sức để @ l gm giúp ích nâng cao chất lượng, phục vụ cho trình khám, chữa bệnh m hình ảnh" làm luận văn tốt nghiệp co tốt Chính em chọn đề tài "Nội suy ảnh hỗ trợ chẩn đoán an Lu n va ac th si 52 KẾT LUẬN Với nội dung trình bày lý thuyết thực nghiệm, kết mà luận văn đạt tổng kết thành phần sau: Những kết đạt - Tìm hiểu khái quát ảnh y tế, nguyên lý tạo ảnh chuẩn lưu trữ Trình bày chi tiết cấu trúc file ảnh DICOM sử dụng ảnh y khoa - Hệ thống hóa kỹ thuật nội suy ảnh, nhận xét ưu, nhược điểm ứng dụng kỹ thuật việc hỗ trợ chẩn đốn hình ảnh lu - Cài đặt thực nghiệm hai kỹ thuật nội suy đại diện cho hai nhóm nghiên an cứu nội suy lát cắt nội suy dựa cường độ điểm ảnh nội va n suy dựa đối tượng to gh tn - Kết thực nghiệm đánh giá, so sánh cho thấy nhóm kỹ thuật ie nội suy dựa đối tượng cho hình ảnh rõ nét hơn, khắc phục vết mờ p đường biên kỹ thuật nội suy dựa cường độ nl w Hướng mở rộng nghiên cứu d oa Độ xác kỹ thuật nội suy lát cắt tăng việc ứng dụng kỹ an lu thuật vào trình tái cấu trúc mơ hình 3D giống với thực tế Điều nf va góp phần hỗ trợ tốt q trình chẩn đốn điều trị cho bệnh lm ul nhân Trong thiết bị chẩn đốn hình ảnh đại có giá thành z at nh oi cao, việc đầu tư rộng rãi thiết bị điều khiện nước ta chưa khả thi Do việc phát triển hướng nghiên cứu nội suy lát cắt thiết thực sát với thực tế Chính ngồi kỹ thuật nội suy trình bày z luận văn, toán nội suy sinh lát cắt trung gian cần tiếp tục nghiên m co l gm @ cứu phát triển an Lu n va ac th si 53 TÀI LIỆU THAM KHẢO Tiếng Việt [1] Lương Mạnh Bá, Nguyễn Thanh Thuỷ (1999), Nhập môn xử lý ảnh, NXB Khoa học kỹ thuật, Hà Nội [2] Phạm Việt Bình, Đỗ Năng Tồn (2008), Xử lý ảnh, NXB Khoa học kỹ thuật, Hà Nội Tiếng Anh [3] A Goshta by, D A Turner, and L V Ackerman, Jan 1992, “Matching of lu tomographic slices for interpolation”, IEEE Trans on medical imaging, vol 11, an no 4, pp 507–16 va n [4] B Fischer and J Modersitzki, Mar 2004, “A unified approach to fast image gh tn to registration and a new curvature based registration technique”, Linear Algebra p ie and its Applications, vol 380, pp 107– 124 [5] J Modersitzki, Aug 2004, Numerical Methods for Image Registration USA d oa nl w (Numerical Mathematics and Scientific Computation), Oxford university press an lu [6] J Leng, G Xu, and Y Zhang, 2013, “Medical image interpolation based on nf va multi-resolution registration”, Computers & Mathematics with Applications, lm ul vol 66, no 1, pp 1–18 z at nh oi [7] Rorbert G.Keys, 1981, “Cubic convolution interpolation for digital image processing”, IEEE Transactions on Acoustics, Speech, and Signal Processing, vol 29, no 6, pp 1153-1160 z @ [8] Thomas M Lehmann, Claudia Gonner, Klaus Spitzer, November 1999, co Transactions on Medical Imaging, vol 18, no 11 l gm “Survey: Interpolation Methods in Medical Image Processing”, IEEE m [9] Zeyun Yu, Ahmadreza Baghaie, 2014, “Curvature-Based registration for an Lu slice interpolation of medical image ”, Computational Modeling of Objects n va ac th si 54 Presented in Images Fundamentals, Methods, and Applications Lecture Notes in Computer Science , Springer,Volume 8641, pp 69-80 Trang WEB http://chrisk91.me/2016/10/30/Pixels.html http://prgmobileapps.com/AppUpdates/ors/Abstracts/abs1598.html http://people.cas.sc.edu/rorden/dicom/index.html https://vi.wikipedia.org/wiki/DICOM https://en.wikipedia.org/wiki/Nearest-neighbor_interpolation lu https://en.wikipedia.org/wiki/Linear_interpolation an n va https://en.wikipedia.org/wiki/Bilinear_interpolation p ie gh tn to d oa nl w nf va an lu z at nh oi lm ul z m co l gm @ an Lu n va ac th si 55 PHỤ LỤC Hàm hiển thị tập tin DICOM private void ReadAndDisplayDicomFile(string fileName, string fileNameOnly) { ddRe.DicomFileName = fileName; //MessageBox.Show(ddRe.DicomFileName); TypeOfDicomFile typeOfDicomFile = ddRe.typeofDicomFile; lu an if (typeOfDicomFile == TypeOfDicomFile.Dicom3File || va n typeOfDicomFile == tn to TypeOfDicomFile.DicomOldTypeFile) gh { p ie imageWidth = ddRe.width; w imageHeight = ddRe.height; oa nl bitDepth = ddRe.bitsAllocated; winCentre = ddRe.windowCentre; d an lu winWidth = ddRe.windowWidth; nf va samplesPerPixel = ddRe.samplesPerPixel; signedImage = ddRe.signedImage; lm ul z at nh oi label1.Visible = true; label2.Visible = true; label3.Visible = true; z //bnSave.Enabled = true; //bnTags.Enabled = true; m co //bnResetWL.Enabled = true; l gm @ label4.Visible = true; imageHeight.ToString(); an Lu label2.Text = imageWidth.ToString() + " X " + n va ac th si 56 if (samplesPerPixel == 1) label4.Text = bitDepth.ToString() + " bit"; else label4.Text = bitDepth.ToString() + " bit, " + samplesPerPixel + " samples per pixel"; imagePanelControl.NewImage = true; Text = "DICOM Image Viewer: " + fileNameOnly; lu if (samplesPerPixel == && bitDepth == 8) an { va pixels8.Clear(); n gh tn to pixels16.Clear(); p ie if (ddRe.signedImage) pixels24.Clear(); nl w ddRe.GetPixels8(ref pixels8); d oa minPixelValue = pixels8.Min(); nf va an lu maxPixelValue = pixels8.Max(); if (ddRe.signedImage) lm ul { } z at nh oi winCentre -= char.MinValue; z if (Math.Abs(winWidth) < 0.001) gm @ { m co } l winWidth = maxPixelValue - minPixelValue; an Lu if ((winCentre == 0) || n va ac th si 57 (minPixelValue > winCentre) || (maxPixelValue < winCentre)) { winCentre = (maxPixelValue + minPixelValue) / 2; } imagePanelControl.SetParameters(ref pixels8, imageWidth, imageHeight, lu winWidth, winCentre, samplesPerPixel, an true, this); va } n tn to if (samplesPerPixel == && bitDepth == 16) gh p ie { pixels16.Clear(); nl w pixels8.Clear(); d oa pixels24.Clear(); an lu ddRe.GetPixels16(ref pixels16); minPixelValue = pixels16.Min(); nf va maxPixelValue = pixels16.Max(); lm ul if (ddRe.signedImage) z at nh oi { winCentre -= short.MinValue; } z @ l { gm if (Math.Abs(winWidth) < 0.001) } m co winWidth = maxPixelValue - minPixelValue; an Lu n va ac th si 58 if ((winCentre == 0) || (minPixelValue > winCentre) || (maxPixelValue < winCentre)) { winCentre = (maxPixelValue + minPixelValue) / 2; } imagePanelControl.Signed16Image = lu ddRe.signedImage; an imagePanelControl.SetParameters(ref pixels16, va imageWidth, imageHeight, n tn to winWidth, winCentre, true, this); } p ie gh if (samplesPerPixel == && bitDepth == 8) nl w { d oa // This is an RGB colour image an lu pixels8.Clear(); pixels16.Clear(); nf va pixels24.Clear(); lm ul ddRe.GetPixels24(ref pixels24); imageWidth, imageHeight, z at nh oi imagePanelControl.SetParameters(ref pixels24, winWidth, winCentre, samplesPerPixel, z true, this); m co { l else gm } @ } an Lu n va ac th si 59 if (typeOfDicomFile == TypeOfDicomFile.DicomUnknownTransferSyntax) { MessageBox.Show("Sorry, I can't read a DICOM file with this Transfer Syntax.", "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); } else lu { an MessageBox.Show("Sorry, I can't open this va file " + n tn to "This file does not appear to contain a DICOM image.", gh p ie "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); nl w } d oa Text = "DICOM Image Viewer: "; an lu // Show a plain grayscale image instead pixels8.Clear(); nf va pixels16.Clear(); lm ul pixels24.Clear(); z at nh oi samplesPerPixel = 1; imageWidth = imagePanelControl.Width - 25; z imageHeight = imagePanelControl.Height - 25; @ l gm int iNoPix = imageWidth * imageHeight; m co for (int i = 0; i < iNoPix; ++i) { an Lu pixels8.Add(240); n va ac th si 60 } winWidth = 256; winCentre = 127; imagePanelControl.SetParameters(ref pixels8, imageWidth, imageHeight, winWidth, winCentre, samplesPerPixel, true, this); imagePanelControl.Invalidate(); label1.Visible = false; lu label2.Visible = false; an label3.Visible = false; va label4.Visible = false; n tn to //bnSave.Enabled = false; //bnTags.Enabled = false; gh p ie //bnResetWL.Enabled = false; } nl w } d oa Hàm tính lát cắt nội suy theo kỹ thuật nội suy tuyến tính { int i; nf va an lu private void btPolation_Click(object sender, EventArgs e) lm ul imagePanelControl2.NewImage = true; z at nh oi if ((imageOpened1 == true) && (imageOpened == true )) { z @ m co l { gm if (samplesPerPixel == && bitDepth == 8) an Lu List px8Ta = ddTa.pixels8; List px8Re = ddRe.pixels8; n va ac th si 61 List px8 = new List(); for (i = 0; i < px8Ta.Count; i++) { byte pi = (byte)((px8Ta[i] + px8Re[i]) / 2); px8.Add(pi); } lu minPixelValue = px8.Min(); an maxPixelValue = px8.Max(); n va tn to if (ddTa.signedImage) { gh p ie winCentre -= char.MinValue; nl w } d oa if (Math.Abs(winWidth) < 0.001) winWidth = maxPixelValue - minPixelValue; nf va an lu { } lm ul z at nh oi if ((winCentre == 0) || (minPixelValue > winCentre) || (maxPixelValue < winCentre)) z { @ minPixelValue) / 2; m co } l gm winCentre = (maxPixelValue + an Lu n va ac th si 62 imagePanelControl2.SetParameters(ref px8, imageWidth, imageHeight, winWidth, winCentre, samplesPerPixel, true, this); } if (samplesPerPixel == && bitDepth == 16) { lu List px16Ta = ddTa.pixels16; an List px16Re = ddRe.pixels16; n va gh tn to pxPo16 = new List(); p ie for (i = 0; i < px16Re.Count; i++) { nl w ushort pi = (ushort)((px16Re[i] + d oa px16Ta[i]) / 2); an lu pxPo16.Add(pi); } nf va lm ul minPixelValue = pxPo16.Min(); z at nh oi maxPixelValue = pxPo16.Max(); if (ddTa.signedImage) z { @ m co l } gm winCentre -= short.MinValue; if (Math.Abs(winWidth) < 0.001) an Lu { n va ac th si 63 winWidth = maxPixelValue - minPixelValue; } if ((winCentre == 0) || (minPixelValue > winCentre) || (maxPixelValue < winCentre)) { winCentre = (maxPixelValue + minPixelValue) / 2; lu } an imagePanelControl2.Signed16Image = va ddTa.signedImage; n tn to imagePanelControl2.SetParameters(ref pxPo16, imageWidth, imageHeight, gh p ie winWidth, winCentre, true, this); nl w } d oa if (samplesPerPixel == && bitDepth == 8) an lu { // This is an RGB colour image nf va lm ul List px24Ta = ddTa.pixels24; z at nh oi List px24Re = ddRe.pixels24; List px24 = new List(); z for (i = 0; i < px24Re.Count; i++) @ gm { l byte pi = (byte)((px24Re[i] + px24Ta[i]) / px24.Add(pi); an Lu } m co 2); n va ac th si 64 imagePanelControl2.SetParameters(ref px24, imageWidth, imageHeight, winWidth, winCentre, samplesPerPixel, true, this); } } } Hàm tính lát cắt nội suy theo kỹ thuật nội suy lát cắt dựa cải tiến lu phép hợp biến dạng cong an private void btnRes_Click(object sender, EventArgs e) va n { to tn imageWidth = ddRe.width; gh imageHeight = ddRe.height; p ie bitDepth = ddRe.bitsAllocated; winWidth = ddRe.windowWidth; oa nl w winCentre = ddRe.windowCentre; samplesPerPixel = ddRe.samplesPerPixel; d nf va an lu signedImage = ddRe.signedImage; label1.Visible = true; lm ul label2.Visible = true; z at nh oi label3.Visible = true; label4.Visible = true; //bnSave.Enabled = true; z //bnResetWL.Enabled = true; l gm @ //bnTags.Enabled = true; //label2.Text = imageWidth.ToString() + " X " + an Lu // m //if (samplesPerPixel == 1) co imageHeight.ToString(); label4.Text = bitDepth.ToString() + " bit"; n va ac th si 65 //else // label4.Text = bitDepth.ToString() + " bit, " + samplesPerPixel + // " samples per pixel"; imagePanelControl3.NewImage = true; //pixels16.Clear(); //pixels8.Clear(); lu //pixels24.Clear(); an //ddRe.GetPixels16(ref pixels16); va List px16Ta = ddTa.pixels16; n gh tn to List px16Re = ddRe.pixels16; p ie px16 = new List(); { nl w for (int i = 0; i < px16Re.Count; i++) d oa double p = 0.7; p)*px16Ta[i]); nf va an lu ushort pi = (ushort)(px16Re[i]*p + (1- px16.Add(pi); z at nh oi lm ul } minPixelValue = px16.Min(); maxPixelValue = px16.Max(); z winCentre -= short.MinValue; an Lu if (Math.Abs(winWidth) < 0.001) m } co l gm { @ if (ddRe.signedImage) n va ac th si 66 { winWidth = maxPixelValue - minPixelValue; } if ((winCentre == 0) || (minPixelValue > winCentre) || (maxPixelValue < winCentre)) { winCentre = (maxPixelValue + minPixelValue) / 2; lu } an imagePanelControl3.Signed16Image = ddRe.signedImage; va imagePanelControl3.SetParameters(ref px16, imageWidth, n tn to imageHeight, winWidth, winCentre, true, this); gh p ie } d oa nl w nf va an lu z at nh oi lm ul z m co l gm @ an Lu n va ac th si