Thông báo

Collapse
No announcement yet.

Xin giúp đỡ về bộ lọc tuyến tính ( linear filter )

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • Xin giúp đỡ về bộ lọc tuyến tính ( linear filter )

    Chào các bạn, anh chị trong diễn đàn, mình đang tìm hiểu về Xử lý ảnh bằng C#. Mình có đọc 1 số tài liệu về XLA và đang bị đứng ở kiến thức bộ lọc tuyến tính, dưới đây mình có 1 source code của người ta nhưng mình không hiểu ý tưởng của họ.
    Trong lý thuyết mình đọc thì lọc tuyến tính người ta sử dụng nhân kernel, trong source này họ cũng dùng nhân kernel, họ dùng 1 biến là Mask (mặt nạ), nhưng mình ko hiểu được ý tưởng của họ, mong đuọc mọi người giúp đỡ !
    Code:
    public override void Apply(Bitmap img) 
    		{
    			float[] ra = new float[w];
    			float[] rb = new float[w];
    			float[] ca = new float[h];
    			float[] cb = new float[h];
    			float sx, sy, sxy, sxx;
    			int n;
    			float p;
    			// for rows :
    			for(int l=0; l<w;l++)  
    			{
    				n=0; sx = 0; sy = 0; sxy = 0; sxx = 0;
    				for(int c=0; c<h;c++) 
    				{
    					if (mask[l][c] == 1) 
    					{
    						sx += c; 
                                                    sxx += c * c;
    						p = img.GetPixel(l,c).R;
    						sy += p; 
                                                    sxy += p*c;
    						n++;
    					}
    				}
    				ra[l] = (n*sxy - sx*sy)/(n*sxx - sx*sx);
    				rb[l] = sy/n - ra[l] * sx/n;
    			}
    			//for columns
    			for(int c=0; c<h;c++) 
    			{
    				n=0; sx = 0; sy = 0; sxy = 0; sxx = 0;
    				for(int l=0; l<w;l++)  
    				{
    					if (mask[l][c] == 1) 
    					{
    						sx += l; sxx += l * l;
    						p = ra[l] * c + rb[l]; // c ou l ?
    						sy += p; sxy += p*l;
    						n++;
    					}
    				}
    				ca[c] = (n*sxy - sx*sy)/(n*sxx - sx*sx);
    				cb[c] = sy/n - ca[c] * sx/n;
    			}
    			// apply on img : -- Douteux
    			int g;
    			for(int l=0; l<w;l++)  
    				for(int c=0; c<h;c++) 
    				{
    
    					g = img.GetPixel(l,c).R;
    					g = g - (int)(ca[c] * l + cb[c])+128;
    		
    					if (g<0) g = 0;
    					if (g>255) g = 255; 
    					img.SetPixel(l,c,Color.FromArgb(g, g, g));
    		
    				}
    		}
    	}

Về tác giả

Collapse

SkyAndOcean Tìm hiểu thêm về SkyAndOcean

Bài viết mới nhất

Collapse

  • nguyendinhvan
    Trả lời cho Vấn đề về tốc độ quay
    bởi nguyendinhvan
    Sử dụng động cơ servor, hoặc lắp thêm một cái encoder vào động cơ bước. Encoder sẽ kiểm soát động cơ có quay hoặc đứng im.
    Hôm qua, 19:50
  • Andrea14
    Vấn đề về tốc độ quay
    bởi Andrea14
    Chào mọi người,

    Tôi muốn mô phỏng sự thay đổi các mùa bằng cách từ từ nghiêng một quả địa cầu 16 inch bằng một động cơ bước nhỏ. Một động cơ bước khác sẽ quay quả địa cầu theo thời gian thực. Hệ thống truyền động...
    12-12-2025, 12:42
  • bqviet
    Trả lời cho Đấu tắt điện cho máy tính bảng
    bởi bqviet
    Bqv cáo lỗi vì chưa đủ khả năng diễn giải để người đọc hiểu. Người làm kỹ thuật sâu đôi khi như thế đó. Về việc nạp pin không vào dù cell mới, khả năng cái mạch quản lý đó đã hỏng - cũng chính là nguyên nhân đám cell cũ hỏng từ đầu.
    06-12-2025, 17:17
  • nguyendinhvan
    Trả lời cho Xin hỏi về mạch thu FM/AM trong catsette
    bởi nguyendinhvan
    Theo tôi, nó chỉ là cái Tuy- ê - nơ, hoặc là khối Trung Văn Tần, nó một phần trong cái Da đì ô thôi. Vì có thấy một chỗ có ba chân hàn, giiống như chân Cờ rít sờ tăng 455 ki nô hẹc. Còn khối Tuy ê nơ thì không nhìn thây cái Di ốt Va di cáp...
    05-12-2025, 19:59
Đang tải...
X