我必须做一个matlab程序,它应该创建一个QR码。
我的问题是Reed Solomon纠错
用户输入他想要的单词。[…我得到了一串数字,我应该在一个多项式生成器(里德所罗门)(我发现一些网站做得很好:http://www.pclviewer.com/rs2/calculator.html)
我希望它发生:例如我输入:32 91 11 120 209 114 220 77 67 64 236 17 236
[Reed Solomon generator polynomial]
我想知道:168 72 22 82 217 54 156 0 46 15 180 122 16
我发现函数rsenc com .rsencoder gf…但是要理解这些函数的操作是不可能的。函数详细说明:http://www.mathworks.fr/fr/help/comm...n.html#fp12225
我尝试了如下类型的代码:
n = 255; k = 13; % Codeword length and message length
m = 8; % Number of bits in each symbol
msg = [32 91 11 120 209 114 220 77 67 64 236 17 236]; % Message is a Galois array.
obj = comm.RSEncoder(n, k);
c1 = step(obj, msg(1,:)');
c = [c1].';
他输出了一个255的字符串,而我想要13的输出。
谢谢你的帮助。
我认为你犯了一个错误。
'n'是包含奇偶校验码的最终消息的长度。'k'是消息的长度(符号数)
我想这会对你有帮助。
clc, clear all;
M = 16; % Modulation Order || same that Max value, at your case: 256! 2^m
hEnc = comm.RSEncoder;
hEnc.CodewordLength = M - 1; % Max = M-1, Min = 4, Must be greater than MessageLenght
hEnc.MessageLength = 13; % Experiment change up and down value (using odd number)
hEnc.BitInput = false;
hEnc
t = hEnc.CodewordLength - hEnc.MessageLength;
frame = 2*hEnc.MessageLength; % multiple of MensagemLength
fprintf('tError Detection (in Symbols): %dn',t);
fprintf('tError Correction: %.2fn',t/2);
data = randi([0 M-1], frame, 1); % Create a frame with symbols range (0 to M-1)
encodedData = step(hEnc, data); % encod the frame