網站首頁 編程語言 正文
寫了一個配對箱線圖繪制模板:
數據準備
這里隨機生成了一些正態分布隨機數作為數據,使用時可以將Y換成自己的數據:
% 隨機構造一組數據 PntSet1=sort(mvnrnd(0,2,25)); PntSet2=sort(mvnrnd(.5,2.5,25)); PntSet3=sort(mvnrnd(0,2,25)); PntSet4=sort(mvnrnd(.5,2.5,25)); % Y=[PntSet1,PntSet2]; Y=[PntSet1,PntSet2,PntSet3,PntSet4];
配色
這里準備了七組數據,只需要修改colorList=Cn
即可:
% 配色列表 C1=[59 125 183;244 146 121;242 166 31;180 68 108;220 211 30]./255; C2=[102,173,194;36,59,66;232,69,69;194,148,102;54,43,33]./255; C3=[38,140,209;219,51,46;41,161,153;181,138,0;107,112,196]./255; C4=[110,153,89;230,201,41;79,79,54;245,245,245;199,204,158]./255; C5=[235,75,55;77,186,216;2,162,136;58,84,141;245,155,122]./255; C6=[23,23,23;121,17,36;44,9,75;31,80,91;61,36,42]./255; C7=[126,15,4;122,117,119;255,163,25;135,146,73;30,93,134]./255; colorList=C7;
C1:
C2:
C3:
C4:
C5:
C6:
C7:
繪圖及修飾
這里的修飾分為坐標區域修飾以及圖形對象修飾兩部分,已在代碼中標注好:
% 繪圖 boxplot(Y,'Symbol','o','OutlierSize',3,'Colors',[0,0,0]); % 坐標區域屬性設置 ax=gca;hold on; ax.LineWidth=1.1; ax.FontSize=11; ax.FontName='Arial'; ax.XTickLabel={'AA','BB','CC','DD','EE','FF'}; ax.Title.String='Title of Paired BoxPlot'; ax.Title.FontSize=13; ax.YLabel.String='expression of XXX'; % 修改線條粗細 lineObj=findobj(gca,'Type','Line'); for i=1:length(lineObj) lineObj(i).LineWidth=1; lineObj(i).MarkerFaceColor=[1,1,1].*.3; lineObj(i).MarkerEdgeColor=[1,1,1].*.3; end % 為箱線圖的框上色 boxObj=findobj(gca,'Tag','Box'); for i=1:length(boxObj) patch(boxObj(i).XData,boxObj(i).YData,colorList(length(boxObj)+1-i,:),'FaceAlpha',0.5,... 'LineWidth',1.1); end % 繪制配對線 X=ones(size(Y)).*(1:size(Y,2)); plot(X',Y','Color',[0,0,0,.3],'Marker','o','MarkerFaceColor',[1,1,1].*.3,... 'MarkerEdgeColor',[1,1,1].*.3,'MarkerSize',3,'LineWidth',.6)
完整代碼
% pairboxplot % 隨機構造一組數據 PntSet1=sort(mvnrnd(0,2,25)); PntSet2=sort(mvnrnd(.5,2.5,25)); PntSet3=sort(mvnrnd(0,2,25)); PntSet4=sort(mvnrnd(.5,2.5,25)); % Y=[PntSet1,PntSet2]; Y=[PntSet1,PntSet2,PntSet3,PntSet4]; % 配色列表 C1=[59 125 183;244 146 121;242 166 31;180 68 108;220 211 30]./255; C2=[102,173,194;36,59,66;232,69,69;194,148,102;54,43,33]./255; C3=[38,140,209;219,51,46;41,161,153;181,138,0;107,112,196]./255; C4=[110,153,89;230,201,41;79,79,54;245,245,245;199,204,158]./255; C5=[235,75,55;77,186,216;2,162,136;58,84,141;245,155,122]./255; C6=[23,23,23;121,17,36;44,9,75;31,80,91;61,36,42]./255; C7=[126,15,4;122,117,119;255,163,25;135,146,73;30,93,134]./255; colorList=C7; % 繪圖 boxplot(Y,'Symbol','o','OutlierSize',3,'Colors',[0,0,0]); % 坐標區域屬性設置 ax=gca;hold on; ax.LineWidth=1.1; ax.FontSize=11; ax.FontName='Arial'; ax.XTickLabel={'AA','BB','CC','DD','EE','FF'}; ax.Title.String='Title of Paired BoxPlot'; ax.Title.FontSize=13; ax.YLabel.String='expression of XXX'; % 修改線條粗細 lineObj=findobj(gca,'Type','Line'); for i=1:length(lineObj) lineObj(i).LineWidth=1; lineObj(i).MarkerFaceColor=[1,1,1].*.3; lineObj(i).MarkerEdgeColor=[1,1,1].*.3; end % 為箱線圖的框上色 boxObj=findobj(gca,'Tag','Box'); for i=1:length(boxObj) patch(boxObj(i).XData,boxObj(i).YData,colorList(length(boxObj)+1-i,:),'FaceAlpha',0.5,... 'LineWidth',1.1); end % 繪制配對線 X=ones(size(Y)).*(1:size(Y,2)); plot(X',Y','Color',[0,0,0,.3],'Marker','o','MarkerFaceColor',[1,1,1].*.3,... 'MarkerEdgeColor',[1,1,1].*.3,'MarkerSize',3,'LineWidth',.6)
原文鏈接:https://blog.csdn.net/slandarer/article/details/126372270
相關推薦
- 2024-01-31 深入理解Python中的 `yield` 和 `yield from`
- 2022-09-22 docker安裝Oracle數據庫
- 2023-05-24 Android打空包后提示沒有"android:exported"的屬性設置問題解決_Android
- 2024-01-30 在 Jenkins 中使用 SSH Servers 配置文件上傳路徑
- 2022-08-03 python數據類型可變與不可變深入分析_python
- 2023-07-18 List集合循環刪除特殊元素之六種方法(實踐)
- 2022-04-20 常用正則表達式之密碼格式驗證大全_正則表達式
- 2023-10-25 用promise.all搭配map方法解決異步問題
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支