Thông báo

Collapse
No announcement yet.

giải đáp code matlab STBC system MIMO

Collapse
X
 
  • Lọc
  • Giờ
  • Show
Clear All
new posts

  • giải đáp code matlab STBC system MIMO

    Mọi người cho mình hỏi chút về code matlab này, mình đọc không hiểu :
    clear
    N = 10^6; % number of bits or symbols
    Eb_N0_dB = [0:25]; % multiple Eb/N0 values

    for ii = 1:length(Eb_N0_dB)

    % Transmitter
    ip = rand(1,N)>0.5; % generating 0,1 with equal probability cái này sao phải điều kiện >0.5
    s = 2*ip-1; % BPSK modulation 0 -> -1; 1 -> 0 sao cai này phải trừ đi 1, mà theo mình biết

    % Alamouti STBC
    sCode = zeros(2,N);
    sCode(:,1:2:end) = (1/sqrt(2))*reshape(s,2,N/2); % [x1 x2 ...]
    sCode(:,2:2:end) = (1/sqrt(2))*(kron(ones(1,N/2),[-1;1]).*flipud(reshape(conj(s),2,N/2))); % [-x2* x1* ....]

    h = 1/sqrt(2)*[randn(1,N) + j*randn(1,N)]; % Rayleigh channel
    hMod = kron(reshape(h,2,N/2),ones(1,2)); % repeating the same channel for two symbols

    n = 1/sqrt(2)*[randn(1,N) + j*randn(1,N)]; % white gaussian noise, 0dB variance

    % Channel and noise Noise addition
    y = sum(hMod.*sCode,1) + 10^(-Eb_N0_dB(ii)/20)*n;

    % Receiver
    yMod = kron(reshape(y,2,N/2),ones(1,2)); % [y1 y1 ... ; y2 y2 ...]
    yMod(2, = conj(yMod(2,; % [y1 y1 ... ; y2* y2*...]

    % forming the equalization matrix
    hEq = zeros(2,N);
    hEq(:,[1:2:end]) = reshape(h,2,N/2); % [h1 0 ... ; h2 0...]
    hEq(:,[2:2:end]) = kron(ones(1,N/2),[1;-1]).*flipud(reshape(h,2,N/2)); % [h1 h2 ... ; h2 -h1 ...]
    hEq(1, = conj(hEq(1,; % [h1* h2* ... ; h2 -h1 .... ]
    hEqPower = sum(hEq.*conj(hEq),1);

    yHat = sum(hEq.*yMod,1)./hEqPower; % [h1*y1 + h2y2*, h2*y1 -h1y2*, ... ]
    yHat(2:2:end) = conj(yHat(2:2:end));

    % receiver - hard decision decoding
    ipHat = real(yHat)>0;

    % counting the errors
    nErr(ii) = size(find([ip- ipHat]),2);

    end

    simBer = nErr/N; % simulated ber
    EbN0Lin = 10.^(Eb_N0_dB/10);
    theoryBer_nRx1 = 0.5.*(1-1*(1+1./EbN0Lin).^(-0.5));

    p = 1/2 - 1/2*(1+1./EbN0Lin).^(-1/2);
    theoryBerMRC_nRx2 = p.^2.*(1+2*(1-p));

    pAlamouti = 1/2 - 1/2*(1+2./EbN0Lin).^(-1/2);
    theoryBerAlamouti_nTx2_nRx1 = pAlamouti.^2.*(1+2*(1-pAlamouti));

    close all
    figure
    semilogy(Eb_N0_dB,theoryBer_nRx1,'bp-','LineWidth',2);
    hold on
    semilogy(Eb_N0_dB,theoryBerMRC_nRx2,'kd-','LineWidth',2);
    semilogy(Eb_N0_dB,theoryBerAlamouti_nTx2_nRx1,'c+-','LineWidth',2);
    semilogy(Eb_N0_dB,simBer,'mo-','LineWidth',2);
    axis([0 25 10^-5 0.5])
    grid on
    legend('theory (nTx=1,nRx=1)', 'theory (nTx=1,nRx=2, MRC)', 'theory (nTx=2, nRx=1, Alamouti)', 'sim (nTx=2, nRx=1, Alamouti)');
    xlabel('Eb/No, dB');
    ylabel('Bit Error Rate');
    title('BER for BPSK modulation with Alamouti STBC (Rayleigh channel)');

  • #2
    khong ai tra loi giup minh ak

    Comment


    • #3
      Mình cũng học matlab nhưng cỡ như thế này thì mình cũng bó tay rồi, chia buồn.

      Comment

      Về tác giả

      Collapse

      bilong229 Tìm hiểu thêm về bilong229

      Bài viết mới nhất

      Collapse

      • bqviet
        Trả lời cho Đấu tắt điện cho máy tính bảng
        bởi bqviet
        Bqv cáo lỗi vì chưa đủ khả năng diễn giải để người đọc hiểu. Người làm kỹ thuật sâu đôi khi như thế đó. Về việc nạp pin không vào dù cell mới, khả năng cái mạch quản lý đó đã hỏng - cũng chính là nguyên nhân đám cell cũ hỏng từ đầu.
        06-12-2025, 17:17
      • nguyendinhvan
        Trả lời cho Xin hỏi về mạch thu FM/AM trong catsette
        bởi nguyendinhvan
        Theo tôi, nó chỉ là cái Tuy- ê - nơ, hoặc là khối Trung Văn Tần, nó một phần trong cái Da đì ô thôi. Vì có thấy một chỗ có ba chân hàn, giiống như chân Cờ rít sờ tăng 455 ki nô hẹc. Còn khối Tuy ê nơ thì không nhìn thây cái Di ốt Va di cáp...
        05-12-2025, 19:59
      • afrendly
        Trả lời cho Đấu tắt điện cho máy tính bảng
        bởi afrendly
        Có vẻ ngoài hiểu biết của mình rồi. Cuối cùng mình quyết định tìm mua 2 pin trên Shopee, giá 200K thay vào. Tuy nhận pin được 1%, sạc mãi không vào nhưng cũng mở được máy lên. Vậy cũng tạm. Cảm ơn bạn đã hỗ trợ nhé....
        04-12-2025, 01:27
      • nick22
        Trả lời cho Máy điện châm ?
        bởi nick22
        Đúng như bạn nói, máy điện châm hiện nay trên thị trường đã khá đa dạng về mẫu mã, chức năng và giá thành.
        01-12-2025, 13:23
      Đang tải...
      X