Ai tốt bụng test thêm giùm đi hoặc có cách nào test chuyên nghiệp hơn ko?
Thông báo
Collapse
No announcement yet.
Hobby project ... FFT/IFFT
Collapse
X
-
Jeff kỳ này viết systemC hết xẩy rồi. Khi nào xét nghiệm xong ở floating point model rồi thì dùng systemC data type để chuyển qua bit accurate model nhe.
Jeff thử dùng header file để làm typedef thì sau này chuyển qua data type khác sẽ dễ dàng hơn. Ví dụ
// typedef.h
#ifndef BIT_ACCURATE
typedef float my_data_t;
#else
typedef sc_fixed<64,32> my_data_t;
#endif
Dùng my_data_t ở những chỗ dùng float. Thêm typedef nếu cần.
Chúc thành công
TonyLast edited by tonyvandinh; 25-05-2010, 07:28.
Comment
-
Nguyên văn bởi tonyvandinh Xem bài viếtJeff kỳ này viết systemC hết xẩy rồi. Khi nào xét nghiệm xong ở floating point model rồi thì dùng systemC data type để chuyển qua bit accurate model nhe.
Jeff thử dùng header file để làm typedef thì sau này chuyển qua data type khác sẽ dễ dàng hơn. Ví dụ
// typedef.h
#ifndef BIT_ACCURATE
typedef float my_data_t;
#else
typedef sc_fixed<64,32> my_data_t;
#endif
Dùng my_data_t ở những chỗ dùng float. Thêm typedef nếu cần.
Chúc thành công
Tony
Uhm, okie a. Em đang tính coi cái phần fixed-point này chứ viết kiểu integer hơi mệt. Thanks.
Comment
-
-
Đã chuyển sang mô phỏng với Fixed-point
Phương pháp kiểm tra và so sánh kết quả khi thay đổi độ rộng của input (bitwidth):
- Dùng Matlab tạo 1 chuỗi số nguyên random từ 0 tới 3, cái này dùng làm data, dùng hàm qammod để tạo số phức biểu diễn data ở dạng constellation:
X(k) = a+ bi, a, b = +/-1
- Dùng Matlab tạo ifft từ chuỗi X(k) ... W=ifft(x) ... rồi in mảng W ra file.
- Khi dùng SystemC chạy mô phỏng FFT, output sẽ được mảng Y, đem Y so sánh với mảng ban đầu X.
- Sai số giữa Y và X được đánh giá bằng thông số MER (modulation error ratio), trong đó:
ERROR = \sum_{}^{k} |Y(k)-X(k)|^2
SIGPOW=mean(|X(k)|^2)
MER = 10log10(SIGPOW/ERROR)
Kết quả:
Với 16bit twiddle factor:
Input Bit MER(dB)
8 | 27.38
9 | 33.40
10 | 39.21
11 | 45.14
12 | 51.16
13 | 57.22
14 | 63.24
Sai số này là do quá trính tính toán bằng số fixed-point (quantization noise)... Kết quả này khá khớp với công thức: "thêm 1 bit sẽ tảng thêm khoảng 6dB "Last edited by jefflieu; 05-06-2010, 02:23.
Comment
-
Nguyên văn bởi jefflieu Xem bài viếtMắc kẹt chỗ này gần 1 tháng rồi.
Vừa bận vừa bí thiết kế chỗ Block Floating Point.
Haiz. Ai có cao kiến gì hok?
Chúc Jeff thành công.
Comment
-
Nguyên văn bởi tonyvandinh Xem bài viếtJeff thử "profile" mấy variables mà chuyển từ floating to fixed point để xem sai số ở chỗ nào. Để profile cho một variable, thì chạy simulation rồi dùng printf để viết tất cả giá trị ra bài. Sau đó dùng excel để sort là sẽ biết minimum và maximum và từ đó có thể quyết đoán độ dài (bit width, cho nguyên và phân số, etc ), .
Nhưng nếu tăng bitwidth lên như vậy sẽ mất nhiều memory bit.
Phương pháp block-floating-point là dùng fixed point + một số gọi là exponent (khác biệt với dùng số float là, số exponent này được dùng chung cho 1 stage, tức là mọi số sẽ được scale với cùng 1 số exponent).
Vấn đề là làm sao biết được max, min trong lúc chạy (run-time) để scale cho phù hợp.
Khi chuyển qua fixed point, cũng nên để ý tới "overflow" mode (by default, thường ở mode wrap over). Chuyển qua saturation có thể bị ít sai số hơn.
Comment
-
Nguyên văn bởi jefflieu Xem bài viếtVấn đề là làm sao biết được max, min trong lúc chạy (run-time) để scale cho phù hợp.
Comment
-
Nguyên văn bởi tonyvandinh Xem bài viếtNhư đã đề cập trước, nếu in (dùng fprintf) tất cả giá trị trong khi chạy simulation (run time) và khi variable còn ở float rồi dùng excel để xếp thứ tự (sorting) thì sẽ biết được min và max trong testcase đó.
Comment
Về tác giả
Collapse
Email minh trực tiếp nếu bạn cần download tài liệu gấp
Tìm hiểu thêm về jefflieu
Bài viết mới nhất
Collapse
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi vi van phamKhông thể đổ lỗi cho không biết nhạc lý. Nhắm mắt lại gõ vào chương trình viết nhạc, phần mềm vẫn tạo ra giai điệu.
Phần mềm chia nốt đen cho trường canh không sai. Cái sai ở đây là cháu không phân biệt phách mạnh, yếu để tạo nhịp thuận....-
Channel: Tâm tình dân kỹ thuật
05-06-2024, 10:35 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Dạ là vì tác giả không có căn bản nhạc lí nên cái sheet đó chắc hẳn sẽ sai về qui cách biểu thị, và đó chỉ là thể hiện các nốt nhạc như trên piano vậy, phần mền nó vẫn chạy ra am thanh giai điệu được....
-
Channel: Tâm tình dân kỹ thuật
05-06-2024, 08:46 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi vi van phamTôi không hiểu ý tác giả thế nào, khi shhet nhac không đúng làm sao có giai điệu?
Khi hát, hay chơi đàn, ca sĩ hoặc nhạc công giẫm chân để giữ nhịp, cap cấp hơn trong organ có cả máy metronom để giữ nhịp. Tác giả sáng tác toàn nhịp chỏi, rất khó hát và khó giữ nhịp....-
Channel: Tâm tình dân kỹ thuật
04-06-2024, 16:28 -
-
bởi jack22Tôi có một chiếc máy in Anet A6 cũ ở đây, chiếc máy in này tôi đã dần dần chuyển đổi thành bản sao Prusa MK3. Chỉ có động cơ bước và trục là Anet nguyên bản. Mặc dù đã có nhiều cải tiến và chất lượng in khá tốt nhưng vẫn có những...
-
Channel: Điện tử dành cho người mới bắt đầu
04-06-2024, 16:02 -
-
bởi pia2k1Chạy nhiều thì nó nóng thui
-
Channel: Điện tử dành cho người mới bắt đầu
04-06-2024, 11:48 -
-
Trả lời cho Lý luận về hướng phát triển thị trườngbởi pia2k1Lý luận là thế nhưng sẽ còn tùy thuộc vào hiện trạng nữa....
-
Channel: Xu hướng, nhu cầu và thị trường
04-06-2024, 11:09 -
-
Trả lời cho Yêu thơ mê nhạc, mời các bác vào đây!bởi dinhthuong92Chỉ ngân dài từ ơn thôi bác, không thay đổi nhạc là mấy ...
-
Channel: Tâm tình dân kỹ thuật
04-06-2024, 10:20 -
-
Trả lời cho Kiểm tra biến ápbởi nhathung1101Lão lại mô tả dây chuyền dùng robot cơm à? Giờ công nghệ 4.0 chứ có phải 0.4 đâu.
Biến áp xung giờ chế tạo đơn giản lắm. Máy tự quấn. Robot gắp ra, đặt lên đế test, máy tự phát xung rồi đo kiểm. Ngon thì nó im lìm đưa lên...-
Channel: Điện tử dành cho người mới bắt đầu
04-06-2024, 02:27 -
-
Trả lời cho Kiểm tra biến ápbởi nguyendinhvanLàm BAX sẽ cần nhiều công đoạn kiểm tra hơn là biến áp sắt.
- Công đoạn đầu tiên là bạn phải phân loại được lõi Ferit, Có nhiều lõi Feerrit rất đẹp, không khác gì mọi cái khác, nhưng hệ số từ thẩm thì lại giống như không...-
Channel: Điện tử dành cho người mới bắt đầu
04-06-2024, 01:13 -
-
Trả lời cho Kiểm tra biến ápbởi nguyendinhvanTôi cố gắng tưởng tượng xem làm thế nào để công nhân tháo tác cho nó sai vòng dây, nhưng không tưởng tượng ra được.
Nhưng sai sót cực kỳ dễ xảy ra , đó là nhầm chân.
Theo quy trình, công nhân lắp cốt vào dưỡng, khóa lại,...-
Channel: Điện tử dành cho người mới bắt đầu
04-06-2024, 00:57 -
Comment