annotate testPrograms/demoTwisterSpikes.m @ 30:1a502830d462

MT update
author Ray Meddis <rmeddis@essex.ac.uk>
date Mon, 11 Jul 2011 14:31:29 +0100
parents b03ef38fe497
children 82fb37eb430e
rev   line source
rmeddis@9 1 function demoTwisterSpikes
rmeddis@9 2
rmeddis@9 3 % MAPdemo runs the MATLAB auditory periphery model (MAP1_14) as far as
rmeddis@23 4 % 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@24 9
rmeddis@9 10
rmeddis@9 11 %% #1 parameter file name
rmeddis@9 12 MAPparamsName='Normal';
rmeddis@9 13
rmeddis@9 14
rmeddis@24 15 %% #2 spikes (slow) representation
rmeddis@9 16 AN_spikesOrProbability='spikes';
rmeddis@9 17
rmeddis@9 18
rmeddis@24 19 %% #3 speech file input
rmeddis@9 20 signalType= 'file';
rmeddis@9 21 fileName='twister_44kHz';
rmeddis@9 22
rmeddis@9 23
rmeddis@9 24 %% #4 rms level
rmeddis@9 25 % signal details
rmeddis@9 26 leveldBSPL=70; % dB SPL
rmeddis@9 27
rmeddis@9 28
rmeddis@9 29 %% #5 number of channels in the model
rmeddis@9 30 % 21-channel model (log spacing)
rmeddis@9 31 numChannels=21;
rmeddis@9 32 lowestBF=250; highestBF= 8000;
rmeddis@9 33 BFlist=round(logspace(log10(lowestBF), log10(highestBF), numChannels));
rmeddis@9 34
rmeddis@9 35
rmeddis@9 36 %% #6 change model parameters
rmeddis@9 37 paramChanges=[];
rmeddis@9 38
rmeddis@9 39 %% delare showMap options
rmeddis@9 40 showMapOptions=[]; % use defaults
rmeddis@9 41
rmeddis@9 42 % or (example: show everything including an smoothed SACF output
rmeddis@23 43 showMapOptions.printModelParameters=1;
rmeddis@9 44 showMapOptions.showModelOutput=1;
rmeddis@9 45 showMapOptions.printFiringRates=1;
rmeddis@9 46 showMapOptions.showACF=0;
rmeddis@23 47 showMapOptions.showEfferent=0;
rmeddis@26 48 showMapOptions.surfSpikes=1;
rmeddis@26 49
rmeddis@9 50 %% Generate stimuli
rmeddis@9 51 switch signalType
rmeddis@9 52 case 'tones'
rmeddis@9 53 inputSignal=createMultiTone(sampleRate, toneFrequency, ...
rmeddis@9 54 leveldBSPL, duration, rampDuration);
rmeddis@9 55
rmeddis@9 56 case 'file'
rmeddis@9 57 [inputSignal sampleRate]=wavread(fileName);
rmeddis@9 58 inputSignal(:,1);
rmeddis@9 59 targetRMS=20e-6*10^(leveldBSPL/20);
rmeddis@9 60 rms=(mean(inputSignal.^2))^0.5;
rmeddis@9 61 amp=targetRMS/rms;
rmeddis@9 62 inputSignal=inputSignal*amp;
rmeddis@9 63 end
rmeddis@9 64
rmeddis@9 65
rmeddis@9 66 %% run the model
rmeddis@9 67 tic
rmeddis@9 68
rmeddis@9 69 fprintf('\n')
rmeddis@9 70 disp(['Signal duration= ' num2str(length(inputSignal)/sampleRate)])
rmeddis@9 71 disp([num2str(numChannels) ' channel model'])
rmeddis@9 72 disp('Computing ...')
rmeddis@26 73
rmeddis@9 74 MAP1_14(inputSignal, sampleRate, BFlist, ...
rmeddis@9 75 MAPparamsName, AN_spikesOrProbability, paramChanges);
rmeddis@26 76
rmeddis@9 77
rmeddis@9 78 % the model run is now complete. Now display the results
rmeddis@26 79 UTIL_showMAP(showMapOptions, paramChanges)
rmeddis@9 80
rmeddis@9 81 toc
rmeddis@9 82 path(restorePath)
rmeddis@9 83
rmeddis@9 84 function inputSignal=createMultiTone(sampleRate, toneFrequency, ...
rmeddis@9 85 leveldBSPL, duration, rampDuration)
rmeddis@9 86 % Create pure tone stimulus
rmeddis@9 87 dt=1/sampleRate; % seconds
rmeddis@9 88 time=dt: dt: duration;
rmeddis@9 89 inputSignal=sum(sin(2*pi*toneFrequency'*time), 1);
rmeddis@9 90 amp=10^(leveldBSPL/20)*28e-6; % converts to Pascals (peak)
rmeddis@9 91 inputSignal=amp*inputSignal;
rmeddis@9 92
rmeddis@9 93 % apply ramps
rmeddis@9 94 % catch rampTime error
rmeddis@9 95 if rampDuration>0.5*duration, rampDuration=duration/2; end
rmeddis@9 96 rampTime=dt:dt:rampDuration;
rmeddis@9 97 ramp=[0.5*(1+cos(2*pi*rampTime/(2*rampDuration)+pi)) ...
rmeddis@9 98 ones(1,length(time)-length(rampTime))];
rmeddis@9 99 inputSignal=inputSignal.*ramp;
rmeddis@9 100 ramp=fliplr(ramp);
rmeddis@9 101 inputSignal=inputSignal.*ramp;
rmeddis@9 102
rmeddis@9 103 % add 10 ms silence
rmeddis@9 104 silence= zeros(1,round(0.03/dt));
rmeddis@9 105 % inputSignal= [silence inputSignal silence];
rmeddis@9 106