TSS, Lab02 - Operaciones Básicas Sobre Señales en Matlab

Descargar como docx, pdf o txt
Descargar como docx, pdf o txt
Está en la página 1de 21

PRÁCTICA No.

2
OPERACIONES BÁSICAS SOBRE SEÑALES EN MATLAB®

1. OBJETIVOS

1.1. Objetivo General

 Realizar operaciones básicas sobre señales utilizando MATLAB®.

1.2. Objetivos Específicos

 Conocer los comandos, algoritmos y funciones necesarias para realizar operaciones


básicas de señales en MATLAB®.
 Identificar las operaciones a utilizar en cada una de las representaciones de una señal en
su expresión matemática.

2. JUSTIFICACIÓN

La realización de esta práctica le permitirá al estudiante conocer y aplicar los conocimientos


teóricos vistos en clase sobre las operaciones básicas sobre señales en MATLAB®.

3. MARCO TEÓRICO

Un aspecto de fundamental importancia en el estudio de señales es el uso de sistemas para


procesar o manipular señales. Este aspecto suele implicar una combinación de algunas
operaciones básicas. En particular, es posible identificar dos clases de operaciones:
operaciones efectuadas sobre variables dependientes y operaciones efectuadas sobre la
variable independiente.

3.1. Operaciones efectuadas sobre variables dependientes

 Escalamiento de amplitud. Considere una señal x ( t ). La señal y ( t ) resultante del


escalamiento de amplitud aplicado a x ( t ) se define mediante:

y ( t ) =c∗x ( t )

Donde c es el factor de escala. De acuerdo con lo anterior, el valor de y ( t ) se obtiene


multiplicando el valor correspondiente de x ( t ) por el escalar c. De manera similar para
señales en tiempo discreto:

y [ n ] =c∗x [ n ]

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 1 de 21
Figura 1. Operación de escalamiento de amplitud: Señal en tiempo continuo de amplitud y duración .
Versión escalada en amplitud de por un factor de .

 Suma. Considere dos señales x 1 ( t ) y x 2 ( t ). La señal y ( t ) obtenida por la suma de estas dos
señales está definida por:

y ( t ) =x1 ( t )+ x 2 ( t )

De modo similar para señales en tiempo discreto:

y [ n ] =x 1 [ n ] + x 2 [ n ]

Figura 2. Operación de suma: . Las amplitudes de las señales y se suman en los instantes de tiempo
correspondientes para formar la señal .
 Multiplicación. La señal y ( t ) resultante de la multiplicación de dos señales x 1 ( t ) y x 2 ( t ) está
definida por:

y ( t ) =x1 ( t )∗x 2 ( t )

Es decir, en cada tiempo pre-escrito t el valor de y (t) está dado por el producto de los
valores correspondientes de x 1 ( t ) y x 2 ( t ). De manera similar para señales discretas:

y [ n ] =x 1 [ n ]∗x2 [ n ]

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 2 de 21
Figura 3. Operación de multiplicación: . Las amplitudes de las señales y se multiplican en los instantes
de tiempo correspondientes para formar la señal .
 Diferenciación. La derivada de x ( t )con respecto al tiempo se define como:

d
y (t)= x (t)
dt

Figura 4. Operación de diferenciación: .

 Integración. La integral de x ( t ) con respecto al tiempo se define como:


t
y ( t ) =∫ x ( τ ) dτ
−∞

Donde τ es la variable de integración.

Figura 5. Operación de integración: .

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 3 de 21
3.2. Operaciones efectuadas sobre la variable independiente

 Escalamiento de tiempo. Es la operación de compresión o expansión en el tiempo. La


señal y ( t ) obtenida por el escalamiento de la variable independiente, tiempo t, por un
factor a se define como:

y ( t ) =x( a∗t)

Si a> 1, la señal y ( t ) es una versión comprimida de x ( t ). Si, por otro lado, 0< a<1, la señal
y ( t ) es una versión expandida (alargada) de x ( t ). Estas dos operaciones se ilustran en la
figura 6.

Figura 6. Operación de escalamiento de tiempo: Señal en tiempo continuo . Versión comprimida de por un
factor de . Versión expandida de por un factor de .

En el caso de tiempo discreto:

y [ n ] =x [ k∗n ]

Donde k se define solo para valores enteros y con las mismas observaciones del factor a.
Es importante mencionar que cuando k > 1, algunos valores de la señal en tiempo discreto
y [ n ] se pierden, como se ilustra en la figura 7.

Figura 7. Efecto de escalamiento de tiempo en una señal en tiempo discreto: Señal en tiempo discreto .
Versión comprimida de por un factor de , con algunos valores de la original perdidos como resultado de la
compresión.

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 4 de 21
 Reflexión. Sea y ( t ) la señal obtenida al sustituir la variable de tiempo t con −t , como se
muestra mediante:

y ( t ) =x (−t )

La señal y ( t ) representa la versión reflejada de x ( t ) en torno al eje de amplitud, lo que es


equivalente a “doblar” la señal (rotación de 180 ° ) en torno a la línea t=0 o simplemente a
intercambiar el “pasado” y el “futuro” de la señal de tiempo. Los siguientes dos casos son de
interés especial:

o Señales pares, para las cuales x (−t )=x ( t )para todo t ; es decir, una señal par es la misma
que su versión reflejada.
o Señales impares, para las cuales se tiene que x (−t )=−x ( t )para todo t ; es decir, una señal
impar es el negativo de su versión reflejada.

Nota: El tema de las señales pares e impares se estudiarán en detalle en una práctica
posterior.

Se aplican observaciones similares a las señales en tiempo discreto, teniendo:

y [ n ] =x [−n ]

Figura 8. Operación de reflexión: Señal en tiempo continuo . Versión reflejada de alrededor del origen.

 Corrimiento en tiempo o desplazamiento. La versión desplazada de x ( t ) se define


como:

y ( t ) =x( t−t 0 )

Donde t 0 es un número real que representa el corrimiento en el tiempo. Si t 0> 0, entonces


la señal es retrasada t 0 unidades de tiempo, es decir, la forma de onda que representa x ( t )
se corre intacta a la derecha, con respecto al eje de tiempo. Físicamente, t 0 no puede
tomar valores negativos, pero desde un punto de vista analítico, si t 0< 0, entonces la señal
es adelantada t 0 unidades de tiempo, es decir, la forma de onda se corre a la izquierda.

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 5 de 21
Figura 9. Operación de corrimiento en el tiempo: Señal en tiempo continuo , de amplitud y duración ,
simétrica en torno al origen. Versión recorrida o desplazada de en unidades de tiempo.

En el caso de una señal en tiempo discreto x [ n ], se define la versión desplazada en el


tiempo como:

y [ n ] =x [ n−m ]

Donde el corrimiento m debe ser un número entero; éste puede ser positivo o negativo.

3.3. Regla de la precedencia para el corrimiento en el tiempo y el escalamiento en


el tiempo

Sea una señal y ( t ) que se obtiene de otra señal x ( t ) por medio de una combinación de
corrimiento en el tiempo y escalamiento en el tiempo, como se describe a continuación:

y ( t ) =x ( a∗t−t 0 )

Esta relación cumple las siguientes condiciones:

y ( 0 )=x (−t 0 ) y y ( ta )=x ( 0)


0

Las cuales brindan útiles comprobaciones en y ( t ) en términos de valores correspondientes


de x ( t ).

Para obtener correctamente y ( t ) a partir de x ( t ), las operaciones de corrimiento y


escalamiento de tiempo deben efectuarse en el orden correcto. El orden apropiado se basa
en el hecho de que la operación de escalamiento siempre sustituye a t por a∗t, en tanto que
la operación de corrimiento siempre remplaza t por t−t 0. En consecuencia, la operación de

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 6 de 21
corrimiento se efectúa primero sobre x ( t ), lo que origina una señal intermedia v ( t ) definida
por:
v ( t )=x ( t−t 0 )

Luego, la operación de escalamiento de tiempo se realiza sobre v ( t ), produciéndose la salida


deseada.

y ( t ) =v ( a∗t ) =x ( a∗t−t 0 )

Se aplican comentarios similares al caso de señales en tiempo discreto, obteniendo:

y [ n ] =v [ k∗n ] =x [ k∗n−m ]

Figura 10. Regla de la precedencia aplicada correctamente: Señal en tiempo continuo , de amplitud y
duración , simétrica en torno al origen. Señal intermedia , representando la versión recorrida en el tiempo
de en unidades de tiempo. Señal deseada , resultado de la compresión de por un factor de .

Figura 11. Regla de la precedencia aplicada incorrectamente: Señal en tiempo continuo , de amplitud y
duración , simétrica en torno al origen. Señal escalada en el tiempo . Señal obtenida recorriendo 3
unidades de tiempo.

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 7 de 21
4. TRABAJO PREVIO

Resuelva de forma teórica los siguientes ejercicios:

a. Para la señal x (t ) dada como:


t ,−1< t<0
{
x ( t )= 1 ,1<t ≤2
0 , otros valores de t
grafique y halle las expresiones analíticas para las siguientes funciones:
 x ( t −2 ) −t 1
 x ( 2 t−4 )
 x +
3 2 ( )
 x ( 3−t )

b. Para la señal de tiempo discreto mostrada en la figura, dibuje cada una de las señales
siguientes:
 x [ 2−n ] −n+8
 x [ 3 n−4 ]
 x
4 [ ]
2  x [ 2−n ] + x [ 3 n−4 ]
[
 x n+1
3 ]

5. DESARROLLO DE LA PRÁCTICA

Operaciones efectuadas sobre variables dependientes


Escalamiento de amplitud
Sintaxis
 No aplica.

Descripción
Para realizar escalamiento de amplitud en MATLAB® basta con multiplicar mediante el

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 8 de 21
operador * una señal dada por un escalar. Así, por ejemplo, dada una señal x ( t ) que se
desea escalar en una amplitud A, la sintaxis sería: A.*x(t). El punto “.” antes del operador
* se hace necesario siempre y cuando la variable de tiempo de la que depende la señal este
definida vectorialmente, en caso de que este definida simbólicamente se omite el punto.
Se aplican comentarios similares al caso de señales en tiempo discreto.
Comandos
%% Escalamiento de Amplitud en Tiempo Continuo y Discreto
A = 5; %Factor de Escalamiento de amplitud
Fs = 10000; %Frecuencia de Muestreo
f = 0.1; %Frecuencia Fundamental Hz
T = 3*(1/f); %Número de Periodos a Graficar
t = 0:1/Fs:T-1/Fs; %Tiempo de Simulación
xt = A.*sin(2*pi*f.*t); %Generación de Señal
subplot(2,1,1),plot(t,xt),grid on,ylim([-A A]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('x(t)')
n = 0:T; %Vector de Tiempo Dicreto
xn = A.*sin(2*pi*f.*n); %Generación de Señal x[n]
subplot(2,1,2),stem(n,xn),grid on,ylim([-A A]) %Grafica
xlabel('Tiempo (n)'),ylabel('Amplitud'), title('x[n]')
Gráfica

Suma
Sintaxis
 No aplica.

Descripción

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 9 de 21
Para realizar la suma de dos señales en MATLAB® se requiere, además de utilizar el
operador +, que las dos señales a sumar compartan la misma variable de tiempo; ya sea un
vector (variable de tiempo numérica) o una variable simbólica.

Comandos
%% Suma de Señales en Tiempo Continuo y Discreto
A = 5; %Amplitud
Fs = 10000; %Frecuencia de Muestreo
f1 = 0.1; %Frecuencia Fundamental de la Señal x1(t) Hz
f2 = 0.2; %Frecuencia Fundamental de la Señal x2(t) Hz
t = 0:1/Fs:30; %Tiempo de Simulación
x1t = A.*sin(2*pi*f1.*t); %Generación de Señal x1(t)
x2t = A.*cos(2*pi*f2.*t); %Generación de Señal x2(t)
yt = x1t + x2t; %Señal suma y(t)=x1(t)+x2(t)
subplot(2,1,1),plot(t,yt),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y(t)=x1(t)+x2(t)')
n = 0:30; %Vector de Tiempo Dicreto
x1n = A.*sin(2*pi*f1.*n); %Generación de Señal x1[n]
x2n = A.*cos(2*pi*f2.*n); %Generación de Señal x2[n]
yn = x1n + x2n; %Señal suma y[n]=x1[n] + x2[n]
subplot(2,1,2),stem(n,yn),grid on %Grafica
xlabel('Tiempo (n)'),ylabel('Amplitud'), title('y[n]=x1[n]+x2[n]')
Gráfica

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 10 de 21
Multiplicación
Sintaxis
 No aplica.

Descripción
Para este caso se aplica la misma descripción que para el “Escalamiento de Amplitud”
teniendo en cuenta que el parámetro A ahora no será un escalar sino una señal.
Comandos
%% Multiplicación de Señales en Tiempo Continuo y Discreto
A = 5; %Amplitud
Fs = 10000; %Frecuencia de Muestreo
f1 = 0.1; %Frecuencia Fundamental de la Señal x1(t) Hz
f2 = 0.2; %Frecuencia Fundamental de la Señal x2(t) Hz
t = 0:1/Fs:30; %Tiempo de Simulación
x1t = A.*sin(2*pi*f1.*t); %Generación de Señal x1(t)
x2t = A.*cos(2*pi*f2.*t); %Generación de Señal x2(t)
yt = x1t .* x2t; %Señal suma y(t)=x1(t)*x2(t)
subplot(2,1,1),plot(t,yt),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y(t)=x1(t)*x2(t)')
n = 0:30; %Vector de Tiempo Dicreto
x1n = A.*sin(2*pi*f1.*n); %Generación de Señal x1[n]
x2n = A.*cos(2*pi*f2.*n); %Generación de Señal x2[n]
yn = x1n .* x2n; %Señal suma y[n]=x1[n] * x2[n]
subplot(2,1,2),stem(n,yn),grid on %Grafica
xlabel('Tiempo (n)'),ylabel('Amplitud'), title('y[n]=x1[n]*x2[n]')
Gráfica

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 11 de 21
Diferenciación
Sintaxis
 diff(x,n,dim)

Descripción
diff permite calcular la derivada de una expresión matemática, el argumento x es dicha
expresión y puede ser tanto un vector(numérica) como una función simbólica. El argumento n
es el grado de la derivada que se desea calcular, por ejemplo, para un n=2, diff calculará
la segunda derivada de la expresión x. Finalmente, el argumento dim es la dimensión en la
cual se desea calcular la derivada siempre y cuando x sea una matriz de tamaño superior al
especificado en dim. Los argumentos n y dim son opcionales y para el caso de estudio que
compete a esta práctica no será necesario definirlos, pues al omitir n en el comando diff,
éste asume el cálculo de una derivada de grado 1.
Comandos

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 12 de 21
Para generar una señal que sea la derivada de otra señal en MATLAB® se tienen dos opciones: la primera es
creando una señal simbólica que represente la señal original, luego se calcula la derivada con el comando diff y
finalmente se hace una sustitución de la variable simbólica de tiempo por un vector de tiempo; la segunda
opción es realizar la diferenciación de forma aproximada con la señal definida mediante el vector de tiempo
directamente. A continuación, se presentan ejemplos de ambos casos.
%% Diferenciación en Tiempo Continuo y Discreto
%--------Diferenciación Método Aproximado-------------
Fs = 200; %Frecuencia de Muestreo
t = 0:1/Fs:2*pi; %Tiempo de Simulación
xt = sin(t); %Generación de Señal x(t)
yt = diff(xt).*Fs; %Cálculo de la derivada y(t)=x'(t)
subplot(2,2,1),plot(t(:,1:length(yt)),yt,'r',t,xt,'b'),legend('y(t)=Derivada de
x(t)','Señal Original x(t)'),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('x(t) y su Diferenciación - Método
Aproximado')
n = 0:7; %Vector de Tiempo Dicreto
xn = sin(n); %Generación de Señal x[n]
yn = diff(xn); %Cálculo de la derivada y[n]=x'[n]
subplot(2,2,2),stem(n(:,1:length(yn)),yn,'Color','r'),hold on,
stem(n,xn,'Color','b'),legend('y[n]=Derivada de x[n]','Señal Original x[n]'),grid
on %Grafica
xlabel('Tiempo (n)'),ylabel('Amplitud'), title('x[n] y su Diferenciación - Método
Aproximado')
%--------Diferenciación Método Simbólico(Exácto)-------------
syms tiempo;
Fs = 200; %Frecuencia de Muestreo
t = 0:1/Fs:2*pi; %Tiempo de Simulación
xt = sin(tiempo); %Generación de Señal x(t)
yt = diff(xt,tiempo); %Cálculo de la derivada y(t)=x'(t)
xt = double(subs(xt,tiempo,t)); %Cambio de variable
yt = double(subs(yt,tiempo,t)); %Cambio de variable
subplot(2,2,3),plot(t,yt,'r',t,xt,'b'),legend('y(t)=Derivada de x(t)','Señal
Original x(t)'),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('x(t) y su Diferenciación - Método
Simbólico(Exácto)')
n = 0:7; %Vector de Tiempo Dicreto
xn = sin(tiempo); %Generación de Señal x[n]
yn = diff(xn); %Cálculo de la derivada y[n]=x'[n]
xn = double(subs(xn,tiempo,n)); %Cambio de varible
yn = double(subs(yn,tiempo,n)); %Cambio de varible
subplot(2,2,4),stem(n,yn,'Color','r'),hold on,
stem(n,xn,'Color','b'),legend('y[n]=Derivada de x[n]','Señal Original x[n]'),grid
on %Grafica
xlabel('Tiempo (n)'),ylabel('Amplitud'), title('x[n] y su Diferenciación - Método
Simbólico(Exácto)')
Gráfica

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 13 de 21
Integración
Sintaxis
 int(expr,var,a,b,Name,Value)

Descripción
El comando int que permite calcular tanto integrales definidas como indefinidas con
respecto a una variable simbólica var. Especificar la variable simbólica var es opcional, si
no se especifica int utiliza la variable predeterminada por symvar, es decir, la única
variable simbólica de la expresión expr, en caso de que expr tenga más de una variable
simbólica se deberá especificar con respecto a cuál se desea integrar. Los argumentos a y b
permiten evaluar la integral en intervalos definidos desde a hasta b. Finalmente, los
argumentos Name y Value son opcionales y permiten especificar funcionalidades adicionales
sobre cómo se debe evaluar la integral, para esta práctica no será necesario profundizar en
ello.

Es importante mencionar que el comando int no admite en su argumento expr funciones


definidas con vectores de tiempo, por lo cual, es necesario realizar la operación de
integración de forma simbólica y luego sustituir la variable de tiempo por su equivalente
vectorial. Un ejemplo similar se realizó para la operación de diferenciación.

Comandos

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 14 de 21
%% Integración en Tiempo Continuo y Discreto
syms tiempo;
Fs = 200; %Frecuencia de Muestreo
t = 0:1/Fs:2*pi; %Tiempo de Simulación
xt = sin(tiempo); %Generación de Señal x(t)
yt = int(xt,tiempo); %Cálculo de la integral y(t)=integral de x(t)
xt = double(subs(xt,tiempo,t)); %Cambio de variable
yt = double(subs(yt,tiempo,t)); %Cambio de variable
subplot(2,1,1),plot(t,yt,'r',t,xt,'b'),legend('y(t)=Integral de x(t)','Señal
Original x(t)'),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('x(t) y su Integración')
n = 0:7; %Vector de Tiempo Dicreto
xn = sin(tiempo); %Generación de Señal x[n]
yn = int(xn); %Cálculo de la derivada y[n]=x'[n]
xn = double(subs(xn,tiempo,n)); %Cambio de varible
yn = double(subs(yn,tiempo,n)); %Cambio de varible
subplot(2,1,2),stem(n,yn,'Color','r'),hold on,
stem(n,xn,'Color','b'),legend('y[n]=Integral de x[n]','Señal Original x[n]'),grid
on %Grafica
xlabel('Tiempo (n)'),ylabel('Amplitud'), title('x[n] y su Integración')
Gráfica

Operaciones efectuadas sobre la variable independiente

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 15 de 21
Escalamiento de tiempo
Sintaxis
 No aplica.

Descripción
Para este caso se aplica la misma descripción que para el “Escalamiento de Amplitud”
teniendo en cuenta la expresión que representa la operación de escalamiento de tiempo. En
términos matemáticos se podría decir que el escalamiento de tiempo es un cambio de
variable en de t por a∗t en una función dada. A continuación, se presentan ejemplos para
casos en tiempo continuo y discreto, con escalamientos mayores y menores que 1; debe
observarse que para el caso de señales discretas con escalamiento de tiempo mayor a 1 hay
pérdida de datos tal como se expresó en la fundamentación teórica de esta práctica.
Comandos
%% Escalamiento de Tiempo en Tiempo Continuo y Discreto
A = 5; %Amplitud
Fs = 200; %Frecuencia de Muestreo
f = 0.1; %Frecuencia fundamental Hz
T = 3*(1/f); %Número de Periodos a Graficar
duty = 50; %Ciclo útil
t = 0:1/Fs:T-1/Fs; %Variable t de la señal x(t)
xt = A.*square(2*pi*f*t,duty); %Generación de Señal
yt1 = A.*square(2*pi*f*2*t,duty); %Señal escalada en el tiempo en un factor de 2
y1(t)=x(2t);
yt2 = A.*square(2*pi*f*0.5*t,duty); %Señal escalada en el tiempo en un factor de
0.5 y2(t)=x(0.5t);
subplot(2,3,1),plot(t,xt),grid on, ylim([-A-1 A+1]) %Grafica
xlabel(‘Tiempo (s)’),ylabel(‘Amplitud’), title(‘Señal Original x(t)’)
subplot(2,3,2),plot(t,yt1),grid on, ylim([-A-1 A+1]) %Grafica
xlabel(‘Tiempo (s)’),ylabel(‘Amplitud’), title(‘Señal Escalada en Tiempo
y1(t)=x(2t)’)
subplot(2,3,3),plot(t,yt2),grid on, ylim([-A-1 A+1]) %Grafica
xlabel(‘Tiempo (s)’),ylabel(‘Amplitud’), title(‘Señal Escalada en Tiempo
y2(t)=x(2t)’)
n = 0:T; %Vector de Tiempo Dicreto
xn = A.*square(2*pi*f*n,duty); %Generación de Señal x[n]
yn1 = A.*square(2*pi*f*2*n,duty); %Señal escalada en el tiempo en un factor de 2
y1[n]=x[2n]);
yn2 = A.*square(2*pi*f*0.5*n,duty); %Señal escalada en el tiempo en un factor de
0.5 y2[n]=x[0.5n]);
subplot(2,3,4),stem(n,xn),grid on, ylim([-A-1 A+1]) %Grafica
xlabel(‘Tiempo (n)’),ylabel(‘Amplitud’), title(‘y[n]=x[n]’)
subplot(2,3,5),stem(n,yn1),grid on, ylim([-A-1 A+1]) %Grafica
xlabel(‘Tiempo (n)’),ylabel(‘Amplitud’), title(‘y1[n]=x[2n]’)
subplot(2,3,6),stem(n,yn2),grid on, ylim([-A-1 A+1]) %Grafica
xlabel(‘Tiempo (n)’),ylabel(‘Amplitud’), title(‘y[n]=x[0.5n]’)

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 16 de 21
Gráfica

Reflexión
Sintaxis
 No aplica.

Descripción
No existe algún comando especial para realizar esta operación; y podría seguirse un análisis
similar al de “Escalamiento de tiempo” tomando la reflexión como un cambio de variable de t
por −ten una función dada.
Comandos
%% Reflexión en Tiempo Continuo y Discreto
Fs = 200; %Frecuencia de muestreo
t = -5:1/Fs:5; %Variable de tiempo para x(t)
n = -5:5; %Variable de tiempo para x[n]
xt = ustep(t); %Generación de Señal Tiempo Continuo
yt = ustep(-t); %Reflexión de la señal y(t)=x(-t)
xn = ustep(n); %Generación de Señal Tiempo Discreto
yn = ustep(-n); %Reflexión de la señal y[n]=x[-n]
subplot(2,2,1),plot(t,xt),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('Señal Original x(t)')
subplot(2,2,2),plot(t,yt),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y(t)=x(-t)')
subplot(2,2,3),stem(n,xn),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('Señal Original x[n]')
subplot(2,2,4),stem(n,yn),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y[n]=x[-n]')

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 17 de 21
Gráfica

Corrimiento en tiempo
Sintaxis
 No aplica.

Descripción
No existe algún comando especial para realizar esta operación; y podría seguirse un análisis
similar al de “Escalamiento de tiempo” tomando el corrimiento de tiempo como un cambio de
variable de t por t ± t 0en una función dada.
Comandos
%% Corrimiento en Tiempo o Desplazamiento en Tiempo Continuo y Discreto
Fs = 200; %Frecuencia de muestreo
t = -5:1/Fs:5; %Variable de tiempo para x(t)
n = -5:5; %Variable de tiempo para x[n]
xt = ustep(t); %Generación de Señal Tiempo Continuo
yt1 = ustep(t+2); %Desplazamiento de la señal y1(t)=x(t+2)
yt2 = ustep(t-2); %Desplazamiento de la señal y2(t)=x(t-2)
xn = ustep(n); %Generación de Señal Tiempo Discreto
yn1 = ustep(n+2); %Desplazamiento de la señal y1[n]=x[n+2]
yn2 = ustep(n-2); %Desplazamiento de la señal y2[n]=x[n-2]
subplot(2,3,1),plot(t,xt),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('Señal Original x(t)')
subplot(2,3,2),plot(t,yt1),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y(t)=x(t+2)')
subplot(2,3,3),plot(t,yt2),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y(t)=x(t-2)')

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 18 de 21
subplot(2,3,4),stem(n,xn),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('Señal Original x[n]')
subplot(2,3,5),stem(n,yn1),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y[n]=x[n+2]')
subplot(2,3,6),stem(n,yn2),grid on,ylim([0 1.1]) %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('y[n]=x[n-2]')
Gráfica

Operaciones Sobre Señales Con ADSP Toolbox


Sintaxis
 [ty,y]=operate(t,x,A,B)

Descripción
operate es una función que permite obtener versiones escaladas, reflejadas o desplazadas
en el tiempo de una señal. operate genera dos vectores que representan la señal de salida,
y, y el vector de tiempo correspondiente, ty; esta señal de salida es de la forma x(A*t+B),
donde los parámetros A y B son opcionales y sus valores por defecto son 1 y 0
respectivamente.

Es importante mencionar que esta función puede usarte tanto para tiempo continuo como
discreto.

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 19 de 21
Ejemplo 1: Operaciones básicas sobre señales
Sea x ( t )=2 u ( t+1 ) −r ( t+1 ) +r ( t −1 ) la entrada de un sistema, calcule la salida y ( t ) =x (−2 t+5 )
%% Operaciones sobre señales con ADSP Toolbox
t = -2:0.005:4; %Variable de tiempo para x(t)
xt = 2*ustep(t+1)-uramp(t+1)+uramp(t-1); %Generación de señal x(t)
[ty, y] = operate(t,xt,-2,5); %Genera la señal y(t)=x(-2t+5)
subplot(2,1,1),plot(t,xt),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('Señal Entrada x(t)')
subplot(2,1,2),plot(ty,y),grid on %Grafica
xlabel('Tiempo (s)'),ylabel('Amplitud'), title('Señal Salida y(t)=x(-2t+5)')
Gráfica

6. EVALUACIÓN

a. Verificar la regla de la precedencia, operando de forma correcta e incorrecta haciendo


uso de la función operate y proponiendo un código alternativo usando las diferentes
funciones analizadas en la práctica; para ello use la función
x ( t )=2 u ( t+1 ) −r ( t+1 ) +r ( t −1 ) como la entrada de un sistema y calcule la salida
y ( t ) =x (−2 t+5 ).

NOTA: Se deberá entregar un informe en formato pdf de los resultados en forma individual a
la siguiente semana de terminado la sesión de la práctica.

7. BIBLIOGRAFÍA

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 20 de 21
Ambardar, A. (2002). Procesamiento de Señales Analógica y Digitales (2da ed.). México.
Barchiesi, J. V. (2008). Procesamiento Digital de Señales. Retrieved from
http://www.euv.cl/archivos_pdf/senales.pdf
Haykin, S., & Van Veen, B. (2001). Señales y Sistemas (1ra ed.).
Kamen, E. W., & Heck, B. S. (2008). Fundamentos de Señales y Sistemas Usando la Web y
MATLAB (3ra ed.). México.
Morón, J. (2011). Señales y Sistemas (1ra ed.). Venezuela: Fondo Editorial Biblioteca
Universidad Rafael Urdaneta.
Oppenheim, A. V., & Willsky, A. S. (1998). Señales y Sistemas (2da ed.).
Sistemas y Circuitos, Practica 2: Señales - Curso Académico 07/08. (2011). Madrid:
Departamento de Teoría de la Señal y Comunicaciones, Universidad Carlos III de
Madrid. Retrieved from http://www.tsc.uc3m.es/docencia/SyC/docs/Practica2_SyC_07-
08.pdf
The MathWorks Inc. (2017). MathWorks - Makers of MATLAB and Simulink. Retrieved April
10, 2017, from https://www.mathworks.com/

Teoría de Señales y Sistemas – Lab02, Operaciones Básicas Sobre Señales En MATLAB®


(@Autor Ángelo Joseph Soto Vergel)

Página 21 de 21

También podría gustarte