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

Bài viết mới nhất
Collapse
-
Trả lời cho Biết gì nói nấy, cãi chửi thoải máibởi mèomướpÝ chú nhat... ở đây là đang bêu xấu chú dinh... chưa hiểu được những thứ đơn giản đã đòi làm thứ phức tạp đúng hông ạ. Với ngày trước chưa hẳn đúng, ngày nay thì càng khập khiễng. Kiến thức quá nhìu, không phải ai cũng có đủ...
-
Channel: Tâm tình dân kỹ thuật
hôm nay, 09:19 -
-
Trả lời cho Biết gì nói nấy, cãi chửi thoải máibởi nhathung1101Cáu nhau cứ vào đây giải quyết.
Đừng để lũ trẻ nhìn ở ngoài, học theo thói xấu...
Và tuyệt đối không để bọn trẻ học theo cái "ngu" ở đó.-
Channel: Tâm tình dân kỹ thuật
hôm nay, 00:51 -
-
Trả lời cho Biết gì nói nấy, cãi chửi thoải máibởi nhathung1101Khơi mào luôn:
Một người chưa hiểu nguyên lý ổn áp tuyến tính (Linear Voltage Regulator) lại muốn hiểu MPPT???...-
Channel: Tâm tình dân kỹ thuật
hôm nay, 00:47 -
-
bởi nhathung1101Tinh thần của luồng:
- Biết gì nói nấy.
- Cãi chửi nhau thoải mái.
- Chỉ vì kỹ thuật.
- Càng vui càng tốt.
Oh... Yeah... Please....
Anh em nào có khúc mắc cứ vào đây, đừng vào những luồng "đèn đỏ" nhé.-
Channel: Tâm tình dân kỹ thuật
hôm nay, 00:29 -
-
Trả lời cho Hỗ trợ tìm linh kiện mạch hạ áp 220V - 110Vbởi nhathung1101Lại phát hiện thêm con Mèo Núp. Lo đi bắt chuột đi.
Mấy chị trong bản đang sợ chuột. Còn mấy ông đi bắt chuột cứ chạy quanh giường......-
Channel: Hướng dẫn tìm thông tin linh kiện
hôm nay, 00:14 -
-
Trả lời cho Hỗ trợ tìm linh kiện mạch hạ áp 220V - 110Vbởi nhathung1101Giờ mới nhìn thấy bài này.
Hôm qua nhìn qua, phân tích mạch nên không thấy.
Nhắc bạn nhỏ một câu: "Biết thì thưa thốt, không biết dựa cột mà nghe".
Mạch ổn áp DC mà cho vào loa???
Xui dại cũng phải chọn người nhé!...-
Channel: Hướng dẫn tìm thông tin linh kiện
hôm nay, 00:01 -
-
Trả lời cho Tiếng Anh cho người Việtbởi nhathung1101
Không ngờ ku em chuyển sang hệ trung dung....
-
Channel: Tâm tình dân kỹ thuật
Hôm qua, 22:04 -
-
Trả lời cho Tiếng Anh cho người Việtbởi bqvietBqv rất ngại vụ tư vấn kiểu này, vì "văn mình vợ người" kiểu gì cũng có thể chỉ ra cái chưa hợp lý văn viết của người khác nhưng chính mình cũng dễ bị bắt lỗi. Rào trước như vậy, xin viết thêm vài dòng góp ý.
...-
Channel: Tâm tình dân kỹ thuật
Hôm qua, 21:27 -
-
Trả lời cho Tìm linh kiện sửa loa vi tính.bởi nhathung1101Ra cửa hàng điện tử bất kỳ.
Dõng dạc hét lên:
- Cho 1 con 4558.
Có luôn. Nó chỉ là con Opamp cùi bắp thông thường thôi mà. Giá 2k hay 3k gì đó.
Nếu muốn âm thanh hay hơn, thì mua NE5535, mất 2 cốc beer thôi.-
Channel: Điện tử dành cho người mới bắt đầu
26-02-2025, 22:38 -
-
Trả lời cho Hỗ trợ tìm linh kiện mạch hạ áp 220V - 110Vbởi nhathung1101Mạch dùng được, nhưng phải kết hợp với Transistor NPN công suất bên ngoài. Loại chịu điện áp cao, dòng lớn.
Loại mạch này nhái theo cái loại IC họ STR trong mấy cái ti vi cổ lỗ ngày xưa thôi mà. Còn được gọi là "ổn áp...-
Channel: Hướng dẫn tìm thông tin linh kiện
26-02-2025, 22:28 -
Comment