data = readmatrix('G:\19\19\2.xls'); % 生成标签 newLabels = {'2FSK', 'BPSK', 'CW', 'LFM', 'LFM-BPSK', 'QPSK', 'NLFM', 'FSK-BPSK', 'LFM-FSK', 'MPSK', 'T1', 'T2', 'T3', 'T4'}; labels = repmat(newLabels, 100, 1); labels = labels(:); % 计算准确率和混淆矩阵 accuracy = zeros(14, 1); confusionMat = zeros(14); for i = 1:14 start_idx = (i-1)*100 + 1; end_idx = i*100; accuracy(i) = sum(data(start_idx:end_idx, 2) == i) / 100; idx = find(labels == newLabels{i}); confusionMat(i, :) = histcounts(data(idx, 1), 1:15); end 画出混淆矩阵后怎么在每个格子内显示数值

时间: 2023-07-16 12:12:51 浏览: 51
可以使用 `text` 函数在每个格子内显示数值。以下是添加数值的代码: ``` % 绘制混淆矩阵 figure; imagesc(confusionMat); colorbar; colormap(flipud(gray)); % 添加数值 textStrings = num2str(confusionMat(:),'%d'); textStrings = strtrim(cellstr(textStrings)); [x, y] = meshgrid(1:size(confusionMat,1), 1:size(confusionMat,2)); hStrings = text(x(:), y(:), textStrings(:), 'HorizontalAlignment', 'center'); midValue = mean(get(gca,'CLim')); textColors = repmat(confusionMat(:) > midValue, 1, 3); set(hStrings, {'Color'}, num2cell(textColors, 2)); ``` 这段代码会在混淆矩阵每个格子内显示对应的数值。
相关问题

% % 读取数据 data = readmatrix('G:\19\19\2.xls'); % % % 生成标签 labels = repmat(1:14, 100, 1); labels = labels(:); % % 计算准确率 accuracy = zeros(14, 1); for i = 1:14 start_idx = (i-1)100 + 1; end_idx = i100; accuracy(i) = sum(data(start_idx:end_idx, 1) == labels(start_idx:end_idx)) / 100; end for i = 1:14 idx = find(data(:, 1) == i); correct = sum(data(idx, 2) == i); accuracy(i) = correct / length(idx); end % 生成混淆矩阵 confusionMat = confusionmat(labels, data(:, 2)); figure newLabels = {'2FSK', 'BPSK', 'CW', 'LFM', 'LFM-BPSK', 'QPSK', 'NLFM', 'FSK-BPSK', 'LFM-FSK', 'MPSK', 'T1', 'T2', 'T3', 'T4'}; confusionchart(confusionMat,newLabels ,'Normalization', 'row-normalized'); % 将百分比符号添加到矩阵中 h = gca; h.Axes.XTickLabelFormat = '%.1f%%'; h.YAxis.TickLabelFormat = '%.1f%%';这段代码有问题吗?可以画出每个格子内带有百分比的数值的混淆矩阵吗?用2019a的matlab,如果不行,那应该怎么修改呢

这段代码有一些问题: 1. 第一段计算准确率的循环中,变量 `accuracy` 每次都被重新赋值,应该将 `zeros(14, 1)` 放在循环外面,只需要在每次循环中更新对应的元素。 2. 第二段计算准确率的循环中,变量 `accuracy` 又被重新赋值了,这会导致第一段循环中计算的准确率被覆盖掉。可以将第二段循环改为更新 `confusionMat` 的同时计算准确率。 3. 在画混淆矩阵时,标签应该是字符串数组,而不是数字数组。可以将第一段生成标签的代码改为 `labels = repmat(newLabels, 100, 1); labels = labels(:);` 4. 在设置坐标轴标签格式时,应该使用 `YTickLabelFormat` 而不是 `YAxis.TickLabelFormat`。 下面是修改后的代码: ``` data = readmatrix('G:\19\19\2.xls'); % 生成标签 newLabels = {'2FSK', 'BPSK', 'CW', 'LFM', 'LFM-BPSK', 'QPSK', 'NLFM', 'FSK-BPSK', 'LFM-FSK', 'MPSK', 'T1', 'T2', 'T3', 'T4'}; labels = repmat(newLabels, 100, 1); labels = labels(:); % 计算准确率和混淆矩阵 accuracy = zeros(14, 1); confusionMat = zeros(14); for i = 1:14 start_idx = (i-1)*100 + 1; end_idx = i*100; accuracy(i) = sum(data(start_idx:end_idx, 2) == i) / 100; idx = find(labels == newLabels{i}); confusionMat(i, :) = histcounts(data(idx, 1), 1:15); end % 画混淆矩阵 figure confusionchart(confusionMat, newLabels, 'Normalization', 'row-normalized'); h = gca; h.Axes.XTickLabelFormat = '%.1f%%'; h.YTickLabelFormat = '%.1f%%'; ```

生成2FSK调制信号变为.wav文件格式

要将生成的2FSK调制信号保存为.wav文件格式,你可以使用MATLAB中的`audiowrite`函数。 以下是修改后的代码示例: ```matlab % 设置参数 fs = 44100; % 采样频率 bitrate = 100; % 比特率 frequency_1 = 1000; % 第一种频率 frequency_2 = 2000; % 第二种频率 amplitude = 1; % 调制信号幅度 bits = [0 1 0 1]; % 要传输的比特串 % 生成时间轴 t = 0:1/fs:((length(bits)*bitrate)-1)/fs; % 生成调制信号 signal = zeros(1, length(t)); for i = 1:length(bits) if bits(i) == 1 signal((i-1)*bitrate*fs+1:i*bitrate*fs) = amplitude * cos(2*pi*frequency_2*t((i-1)*bitrate*fs+1:i*bitrate*fs)); else signal((i-1)*bitrate*fs+1:i*bitrate*fs) = amplitude * cos(2*pi*frequency_1*t((i-1)*bitrate*fs+1:i*bitrate*fs)); end end % 将信号归一化到[-1, 1]范围 signal = signal / max(abs(signal)); % 将信号保存为.wav文件 filename = '2FSK_modulated_signal.wav'; audiowrite(filename, signal, fs); disp('2FSK调制信号已保存为.wav文件。'); ``` 在这个例子中,我们使用了更高的采样频率(fs = 44100)以提高音频质量。调用`audiowrite`函数来保存信号到.wav文件中。你可以根据需要修改参数和比特串,运行代码后将会保存2FSK调制信号为.wav文件,并在控制台打印相关信息。请确保你有适当的读写权限来保存文件。

相关推荐

最新推荐

recommend-type

基于MATLAB的2FSK调制及仿真.doc

基于MATLAB的2FSK调制及仿真本文通过分别用Matlab、Simulink、System view设计2FSK调制与解调的仿真,深入了解数字频率调制2FSK的基本原理,掌握用现代通信仿真技术对解调与调制的实现,深刻理解Matlab、Simulink...
recommend-type

(新)2FSK课程设计实验报告

(新)2FSK课程设计实验报告,用systemview软件对2FSK进行仿真。。
recommend-type

论文:2FSK调制解调的simulink仿真

2FSK调制解调的simulink仿真,分别应用模拟法和键控法产生2FSK信号
recommend-type

数字信号的载波调制 2ASK、2FSK、2PSK、2DPSK等方式进行仿真模拟

深入理解键控调制的理论基础、实现技术及物理含义,4通过实验结果分析数字调制的重要价值
recommend-type

阿里巴巴六个盒子实践.pptx

阿里巴巴六个盒子实践.pptx
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

优化MATLAB分段函数绘制:提升效率,绘制更快速

![优化MATLAB分段函数绘制:提升效率,绘制更快速](https://ucc.alicdn.com/pic/developer-ecology/666d2a4198c6409c9694db36397539c1.png?x-oss-process=image/resize,s_500,m_lfit) # 1. MATLAB分段函数绘制概述** 分段函数绘制是一种常用的技术,用于可视化不同区间内具有不同数学表达式的函数。在MATLAB中,分段函数可以通过使用if-else语句或switch-case语句来实现。 **绘制过程** MATLAB分段函数绘制的过程通常包括以下步骤: 1.
recommend-type

SDN如何实现简易防火墙

SDN可以通过控制器来实现简易防火墙。具体步骤如下: 1. 定义防火墙规则:在控制器上定义防火墙规则,例如禁止某些IP地址或端口访问,或者只允许来自特定IP地址或端口的流量通过。 2. 获取流量信息:SDN交换机会将流量信息发送给控制器。控制器可以根据防火墙规则对流量进行过滤。 3. 过滤流量:控制器根据防火墙规则对流量进行过滤,满足规则的流量可以通过,不满足规则的流量则被阻止。 4. 配置交换机:控制器根据防火墙规则配置交换机,只允许通过满足规则的流量,不满足规则的流量则被阻止。 需要注意的是,这种简易防火墙并不能完全保护网络安全,只能起到一定的防护作用,对于更严格的安全要求,需要
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。