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 Kiểm tra biến ápbởi nguyendinhvanVề kỹ thuật, hiện nya ĐTVN cũng rất mơ hồ về phân cấp kỹ thuật.
Đơn vị nhỏ nhất trong kỹ thuật là linh kiện, vật tư.
Nhiều LINH KIỆN kết hợp thành cái MẠCH
Cần nhiều cái MẠCH kết hợp thành cái MÁY
Nhiều cái...-
Channel: Điện tử dành cho người mới bắt đầu
hôm nay, 02:53 -
-
Trả lời cho Kiểm tra biến ápbởi nguyendinhvanCái chuyện này thì những gì hay của " thằng hàn" không áp dụng được. Vì ngững người ở bên ... "chúng ta" không có những hợp đồng dài hạn hàng đến 3 hay 6 tháng hay một năm. Vì thế không đủ sản lượng để đầu tư vào...
-
Channel: Điện tử dành cho người mới bắt đầu
hôm nay, 02:05 -
-
Trả lời cho Kiểm tra biến ápbởi nguyendinhvanBạn Hùng nói có quá nhiều vấn đề.
..."Tôi từng làm với thằng Hàn..."
Thứ nhất là cần phải loại bỏ tính "thành tích" và "hình thức". Một căn bệnh khá là nặng của đtvn. Không được và cần trốn tránh...-
Channel: Điện tử dành cho người mới bắt đầu
hôm nay, 01:55 -
-
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 -
Comment