Professional Documents
Culture Documents
Simulacion de Sistemas Mimo Multi Usuario Via Proc
Simulacion de Sistemas Mimo Multi Usuario Via Proc
net/publication/48140781
Article
Source: OAI
CITATIONS READS
0 626
2 authors, including:
Franklin Guailacela
Universidad de Especialidades Espíritu Santo (UEES)
2 PUBLICATIONS 0 CITATIONS
SEE PROFILE
All content following this page was uploaded by Franklin Guailacela on 31 May 2017.
DIAGONALIZACIÓN DE BLOQUES”
TESINA DE SEMINARIO
INGENIERO EN ELECTRÓNICA Y
TELECOMUNICACIONES
Presentado por:
GUAYAQUIL – ECUADOR
2010
AGRADECIMIENTO
y consejos.
DEDICATORIA
Jaime Barzola S.
DEDICATORIA
Franklin Guailacela R.
TRIBUNAL DE SUSTENTACIÓN
________________________ ________________________
________________________
DELEGADOR DE LA UNIDAD
DECLARACIÓN EXPRESA
________________________ ________________________
AGRADECIMIENTO ..................................................................................................ii
DEDICATORIA .........................................................................................................iii
RESUMEN...............................................................................................................vii
INTRODUCCIÓN .......................................................................................................x
4.4.2. Complemento…………………………………………………………..…62
CONCLUSIONES………………………………………………………………………….69
BIBLIOGRAFÍA…………………………………………………………………………….89
INTRODUCCIÓN
CAPÍTULO 1
frecuencias disponibles para la red celular, es decir ningún canal puede ser
reusado dentro del cluster [1]. Sin embargo, sí se reutilizarán las bandas
dúplex para usar, y un clúster lo conforman N celdas. Cada una de las celdas
manera:
S = k. N
𝐶 = 𝑀. 𝑆 = 𝑀. 𝑘. 𝑁
Esto puede ser considerado como una medida de capacidad para el sistema,
A las celdas que utilizan las mismas bandas de frecuencias se las llama
f1
f1
f1
𝑄 = 𝐷/𝑅
expresado como:
𝑆 𝑆
= 𝑖𝑜
𝐼
𝑖=1 𝐼𝑖
2.1.1):
−𝑛
𝑑
𝑃𝑟 = 𝑃𝑜
𝑑𝑜
6
−𝑛
𝑅
𝑆 = 𝑃𝑜
𝑑𝑜
𝑖𝑜
−𝑛
𝐷𝑖
𝐼= 𝑃𝑂
𝑑𝑜
𝑖=1
𝑆 𝑅 −𝑛
= 𝑖𝑜
𝐼 𝐷𝑖 −𝑛
𝑖=1
𝑆 𝑅 −𝑛
=
𝐼 𝐷 −𝑛 𝑖𝑜 1
𝑖=1
𝑆 𝑅 −𝑛
= −𝑛
𝐼 𝐷 𝑖𝑜
−𝑛
𝑆 𝐷/𝑅
=
𝐼 𝑖𝑜
𝑆 𝑄 −𝑛
=
𝐼 𝑖𝑜
Aquí vemos que esta relación depende del número de celdas interferentes,
tolerables [2].
subconjuntos, los cuales pueden ser asignados a cada celda de un modo fijo
o dinámico [4]. Cuando se realiza una llamada, uno de esos canales son
llamada, ese canal vuelve a estar disponible para una nueva llamada. Al
[4].
Anteriormente, los sistemas que poseían solo una antena, además de recibir
la señal útil en la parte del receptor, captaban las señales de los demás
ciudad, ambiente indoor, o cualquiera, las señales viajan por muchas rutas
matemáticamente:
Pensemos que un transmisor envía una señal cualquiera (f) en el tiempo t=0,
𝑥=𝑓 𝑡 ; 𝑡=0
transmitida, más de una señal será recibida, y cada una de ellas llegará en
siguiente manera:
𝑁−1
𝑦= 𝜌𝑖 𝑒 𝑗𝜃𝑖 𝑓(𝑡 − 𝜏𝑛 )
𝑖=0
𝑥(𝑡)
𝜏1 𝜏2 𝜏3 𝜏𝑁
𝜌1 𝑒 𝑗𝜃 1 𝜌2 𝑒 𝑗𝜃 2 𝜌3 𝑒 𝑗𝜃 3 𝜌𝑁 𝑒 𝑗𝜃𝑁
𝑦(𝑡)
En este caso, realizamos una grafica con 5 rutas, y obtuvimos una resultante
de una amplitud considerable, pero si notamos que está muy desfasada con
Como estamos enviando diferentes señales a través de las “t” antenas del
interferencia.
𝑦 = 𝐻𝑥 + 𝑛 (1.2)
en recepción.
como:
𝜌
𝐶 = 𝑙𝑜𝑔2 𝑑𝑒𝑡 𝐼𝑟 + 𝐻𝐻 ∗ (1.4)
𝑡
1. Diversidad.
2. Multiplexado.
deseados de la independencia.
entonces aplicar la técnica MIMO a cada uno de esos sub canales [13].
Lo que significa que las llamadas en una celda aun están limitadas por la
Las redes celulares están evolucionando cada vez más, y los investigadores
Las investigaciones en canales MIMO, tanto para simple usuario y multi usuario,
las tasas de información de todos los usuarios pero sujetos a una potencia
19
transmisor, la cobertura de las señales será menor que trabajar con una
menor cantidad.
ortogonal [15].
celulares [6].
Podemos hacer una analogía de la red MIMO multi-user con una red
sistema.
Figura 1.11. Analogía de un sistema MIMO multi-user con una red LAN
usando un HUB. Los datos de un usuario, le llegan a todos. Existe transmisión
ineficiente.
21
corresponde o no. Algo similar hacen las PCs en una red LAN, las cuales
o no.
funcionamiento del SWITCH en una red LAN, que solo le envía los datos al
ella y cada usuario del sistema; y teniendo estos datos, podremos calcular
Figura 1.12. Analogía de un Sistema MIMO con una red LAN usando un
SWITCH. Similar a lo que realiza BD.
muy importante tener una perfecta “información del estado del canal” (CSI)
𝑲
𝒎𝒂𝒙 𝟏
𝑪𝑩𝑫 = 𝑯 𝑴 = 𝟎, 𝒊 ≠ 𝒋 𝒍𝒐𝒈𝟐 𝑰𝒓 + 𝑯 𝑴 𝑴∗ 𝑯∗ (𝟏. 𝟓)
𝒊 𝒋 𝝈𝟐 𝒋 𝒋 𝒋 𝒋
𝒋=𝟏
sus límites vienen definidos por una región de capacidad, que es una región
CAPÍTULO 2
la siguiente tabla.
26
Symbol Parameter
𝛼 Pathloss exponent
𝑣𝑓𝑐
Dopler spread (maximum Doppler frecuency), 𝑓𝐷 = 𝑐
𝑓𝐷
Tabla 2.1
que la potencia recibida varíe sobre distancias muy largas (path loss),
𝜆2 𝐺𝑡 𝐺𝑟
𝑃𝑟 = 𝑃𝑡 (2.1)
(4𝜋𝑑)2
𝑐2 1
𝑃𝑟 = 𝑃𝑡 (2.2)
(4𝜋𝑑)2 𝑓 2
𝐺𝑡 𝐺𝑟 𝑡2 𝑟2
𝑃𝑟 = 𝑃𝑡 (2.3)
𝑑2
Una fórmula empírica muy común y muy simple usada para la perdida de
paso es:
∝
𝑑𝑜
𝑃𝑟 = 𝑃𝑡 𝑃𝑜 (2.4)
𝑑
∝
𝑑0
𝑃𝑟 = 𝑃𝑡 𝑃𝑜 𝜒 (2.5)
𝑑
Múltiples señales recibidas son causadas por reflexiones que son referidas
Figura 2.4.- Fast Fading (Rojo), Slow Fading (Verde) y Potencia total final
frecuencia.
32
independientes [20].
potencia del canal versus frecuencia para una señal transmitida a una
𝑓𝐷 = 𝑣𝑓𝑐 𝑐
33
𝑓1 − 𝑓2 ≤ 𝐵𝑐 → 𝐻 𝑓1 ≈ 𝐻(𝑓2)
𝑓1 − 𝑓2 ≥ 𝐵𝑐 → 𝐻 𝑓1 𝑦 𝐻 𝑓2 𝑠𝑜𝑛 𝑛𝑜 𝑐𝑜𝑟𝑟𝑒𝑙𝑎𝑐𝑖𝑜𝑛𝑎𝑑𝑎𝑠
permanece constante.
34
selectica. plana.
plana. selectiva.
diversidad. diversidad.
magnitud de fading.
Con respecto a los usuarios, se asumirá que ellos están muy distanciados,
por lo que el canal del usuario k será independiente con respecto al resto.
CAPÍTULO 3
COMPRENSIÓN DE LA SOLUCIÓN
De las diversas soluciones que hay para mitigar el problema que estamos
inversión del canal. Hace uso de una matriz de pre codificación lineal para
𝑦𝑖 = 𝑖 𝑤𝑗 𝑠𝑗 + 𝑛𝑖
𝑗 =1
pre codificación del usuario i, 𝑠𝑖 son los datos de ese mismo usuario, y 𝑛𝑖 es
de arriba, tenemos:
𝑦𝑖 = 𝑖 𝑤𝑖 𝑠𝑖 + 𝑖 𝑤𝑗 𝑠𝑗 + 𝑛𝑖
𝑗 =1;𝑗 ≠𝑖
propósito:
𝑖 𝑤𝑗 = 0 ; 𝑖 ≠ 𝑗
𝐻 = [1 𝑡 2 𝑡 3 𝑡 … … 𝑘 𝑡 ]𝑡
existe una combinación lineal entre sus filas o columnas, lo mismo que seria
pseudo inversa es una matriz única (𝑛 × 𝑚), que satisface las siguientes 4
condiciones. [23]
1. 𝐴. 𝐴+ . 𝐴 = 𝐴
2. 𝐴+ . 𝐴. 𝐴+ = 𝐴+
3. (𝐴. 𝐴+ )𝐻 = 𝐴. 𝐴+
4. 𝐴+ . 𝐴 𝐻
= 𝐴+ . 𝐴
𝑊 = 𝐻 + = 𝐻 𝐻 (𝐻𝐻 𝐻 )−1
40
matriz, ya que ellas formarán las matrices de pre codificación del algoritmo
𝑖 + 𝑊(: , 𝑖)
𝑤𝑖 = + =
𝑛𝑜𝑟𝑚(𝑖 ) 𝑛𝑜𝑟𝑚(𝑊(: , 𝑖))
normalización del vector dentro de ella, y 𝑊(: , 𝑖) nos indica que se toma toda
𝐻 = [𝐻1 𝑡 𝐻2 𝑡 𝐻3 𝑡 … … 𝐻𝑘 𝑡 ]𝑡
𝑀𝑠 = [𝑀1 𝑀2 𝑀3 … … 𝑀𝑘 ]
𝐵𝐷 = 𝐻𝑠 ∗ 𝑀𝑠
𝐻1
𝐻2
𝐻 = [𝐻1 𝑡 𝐻2 𝑡 𝐻3 𝑡 … … 𝐻𝑘 𝑡 ]𝑡 = ⋮
⋮
𝐻𝑘
𝐻1
𝐻2
𝐵𝐷 = 𝐻𝑠 ∗ 𝑀𝑠 = ⋮ 𝑀1 𝑀2 … 𝑀𝑘
⋮
𝐻𝑘
42
𝐻1 𝑀1 ⋯ 𝐻1 𝑀𝑘
𝐻2 𝑀1 𝐻2 𝑀𝑘
⋮ ⋱ ⋮
𝐵𝐷 = ⋮ ⋮ ⋮
⋮ ⋱ ⋮
𝐻𝑘 𝑀1 ⋯ 𝐻𝑘 𝑀 𝑘
𝐻1 𝑀1 0 0
𝑜 𝐻2 𝑀2 0
⋮ ⋱ ⋮
𝐵𝐷 = ⋮ ⋮ ⋮
0 ⋱ ⋮
0 0 𝐻𝑘 𝑀 𝑘
𝑁𝑟 = 1, comprobaremos lo siguiente:
𝐵𝐷 𝑁𝑟 =1 = 𝐻𝑠 ∗ 𝑊𝑧𝑓
cuál calcula las matrices BD, Hs, Ms, y ZF, y efectivamente, se cumple lo que
establecimos:
𝐵𝐷 𝑁𝑟 =1 = 𝐻𝑠 ∗ 𝑊𝑧𝑓
43
simple usuario, pero estamos viendo, que el mismo algoritmo (ZF), se puede
usar para ambientes multi usuarios, en los cuales cada uno tiene una sola
usuarios en el sistema.
Con BD, la matriz de pre codificación de cada usuario, cae en el espacio nulo
buscar una determinada matriz, cuyo producto con otra matriz me de como
resultado una matriz llena de cero. De forma más detallada, veremos esto al
44
FEEDBACK para la obtención del canal. Sin embargo, como sabemos que el
se realiza lo siguiente:
posee la BS, sea la misma que el canal físico real. Sin embargo, el canal
pueden ser usadas para conocer el estado del canal de cada dispositivo
[24]
ruido.
retroalimentación al mismo.
pre codificación de acuerdo a la estimación que posee del CSI, pero debido a
𝑡≥ 𝑟𝑖 (3.1)
𝑖=1
Figura 3.1. Esquema MIMO multi-usuario, junto con la matriz Pre Coding en la
parte del transmisor.
𝑦𝑘 = 𝐻𝑘 𝑥 + 𝑛𝑘 3.2
Donde:
usuario k.
𝑇
x= x1 ⋯ xq ⋯ xt ; Este vector es la señal transmitida por todas las t antenas,
expresar como:
50
𝑦𝑘 = 𝐻𝑘 𝑥𝑘 + 𝐻𝑘 𝑥𝑖 + 𝑛𝑘 (3.3)
𝑖=1,𝑖≠𝑘
𝐾
Donde 𝑖=1;𝑖≠𝑘 𝐻𝑘 𝑥𝑖 representa la interferencia inter usuario para el receptor
𝑏𝑘 ∈ 𝐶 𝑟×1
𝑊𝑘 ∈ 𝐶 𝑡×𝑟
𝑥𝑘 = 𝑊𝑘 𝑏𝑘 (3.4)
𝑏𝑘 = 𝑅𝑘 𝐻𝑘 𝑊𝑖 𝑥𝑖 + 𝑛𝑘 (3.5)
𝑖=1
51
𝑁
𝑝𝑟𝑒 −𝑐𝑜𝑑𝑖𝑓𝑖𝑐𝑎𝑑𝑎
𝑦𝑘 = 𝐻𝑘 𝑊𝑘 𝑏𝑘 + 𝐻𝑘 𝑊𝑖 𝑏𝑖 + 𝑛𝑘 (3.6)
𝑖=1,𝑖≠𝑘
𝐻𝑖 𝑊𝑘 = 0 ; ∀𝑖 ≠ 𝑘 (3.7)
Entonces tendremos:
𝑦𝑘 = 𝐻𝑘 𝑊𝑘 𝑏𝑘 + 𝑛𝑘 (3.8)
el espacio nulo (se define ESPACIO NULO en Anexo D) de los canales del
𝑇 𝑇 𝑇
𝐻𝑘 = 𝐻1𝑇 … 𝐻𝑘−1 𝐻𝑘+1 … 𝐻𝑁𝑇 (3.9)
52
significa que no existe combinación lineal entre sus filas o columnas; o que
matriz 𝐻𝑘 .
𝑇
𝐻𝑘 = 𝑈𝑘 𝑘0 𝑉𝑘1 𝑉𝑘0 (3.11)
anula.
𝑇
𝐻𝑘 = 𝐻𝑘 𝑉𝑘0 = 𝑈𝑘 0 𝑉𝑘1 𝑉𝑘0 (3.12)
𝑘
obtendremos:
𝑦𝑘 = 𝐻𝑘 𝑉𝑘0 𝑉𝑘1 𝑏𝑘 + 𝑛𝑘
tenemos:
𝑇
𝑦𝑘 = 𝑈𝑘 0 𝑉𝑘1 𝑉𝑘0 𝑉𝑘1 𝑏𝑘 + 𝑛𝑘
𝑘
𝑇
Si hacemos en producto entre 𝑘0 𝑉𝑘1 𝑉𝑘0 , nos daremos cuenta que aquí
1𝑇 1
𝑦𝑘 = 𝑈𝑘 𝑘 𝑉𝑘 𝑉𝑘 𝑏𝑘 + 𝑛𝑘
55
Cuando descomponemos una matriz usando SVD, tanto las matrices U como
𝐻 𝐻 𝐻
V, son ortonormales, es decir, que 𝑈𝑘 . 𝑈𝑘 = 𝐼, o 𝑈𝑘 . 𝑈𝑘 = 𝐼, y que 𝑉𝑘 . 𝑉𝑘 =
𝐻
𝐼, o 𝑉𝑘 . 𝑉𝑘 = 𝐼. Sabiendo esto, reducimos aun más nuestra expresión.
𝑦𝑘 = 𝑈𝑘 𝑘 𝐼𝑟 𝑏𝑘 + 𝑛𝑘
identidad, lograremos una matriz de una sola columna cuyos elementos son
1/2
𝜆11 0 1 0
𝑘 . 𝐼𝑟 = ⋱ . ⋱
1/2 0 1
0 𝜆𝑘𝑘
1/2
𝜆11 0
𝑘 . 𝐼𝑟 = ⋱
1/2
0 𝜆𝑘𝑘
1/2
𝜆11 0
𝑦𝑘 = 𝑈𝑘 ⋱ 𝑏𝑘 + 𝑛𝑘
1/2
0 𝜆𝑘𝑘
y multiplicando tendremos:
1/2
𝜆11 0
𝑦𝑘 = 𝑈𝑘 ⋱ (𝑏𝑘1 𝑏𝑘2 𝑏𝑘3 … 𝑏𝑘𝑟 )𝑡
1/2
0 𝜆𝑘𝑘
56
1/2 1/2 𝑇
𝑦𝑘 = 𝑈𝑘 𝜆𝑘1 𝑏𝑘1 … 𝜆𝑘𝑟 𝑏𝑘𝑟 + 𝑛𝑘 (3.15)
1/2 1/2 𝑇
𝑦𝑘 = 𝑈𝑘𝑇 𝑦𝑘 = 𝑈𝑘𝑇 𝑈𝑘 𝜆𝑘1 𝑏𝑘1 … 𝜆𝑘𝑟 𝑏𝑘𝑟 + 𝑈𝑘𝑇 𝑛𝑘
1/2 1/2 𝑇
𝑦𝑘 = 𝜆𝑘1 𝑏𝑘1 … 𝜆𝑘𝑟 𝑏𝑘𝑟 + 𝑛𝑘 (3.16)
transformación unitaria.
57
CAPÍTULO 4
MODELAMIENTO Y SIMULACIÓN
bloque modulado. La mayor parte del código fue generado por nosotros
Figura 4.1 Esquema del transmisor y receptor para un sistema MIMO Multi-user.
Crea los datos que el transmisor enviará a cada usuario, tomando en cuenta
entre 0 y M-1.
for(i = 1:Nuser)
temp(:,:,i) = 1/sqrt(2)*[randn(Nr,Nt) + j*randn(Nr,Nt)]; % Rayleigh channel
H(:,:,i) = abs(temp(:,:,i));
end;
4.3. Función BD
Htemp = temp2';
V0 = null(Htemp);
Hpp = H(:,:,user)*V0;
[U,D,V] = svd(Hpp);
V1 = V;%(:,1:x);
%pot = potencia(D);
T = V0*V1; %*pot;
G = conj(U');%Post-coding RECEPTOR,esto es: transpuesta conjugada de U
pre_coding = T;
post_coding = G;
4.4.1. Fuente de Datos.- Son los datos que se van a modular por el transmisor;
determinar el tamaño del prefijo cíclico, además del número de puntos para
4.4.2. Complemento.- En este bloque, se trata que los datos de entrada estén con
esto no es así, entonces se agregan ceros al final de los datos para cumplir
el objetivo.
% Make the serial stream a matrix where each column represents a pre-
OFDM
% First: Find out the number of colums that will exist after reshaping
num_cols=length(qpsk_modulated_data)/block_size;
4.4.4. IFFT, P/S y CP.- Aquí también se variará el orden de los bloques
queremos.
63
transformada inversa de Fourier (IFFT), y con ella, se generan los datos del
medio de transmisión.
OFDM [26]. Aquí tenemos un grafico que detalla un poco los componentes
del demodulador:
64
Demodulation De
Remove
CP S/P FFT
QPSK
P/S Inter Data
Leaving
[rows_ifft_data cols_ifft_data]=size(ifft_data);
cp_len = ceil(0.1*block_size);
no_of_fft_points = block_size;
recvd_signal = dato_in;
% 5. Remove CP
recvd_signal_matrix(1:cp_len,:)=[];
% 6. Perform FFT
for i=1:cols_ifft_data,
% FFT
fft_data_matrix(:,i) = fft(recvd_signal_matrix(:,i),no_of_fft_points);
end
qpsk_demodulated_data = pskdemod(recvd_serial_data,M);
dato_out = qpsk_demodulated_data;
hacemos en nuestro código, es que “t” sea igual al producto entre “r “y “K”.
Las variables de salida son los datos de entrada de cada usuario, los datos a
continuación:
66
el SNR.
CONCLUSIONES
la capacidad se va acotando.
4. Es necesario tener un canal de retorno para el envío del estado del canal al
transmisor, para que este, genere las matrices de pre codificación correctas
inter usuario.
71
ANEXO A
%Multipath
n = 5; %Numero de path
y = 0;
for i=1:n
angle = 2*pi*rand;
fac_pot = rand;
x(:,:,i) = A * fac_pot * sin(2*pi*f*t + angle);
y = y + x(:,:,i);
end;
forma = ['bx-';'r+:';'k*-';'bo:';'rx-';'k+:';'b*-';'ro:';'kx-';'b+:';'r*-';'ko:'];
figure(1);
for i=1:n
plot(t,x(:,:,i),forma(i,:));
hold on;
end;
grid on;
title('COMPONENTES MULTIPATH');
xlabel('Tiempo [seg]');
ylabel('Amplitud [mtrs]');
figure(2)
plot(t,y,'-b*');
legend(['Señal Original - Amplitud=',num2str(A)...
,' - Numero de Path=',num2str(n)],2);
grid on;
title('RESULTANTE MULTIPATH');
xlabel('Tiempo [seg]');
ylabel('Amplitud [mtrs]');
72
ANEXO B
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% FAST Y SLOW FADING
%
% Fuente:
% http://www.ece.udel.edu/~bohacek/Classes/SensorNets2007/...
% propagationhomework.pdf
%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
Po = 20;
do = 100;
for i=1:length(d)
X = mean(exprnd(1,W,1)); %Fast fading
Y = normrnd(0,s,1,1); %Log-normal shadowing
Path(i) = Po - (10*n*log10(d(i)/do));
fast(i) = Path(i) + X;
slow(i) = Path(i) + Y;
total (i) = Path(i) + X + Y;
end;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
figure(1);
plot(d,Path,'-r',d,fast,'-b');
grid on
xlabel('Distancias de Recepcion, [mtrs]')
ylabel('Potencia de Recepcion, [dB]')
title('Perdida de paso y Fast Fading')
73
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
figure(2)
plot(d,Path,'-r',d,slow,'-b');
grid on
xlabel('Distancias de Recepcion, [mtrs]')
ylabel('Potencia de Recepcion, [dB]')
title('Perdida de Paso y Slow Fading')
legend(['Perdida de Paso. Pot referente = '...
,num2str(Po),'.Dist referente = ',num2str(do)],...
['Slow Fading. Varianza = ',num2str(s)],2);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
figure(3);
plot(d,Path,'-r',d,total,'-b');
grid on
xlabel('Distancias de Recepcion, [mtrs]')
ylabel('Potencia de Recepcion, [dB]')
title('Perdida de Paso y Potencia total')
legend(['Perdida de Paso. Pot referente = '...
,num2str(Po),'.Dist referente = ',num2str(do)],...
['Potencia Total = Fast + Slow'],2);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
figure(4);
plot(d,fast,'-r',d,total,'-b');
grid on
xlabel('Distancias de Recepcion, [mtrs]')
ylabel('Potencia de Recepcion, [dB]')
title('Fast Fading y Potencia total')
legend(['Fast Fading']...
,['Potencia Total = Fast + Slow'],2);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%%
74
figure(5);
plot(d,fast,'-r',d,slow,'-g',d,total,'-b');
grid on
xlabel('Distancias de Recepcion, [mtrs]')
ylabel('Potencia de Recepcion, [dB]')
title('Fast Fading, Slow Fading, Pot. total')
legend('Fast Fading','Slow Fading'...
,'Potencia Total = Fast + Slow',2);
75
ANEXO C
filas y columnas.
como:
𝐻 = 𝑈 ∙ 𝐷 ∙ 𝑉𝐻
Siendo;
U y V matrices ortonormales.
𝐷 = 𝑈𝐻 ∙ 𝐻 ∙ 𝑉
𝐻 ∙ 𝐻 𝐻 y 𝐻 𝐻 ∙ 𝐻, que son los mismos para las dos matrices. Estas dos matrices son
76
hermíticas, por lo que sus autovalores son positivos o ceros. Se denomina 𝑟 𝑟 < 𝑛
𝐻∙𝑉 =𝑈∙𝐷
𝑈𝐻 ∙ 𝐻 = 𝐷 ∙ 𝑉 𝐻
Se calcula la matriz 𝐻 𝐻 ∙ 𝐻.
expresión:
𝑈𝑖 = 𝐻 ∙ 𝑉𝑖 /𝑑𝑖
𝑈 = 𝐻 ∙ 𝑉 ∙ 𝐷−1
MIMO esto no es necesario, porque los elementos nulos de la diagonal indican que
sus modos no propagan energía, por tanto sus antenas permanecen inactivas.
78
ANEXO D
ESPACIO NULO
𝑁𝐴 = 𝐱 ∈ 𝑹𝑛 : 𝐴𝐱 = 𝟎
Entonces, se define:
Ejemplo
𝑥 + 2𝑦 − 𝑧 = 0
2𝑥 − 𝑦 + 3𝑧 = 0
1 2 −1
Sea 𝐴 = . Entonces,
2 −1 3
79
1 2 −1 0 1 2 −1 0 1 2 −1 0 1 0 1 0
2 −1 3 0 0 −5 5 0 0 1 −1 0 0 1 −1 0
−𝑧 −1
𝑧 , Así, 𝑁𝐴 está generado por 1 , y 𝑣 𝐴 = 1.
𝑧 1
80
ANEXO E
Función MIMO_MU
if(Nt ~= (Nr*Nuser))
disp('EL MINIMO DE ANTENAS TRANSMISORAS ES LA');
disp('MULTIPLICACION DE Nr*Nuser');
dato_in = 0;
dato_out = 0;
H = 0;
pre = 0;
else
setup_proyect;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% GENERACION DE DATOS PARA CADA USER
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
for i=1:Nuser
data_user_in(:,:,i) = gen_datos(no_of_data_points*Nr, M); %Matriz
1xNo_point*Nr
dato_antena_user(:,:,i) = reshape(data_user_in(:,:,i), Nr, no_of_data_points);
%No_point X Nt
end;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% TRANSMISOR DE DATOS EN LA ESTACION
% BASE. Tambien se hace la multiplicacion
% con cada matriz Pre-coding
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
for i = 1:Nuser
temp = dato_antena_user(:,:,i);
[Htemp] = gen_channel(Nuser,Nr,Nt);
H(:,:,i) = Htemp(:,:,i);
[pre(:,:,i), post(:,:,i)] = BD(Htemp, Nuser, i);
81
x = pre(:,:,i) * ofdm_tx(:,:,i);
[y,xy,acum_signal,veces] = setup_recep(acum_signal,ifft_data,Nr,Nuser,veces);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% TRANSMISION POR EL CANAL, RECEPCION, Y POST
% CODIFICACION.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
for k=1:Nuser
% y() = Transmision de los datos por el canal.
% La variable "y", obtiene la señal recibido en el receptor,
% luego de haber pasado por el Canal.
y(:,:,k) = (Htemp(:,:,k)*x); % Señal Tx pasada por el CANAL. Señal
recibida
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% SUMA DE RUIDO ADITIVO BLANCO GAUSIANO
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%y(:,:,k) = y(:,:,k) + (10^(-Es_N0_dB/20)*awgn_pro(y(:,:,k))); % additive
white gaussian noise
temp = y(:,:,i);
for r=1:Nr
y(r,:,k) = awgn(temp(r,:),SNR_dB,0);
end;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% DEMODULADOR OFDM
% Demodula todas las señales de cada user
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
for i=1:Nuser
temp = acum_signal(:,:,i);
for j=1:Nr
demod_out(j,:,i) = demod_ofdm(temp(j,:),block_size,M,ifft_data,num_cols);
end;
data_user_out(:,:,i)= reshape(demod_out(:,:,i), 1, Nr*no_of_data_points);
end;
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% VARIABLES DE SALIDA
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
dato_in = data_user_in;
dato_out = data_user_out;
end;
83
ANEXO F
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% BER vs SNR_dB
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clear all, close all, clc
Nr = 3;
Nuser = 4;
Nt = 12; %Nr*Nuser; % Consideracion
SNR_dB = [0:1:40];
BER = zeros(1,length(SNR_dB),Nuser);
for i=1:length(SNR_dB)
[in,out,H,PreCoding] = MIMO_MU(Nuser,Nt,Nr,SNR_dB(i));
n = length(out(:,:,1));
[NUMBER,RATIO] = symerr(in(:,:,1),out(:,:,1));
BER(i) = NUMBER/n;
end;
g1 = figure(1);
%semilogy(SNR_dB,BER(:,:,1));
scatter(SNR_dB,BER(:,:,1))
grid on
xlabel('SNR dB por antena Rx, dB')
ylabel('BER')
title('BER vs. SNR dB por antena Rx')
legend(['Nuser = ',num2str(Nuser),' ,Nt = ',num2str(Nt),' ,Nr = ',num2str(Nr)],2);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% CAPACIDAD vs SNR
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clear all, close all, clc
Nr = 3;
84
Nuser = 4;
Nt = 12; %Nr*Nuser; % Consideracion
SNR_dB = [0:3:35];
SNR_V = 10.^(SNR_dB/10);
for i=1:length(SNR_dB)
[in,out,H,PreCoding] = MIMO_MU(Nuser,Nt,Nr,SNR_dB(i));
CAPACIDAD(i) = capacidad(SNR_V(i),H,PreCoding);
end;
g2 = figure(2);
plot(SNR_dB,CAPACIDAD,'r+:');
legend(['Nuser = ',num2str(Nuser),' ,Nt = ',num2str(Nt),' ,Nr = ',num2str(Nr)],2);
grid on;
title('SUMA DE CAPACIDAD EN MIMO MULTIUSER SYSTEM');
xlabel('SNR in dB por antena Rx');
ylabel('Sum Capacity bits/s/Hz');
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% CAPACIDAD vs user
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clear all, close all, clc
Nr = 3;
Nuser = [2:1:20];
Nt = Nr*Nuser;%Nr*Nuser; % Consideracion
SNR_dB = 15;
SNR_V = 10.^(SNR_dB/10);
for i=1:length(Nuser)
[in,out,H,PreCoding] = MIMO_MU(Nuser(i),Nt(i),Nr,SNR_dB);
CAPACIDAD(i) = capacidad(SNR_V,H,PreCoding);
end;
g3 = figure(3);
plot(Nuser,CAPACIDAD,'r*:');
legend(['SNR dB = ',num2str(SNR_dB)],2);
grid on;
85
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% CAPACIDAD vs SNR vs USER
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clear all, close all, clc
Nr = 3;
Nuser = [5:1:9];
Nt = Nr*Nuser; %Nr*Nuser % Consideracion
SNR_dB = [15:3:50];
SNR_V = 10.^(SNR_dB/10);
forma = ['bx-';'r+:';'k*-';'bo:';'rx-';'k+:';'b*-';'ro:';'kx-';'b+:';'r*-';'ko:'];
temp = []; % Para acumular las leyendas
for j=1:length(Nuser)
for i=1:length(SNR_dB)
[in,out,H,PreCoding] = MIMO_MU(Nuser(j),Nt(j),Nr,SNR_dB(i));
CAPACIDAD(j,i) = capacidad(SNR_V(i),H,PreCoding);
end;
end;
g4=figure(4);
for i=1:length(Nuser)
plot(SNR_dB,CAPACIDAD(i,:),forma(i,:));
temp = [temp ; 'Nuser=',num2str(Nuser(i)),',Nt=',num2str(Nt(i)),',Nr=',num2str(Nr)];
hold on;
end;
legend(temp,2);
grid on;
title('Capacidad vs SNR vs USERS');
xlabel('SNR in dB');
ylabel('Sum Capacity bits/s/Hz');
86
ANEXO G
DEMOSTRACIÓN: BD (r=1) cumple lo mismo que ZF
clear all;
close all;
clc;
Nr = 1;
Nuser = 3;
[H,M] = MIMO_MU_PSEUDO(Nuser,Nt,Nr,45);
%Definimos Matriz Ms
Ms = [];
for(i = 1:Nuser)
temp = M(:,:,i);
Ms = cat(2,Ms,temp);
end;
%Defino Hs
Hs = [];
for i = 1:Nuser
temp = H(:,:,i);
87
Hs = cat(2,Hs,temp');
end;
Hs = Hs';
BD=Hs*Ms;
BDinv = inv(BD);
%%%%%%%%%%%%%%%%%%
% PSEUDO-INVERSE CHANNEL
%%%%%%%%%%%%%%%%%
Mps = [];
for i = 1:Nuser
Modulo = norm(Mps(:,i));
Mps(:,i) = Mps(:,i)/Modulo;
end;
BD %Matriz de BD
ARCHIVO MIMO_MU_PSEUDO.m
setup_proyect;
for i=1:Nuser
end;
89
BIBLIOGRAFÍA
Celular” -
http://bieec.epn.edu.ec:8180/dspace/bitstream/123456789/547/8/T104
http://www.edicionsupc.es/ftppublic/pdfmostra/TL03204M.pdf. Año de
publicación: 2003.
http://www.monografias.com/trabajos14/celularhist/celularhist.shtml.
2002
2008.
16. Jia Liu, Thomas Hou, Yi Shi, Hanif Sherali, Sastry Kompella. “On the
17. Bin Song and Martin Haardt. “Analysis and Improvements of Linear
2009.
21. Zukang Shen, Runhua Chen, Jeffrey G. Andrews, Robert Heath, Jr,
octubre / 2009.
http://en.wikipedia.org/wiki/Moore-Penrose_pseudoinverse. Consulta:
12 / enero / 2010.
26. Ami Wiesel, Yonina C. Eldar and Shlomo Shamai – “ZERO FORCING
http://es.wikipedia.org/wiki/Distribuci%C3%B3n_de_Rayleigh.
http://www.pages.drexel.edu/~sd65/ofdm/sample_code/ofdm_012/ofd