Azzera filtri
Azzera filtri

I have a matrix of 4095 by 4. i need to divide it into submatrices of 117 by 1.

1 visualizzazione (ultimi 30 giorni)
How can I do this using for loop? I mean I have to select first 117 rows and 1st column then first 117 rows and 2nd column, then first 117 rows and 3rd column and then 1st 117 rows and 4th column. after that repeat this for next 117 rows and so on uptill 4095 rows.

Risposta accettata

Walter Roberson
Walter Roberson il 9 Nov 2018
Baserow = (column-1) * 117;
Subset = YourImage(Baserow+(1:117),column, :) ;
  6 Commenti
Sajid Sarwar
Sajid Sarwar il 19 Nov 2018
Modificato: Walter Roberson il 19 Nov 2018
txSig(n, n1, :) = ofdmMod(Subset);
by this line I'm getting txSig in 3 dimensions whereas I need 2D data for further use in y = awgn(txSig, SNR(k));
and sigRx = ofdmDemod(y);
Walter Roberson
Walter Roberson il 19 Nov 2018
You do not need 2D data for awgn. You might need a row vector for ofdmDemod though.
st=rand(9945,4)
for n=1:85
Baserow = (n-1) * 117;
for n1 = 1:4
Subset = st(Baserow+(1:117),n1, :)
txSig(n, n1, :) = ofdmMod(Subset);
y = awgn(txSig(n, n1, :), SNR(k));
sigRx(n, n1, :) = ofdmDemod(y(:).');
end
end

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Propagation and Channel Models in Help Center e File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by