how to save variable data that we changed ?
이전 댓글 표시
this is my code:
nSamp = 3251;
Fs = 1024e3;
SNR = 40;
rng default
t = (0:nSamp-1)'/Fs;
x = sin(2*pi*t*100.123e3);
x = x + randn(size(x))*std(x)/db2mag(SNR);
[Pxx,f] = periodogram(x,kaiser(nSamp,38),[],Fs);
meanfreq(Pxx,f);
i change the variable in this code to my dataset . then after run, the variable go to its original data . how to solve this problem?
댓글 수: 9
KSSV
2021년 3월 9일
Which variable you have changed and how you have changed?
NUR BATRISYIA HANNANI ZAIN AZMI
2021년 3월 9일
편집: NUR BATRISYIA HANNANI ZAIN AZMI
2021년 3월 9일
Walter Roberson
2021년 3월 9일
where do you insert the value? your line
x = sin(2*pi*t*100.123e3);
overwrites all of x
NUR BATRISYIA HANNANI ZAIN AZMI
2021년 3월 10일
편집: NUR BATRISYIA HANNANI ZAIN AZMI
2021년 3월 10일
Walter Roberson
2021년 3월 10일
We need to see your current code.
Jorg Woehl
2021년 3월 10일
편집: Jorg Woehl
2021년 3월 10일
Walter is right; you are defining x in your code, so what you have in the workspace doesn't matter. Without really knowing what you are trying to code, my guess would be that you need to remove at least this line:
x = sin(2*pi*t*100.123e3);
NUR BATRISYIA HANNANI ZAIN AZMI
2021년 3월 11일
Walter Roberson
2021년 3월 11일
What is the source of your signal? Is it stored in a .mat file at the moment? Does it need to be read from a .wav ?
NUR BATRISYIA HANNANI ZAIN AZMI
2021년 3월 11일
답변 (1개)
TED MOSBY
2024년 8월 25일
I understand that you want to change the value of a variable in the workspace. The problem you are facing is because you are changing the values in the workspace but that is not the right way as the variables in the workspace are generated after the script is executed.
So, changing the values in the workspace won’t help as when you run the script again it will generate the values according to the code and not take the values of the workspace.
So, to change any value of the variable you must modify the script. You can make your code as a function and then call it as shown below:
function plotPeriodogram(x)
nSamp = numel(x);
Fs = 1024e3;
SNR = 40;
rng default
x = x + randn(size(x)) * std(x) / db2mag(SNR);
[Pxx, f] = periodogram(x, kaiser(nSamp, 38), [], Fs);
meanFreq = meanfreq(Pxx, f);
disp(['Mean Frequency: ', num2str(meanFreq)]);
end
plotPeriodogram(myNewData);
Hope this helps!
카테고리
도움말 센터 및 File Exchange에서 Programming에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!