Hi, can anyone help me to generate 2 sounds of 500 and 1000 Hz with 25 ms duration with ISI of 30 ms and rise/fall time of 10 ms with Fs of 44100 and I want to 500 Hz be 10 dB less than 1000 Hz

 Réponse acceptée

Shae Morgan
Shae Morgan le 31 Juil 2020
Modifié(e) : Shae Morgan le 31 Juil 2020

1 vote

%set-up parameters
fs=44100; %CD quality - also conveniently divisible by 30 and 25
stim_dur=.025; %duration in seconds
ISI_dur=.030; %ISI duration in seconds
ramp_dur=.010; %ramp duration in seconds
t=0:1/fs:stim_dur-1/fs;
f1=500;
f2=1000;
%create signals
xt1=sin(2*pi*f1*t);
xt2=sin(2*pi*f2*t);
%setup ramp
rampSamps = floor(fs*ramp_dur);
window=hanning(2*rampSamps)'; %hanning window is cosine^2 this will change depending on the kind of ramp you want
w1=window(1:ceil((length(window))/2)); %use the first half of hanning function for onramp
w2=window(ceil((length(window))/2)+1:end); %use second half of hanning function of off ramp
w1 = [w1 ones(1,length(xt1)-length(w1))];
w2 = [ones(1,length(xt1)-length(w2)) w2];
%ramp stimuli
xt1_ramped = xt1.*w1.*w2;
xt2_ramped = xt2.*w1.*w2;
%generate ISI
ISI=zeros(ISI_dur*fs,1);
%final stimulus
out=[xt1_ramped';ISI;xt2_ramped'];
plot(out)

9 commentaires

Shae Morgan
Shae Morgan le 31 Juil 2020
Edited for transposition to allow concatenation*
I hope this is what you're looking for!
Parisa
Parisa le 31 Juil 2020
Thank you very much,you helped me alot. but how can I hear this sound?
Shae Morgan
Shae Morgan le 31 Juil 2020
See below
sound(out,fs) %play the sound
audiowrite('filename.wav',out,fs) %save it
If this answer works for you, please accept! :)
Parisa
Parisa le 31 Juil 2020
Im so grateful. thanks again
Parisa
Parisa le 2 Août 2020
I am sorry but I have another question, what if I want to 500 Hz signal to be 10 dB more than 1000 Hz?
Shae Morgan
Shae Morgan le 3 Août 2020
Modifié(e) : Shae Morgan le 3 Août 2020
sure,
so the amplitude of each sine wave is a multiplier added to the sin function
amp = 1 by default, but since we added a ramp to these stimuli, their total average loudness will vary - so the question is, do you want the peak (after the ramp on but before the ramp off) to be 10 dB louder? or do you want the overall ramped stimulus to be 10 dB louder?
%% option 1
% %scale stimuli and then ramp
amp1=1;
amp2=10^(-10/20);
%create signals
xt1=amp1*sin(2*pi*f1*t);
xt2=amp2*sin(2*pi*f2*t);
%check
rms1=rms(xt1);
rms2=rms(xt2);
dB_diff=20*log10(rms1/rms2);
%proceed with th rest of the code and perform the ramping
%% option 2
%ramp stimuli and then scale
rms_xt1_ramped=rms(xt1_ramped); %check the average intensity of the ramped 500 Hz signal
amp2_10dB=10^(-10/20)*rms_xt1_ramped; %find the new amplitude that is 10 dB lower
%normalize the xt2_ramped stimulus and then scale to -10 dB
xt2_ramped_norm=xt2_ramped./rms(xt2_ramped);
xt2_ramped_10dB=xt2_ramped_norm.*amp2_10dB;
%check
rms_xt2_ramped=rms(xt2_ramped_10dB);
20*log10(rms_xt1_ramped/rms_xt2_ramped)
Parisa
Parisa le 3 Août 2020
once again you helped me, thank you so so much for your help
Parisa
Parisa le 7 Août 2020
Modifié(e) : Parisa le 7 Août 2020
Hi dear Shae
I asked another question but nobody answered it. can you see if you can answer me please?
I want to replace 500 Hz to a 200 ms 950 to 1050 Hz noise with 10 ms rise/ fall time and 10 dB SNR with 10 ms ISI
Generating pure tone and noise
Shae Morgan
Shae Morgan le 7 Août 2020
I looked at your question and submitted an answer - there you asked for a 20 ms ISI, so I answered the question you asked there, not here. Please update the question if it isn't what you need and I'll be happy to submit an answer.
If the solution works, please choose to accept my answer! It helps me a lot as I try to help you!

Connectez-vous pour commenter.

Plus de réponses (0)

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by