annotate testPrograms/demoTwisterProbability.m @ 24:a5e4a43c1673

major revision looks stable
author Ray Meddis <rmeddis@essex.ac.uk>
date Thu, 16 Jun 2011 16:43:49 +0100
parents 6cce421531e2
children d2c4c07df02c
rev   line source
rmeddis@9 1 function demoTwisterProbability
rmeddis@9 2
rmeddis@9 3 % MAPdemo runs the MATLAB auditory periphery model (MAP1_14) as far as
rmeddis@9 4 % the AN (probabilities) or IC (spikes) with graphical output
rmeddis@9 5
rmeddis@24 6 restorePath=path;
rmeddis@24 7 addpath (['..' filesep 'MAP'], ['..' filesep 'wavFileStore'], ...
rmeddis@24 8 ['..' filesep 'utilities'])
rmeddis@9 9
rmeddis@9 10 %% #1 parameter file name
rmeddis@9 11 MAPparamsName='Normal';
rmeddis@9 12
rmeddis@9 13
rmeddis@24 14 %% #2 probability (fast)
rmeddis@9 15 AN_spikesOrProbability='probability';
rmeddis@9 16
rmeddis@9 17
rmeddis@24 18 %% #3 speech file input
rmeddis@9 19 signalType= 'file';
rmeddis@9 20 fileName='twister_44kHz';
rmeddis@9 21
rmeddis@9 22
rmeddis@9 23 %% #4 rms level
rmeddis@24 24 leveldBSPL=60; % dB SPL
rmeddis@9 25
rmeddis@9 26
rmeddis@9 27 %% #5 number of channels in the model
rmeddis@9 28 % 21-channel model (log spacing)
rmeddis@9 29 numChannels=21;
rmeddis@24 30 lowestBF=250; highestBF= 8000;
rmeddis@9 31 BFlist=round(logspace(log10(lowestBF), log10(highestBF), numChannels));
rmeddis@9 32
rmeddis@24 33 %% #6 no change to model parameters
rmeddis@9 34 paramChanges=[];
rmeddis@9 35
rmeddis@9 36
rmeddis@9 37 %% delare showMap options
rmeddis@24 38 showMapOptions.printModelParameters=1;
rmeddis@24 39 showMapOptions.showModelOutput=1;
rmeddis@24 40 showMapOptions.printFiringRates=1;
rmeddis@24 41 showMapOptions.showACF=0;
rmeddis@24 42 showMapOptions.showEfferent=0;
rmeddis@24 43 showMapOptions.surfProbability=1; % 2D plot of HSR response
rmeddis@9 44
rmeddis@9 45 %% Generate stimuli
rmeddis@9 46
rmeddis@9 47 dbstop if error
rmeddis@9 48 restorePath=path;
rmeddis@9 49 addpath (['..' filesep 'MAP'], ['..' filesep 'wavFileStore'])
rmeddis@9 50 switch signalType
rmeddis@9 51 case 'tones'
rmeddis@9 52 inputSignal=createMultiTone(sampleRate, toneFrequency, ...
rmeddis@9 53 leveldBSPL, duration, rampDuration);
rmeddis@24 54
rmeddis@9 55 case 'file'
rmeddis@24 56 [inputSignal sampleRate]=wavread(fileName);
rmeddis@9 57 inputSignal(:,1);
rmeddis@9 58 targetRMS=20e-6*10^(leveldBSPL/20);
rmeddis@9 59 rms=(mean(inputSignal.^2))^0.5;
rmeddis@9 60 amp=targetRMS/rms;
rmeddis@9 61 inputSignal=inputSignal*amp;
rmeddis@9 62 end
rmeddis@9 63
rmeddis@9 64
rmeddis@9 65 %% run the model
rmeddis@9 66 tic
rmeddis@9 67
rmeddis@9 68 MAP1_14(inputSignal, sampleRate, BFlist, ...
rmeddis@9 69 MAPparamsName, AN_spikesOrProbability, paramChanges);
rmeddis@24 70
rmeddis@9 71 toc
rmeddis@9 72
rmeddis@9 73 % the model run is now complete. Now display the results
rmeddis@23 74 UTIL_showMAP(showMapOptions)
rmeddis@9 75
rmeddis@9 76 toc
rmeddis@9 77 path(restorePath)
rmeddis@9 78
rmeddis@9 79
rmeddis@9 80 function inputSignal=createMultiTone(sampleRate, toneFrequency, ...
rmeddis@9 81 leveldBSPL, duration, rampDuration)
rmeddis@9 82 % Create pure tone stimulus
rmeddis@9 83 dt=1/sampleRate; % seconds
rmeddis@9 84 time=dt: dt: duration;
rmeddis@9 85 inputSignal=sum(sin(2*pi*toneFrequency'*time), 1);
rmeddis@9 86 amp=10^(leveldBSPL/20)*28e-6; % converts to Pascals (peak)
rmeddis@9 87 inputSignal=amp*inputSignal;
rmeddis@9 88
rmeddis@9 89 % apply ramps
rmeddis@9 90 % catch rampTime error
rmeddis@9 91 if rampDuration>0.5*duration, rampDuration=duration/2; end
rmeddis@9 92 rampTime=dt:dt:rampDuration;
rmeddis@9 93 ramp=[0.5*(1+cos(2*pi*rampTime/(2*rampDuration)+pi)) ...
rmeddis@9 94 ones(1,length(time)-length(rampTime))];
rmeddis@9 95 inputSignal=inputSignal.*ramp;
rmeddis@9 96 ramp=fliplr(ramp);
rmeddis@9 97 inputSignal=inputSignal.*ramp;
rmeddis@9 98
rmeddis@9 99 % add 10 ms silence
rmeddis@9 100 silence= zeros(1,round(0.03/dt));
rmeddis@9 101 % inputSignal= [silence inputSignal silence];
rmeddis@9 102