Commit 35674e5d authored by Florian Kaltenberger's avatar Florian Kaltenberger

renamed runmeas_woduplex.m -> runmeas_full_duplex.m

deleted runmeas_wduplex.m
added runmeas_long_chanest.m

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@4359 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent 55028fbb
% do some beamforming % do some beamforming
signalA2B=zeros(N,4); signalA2B=zeros(N,4);
signalB2A=zeros(N,4); signalB2A=zeros(N,4);
signalB2A_prec=zeros(N,4); signalB2A_prec_full=zeros(N,4);
signalB2A_diag=zeros(N,4); signalB2A_prec_diag=zeros(N,4);
%%----------Node A to B transmission---------%% %%----------Node A to B transmission---------%%
for i=1:4 for i=1:4
......
# % Author: Mirsad Cirkic # % Author: Mirsad Cirkic, Florian Kaltenberger
# % Organisation: Eurecom (and Linkoping University) # % Organisation: Eurecom (and Linkoping University)
# % E-mail: mirsad.cirkic@liu.se # % E-mail: mirsad.cirkic@liu.se
if(paramsinitialized && LSBSWITCH_FLAG) if(paramsinitialized && ~LSBSWITCH_FLAG)
disp(["\n\n------------\nThis code is, so far, only written for single runs. Multiple " ... disp(["\n\n------------\nThis code is, so far, only written for single runs. Multiple " ...
"runs will overwrite the previous measurement data, i.e., the " ... "runs will overwrite the previous measurement data, i.e., the " ...
"data structures are not defined for multiple runs. You will need to " ... "data structures are not defined for multiple runs. You will need to " ...
"add code in order to save the intermediate measurements and the " ... "add code in order to save the intermediate measurements and the " ...
"corresponding timestamps.\n------------"]) "corresponding timestamps.\n------------"])
N=76800; N=76800;
M=4; M=4;
indA=find(active_rfA==1); Ntaps=8;
indB=find(active_rfB==1); indA=find(active_rfA==1);
Nanta=length(indA); indB=find(active_rfB==1);
Nantb=length(indB); Nanta=length(indA);
Niter=1; Nantb=length(indB);
Nofs=3840; % The offset in samples between the downlink and uplink sequences. It must be a multiple of 640, 3840 samples is 0.5 ms. if(Nanta!=1)
if(mod(Nofs,640)!=0) error("blabla") endif error("Node A can only have one antenna active\n");
endif
if(Nanta!=1) error("Node A can only have one antenna active\n"); endif Niter=1;
if(Niter!=1) error("We should only use one get_frame at each run.\n"); endif if(Niter!=1)
error("We should only use one get_frame at each run.\n");
# %% ------- Prepare the signals for both A2B and B2A ------- % endif
maskA2B=kron(ones(1,N/(2*Nofs)),[ones(1,Nofs) zeros(1,Nofs)])'; Nmeas = 10;
maskB2A=ones(N,1)-maskA2B;
datamaskA2B=diag(kron(ones(1,N/(2*Nofs)),[ones(1,Nofs/640) zeros(1,Nofs/640)])); # %% ------- Prepare the signals for A2B ---------- %%
datamaskB2A=eye(N/640)-datamaskA2B; signalA2B=zeros(N,4,Nmeas);
signalA2B=zeros(N,4); signalB2A=zeros(N,4,Nmeas);
signalB2A=zeros(N,4); Db2a_T=[];
ia=1; ib=1; for meas=1:Nmeas
Db2a_T=[]; ia=1; ib=1;
for i=1:4 Dtmp=[];
if(indA(ia)==i) for i=1:4
[tmpd, tmps]=genrandpskseq(N,M,amp); if(indA(ia)==i)
Da2b_T=datamaskA2B*tmpd; [tmpd, tmps]=genrandpskseq(N,M,amp);
signalA2B(:,i)=tmps*4.*maskA2B+maskB2A*sqrt(-1); %Added maskB2A to set the LSB correctly. The factor 4 there should make a 2 bit shift. Don't know if that is correct signalA2B(:,i,meas)=tmps; %make sure LSB is 0 (switch=tx)
if(length(indA)> ia) ia=ia+1; endif Dtmp=[Dtmp tmpd];
endif if(length(indA)> ia) ia=ia+1; endif
if(indB(ib)==i) endif
% This part could be improved by creating fully orthogonal sequences % if(indB(ib)==i)
[tmpd, tmps]=genrandpskseq(N,M,amp); % % This part could be improved by creating fully orthogonal sequences
signalB2A(:,i)=tmps*4.*maskB2A+maskA2B*sqrt(-1); %Added maskA2B to set the LSB correctly. The factor 4 there should make a 2 bit shift. Don't know if that is correct. % [tmpd, tmps]=genrandpskseq(N,M,amp);
Db2a_T=[Db2a_T datamaskB2A*tmpd]; % signalB2A(:,i)=tmps*2;
if(length(indB)> ib) ib=ib+1; endif % signalA2B(:,i)=repmat(1+1j,76800,1);
endif % Db2a_T=[Db2a_T tmpd];
endfor % if(length(indB)> ib) ib=ib+1; endif
% endif
signal = signalA2B+signalB2A; endfor
Da2b_T=[Da2b_T; Dtmp];
# %% ------- Node B and A duplex transmission/reception ------- %%
rf_mode_current = rf_mode + (DMAMODE_TX+TXEN+DMAMODE_RX+RXEN)*active_rf; #%%------------Prepare the signals for B2A---------------%%
oarf_config_exmimo(card, freq_rx,freq_tx,tdd_config,syncmode,rx_gain,tx_gain,eNB_flag,rf_mode_current,rf_rxdc,rf_local,rf_vcocal,rffe_rxg_low,rffe_rxg_final,rffe_band,autocal_mode); Dtmp=[];
oarf_send_frame(card,signal,n_bit); for i=1:4
received=oarf_get_frame(card); if(indB(ib)==i)
oarf_stop(card); [tmpd, tmps]=genrandpskseq(N,M,amp);
receivedA2B=received.*repmat(maskA2B,1,4); signalB2A(:,i,meas)=tmps*2; %make sure LSB is 0 (switch=tx)
receivedB2A=received.*repmat(maskB2A,1,4); signalA2B(:,i,meas)=repmat(1+1j,76800,1); %make sure LSB is 1 (switch=rx)
Dtmp=[Dtmp tmpd];
# %% ------- Do the A to B channel estimation ------- %% if(length(indB)> ib) ib=ib+1; endif
Da2b_R=zeros(Niter*120,Nantb*301); endif
for i=0:119; endfor
ifblock=receivedA2B(i*640+[1:640],indB); Db2a_T=[Db2a_T; Dtmp];
ifblock(1:128,:)=[]; endfor
fblock=fft(ifblock);
fblock(1,:)=[]; Da2b_R=zeros(Nmeas*120,Nantb*301);
fblock(151:360,:)=[]; Db2a_R=zeros(Nmeas*120,Nanta*301);
Da2b_R((Niter-1)*120+i+1,:)=vec(fblock);
endfor for meas=1:Nmeas
HA2B=repmat(conj(Da2b_T),1,Nantb).*Da2b_R; # %% ------- Node A to B transmission ------- %%
phasesA2B=unwrap(angle(HA2B)); oarf_send_frame(card,squeeze(signalA2B(:,:,meas)),n_bit);
if(mean(var(phasesA2B))>0.5) %keyboard
disp("The phases of your estimates are a bit high (larger than 0.5 rad.), something is wrong."); sleep(0.01);
endif receivedA2B=oarf_get_frame(card);
%oarf_stop(card); %not good, since it does a reset
chanestsA2B=reshape(diag(repmat(Da2b_T,1,Nantb)'*Da2b_R)/size(Da2b_T,1),301,Nantb); sleep(0.01);
fchanestsA2B=zeros(512,Nantb);
for i=1:Nantb #%%----------Node B to A transmission---------%%
fchanestsA2B(:,i)=[0; chanestsA2B([1:150],i); zeros(210,1); chanestsA2B(151:301,i)]; oarf_send_frame(card,squeeze(signalB2A(:,:,meas)),n_bit);
endfor %keyboard
tchanestsA2B=ifft(fchanestsA2B); sleep(0.01);
receivedB2A=oarf_get_frame(card);
%% ------- Do the B to A channel estimation ------- %% %oarf_stop(card); %not good, since it does a reset
Db2a_R=zeros(Niter*120,Nanta*301);
for i=0:119; # %% ------- Do the A to B signal post preparation ------- %%
ifblock=receivedB2A(i*640+[1:640],indA); for i=0:119;
ifblock(1:128,:)=[]; ifblock=receivedA2B(i*640+[1:640],indB);
fblock=fft(ifblock); ifblock(1:128,:)=[];
fblock(1,:)=[]; fblock=fft(ifblock);
fblock(151:360,:)=[]; fblock(1,:)=[];
Db2a_R((Niter-1)*120+i+1,:)=fblock.'; fblock(151:360,:)=[];
endfor Da2b_R((meas-1)*120+i+1,:)=vec(fblock);
HB2A=conj(repmat(Db2a_T,Niter,1)).*repmat(Db2a_R,1,Nantb); endfor
phasesB2A=unwrap(angle(HB2A));
if(mean(var(phasesB2A))>0.5)
disp("The phases of your estimates are a bit high (larger than 0.5 rad.), something is wrong."); %% ------- Do the B to A signal post preparation ------- %%
endif for i=0:119;
chanestsB2A=reshape(diag(repmat(Db2a_T,Niter,1)'*repmat(Db2a_R,1,Nantb)/(Niter*120)),301,Nantb); ifblock=receivedB2A(i*640+[1:640],indA);
ifblock(1:128,:)=[];
%% -- Some plotting code -- %% (you can uncomment what you see fit) fblock=fft(ifblock);
clf fblock(1,:)=[];
figure(1) fblock(151:360,:)=[];
for i=1:4 Db2a_R((meas-1)*120+i+1,:)=fblock.';
subplot(220+i);plot(20*log10(abs(fftshift(fft(receivedA2B(:,i)))))); endfor
endfor endfor
figure(2) # %% ------- Do the A to B channel estimation ------- %%
t=[0:512-1]/512*1e-2; HA2B=repmat(conj(Da2b_T),1,Nantb).*Da2b_R;
plot(t,abs(tchanestsA2B)) phasesA2B=unwrap(angle(HA2B));
xlabel('time') if(mean(var(phasesA2B))>0.5)
ylabel('|h|') disp("The phases of your estimates from A to B are a bit high (larger than 0.5 rad.), something is wrong.");
endif
figure(3) DA2B=repmat(Da2b_T,1,Nantb);
wndw = 50; chanestsA2B=reshape(diag(DA2B'*Da2b_R)./diag(DA2B'*DA2B),301,Nantb);
for i=1:5:Nantb*301 %# sliding window size fchanestsA2B=[zeros(1,Nantb); chanestsA2B([1:150],:); zeros(210,Nantb); chanestsA2B(151:301,:)];
phamean = filter(ones(wndw,1)/wndw, 1, phasesA2B(:,i)); %# moving average tchanestsA2B=ifft(fchanestsA2B);
plot(phamean(wndw:end),'LineWidth',2);
title(['subcarrier ' num2str(i)]); # %% ------- Do the B to A channel estimation ------- %%
xlabel('time') HB2A=conj(Db2a_T.*repmat(Db2a_R,1,Nantb));
ylabel('phase') phasesB2A=unwrap(angle(HB2A));
ylim([-pi pi]) if(mean(var(phasesB2A))>0.5)
drawnow; disp("The phases of your estimates from B to A are a bit high (larger than 0.5 rad.), something is wrong.");
pause(0.1) endif
endfor
phavar=var(phasesA2B); if (chanest_full)
plotphavar=[]; chanestsB2A=zeros(301,Nantb);
for i=0:Nantb-1 inds=repmat([1:Nantb]',1,301);
plotphavar=[plotphavar; phavar([1:301]+i*301)]; for ci=1:301;
endfor data=Db2a_T(:,ci+[0:Nantb-1]*301);
plot([1:150 362:512],plotphavar,'o'); rec=Db2a_R(:,ci);
%ylim([0 pi]) chanestsB2A(ci,:)=(inv(data'*data)*data'*rec).';
xlabel('subcarrier') endfor
ylabel('phase variance') else
chanestsB2A=reshape(diag(Db2a_T'*repmat(Db2a_R,1,Nantb)/(Nmeas*60)),301,Nantb);
end
# figure(4)
# plot(20*log10(abs(fchanests))), ylim([40 100]) #fchanestsB2A=zeros(512,Nantb);
#for i=1:Nantb
# %end # fchanestsB2A(:,i)=[0; chanestsB2A([1:150],i); zeros(210,1); chanestsB2A(151:301,i)];
# fprintf(' done\n') #endfor
fchanestsB2A = [zeros(1,Nantb); chanestsB2A([1:150],:); zeros(210,Nantb); chanestsB2A(151:301,:)];
tchanestsB2A=ifft(fchanestsB2A);
# for i=0:(Nantb-1)
# fchanests(:,i+1)=[0; chanests(301*i+[1:150]); zeros(210,1); chanests(301*i+[151:301])];
# endfor
# tchanests=ifft(fchanests);
%% -- Some plotting code -- %% (you can uncomment what you see fit)
received = receivedB2A;
else phases = phasesB2A;
if(!LSBSWITCH_FLAG) error("You have to set the LSB switch flag (LSBSWITCH_FLAG) in initparams.m.\n") tchanests = [tchanestsA2B(:,:,end), tchanestsB2A(:,:,end)];
else error("You have to run init.params.m first!") fchanests = [fchanestsA2B(:,:,end), fchanestsB2A(:,:,end)];
endif
endif clf
figure(1)
for i=1:4
subplot(220+i);plot(20*log10(abs(fftshift(fft(received(:,i))))));
endfor
figure(2)
t=[0:512-1]/512*1e-2;
plot(t,20*log10(abs(tchanests)))
xlabel('time')
ylabel('|h|')
legend('A->B1','A->B2','A->B3','B1->A','B2->A','B3->A');
%legend('A->B1','A->B2','B1->A','B2->A');
figure(4)
plot(20*log10(abs(fchanests)));
ylim([40 100])
xlabel('freq')
ylabel('|h|')
legend('A->B1','A->B2','A->B3','B1->A','B2->A','B3->A');
%legend('A->B1','A->B2','B1->A','B2->A');
if (0)
figure(3)
wndw = 50;
for i=1:5:Nantb*301 %# sliding window size
phamean = filter(ones(wndw,1)/wndw, 1, phases(:,i)); %# moving average
plot(phamean(wndw:end),'LineWidth',2);
title(['subcarrier ' num2str(i)]);
xlabel('time')
ylabel('phase')
ylim([-pi pi])
drawnow;
pause(0.1)
endfor
phavar=var(phases);
plotphavar=[];
for i=0:Nantb-1
plotphavar=[plotphavar; phavar([1:301]+i*301)];
endfor
plot([1:150 362:512],plotphavar,'o');
%ylim([0 pi])
xlabel('subcarrier')
ylabel('phase variance')
end
else
if(LSBSWITCH_FLAG) error("You have to unset the LSB switch flag (LSBSWITCH_FLAG) in initparams.m.\n")
else error("You have to run init.params.m first!")
endif
endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment