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 Thắc mắc về nguồn tổ ong 12vbởi tuyennhanCách ly dây điện vào , bộ nguồn và đèn khỏi khung xe thì có rò thật cũng không lo bị giật .
-
Channel: Điện tử dành cho người mới bắt đầu
Hôm qua, 08:56 -
-
Trả lời cho Hỏi cách điều chế xungbởi thetungBạn cho qua cái Tờ ri gơ Sờ mít ấy ......
-
Channel: Kỹ thuật điện tử tương tự
16-12-2024, 11:26 -
-
Trả lời cho Hỏi cách điều chế xungbởi nguyendinhvanCó gì mà khó ?
Răn cưa vuông đây
...-
Channel: Kỹ thuật điện tử tương tự
15-12-2024, 23:36 -
-
Trả lời cho hỏi về tụ điệnbởi ndp62Chữ " VENT" không phải là tên hãng sx tụ đâu ,vó thế là 1 ký hiệu liên quan tụ lowesr ?
-
Channel: Điện thanh
15-12-2024, 18:24 -
-
Trả lời cho Thắc mắc về nguồn tổ ong 12vbởi bqvietTrừ trường hợp công suất (rất) thấp, hầu như tất cả các loại nguồn xung thông thường đều có tụ nhỏ 1 - 10nF nối giữa sơ cấp và thứ cấp, để thoát nhiễu và để chống hiện tượng tương tự tĩnh điện. Vụ này đã thảo luận vài...
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 22:02 -
-
Trả lời cho Thắc mắc về nguồn tổ ong 12vbởi namlangnhoE thử 3 cái nguồn nó đều giống nhau. Nên e làm tiếp địa luôn.
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 19:58 -
-
Trả lời cho Thắc mắc về nguồn tổ ong 12vbởi mèomướpDạ chú sắm con át chống giật và thay nguồn tổ ong khác cho an toàn ạ. Đa phần nguồn xung đều xả nhiễu của bên thứ cấp về điện lưới qua 1 con tụ nên cảm giác tê sẽ khó xác định rõ ràng là do rò điện hay là nó vốn vậy...
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 18:51 -
-
bởi namlangnhoXin chào mọi người. E có sử dụng 1 cục nguồn tổ ong 12v-30A chạy đèn led xe trà sữa. Mà thợ thi công bị rò điện nên điện rò ra khung xe. E dùng đồng hồ đo điện ở khung xe và cả output thì thấy có dòng điện xoay chiều hơn 100v. Nên chạm...
-
Channel: Điện tử dành cho người mới bắt đầu
14-12-2024, 00:12 -
-
bởi Manh.n.trCác bác cho em hỏi cách điều chế xung răng cưa sang xung vuông với ạ. Em đang thấy khó ạ...
-
Channel: Kỹ thuật điện tử tương tự
13-12-2024, 20:46 -
Comment