Để hướng tới các project to hơn, em xin lập threat mới (theo sự động viên của bác Tony). Nếu bạn nào quan tâm xin mời tham gia. Rất mong nhận được ý kiến của mọi người
Thông báo
Collapse
No announcement yet.
Project nhỏ: Bộ lọc số FIR thực hiện bằng FPGA
Collapse
This is a sticky topic.
X
X
-
Tiêu chuẩn của thiết kế Generic Ultra-speed FIR Filter
Em xin lấy tiêu chuẩn thiết kế của zipcores http://www.zipcores.com/generic-ultra-speed-fir-filter.html như sau:
General Description
FIR filter designed for very high sample rate applications. Organized as a systolic array, the filter is modular and scalable, permitting the user to specify large order filters without compromising maximum attainable clock-speed. The design is fully generic, with configurable coefficients, data width and number of taps.
Key Design Features
- Systolic array for speed and scalability
- Configurable coefficients
- Configurable data width
- Configurable number of taps
- Symmetric arithmetic rounding
- Output saturation or wrap modes
- FPGA sample rates in excess of 550 MHz
-
Hi Cá Chep,
"Dự án nhỏ" của bạn với yêu cầu trên thật ra không nhỏ tí nào. Mình xin đưa ra một vài chỉ tiêu cơ bản về bộ lọc FIR nha:
- Độ rộng của ngỏ vào có thể cài đặt theo người sử dụng (dùng parameter) tối đa là 32 bit (cái này tùy bạn thôi)
- Độ rộng của ngõ ra có thể cài đặt theo người sử dụng + có thể làm tròn lên, xuống, không làm tròn hay độ rộng lớn nhất (Full)
- Bậc của bộ lọc tối đa là 1024.
- Có thể tùy chọn dùng Register hay dùng RAM trong cấu trúc phần cứng (Cái này có thể tham khảo)
- Có khả năng tối ưu cấu trúc dựa vào sự chên lệch giữa tốc độ mẫu và tốc độ cung cấp cho IP (ví dụ tốc độ clock gấp 3 lần tốc độ lấy mẫu)
- Có khả năng tối ưu theo thông số bộ lọc: đối xứng, lọc 1/k băng thông
- Có khả năng nạp lại hệ số (hiện tại cái này thì chưa cần thiết)
- Tần số lấy mẫu tối đa là 27MHz. Còn tần số hoạt động của IP thì tùy bạn có thể là 100 - 200MHz
- Khi nào làm xong cái đó thì hãy nghĩ đến xử lí đa kênh
Những điều kiện trên chỉ mang tính tham khảo bạn có thể chọn để làm nha. Chúc bạn thành công
.^_^.
Comment
-
Tôi cũng xin đề nghị là chưa nên làm cách thức "systolic array" ngay từ đầu vì nó sẽ giới hạn vô một cấu trúc riêng biệt cho tốc độ mà thôi. Những tiêu chuẩn khác có thể giữ như trên để mọi người cùng tham khảo về lợi hại của mỗi tiêu chuẩn.
Mặc dù project này có thể làm bằng một người nhưng tôi xin mọi người cùng đóng góp để thiết kế. Có làm sai mới học hỏi được nhiều. Ăn thua là ở tinh thần cầu tiến.
Xin Chào
Comment
-
Nguyên văn bởi tonyvandinh Xem bài viết
Mặc dù project này có thể làm bằng một người nhưng tôi xin mọi người cùng đóng góp để thiết kế. Có làm sai mới học hỏi được nhiều. Ăn thua là ở tinh thần cầu tiến.
Mong mọi người tiếp tục cho ý kiến ạ!!!
Comment
-
Design space nên dịch là gì nhỉ?
Như bạn danbeo85 đã đề ra: design space khá là rộng ... bạn cá chép nên hiểu khá khá phần lý thuyết về FIR trước rồi tiến hành HDL design.
Bạn danbeo85 có đề cập:
- Có khả năng tối ưu theo thông số bộ lọc: đối xứng, lọc 1/k băng thông
....
- Tần số lấy mẫu tối đa là 27MHz. Còn tần số hoạt động của IP thì tùy bạn có thể là 100 - 200MHz
- Khi nào làm xong cái đó thì hãy nghĩ đến xử lí đa kênh
Cho mình hỏi "lọc 1/k băng thông" nghĩa là gì? ... tại sao tần số lấy mẫu tối đa là 27MHz? ... còn xử lý đa kênh nghĩa là gì? ... có phải polyphase ko?
Thanks.
Comment
-
Hi, jefflieu
Mình xin giải nghĩa một số từ trên:
- 1/k băng thông là sai. Băng thông bằng 1/k fs/2 thì đúng hơn. Lấy một ví dụ nếu bạn dùng một bộ lọc FIR thông thấp lấy 1/2 của fs/2, bạn sẽ có một tập hợp các hệ số của bộ lọc mà trong đó sẽ có giá trị 0 được lặp lại theo một quy luật. Mà trong tính toán thì chúng ta không cần lưu những hệ số này vì nó không cần thiết (trong trường hợp không cần nạp lại các hệ số khi hệ thống đang chạy).
- Mình lấy tín hiệu mẫu cao nhất là 27MHz chỉ là ngẫu nhiên (random) thôi không có gì hết
- Còn xử lí đa kênh có nghĩa là do cấu trúc FIR của bạn có thể xử lí nhiều tin hiệu ngõ vào liên tục (và các tín hệu này cần dùng chung một tập hợp hệ số bộ lọc). Bạn có thể tham khảo chức năng này trong FIR IP của Altera và Xilinx.
Mình hi vọng câu trả lời này sẽ làm rõ nghĩa thêm yêu cầu của đề tài.
,^_^.
Comment
-
Như bạn danbeo đã nêu ra, rất rất nhiều option cần phải để tâm khi thiết kế.
Theo mình thấy specifications quan trọng nhất của bô lọc FIR:
- Độ rộng của tín hiệu và các hệ số vào phải là parameter nghĩa là re-configurable. Điều này ảnh hưởng trực tiếp đến khả năng của bộ lọc.
Các yếu tố còn lại:
- Bậc của FIR : mình nghĩ bạn có thể cố định cho nó trước rồi sau này cải tiến cho nó configurable.
Có thể bắt đầu bằng 8-tap, rồi phát triển lên.
- Độ rộng của ngõ ra, đơn giản nhất là Full-precision, không bỏ bớt bit nào hết.
- Chênh lệch giữa tốc độ lấy mẫu và tốc độ của IP. Để đơn giản hóa bạn có thể bắt đầu bằng tốc độ lấy mẫu = tốc độ của mạch
Về cấu trúc của mạch FIR, mình search trên mạng thì thấy có 3 dạng cơ bản sau (và rất nhiều dạng phức tạp từ các bài báo khoa học khác)
Comment
-
Bộ lọc FIR 8 taps
@cachep, bạn có ý định gì về FIR chưa? Thôi để mình gồng mình lên làm mẫu trước nhé.
1) 8 TAPS - có thể đổi được
2) Độ rộng (8 bit integer, có thể đổi được)
3) Coefficient - Truyền từ ngoài vô (programmable)
4) Register base cho shift registers.
Đính kèm là systemC model với test bench. Mô hình này sẽ nhận 1 sample và cho ra 1 sample cho mỗi clock. Nhân của FIR là untime model. Tùy theo tiêu chuẩn, nhân nên đổi ra time model với cấu trúc chỉ tiêu.
Các bạn có thể theo cái link dưới đây để lấy chỉ dẫn thêm về systemC.
http://www.dientuvietnam.net/forums/...729#post253729
Chúc các bạn nghiên cứu vui vẻ và đóng góp.
TonyAttached FilesLast edited by tonyvandinh; 16-04-2010, 04:55.
Comment
-
Nguyên văn bởi tonyvandinh Xem bài viết@cachep, bạn có ý định gì về FIR chưa? Thôi để mình gồng mình lên làm mẫu trước nhé.
1) 8 TAPS - có thể đổi được
2) Độ rộng (8 bit integer, có thể đổi được)
3) Coefficient - Truyền từ ngoài vô (programmable)
4) Register base cho shift registers.
Đính kèm là systemC model với test bench. Mô hình này sẽ nhận 1 sample và cho ra 1 sample cho mỗi clock. Nhân của FIR là untime model. Tùy theo tiêu chuẩn, nhân nên đổi ra time model với cấu trúc chỉ tiêu.
Các bạn có thể theo cái link dưới đây để lấy chỉ dẫn thêm về systemC.
http://www.dientuvietnam.net/forums/...729#post253729
Chúc các bạn nghiên cứu vui vẻ và đóng góp.
Tony
bác Tony ở em mới chỉ ngâm cứu vhdl thôi. bác có thể viết nó với ngôn ngữ vhdl dc k ạ?
thanks bác trước!
Comment
-
Nguyên văn bởi robocon2011 Xem bài viếtbác Tony ở em mới chỉ ngâm cứu vhdl thôi. bác có thể viết nó với ngôn ngữ vhdl dc k ạ?
thanks bác trước!Không có việc gì khó,
chỉ sợ lòng không bền!
Comment
-
Một vài góp ý vế FIR filter implementation:
- Thông thường thì bạn cần analyze filter requirements (ripple characteristics, response) để derive number of taps và filter data width cần thiết.
- Hardware platform: design sẽ chạy trên FPGA nào, và realistically, maximum attainable / target clock rate của design là bao nhiêu?
- Number of taps, output data rate, và design clock rate ảnh hưởng đến cấu trúc của filter --> cần dùng maximum number of multipliers hoặc có thể share resource? Design clock rate x number of multipliers cần phải > output data rate x number of taps. (Chẳng hạn như resampling FIR filter, input data rate không quan trọng, chỉ ăn thua ở output data rate).
- Với một design thật sự, scalability rất quan trọng, chẳng hạn như dùng generate để tùy ý thay đổi number of multipliers từ 1 đến N. Support data / filter data width khác nhau dễ dàng thực hiện hơn, như dùng parameters đã được đề cập đến, hoặc dùng unconstrained ports.
- Trước tiên bạn nên tạo ra một fixed-point mathematical model với Matlab hoặc Numerical Python. Dù FIR filter hơi đơn giản một chút, nhưng bạn sẽ verify design của bạn như thế nào? Bạn nên đạt được bit-exact match giữa model và simulation/hardware output. Với algorithm khó hơn một chút như Cholesky decomposition, QR decomposition hoặc SVD decomposition, bạn không thể bỏ qua phần modeling được.
Comment
Bài viết mới nhất
Collapse
-
Trả lời cho Hỏi về test hipot cao ápbởi nguyendinhvanCách nghĩ của bạn là theo duy tâm thôi. Còn trong công việc thì phải theo duy lý.
Bạn vào goggle và gõ từ : tiêu chuẩn an toàn cách điện.
Bạn sẽ thấy vô vàn các quy định, VN cũng có , quốc tế cũng có. Mỗi vùng , mỗi khu vực,...-
Channel: Điện tử dành cho người mới bắt đầu
02-11-2024, 20:04 -
-
bởi lamvu0677Chào mọi người, ai làm về điện, đặc biệt biến áp xung, mâý con nho nhỏ gắn vào mạch nguồn, cho e hỏi tí ą, e cũng làm trong ty về biển áp thì đo kiểm thành phẩm sẽ kiểm cao áp, tức là kiểm xem có phóng điện giữa các cuộn dây với...
-
Channel: Điện tử dành cho người mới bắt đầu
01-11-2024, 21:05 -
-
bởi AaaabbbbbEm chào các anh chị ,cô chú . Em đang có 1 đề tài: Mô phỏng điều khiển động cơ 1 chiều và bộ điều khiển điện áp tự động (AVR) sử dụng MATLAB/Simulink và Arduino . Anh chị có thế giải thích hoặc định hướng giúp em với được không ạ . Em xin cảm ơn !!...
-
Channel: Vi điều khiển AVR
30-10-2024, 16:38 -
-
bởi 2embeyeuem mới nhập môn, bác nào có sơ đồ của mạch này và cách cắm mạch trên panel cho em xin với, em cảm ơn ạ
-
Channel: Điện tử dành cho người mới bắt đầu
30-10-2024, 15:52 -
-
bởi dqt21091997Hi mọi người,
Team mình hiện là đối tác phân phối cho 1 dịch vụ Proxy US chuẩn bị mở mang tên Proxy Compass. Mọi người có thể trải nghiệm ở đây: https://proxycompass.com/vi/free-trial/
Điểm mạnh của Proxy Compass là:
- 50 địa chỉ IP proxy
...-
Channel: Tổng quan về ngành viễn thông
30-10-2024, 14:46 -
-
Trả lời cho Thắc mắc về kiến thức điện xoay chiềubởi SteinsKMình nhớ là do điện AC không có chia cực cố định như DC, thêm vào đó thì ổ điện loại mà 2 lỗ thì cũng không có phân biệt chiều cắm, thành ra mình cắm chiều nào cũng được. Đây là em hiểu như vậy, có bác nào có ý kiến khác không ạ....
-
Channel: Điện tử dành cho người mới bắt đầu
30-10-2024, 09:57 -
-
bởi tivungvechào mọi người, em là sinh viên mới tìm hiểu về điện em có thắc mắc là tại sao điện AC ở nhà dùng có phích cắm khi cắm vào ổ điện thì cắm chiều nào cũng được, mà em đọc trên mạng thấy điện AC có dây trung tính và dây pha mà nhỉ...
-
Channel: Điện tử dành cho người mới bắt đầu
27-10-2024, 14:25 -
Comment