Thông báo
Collapse
No announcement yet.
Hobby project ... FFT/IFFT
Collapse
X
-
Okie. Hiện giờ Jeff cũng tịt về FFT. Mọi người cùng nghiên cứu.
Schedule của project như sau:
- Nghiên cứu (lại) FFT/IFFT - 4 tuần
- Nghiên cứu các cấu trúc để thực hiện FFT 4 tuần.
- Specifications + Thiết kế các khối 2 tuần.
- Thực hiện thiết kế + test:
+ 16 point : 2 tuần
+ 256 point: 2 tuần
+ 1k point: 3 tuần
+ 8k point : 3 tuần
+ 32k point: 4 tuần
- Nhìn sơ sơ, mất tổng cộng 6 tháng.
Mình dừng ở 32k Point vì nếu không lầm thì các công cụ Altera và Xilinx chưa support. Và sẽ cần FPGA khá bự để chứa cái core này.
Anh em, mình làm tà tà
.
Bắt đầu bằng việc nghiên cứu lý thuyết FFT.
Comment
-
FFT có khá nhiều ứng dụng, hầu như những ai thuộc lĩnh vực điện tử đều từng nghiên cứu môn học xử lý tín hiệu số. Tham số quan trọng nhất khi chọn thiết kế FFT là số điểm FFT và tốc độ luồng dữ liệu.
Thực chất FFT là thực hiện nhiệm vụ quan sát phổ tín hiệu trong băng tần số, cho phép đánh giá cường độ tín hiệu (hay năng lượng) tại điểm quan sát.
FFT thực hiện phân dải tín hiệu thành các băng tần, do đó tiện lợi cho các bộ lọc phía sau. Khi kết hợp với các bộ lọc thì nó sẽ trở thành từng băng lọc rất hữu ích, giảm đi nhiệm vụ nặng nề cho các bộ lọc khi hệ thống chỉ sử dụng các bộ lọc đơn thuần.
Tài liệu kèm theo hy vọng hữu ích cho các bạnAttached Files
DSP, Embedded System, FPGA/MCU boards & Kits
Comment
-
Không chắc có hiểu đúng ý chữ " in place " của anh ko.Nguyên văn bởi tonyvandinh Xem bài viếtJeff định làm về "in place" hay pipeline?
Em hiểu "in place" là làm FFT theo đúng như butterfly dataflow của nó. Nếu vậy thì làm cho mấy FFT lớn mất nhiều resource quá.
Do vậy chắc là phải làm pipeline mới scalable (=có thể mở rộng được).
Comment
-
Khi làm những FFT lớn, thường thì dùng lại những cấu trúc cho từng bước để giảm cost và vì vậy cần phải có chỗ chứa (storage) chẳng hạn như RAM. Những samples sẽ được chứa vô RAM trước rồi đọc ra, process và viết trở lại vô RAM. Kỹ thuật này gọi là "in place". Còn pipeline thì phải có chỗ chứa ở mỗi bước và không dùng lại butterfly (khối radix) để tăng tốc độ nhưng rất là tốn kém.Nguyên văn bởi jefflieu Xem bài viếtKhông chắc có hiểu đúng ý chữ " in place " của anh ko.
Em hiểu "in place" là làm FFT theo đúng như butterfly dataflow của nó. Nếu vậy thì làm cho mấy FFT lớn mất nhiều resource quá.
Do vậy chắc là phải làm pipeline mới scalable (=có thể mở rộng được).
Comment
-
Bạn nào có hứng thú để dùng systemC thì nên theo cái tutorial ở dưới đây để làm quen nhe. Nếu cần tôi sẽ hướng dẫn thêm.Nguyên văn bởi jefflieu Xem bài viếtDự tính là sau khi nghiên cứu xong lý thuyết với mấy cấu trúc người ta đã làm, thì sẽ mô phỏng bằng SystemC và SystemVerilog thử.
Bạn nào hứng thú thì nghiên cứu phụ SystemC/SystemV nhé
http://www.dientuvietnam.net/forums/...ad.php?t=34991
Comment
-
Òh, vậy Jeff tính làm pipelined ... khá nhiều bài báo suggest pipeline để tăng tốc độ, nhưng cũng dùng lại khối Butterfly. Các khối butterfly ở mỗi bước của FFT được dùng lại.Nguyên văn bởi tonyvandinh Xem bài viếtKhi làm những FFT lớn, thường thì dùng lại những cấu trúc cho từng bước để giảm cost và vì vậy cần phải có chỗ chứa (storage) chẳng hạn như RAM. Những samples sẽ được chứa vô RAM trước rồi đọc ra, process và viết trở lại vô RAM. Kỹ thuật này gọi là "in place". Còn pipeline thì phải có chỗ chứa ở mỗi bước và không dùng lại butterfly (khối radix) để tăng tốc độ nhưng rất là tốn kém.
Người ta lý luận là mỗi clock chỉ có 1 sample mới, cho nên mỗi clock chỉ cần produce 1 output, dẫn đến việc có thể schedule các operation ở mỗi stage vào 1 khối Butterfly phần cứng duy nhất.
Nhưng để schedule như vậy cũng tốn RAM để buffer output của stage trước và output của stage sau.
Để Jeff nghiên cứu thêm.
(bạn nào cần các bài báo để nghiên cứu thì email Jeff)
Comment
-
Hm! Mình chưa hình dung ra được là họ dùng cách nào để dùng lại khối butterfly cho pipeline design, Ví dụ cái FFT cần 3 stages để hoàn tất. Cái hình đính kèm cho thấy làNguyên văn bởi jefflieu Xem bài viếtÒh, vậy Jeff tính làm pipelined ... khá nhiều bài báo suggest pipeline để tăng tốc độ, nhưng cũng dùng lại khối Butterfly. Các khối butterfly ở mỗi bước của FFT được dùng lại.
Người ta lý luận là mỗi clock chỉ có 1 sample mới, cho nên mỗi clock chỉ cần produce 1 output, dẫn đến việc có thể schedule các operation ở mỗi stage vào 1 khối Butterfly phần cứng duy nhất.
Nhưng để schedule như vậy cũng tốn RAM để buffer output của stage trước và output của stage sau.
Để Jeff nghiên cứu thêm.
(bạn nào cần các bài báo để nghiên cứu thì email Jeff)
* stage1 : nhận đường vào, làm butterfly
* stage2 : làm butterfly
* stage3 : làm butterfly rồi cho ra.
Cứ liên tục như vậy cho những clock (transaction) sau. Như vậy thì từ thời điểm C trở đi (C cũng còn được gọi là latency , mối ra đầu tiên), cần có tới 3 butterfly liền một lúc,
Jeff nghĩ sao? Nếu Jeff có thể cho cái link, mình sẽ nghiên cứu và cho Jeff biết là họ có thể thực hiện như nói ở trên.
Tony
Comment
-
tôi thấy là phải chọn thuật toán trước.
Khi học môn Xử lý tín hiệu số 2, tôi có hỏi thầy về FFT, thì thầy tôi nói là phổ biến nhất vẫn là FFT radix 2 hoặc radix 4. vì các kiến trúc này đối xứng (cũng khá quan trọng), và tôi thấy là có thể dùng lại được butterfly của DFT 2 điểm. Tuy nhiên cấu trúc điền khiển sẽ phức tạp.
Nếu đã chọn được kiến trúc rồi, thì tôi nghĩ có thể biểu diễn thuật toán bằng C++, sau đó phân chia các khối chức năng và điều khiển sử dụng SystemC.
Thiết kế SystemC có thể coi như một reference design. Testbench của SystemC có thể dùng lại được, nhưng khi đó sẽ cần các công cụ hỗ trợ đồng mô phỏng có license như Modelsim SE, VCS v.v....
Comment
-
Bạn có thể cho một ví dụ đơn giản về cách dùng lại butterfly mà vẫn cho vào 1 sample và cho ra 1 sample mỗi clock. Sample ở đây là toàn bộ mọi điểm của FFT. Cám ơn bạn trướcNguyên văn bởi cation_h Xem bài viếtKhi học môn Xử lý tín hiệu số 2, tôi có hỏi thầy về FFT, thì thầy tôi nói là phổ biến nhất vẫn là FFT radix 2 hoặc radix 4. vì các kiến trúc này đối xứng (cũng khá quan trọng), và tôi thấy là có thể dùng lại được butterfly của DFT 2 điểm. Tuy nhiên cấu trúc điền khiển sẽ phức tạp.
Comment
-
Ý Jeff là dùng lại cho mỗi stage:Nguyên văn bởi tonyvandinh Xem bài viếtHm! Mình chưa hình dung ra được là họ dùng cách nào để dùng lại khối butterfly cho pipeline design, Ví dụ cái FFT cần 3 stages để hoàn tất. Cái hình đính kèm cho thấy là
* stage1 : nhận đường vào, làm butterfly
* stage2 : làm butterfly
* stage3 : làm butterfly rồi cho ra.
Cứ liên tục như vậy cho những clock (transaction) sau. Như vậy thì từ thời điểm C trở đi (C cũng còn được gọi là latency , mối ra đầu tiên), cần có tới 3 butterfly liền một lúc,
Jeff nghĩ sao? Nếu Jeff có thể cho cái link, mình sẽ nghiên cứu và cho Jeff biết là họ có thể thực hiện như nói ở trên.
Tony
Ví dụ 8-point FFT : mỗi stage có 4 phép tính butterfly, tổng cộng có 12 phép tính butterfly.
Nhưng có thể dùng 1 khối Butterfly cho mỗi stage --> mất 3 khối Butterfly tất cả.
--> cho N-point FFT thì cần log2(N) khối butterfly và một số RAM(theo tính toán của J thì mất 1.5xN-word RAM tất cả) để buffer giữa các stage.
Jeff làm thử với 8 điểm thì có vẻ làm được không bị resource conflict.
Source, phần systolic architecture:
http://www.ll.mit.edu/HPEC/agendas/p...ed/jackson.pdf
Comment
Về tác giả
Collapse
Bài viết mới nhất
Collapse
-
bởi hayarNăm 2026 việc chọn laptop gaming chủ yếu vẫn là cân bằng vì giá cả và phần cứng thay đổi liên tục, nên tập trung vào GPU ổn, tản nhiệt tốt và hiệu năng thực tế sẽ quan trọng hơn việc chạy theo cấu hình cao nhất, giống như trong nulls brawl, chơi hay hơn khi biết cách tối ưu và chọn chiến...
-
Channel: Đánh giá sản phẩm DTVN
Hôm qua, 21:23 -
-
bởi theidiotcatDưới đây là một số gợi ý để các bạn sinh viên chọn được chiếc laptop phù hợp với nhu cầu, ngân sách và ngành học trong bối cảnh giá linh kiện leo thang kéo theo mức giá laptop liên tục tăng cao.
Bước vào mùa tựu trường năm...-
Channel: Đánh giá sản phẩm DTVN
30-06-2026, 11:26 -
-
bởi theidiotcatAMD Ryzen 9 9950X bước sang năm 2026 vẫn là một trong những bộ vi xử lý desktop mạnh mẽ nhất dành cho người dùng phổ thông cao cấp. Dù đã ra mắt từ thế hệ Zen 5 đầu tiên của dòng Ryzen 9000, con chip 16 nhân 32 luồng này vẫn giữ được sức...
-
Channel: Đánh giá sản phẩm DTVN
29-06-2026, 13:58 -
-
bởi theidiotcatTrong thị trường CPU năm 2026, khi các dòng vi xử lý đời mới liên tục ra mắt với những thông số kỹ thuật hào nhoáng, AMD Ryzen 5 7600X vẫn là một cái tên khiến nhiều game thủ và người dùng phổ thông phải cân nhắc kỹ lưỡng. Sau gần hai...
-
Channel: Đánh giá sản phẩm DTVN
29-06-2026, 13:42 -
-
bởi theidiotcatTrong bối cảnh giá linh kiện tăng cao, hiện tại mức giá laptop đã tăng đáng kể so với thời điểm trước cơn sốt AI. Chính vì vậy để lựa chọn được một chiếc laptop đáp ứng tốt nhu cầu vừa học vừa giải trí các bạn sinh viên cần...
-
Channel: Đánh giá sản phẩm DTVN
29-06-2026, 13:33 -
-
bởi theidiotcatViệc lựa chọn một chiếc laptop gaming phù hợp với nhu cầu, ngân sách chưa bao giờ là dễ dàng. Và điều đó càng khó hơn trong năm 2026 khi mà mức giá liên tục tăng.
Nếu bạn chưa biết nên chọn một chiếc laptop gaming như thế nào...-
Channel: Đánh giá sản phẩm DTVN
26-06-2026, 10:29 -
-
bởi theidiotcatVới mức ngân sách 20 - 30 triệu đồng trong năm 2026, các bạn sinh viên và dân văn phòng có thể tìm thấy nhiều lựa chọn cao cấp, mạnh mẽ, pin “trâu”, đặc biệt là các mẫu laptop AI hỗ trợ cho học tập và làm việc.
Trong phân...-
Channel: Đánh giá sản phẩm DTVN
26-06-2026, 10:25 -
-
bởi theidiotcatDưới đây là một số mẫu laptop nổi bật trong phân khúc dưới 20 triệu giúp các bạn văn phòng, sinh viên và đặc biệt là tân sinh viên có thể dễ dàng lựa chọn được mẫu laptop phù hợp với nhu cầu và ngân sách của mình.
Thị...-
Channel: Đánh giá sản phẩm DTVN
26-06-2026, 10:07 -
-
bởi theidiotcatViệc chọn mua một bộ máy tính phục vụ cho các nhu cầu làm việc văn phòng và sử dụng cơ bản hàng ngày đang trở nên dễ dàng và tiết kiệm hơn bao giờ hết. Thay vì phải đau đầu trích ngân sách để mua cả vi xử lý lẫn card đồ họa rời...
-
Channel: Đánh giá sản phẩm DTVN
25-06-2026, 11:23 -

...
Comment