From 35169c13e7a12c6a1aef6283c6c7c0412da592a0 Mon Sep 17 00:00:00 2001
From: Cirkic <cirkic@eurecom.fr>
Date: Fri, 19 Jul 2013 14:35:08 +0000
Subject: [PATCH] Cleaned up some code and made it more transparent.

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@4043 818b1a75-f10b-46b9-bf7c-635c3b92a50f
---
 targets/PROJECTS/TDDREC/initparams.m       |   6 +-
 targets/PROJECTS/TDDREC/runmeas.m          | 134 ------------------
 targets/PROJECTS/TDDREC/runmeas_wduplex.m  | 155 +++++++++++++++++++++
 targets/PROJECTS/TDDREC/runmeas_woduplex.m |  69 +++++----
 4 files changed, 199 insertions(+), 165 deletions(-)
 delete mode 100644 targets/PROJECTS/TDDREC/runmeas.m
 create mode 100644 targets/PROJECTS/TDDREC/runmeas_wduplex.m

diff --git a/targets/PROJECTS/TDDREC/initparams.m b/targets/PROJECTS/TDDREC/initparams.m
index 3f3fd69199..2628e859de 100644
--- a/targets/PROJECTS/TDDREC/initparams.m
+++ b/targets/PROJECTS/TDDREC/initparams.m
@@ -15,6 +15,8 @@ active_rfA=[1 0 0 0];
 active_rfB=[0 1 0 0];
 active_rf=active_rfA+active_rfB;
 
+if(active_rfA*active_rfB'!=0) error("The A and B transceive chains must be orthogonal./n") endif
+
 %fc  = 2660000000;
 fc  = 1912600000; %1907600000;
 %fc = 859.5e6;
@@ -23,8 +25,8 @@ fc  = 1912600000; %1907600000;
 %rf_mode=(RXEN+TXEN+TXLPFNORM+TXLPFEN+TXLPF25+RXLPFNORM+RXLPFEN+RXLPF25+LNA1ON+LNAByp+RFBBLNA1) * active_rf;
 autocal_mode=active_rf;
 rf_mode=(TXLPFNORM+TXLPFEN+TXLPF25+RXLPFNORM+RXLPFEN+RXLPF25+LNA1ON+LNAMax+RFBBNORM) * active_rf;
-tdd_config = DUPLEXMODE_FDD + TXRXSWITCH_TESTTX; 
-%tdd_config = DUPLEXMODE_FDD + TXRXSWITCH_LSB;
+tdd_config = DUPLEXMODE_FDD+TXRXSWITCH_TESTTX; LSBSWITCH_FLAG=false; 
+%tdd_config = DUPLEXMODE_FDD+TXRXSWITCH_LSB; LSBSWITCH_FLAG=true;
 syncmode = SYNCMODE_FREE;
 rf_local = [8254744   8255063   8257340   8257340]; %eNB2tx 1.9GHz
 rf_vcocal=rf_vcocal_19G*active_rf;
diff --git a/targets/PROJECTS/TDDREC/runmeas.m b/targets/PROJECTS/TDDREC/runmeas.m
deleted file mode 100644
index 3586e42d4f..0000000000
--- a/targets/PROJECTS/TDDREC/runmeas.m
+++ /dev/null
@@ -1,134 +0,0 @@
-# % Author: Mirsad Cirkic
-# % Organisation: Eurecom (and Linkoping University)
-# % E-mail: mirsad.cirkic@liu.se
-
-if(paramsinitialized)
-	N=76800;
-	M=4;
-	signalB2A=zeros(N,1);	
-	signalA2B=zeros(N,4);	
-	indA=find(active_rfA==1);
-	indB=find(active_rfB==1);	
-	Nanta=length(indA);
-	Nantb=length(indB);
-	Niter=1;
-	# %% ------- Node A to B channel measurements ------- %%	
-	# rf_mode_current = rf_mode + (DMAMODE_TX+TXEN)*active_rfA +(DMAMODE_RX+RXEN)*active_rfB;
-	# 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);
-	# [Da2b_T, signalA2B]=genrandpskseq(N,M,amp);
-	# signalA2B=repmat(signalA2B,1,4);
-	# oarf_send_frame(card,signalA2B,n_bit);
-	# fprintf('A to B: Frame sent to Tx buffer.\n')	
-	# fprintf('A to B: Acquiring chan. measurements....\n')
-	# loop=true;
-	# chanests=[];
-	# Da2b_R=zeros(Niter*120,Nantb*301);
-	# Da2b_T=repmat(Da2b_T,Niter,Nantb);
-	# for iter=0:(Niter-1) % Do the chan. est until SNR is good enough. That is, do the "oarf_get_fram(card)
-	#   receivedA2B=oarf_get_frame(card);
-	#   fprintf('A to B: Frame grabbed from Rx buffer.\n')	  
-	#   for i=0:119;
-	#     ifblock=receivedA2B(i*640+[1:640],indB);
-	#     ifblock(1:128,:)=[];
-	#     fblock=fft(ifblock);
-	#     fblock(1,:)=[];
-	#     fblock(151:360,:)=[];
-	#     Da2b_R(iter*120+i+1,:)=vec(fblock);	      
-	#   endfor
-	# endfor
-	# H=conj(Da2b_T).*Da2b_R;
-	# phases=unwrap(angle(H));
-	# chanests=diag(Da2b_T'*Da2b_R)/size(Da2b_T,1);
-	# 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);
-	
-	# %% -- Do some plotting
-	# clf
-	# figure(1)
-	# for i=1:4 
-	#   subplot(220+i);plot(20*log10(abs(fftshift(fft(receivedA2B(:,i)))))); 
-	# endfor
-	
-	# figure(2)
-	# t=[0:512-1]/512*1e-2;
-	# plot(t,abs(tchanests))
-	# xlabel('time')
-	# ylabel('|h|')
-	
-	# 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')
-	
-
-	# figure(4)
-	# plot(20*log10(abs(fchanests))), ylim([40 100])
-
-	# %end
-	# oarf_stop(card);
-	# fprintf(' done\n')	
-
-	%% ------- Node B to A channel measurements ------- %%
-	rf_mode_current = rf_mode + (DMAMODE_TX+TXEN)*active_rfB +(DMAMODE_RX+RXEN)*active_rfA;
-	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);
-	signalB2A=zeros(N,4);
-	Db2a_R=zeros(Niter*120,Nanta*301);
-	[Db2a_T,tmps]=genorthqpskseq(Nantb,N,amp);
-	ind=1;
-	for i=1:4
-	  if(indB(ind)==i)	    
-	    signalB2A(:,i)=tmps(:,ind);
-	    if(length(indB)> ind) ind=ind+1; endif
-	  endif	  	  
-	endfor
-	%receivedB2A=sum(signalB2A*diag([1 2 3 4]),2)+100*randn(N,1);
-	
-	oarf_send_frame(card,signalB2A,n_bit);
-	if(length(indA)!=1) error("Node A can only have one antenna active\n"); endif
-	for iter=0:(Niter-1) % Do the chan. est until SNR is good enough. That is, do the "oarf_get_fram(card)	   
-	   fprintf('B to A: Frame grabbed from Rx buffer.\n')	  
-	   receivedB2A=oarf_get_frame(card);
-	   
-	   for i=0:119;
-	     ifblock=receivedB2A(i*640+[1:640],indA);
-	     ifblock(1:128,:)=[];
-	     fblock=fft(ifblock);
-	     fblock(1,:)=[];
-	     fblock(151:360,:)=[];
-	     Db2a_R(iter*120+i+1,:)=fblock.';
-	   endfor
-	endfor
-	oarf_stop(card);
-	
-	# # -- Do the channel estimation
-	chanests=reshape(diag(repmat(Db2a_T,Niter,1)'*repmat(Db2a_R,1,Nantb)/(Niter*120)),301,Nantb);
-	H=conj(repmat(Db2a_T,Niter,1)).*repmat(Db2a_R,1,Nantb);
-	phases=unwrap(angle(H));
-	# 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);
-	
-		
-else
-	error('You have to run init.params.m first!')
-end
diff --git a/targets/PROJECTS/TDDREC/runmeas_wduplex.m b/targets/PROJECTS/TDDREC/runmeas_wduplex.m
new file mode 100644
index 0000000000..a10e8aba75
--- /dev/null
+++ b/targets/PROJECTS/TDDREC/runmeas_wduplex.m
@@ -0,0 +1,155 @@
+# % Author: Mirsad Cirkic
+# % Organisation: Eurecom (and Linkoping University)
+# % E-mail: mirsad.cirkic@liu.se
+
+if(paramsinitialized && LSBSWITCH_FLAG)
+  disp(["\n\n------------\nThis code is, so far, only written for single runs. Multiple " ... 
+	"runs will overwrite the previous measurement data, i.e., the " ...
+	"data structures are not defined for multiple runs. You will need to " ...
+	"add code in order to save the intermediate measurements and the " ...
+	"corresponding timestamps.\n------------"])
+  N=76800;
+  M=4;
+  signalA2B=zeros(N,4);
+  signalB2A=zeros(N,4);
+  indA=find(active_rfA==1);
+  indB=find(active_rfB==1);
+  Nanta=length(indA);
+  Nantb=length(indB);
+  Niter=1;
+  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(mod(Nofs,640)!=0) error("blabla") endif
+
+  if(Nanta!=1) error("Node A can only have one antenna active\n"); endif
+  if(Niter!=1) error("We should only use one get_frame at each run.\n"); endif
+  
+# %% ------- Prepare the signals for both A2B and B2A ------- %
+  maskA2B=kron(ones(1,N/(2*Nofs)),[ones(1,Nofs) zeros(1,Nofs)])';
+  maskB2A=ones(N,1)-maskA2B;
+  datamaskA2B=diag(kron(ones(1,N/(2*Nofs)),[ones(1,Nofs/640) zeros(1,Nofs/640)]));
+  datamaskB2A=eye(N/640)-datamaskA2B;
+  signalA2B=zeros(N,4);
+  signalB2A=zeros(N,4);
+  ia=1; ib=1;
+  Db2a_T=[];
+  for i=1:4
+    if(indA(ia)==i)
+      [tmpd, tmps]=genrandpskseq(N,M,amp);
+      Da2b_T=datamaskA2B*tmpd;
+      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
+      if(length(indA)> ia) ia=ia+1; endif
+    endif
+    if(indB(ib)==i)      
+      % This part could be improved by creating fully orthogonal sequences
+      [tmpd, tmps]=genrandpskseq(N,M,amp);
+      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.
+      Db2a_T=[Db2a_T datamaskB2A*tmpd];
+      if(length(indB)> ib) ib=ib+1; endif
+    endif
+  endfor   
+
+  signal = signalA2B+signalB2A;
+
+# %% ------- Node B and A duplex transmission/reception ------- %%	
+  rf_mode_current = rf_mode + (DMAMODE_TX+TXEN+DMAMODE_RX+RXEN)*active_rf;
+  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);
+  oarf_send_frame(card,signal,n_bit);
+  received=oarf_get_frame(card);
+  oarf_stop(card);
+  receivedA2B=received.*repmat(maskA2B,1,4);
+  receivedB2A=received.*repmat(maskB2A,1,4);
+
+# %% ------- Do the A to B channel estimation ------- %%	
+  Da2b_R=zeros(Niter*120,Nantb*301);
+  for i=0:119;
+    ifblock=receivedA2B(i*640+[1:640],indB);
+    ifblock(1:128,:)=[];
+    fblock=fft(ifblock);
+    fblock(1,:)=[];
+    fblock(151:360,:)=[];
+    Da2b_R((Niter-1)*120+i+1,:)=vec(fblock);	      
+  endfor
+  HA2B=repmat(conj(Da2b_T),1,Nantb).*Da2b_R;
+  phasesA2B=unwrap(angle(HA2B));
+  if(mean(var(phasesA2B))>0.5) 
+    disp("The phases of your estimates are a bit high (larger than 0.5 rad.), something is wrong.");
+  endif
+  
+  chanestsA2B=reshape(diag(repmat(Da2b_T,1,Nantb)'*Da2b_R)/size(Da2b_T,1),301,Nantb);
+  fchanestsA2B=zeros(512,Nantb);
+  for i=1:Nantb
+    fchanestsA2B(:,i)=[0; chanestsA2B([1:150],i); zeros(210,1); chanestsA2B(151:301,i)];
+  endfor
+  tchanestsA2B=ifft(fchanestsA2B);
+  
+%% ------- Do the B to A channel estimation ------- %%
+  Db2a_R=zeros(Niter*120,Nanta*301);
+  for i=0:119;
+    ifblock=receivedB2A(i*640+[1:640],indA);
+    ifblock(1:128,:)=[];
+    fblock=fft(ifblock);
+    fblock(1,:)=[];
+    fblock(151:360,:)=[];
+    Db2a_R((Niter-1)*120+i+1,:)=fblock.';
+  endfor  
+  HB2A=conj(repmat(Db2a_T,Niter,1)).*repmat(Db2a_R,1,Nantb);
+  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.");
+  endif
+  chanestsB2A=reshape(diag(repmat(Db2a_T,Niter,1)'*repmat(Db2a_R,1,Nantb)/(Niter*120)),301,Nantb);
+	   	
+# %% -- Some plotting code -- %%  (you can uncomment what you see fit)
+	# clf
+	# figure(1)
+	# for i=1:4 
+	#   subplot(220+i);plot(20*log10(abs(fftshift(fft(receivedA2B(:,i)))))); 
+	# endfor
+	
+	# figure(2)
+	# t=[0:512-1]/512*1e-2;
+	# plot(t,abs(tchanests))
+	# xlabel('time')
+	# ylabel('|h|')
+	
+	# 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')
+	
+
+	# figure(4)
+	# plot(20*log10(abs(fchanests))), ylim([40 100])
+
+	# %end
+	# fprintf(' done\n')	
+
+
+	# 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);
+	
+		
+else
+  if(!LSBSWITCH_FLAG) error("You have to set the LSB switch flag (LSBSWITCH_FLAG) in initparams.m.\n")
+  else error("You have to run init.params.m first!")
+  endif
+endif
diff --git a/targets/PROJECTS/TDDREC/runmeas_woduplex.m b/targets/PROJECTS/TDDREC/runmeas_woduplex.m
index 232b4d876e..a9a354ea85 100644
--- a/targets/PROJECTS/TDDREC/runmeas_woduplex.m
+++ b/targets/PROJECTS/TDDREC/runmeas_woduplex.m
@@ -2,15 +2,16 @@
 # % Organisation: Eurecom (and Linkoping University)
 # % E-mail: mirsad.cirkic@liu.se
 
-if(paramsinitialized)
-  disp("This code is so far only written for single runs. Multiple \
-      runs will overwrite the previous measurement data, i.e., the \
-      data structures are not defined for multiple runs. You will need to \
-      add code in order to save the intermediate measurements.")
+if(paramsinitialized && ~LSBSWITCH_FLAG)
+  disp(["\n\n------------\nThis code is, so far, only written for single runs. Multiple " ... 
+	"runs will overwrite the previous measurement data, i.e., the " ...
+	"data structures are not defined for multiple runs. You will need to " ...
+	"add code in order to save the intermediate measurements and the " ...
+	"corresponding timestamps.\n------------"])
   N=76800;
   M=4;
-  signalB2A=zeros(N,1);
   signalA2B=zeros(N,4);
+  signalB2A=zeros(N,4);
   indA=find(active_rfA==1);
   indB=find(active_rfB==1);
   Nanta=length(indA);
@@ -22,32 +23,39 @@ if(paramsinitialized)
   endif
   
 # %% ------- Prepare the signals for both A2B and B2A ------- %%
-  [Da2b_T, signalA2B]=genrandpskseq(N,M,amp);
-  signalA2B=repmat(signalA2B,1,4);
+  signalA2B=zeros(N,4);
   signalB2A=zeros(N,4);
-  [Db2a_T,tmps]=genorthqpskseq(Nantb,N,amp);
-  ind=1;
+  ia=1; ib=1;
+  Db2a_T=[];
   for i=1:4
-    if(indB(ind)==i)
-      signalB2A(:,i)=tmps(:,ind);
-      if(length(indB)> ind) ind=ind+1; endif
+    if(indA(ia)==i)
+      [Da2b_T, tmps]=genrandpskseq(N,M,amp);
+      signalA2B(:,i)=tmps;
+      if(length(indA)> ia) ia=ia+1; endif
+    endif
+    if(indB(ib)==i)      
+      % This part could be improved by creating fully orthogonal sequences
+      [tmpd, tmps]=genrandpskseq(N,M,amp);
+      signalB2A(:,i)=tmps;
+      Db2a_T=[Db2a_T tmpd];
+      if(length(indB)> ib) ib=ib+1; endif
     endif
   endfor
     
-# %% ------- Node A to B transmission/reception ------- %%	
-  rf_mode_current = rf_mode + (DMAMODE_TX+TXEN)*active_rfA +(DMAMODE_RX+RXEN)*active_rfB;
-  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);	
-  oarf_send_frame(card,signalA2B,n_bit);
-  receivedB2A=oarf_get_frame(card);
-  oarf_stop(card);
-  
-# %% ------- Node B to A transmission/reception ------- %%	
+# %% ------- Node B to A transmission ------- %%	
   rf_mode_current = rf_mode + (DMAMODE_TX+TXEN)*active_rfB +(DMAMODE_RX+RXEN)*active_rfA;
   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);
   oarf_send_frame(card,signalB2A,n_bit);
   receivedB2A=oarf_get_frame(card);
   oarf_stop(card);
 
+# %% ------- Node A to B transmission ------- %%	
+  rf_mode_current = rf_mode + (DMAMODE_TX+TXEN)*active_rfA +(DMAMODE_RX+RXEN)*active_rfB;
+  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);	
+  oarf_send_frame(card,signalA2B,n_bit);
+  receivedA2B=oarf_get_frame(card);
+  oarf_stop(card);
+  
 # %% ------- Do the A to B channel estimation ------- %%	
   Da2b_R=zeros(Niter*120,Nantb*301);
   for i=0:119;
@@ -56,17 +64,18 @@ if(paramsinitialized)
     fblock=fft(ifblock);
     fblock(1,:)=[];
     fblock(151:360,:)=[];
-    Da2b_R(iter*120+i+1,:)=vec(fblock);	      
+    Da2b_R((Niter-1)*120+i+1,:)=vec(fblock);	      
   endfor
-  HA2B=conj(Da2b_T).*Da2b_R;
+  HA2B=repmat(conj(Da2b_T),1,Nantb).*Da2b_R;
   phasesA2B=unwrap(angle(HA2B));
   if(mean(var(phasesA2B))>0.5) 
     disp("The phases of your estimates are a bit high (larger than 0.5 rad.), something is wrong.");
   endif
   
-  chanestsA2B=diag(Da2b_T'*Da2b_R)/size(Da2b_T,1);
-  for i=0:(Nantb-1)
-    fchanestsA2B(:,i+1)=[0; chanestsA2B(301*i+[1:150]); zeros(210,1); chanestsA2B(301*i+[151:301])];
+  chanestsA2B=reshape(diag(repmat(Da2b_T,1,Nantb)'*Da2b_R)/size(Da2b_T,1),301,Nantb);
+  fchanestsA2B=zeros(512,Nantb);
+  for i=1:Nantb
+    fchanestsA2B(:,i)=[0; chanestsA2B([1:150],i); zeros(210,1); chanestsA2B(151:301,i)];
   endfor
   tchanestsA2B=ifft(fchanestsA2B);
   
@@ -78,7 +87,7 @@ if(paramsinitialized)
     fblock=fft(ifblock);
     fblock(1,:)=[];
     fblock(151:360,:)=[];
-    Db2a_R(iter*120+i+1,:)=fblock.';
+    Db2a_R((Niter-1)*120+i+1,:)=fblock.';
   endfor  
   HB2A=conj(repmat(Db2a_T,Niter,1)).*repmat(Db2a_R,1,Nantb);
   phasesB2A=unwrap(angle(HB2A));
@@ -137,5 +146,7 @@ if(paramsinitialized)
 	
 		
 else
-  error("You have to run init.params.m first!")
-end
+  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
-- 
GitLab