Top Banner
Introduction to Matlab, Signal Processing & Speech Signal Processing Department of Electronics & Telecommunication Engineering, MMCT
49

Introduction to Matlab

Sep 25, 2015

Download

Documents

aijazmona

basic
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
  • Introduction to Matlab, Signal Processing & Speech Signal ProcessingDepartment of Electronics & Telecommunication Engineering, MMCT

  • Outline:What is Matlab?Matlab ScreenVariables, array, matrix, indexing Operators (Arithmetic, relational, logical )Using of M-FileWriting User Defined FunctionsSignal ProcessingSpeech Signal Processing

  • What is Matlab?Matlab is basically a high level language which has many specialized toolboxes for making things easier for usHow high?

  • What are we interested in?Matlab is too broad for our purpose.The features we are going to require is

  • Matlab ScreenCommand Windowtype commands

    Current DirectoryView folders and m-files

    WorkspaceView program variablesDouble click on a variable to see it in the Array Editor

    Command Historyview past commandssave a whole session using diary

  • VariablesNo need for types. i.e.,

    All variables are created with double precision unless specified and they are matrices.

    After these statements, the variables are 1x1 matrices with double precision

    Example:>>x=5;>>x1=2;

  • Array, Matrixa vectorx = [1 2 5 1]x = 1 2 5 1

    a matrixx = [1 2 3; 5 1 4; 3 2 -1]

    x = 1 2 3 5 1 4 3 2 -1

    transposey = x y = 12 51

  • Long Array, Matrix t =1:10 t = 1 2 3 4 5 6 7 8 9 10k =2:-0.5:-1 k = 2 1.5 1 0.5 0 -0.5 -1

    B = [1:4; 5:8]

    x = 1 2 3 4 5 6 7 8

  • Matrix IndexThe matrix indices begin from 1 (not 0 (as in C)) The matrix indices must be positive integerGiven:A(-2), A(0)

    Error: ??? Subscript indices must either be real positive integers or logicals.

    A(4,2)Error: ??? Index exceeds matrix dimensions.

  • Concatenation of Matricesx = [1 2], y = [4 5], z=[ 0 0]

    A = [ x y]

    1 2 4 5

    B = [x ; y]

    1 2 4 5

    C = [x y ;z] Error:??? Error using ==> vertcat CAT arguments dimensions are not consistent.

  • Operators (arithmetic)+addition-subtraction*multiplication/division^powercomplex conjugate transpose

  • Matrices OperationsGiven A and B:AdditionSubtractionProductTranspose

  • Operators (Element by Element)

    .*element-by-element multiplication./element-by-element division.^element-by-element power

  • The use of . Element OperationK= x^2Erorr: ??? Error using ==> mpower Matrix must be square.B=x*yErorr:??? Error using ==> mtimes Inner matrix dimensions must agree.A = [1 2 3; 5 1 4; 3 2 -1] A = 1 2 3 5 1 4 3 2 -1y = A(3 ,:)

    y= 3 4 -1b = x .* y

    b= 3 8 -3 c = x . / y

    c= 0.33 0.5 -3 d = x .^2

    d= 1 4 9 x = A(1,:)

    x= 1 2 3

  • General Commands On-line helphelp helpwinhelpdeskhelp topiclookfor stringdemoWorkspace informationwhowhoswhatclearclfclchome

    Directory Information & TerminationpwdcddirlsPatheditpathcopyfile

    General Information & Terminationcomputerclockdatever^cquit or exit

  • Arithmetic OperationsCompute following Result 51. 2 5 1.0323 (2 - 1)

    2 1/32 Area= r take r= - 1 0.6781

    3. Sin /60.5

    x4. 3 = 17 for x 2.57

  • Basic Task: Plot the function sin(x) between 0x4 Create an x-array of 100 samples between 0 and 4.

    Calculate sin(.) of the x-array

    Plot the y-array

    >>x=linspace(0,4*pi,100);>>y=sin(x);>>plot(y)

  • Plot the function e-x/3sin(x) between 0x4 Create an x-array of 100 samples between 0 and 4.

    Calculate sin(.) of the x-array

    Calculate e-x/3 of the x-array

    Multiply the arrays y and y1

    >>x=linspace(0,4*pi,100);>>y=sin(x);>>y1=exp(-x/3);>>y2=y*y1;

  • Plot the function e-x/3sin(x) between 0x4 Multiply the arrays y and y1 correctly

    Plot the y2-array

    >>y2=y.*y1;>>plot(y2)

  • Display Facilitiesplot(.)

    stem(.)

    Example:>>x=linspace(0,4*pi,100);>>y=sin(x);>>plot(y)>>plot(x,y)

    Example:>>stem(y)>>stem(x,y)

  • Display Facilitiestitle(.)

    xlabel(.)

    ylabel(.)>>title(This is the sinus function)>>xlabel(x (secs))>>ylabel(sin(x))

  • Operators (relational, logical)== Equal to~= Not equal to< Strictly smaller> Strictly greater= Greater than equal to& And operator | Or operator

  • Flow Controlif for while break .

  • Control Structures If Statement Syntax

    if (Condition_1)Matlab Commandselseif (Condition_2)Matlab Commandselseif (Condition_3)Matlab CommandselseMatlab Commandsend

  • Control Structures For loop syntax

    for i=Index_ArrayMatlab Commandsend

  • Control StructuresWhile Loop Syntax

    while (condition)Matlab Commandsend

    Dummy Example

    while ((a>3) & (b==5)) Some Matlab Commands;end

  • Use of M-FileClick to create a new M-File Extension .m A text file containing script or function or program to run

  • Use of M-FileIf you include ; at the end of each statement,result will not be shown immediately

    Save file as Denem430.m

  • Writing User Defined Functions Functions are m-files which can be executed by specifying some inputs and supply some desired outputs. The code telling the Matlab that an m-file is actually a function is

    You should write this command at the beginning of the m-file and you should save the m-file with a file name same as the function namefunction out1=functionname(in1)function out1=functionname(in1,in2,in3)function [out1,out2]=functionname(in1,in2)

  • Writing User Defined Functions Another function which takes an input array and returns the sum and product of its elements as outputs

    The function sumprod(.) can be called from command window or an m-file as

  • Useful CommandsThe two commands used most by Matlabusers are

    >>help functionname

    >>lookfor keyword

  • Signal Processing Examples To generate a cosine signal.clc;t=0:.01: pi;y=cos (2*pi*t);subplot (2,1,1);plot (t,y);subplot(2,1,2);stem(t,y);display('the resultant is');

  • Program Output:

  • To generate the exponential signalclc;n= input('enter the length of exponential signal');t= 0:n;a= input('enter the a value');z= exp(a*t);subplot(2,2,1);stem(z,t);display('the result length of exponential signal');z

  • Output:Enter the length of exponential signal 4Enter the a value 1The result length of exponential signalz =1.0000 0.3679 0.1353 0.0498 0.0183

  • Writing User Defined Functions ExamplesWrite a function : out=squarer (A, ind)Which takes the square of the input matrix if the input indicator is equal to 1And takes the element by element square of the input matrix if the input indicator is equal to 2

  • DFTDiscrete Fourier transform(DFT) converts a finite list of equally spacedsamplesof afunctioninto the list ofcoefficientsof a finite combination ofcomplexsinusoids, ordered by theirfrequencies, that has those same sample values. It can be said to convert the sampled function from its original domain (oftentimeor position along a line) to thefrequency domain.

  • DFT In digital signal processing, the function is any quantity orsignalthat varies over time, such as the pressure of asound wave, aradiosignal, or dailytemperaturereadings, sampled over a finite time interval (often defined by awindow function). Inimage processing, the samples can be the values ofpixelsalong a row or column of araster image

  • DFTThesequenceofNcomplex numbersis transformed into anN-periodic sequence of complex numbersaccording to the DFT formula: N-1 -j(2/N)nkF[n]= f[k] e (n=0; N-1) k=0

  • Computing DiscreteFourierTransformclc; xn=[2,1,3,1];n=50;l=length(xn);x1=[xn,zeros(1,n-l)];for k=0:1:n-1; for g=0:1:n-1; p=exp(-i*2*pi*g*k/n); x2(k+1,g+1)=p; endendxk=x1*x2;subplot(2,2,1);y= abs(xk);stem(y);z=angle(xk);subplot(2,2,2);stem(z);disp('the resultant signal is');y

  • Output

  • Matlab Functionality in Speech Signal Processing Basic Functionality read a speech file (i.e., open a .wav speech file and read the speech sample into a MATLAB array) write a speech file (i.e., write a MATLAB array of speech samples into a .wav speech file) play a MATLAB array of speech samples as an audio file plot a speech file (MATLAB array) as a waveform using a strips plot format plot a speech file (MATLAB array) as one or more 4line plot(s) convert the sampling rate associated with a speech file (MATLAB array) to a different sampling rate high pass filter a speech file (MATLAB array) to eliminate hum and low frequency noise plot a frame of speech and its associated spectral log magnitude plot a spectrogram of a speech file (MATLAB array)

  • Recording of speech signalclc;close all;%please say your names to record it For i = 1:4Fs=22050;file = sprintf('%s%d.wav','g',i);input('You have 2 seconds to say your name. Press enter when ready to record--> '); y = wavrecord(2*Fs,Fs); sound(y,Fs); wavwrite(y,Fs,file);end

  • Naming the Speech Filefor i = 1:4 strI=int2str(i); wavName='g'; temp=strcat(wavName,strI); %get the speech signal sample [x,fs]=wavread(temp,[1 44100]);

    ms1=fs/1000; % maximum speech Fx at 1000Hz ms20=fs/50; % minimum speech Fx at 50Hz

    % hamming window

    Y=fft(x.*hamming(length(x)));

  • Waveform Plot% plot waveform

    t=(0:length(x)-1)/fs; % times of sampling instants

    figure;name1='waveform of 'title1=strcat({name1},{temp});plot(t,x);

    Gridtitle(title1);

    xlabel('Time (s)');

    ylabel('Amplitude');end

  • Plotting the spectrum % plot spectrum of bottom 5000Hz

    hz5000=5000*length(Y)/fs;

    f=(0:hz5000)*fs/length(Y);figure;name2=' spectrum of 'title2=strcat({name2},{temp});

    plot(f,20*log10(abs(Y(1:length(f)))+eps));grid;title(title2);

    xlabel('Frequency (Hz)');

    ylabel('Magnitude (dB)');

  • Cepstral Analysis to find fundamental frequency% cepstrum is DFT of log spectrum

    C=fft(log(abs(Y)+eps));% plot between 1ms (=1000Hz) and 20ms (=50Hz)

    q=(ms1:ms20)/fs;

    figure;name3=' cepstrum of 'title3=strcat({name3},{temp});plot(q,abs(C(ms1:ms20)));grid;title(title3);xlabel('Quefrency (s)');

    ylabel('Amplitude');

    %search for the index of the peak in the cepstrum between 1 and 20ms, and then convert back to hertz

    [c,fx]=max(abs(C(ms1:ms20)));

    fprintf('fundamentalfrequency=%gHz\n',fs/(ms1+fx-1));

    %fundamental frequency estimation time domain

    % get a section of vowel

    [x,fs]=wavread(temp,[1 44100]);

    ms20=fs/50; % minimum speech Fx at 50Hz

  • Fundamental Frequency (Speech Feature)%search for the index of the peak in the cepstrum between 1 and 20ms, and then convert back to hertz

    [c,fx]=max(abs(C(ms1:ms20)));

    fprintf('fundamentalfrequency=%gHz\n',fs/(ms1+fx-1));

  • Thank You

    *******************