小编use*_*643的帖子

如何根据列值将CSV文件拆分为多个文件

我有CSV文件,看起来像这样:

name1;1;11880
name2;1;260.483
name3;1;3355.82
name4;1;4179.48
name1;2;10740.4
name2;2;1868.69
name3;2;341.375
name4;2;4783.9
Run Code Online (Sandbox Code Playgroud)

可能会有更多或更少的行,我需要将其拆分为多个.dat文件,每个文件包含与此文件的第二列具有相同值的行.(然后我将为每个.dat文件制作条形图)对于这种情况,它应该是两个文件:

data1.dat 
name1;1;11880
name2;1;260.483
name3;1;3355.82
name4;1;4179.48

data2.dat
name1;2;10740.4
name2;2;1868.69
name3;2;341.375
name4;2;4783.9
Run Code Online (Sandbox Code Playgroud)

用bash做这件事有什么简单的方法吗?

csv bash awk

3
推荐指数
1
解决办法
6281
查看次数

将具有特定 SNR 的随机噪声添加到信号中

我有随机生成的信号,例如:

%frequency
f1 = 1000; f2 = 2000;
Fs = 8000; %sampling frequency

%amplitudes
amp1 = 0.75;
amp2 = 0.2;

%time
dt = 1/Fs
stopTime = 0.3;
t = 0:dt:stopTime;

%random noise
noise = randn(1,length(t))

%generated signal
Signal = amp1*sin(2*pi*f1*t) + amp2*sin(2*pi*f1*t) + noise;
Run Code Online (Sandbox Code Playgroud)

现在我需要使用具有特定 SNR 的随机噪声创建两个信号 S1、S2。添加到 S1 的噪声必须与添加到 S2 的噪声无关这是我尝试过的:

%SNR in dB
SNR = [-80,-40,-20,0,20,40,80];

%S1,S2 = Signal + rand noise with SNR -40dB
S1 = awgn(Signal,SNR(2),'measured')
S2 = awgn(Signal,SNR(2),'measured')
Run Code Online (Sandbox Code Playgroud)

这种创建 SNR 范围为 -80dB 到 …

matlab signal-processing noise

1
推荐指数
1
解决办法
3267
查看次数

标签 统计

awk ×1

bash ×1

csv ×1

matlab ×1

noise ×1

signal-processing ×1