MATLAB | 绘图复刻(六) | 分组环形热图

news2025/1/11 2:04:47

有粉丝问我Ecology Letters, (2021) 24: 1018–1028 Soil carbon persistence governed by plant input and mineral
protection at regional and global scales
这篇文章中的Figure 2咋画,原图长这样:

复刻效果:

完整步骤

0 数据定义

按理说应该从xlsx中读取数据,但是为了大家不需要下载压缩包直接就能运行,这里直接把数据放在m文件:

clc;clear
Data{1}=[ 0.3    -0.13    0.2     0.7     0.72    0.72
          0.1    -0.02    0.1     0.29    0.37    0.35
          0.14    0.01    0.12    0.35    0.4     0.39
          0.06    0.08    0.12    0.05    0.17    0.14];
Data{2}=[ 0.78    0.71    0.79    0.71
          0.44    0.32    0.45    0.31
          0.45    0.26    0.47    0.23
          0.54    0.34    0.54    0.32];
Data{3}=[-0.66   -0.18   -0.67   -0.66   -0.67
         -0.38   -0.31   -0.28   -0.18   -0.29
         -0.18   -0.14   -0.13   -0.08   -0.3
         -0.15   -0.3     0       0      -0.05];
Data{4}=[ 0.32    0.41    0.63    0.35    0.71    0.17   -0.67   -0.61
         -0.12    0.02    0.22    0.12    0.39    0.07   -0.18   -0.27
         -0.2    -0.21    0      -0.11    0.39    0.13    0      -0.05
         -0.29   -0.19   -0.02    0.04    0.27    0.16    0.14   -0.1];
titleName='(a)Topsoil';
className={'Climate(CL)','Plant(PL)','Mineral(MI)','Composition(CO)'};

varNameRow{1}={'Zero','MI','CO','PL'};
varNameRow{2}={'Zero','CL','MI','CO'};
varNameRow{3}={'Zero','CL','CO','PL'};
varNameRow{4}={'Zero','CL','MI','PL'};

varNameCol{1}={'MAT','MTCM','TCQ','MAP','PWETM','PWETQ'};
varNameCol{2}={'NDVI','LAI','EVI','Input'};
varNameCol{3}={'Fe_{o}+Al_{o}','Fe_{p}+Al_{p}','Fe_{d}+Al_{d}','Ca_{exe}','Mg_{exe}'};
varNameCol{4}={'Polysa','Phenol','Lignin','N','Lipid','PAH','MAH','HIX'};

1 图窗、坐标区域、基础数据定义

颜色数据我直接从colorbar上提取了几个颜色,获取颜色rgb值方式很多,我写过一些文章中有提供颜色提取器,甚至qq,ppt也有颜色提取功能。

同时要求大于0.35和小于-0.35的颜色块用黑框框起来:

% 参数预定义 ===============================================================
% 文本所占比例
sepRatio=15/100; 

% 定义配色和颜色范围
CMap=[9,100,203
33,118,199
61,137,200
93,156,200
123,174,201
156,193,199
182,209,199
217,230,200
251,249,200
249,226,184
251,203,167
250,176,149
249,151,130
251,126,114
252,100,95
250,76,78
249,52,61]./255;
% CMap=slanCM(141);
CLim=[-1,1];

% 角度范围
theta1=pi;
theta2=-pi;
% 半径范围
R1=4.5;
R2=8;
R3=9;
R4=10;

% 着重强调值大于0.35或小于-0.35着重强调
thresholdValue=[-.35,.35];

% 计算间隙
ringRatio=zeros(1,length(Data));
for i=1:length(Data)
    ringRatio(i)=size(Data{i},2);
end
txtRatio=sepRatio./length(Data);
ringRatio1=1./sum(ringRatio).*(1-sepRatio);
ringRatio2=ringRatio./sum(ringRatio).*(1-sepRatio);

% 图窗和坐标区域定义
fig=figure('Units','normalized','Position',[0,0,1,1]);
fig.Color=[1,1,1];
ax=axes(fig);hold on
ax.XLim=[-10,10];
ax.YLim=[-10,10];
ax.DataAspectRatio=[1,1,1];
ax.XColor='none';
ax.YColor='none';

2 环形热图绘制

% 绘图部分 =================================================================
% 绘制热图及热图上文字
x=linspace(CLim(1),CLim(2),size(CMap,1))';
y1=CMap(:,1);y2=CMap(:,2);y3=CMap(:,3);
colorFunc=@(X)[interp1(x,y1,X,'pchip'),interp1(x,y2,X,'pchip'),interp1(x,y3,X,'pchip')];
tS=linspace(0,1,50);
for k=1:length(Data)
    theta3=theta1+(theta2-theta1).*(k*txtRatio+sum(ringRatio2(1:(k-1))));
    tData=Data{k};
    for i=1:size(Data{k},1)
        for j=1:size(Data{k},2)
            tT=theta3+[j-1,j].*ringRatio1.*(theta2-theta1);
            tTd=tT(2)-tT(1);
            tT=[tT(1)+tTd/30,tT(2)-tTd/30];
            tR=R2+(R1-R2).*[i-1,i]./size(Data{k},1);
            tRd=tR(2)-tR(1);
            tR=[tR(1)+tRd/30,tR(2)-tRd/30];
            tT=[tT(1)+(tT(2)-tT(1)).*tS,tT(2)+(tT(1)-tT(2)).*tS];
            tR=[tR(1).*ones(1,50),tR(2).*ones(1,50)];
            if tData(i,j)>thresholdValue(2)||tData(i,j)<thresholdValue(1)
                fill(ax,tR.*cos(tT),tR.*sin(tT),colorFunc(tData(i,j)),'EdgeColor',[0,0,0],'LineWidth',1.2,'EdgeAlpha',.8)
            else
                fill(ax,tR.*cos(tT),tR.*sin(tT),colorFunc(tData(i,j)),'EdgeColor',[1,1,1],'LineWidth',1.2)
            end
        end
    end
    for i=1:size(Data{k},1)
        for j=1:size(Data{k},2)
            tT=theta3+[j-1,j].*ringRatio1.*(theta2-theta1);
            tR=R2+(R1-R2).*[i-1,i]./size(Data{k},1);
            tR=mean(tR);
            tT=mean(tT);
            if tT<0&&tT>-pi
                text(ax,tR.*cos(tT),tR.*sin(tT),num2str(tData(i,j)),'Rotation',tT./pi.*180+90,...
                    'Color',[0,0,0],'HorizontalAlignment','center')
            else
                text(ax,tR.*cos(tT),tR.*sin(tT),num2str(tData(i,j)),'Rotation',tT./pi.*180-90,...
                    'Color',[0,0,0],'HorizontalAlignment','center')
            end
        end
    end
end
text(ax,0,0,titleName,'HorizontalAlignment','center','FontSize',18)

3 添加变量标签

% 绘制标签
% 添加文本1
for k=1:length(Data)
    tT=theta1+(theta2-theta1).*((k-.5)*txtRatio+sum(ringRatio2(1:(k-1))));
    for i=1:size(Data{k},1)
        tR=R2+(R1-R2).*[i-1,i]./size(Data{k},1);
        tR=mean(tR);
        tVarNameRow=varNameRow{k};
        if tT<0&&tT>-pi
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameRow{i},'FontSize',14,...
                'Color',[0,0,0],'HorizontalAlignment','center','Rotation',tT./pi.*180+90)
        else
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameRow{i},'FontSize',14,...
                'Color',[0,0,0],'HorizontalAlignment','center','Rotation',tT./pi.*180-90)
        end
    end
end
% 添加文本2
for k=1:length(Data)
    theta3=theta1+(theta2-theta1).*(k*txtRatio+sum(ringRatio2(1:(k-1))));
    tR=(R2*3+R3*2)/5;
    tVarNameCol=varNameCol{k};
    for j=1:size(Data{k},2)
        tT=theta3+[j-1,j].*ringRatio1.*(theta2-theta1);
        tT=mean(tT);
        if tT<0&&tT>-pi
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameCol{j},'Rotation',tT./pi.*180+90,...
                'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
        else
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameCol{j},'Rotation',tT./pi.*180-90,...
                'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
        end
    end
end

4 添加组标签

% 添加文本3
tS=linspace(0,1,100);
for k=1:length(Data)
    theta3=theta1+(theta2-theta1).*((k-1)*txtRatio+sum(ringRatio2(1:(k-1))));
    theta4=theta1+(theta2-theta1).*(k*txtRatio+sum(ringRatio2(1:k)));
    tT=[theta3,theta4];
    tT=[tT(1)-2*pi/40/length(Data),tT(2)];
    tR=[R3,R4];
    ttT=mean(tT);ttR=mean(tR);
    tT=[tT(1)+(tT(2)-tT(1)).*tS,tT(2)+(tT(1)-tT(2)).*tS];
    tR=[tR(1).*ones(1,100),tR(2).*ones(1,100)];
    fill(ax,tR.*cos(tT),tR.*sin(tT),[1,1,1],'EdgeColor',[.3,.3,.3],'LineWidth',1.2,'EdgeAlpha',.8)
    if ttT<0&&ttT>-pi
        text(ax,ttR.*cos(ttT),ttR.*sin(ttT),className{k},'Rotation',ttT./pi.*180+90,...
            'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
    else
        text(ax,ttR.*cos(ttT),ttR.*sin(ttT),className{k},'Rotation',ttT./pi.*180-90,...
            'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
    end
end

5 添加colorbar

% colorbar绘制并修饰
colormap(colorFunc(linspace(-1,1,256)'))
clim(CLim)
cb=colorbar();
cb.Location="southoutside";
cb.LineWidth=1;
cb.TickDirection='out';
cb.TickLength=.005;
cb.FontSize=11;
cb.Label.String={'Correlation';'coefficient r'};
cb.Label.Position=[-.9,3.5,0];
cb.Label.FontSize=13;

6 更换配色

大家可能觉得颜色不好看,大家可以尝试下载文末所提到的压缩包,或者下载以下文章中提到的配色包,使用其中的配色让图象变得更好看一点:
https://slandarer.blog.csdn.net/article/details/127719784

比如将第1部分,基础数据定义配色的代码改为:

% 定义配色和颜色范围
CMap=slanCM(141);
CLim=[-1,1];

141号配色

110号配色

134号配色

102号配色

61号配色

69号配色

7 完整代码

% @author : slandarer
% gzh  : slandarer随笔

clc;clear
Data{1}=[ 0.3    -0.13    0.2     0.7     0.72    0.72
          0.1    -0.02    0.1     0.29    0.37    0.35
          0.14    0.01    0.12    0.35    0.4     0.39
          0.06    0.08    0.12    0.05    0.17    0.14];
Data{2}=[ 0.78    0.71    0.79    0.71
          0.44    0.32    0.45    0.31
          0.45    0.26    0.47    0.23
          0.54    0.34    0.54    0.32];
Data{3}=[-0.66   -0.18   -0.67   -0.66   -0.67
         -0.38   -0.31   -0.28   -0.18   -0.29
         -0.18   -0.14   -0.13   -0.08   -0.3
         -0.15   -0.3     0       0      -0.05];
Data{4}=[ 0.32    0.41    0.63    0.35    0.71    0.17   -0.67   -0.61
         -0.12    0.02    0.22    0.12    0.39    0.07   -0.18   -0.27
         -0.2    -0.21    0      -0.11    0.39    0.13    0      -0.05
         -0.29   -0.19   -0.02    0.04    0.27    0.16    0.14   -0.1];
titleName='(a)Topsoil';
className={'Climate(CL)','Plant(PL)','Mineral(MI)','Composition(CO)'};

varNameRow{1}={'Zero','MI','CO','PL'};
varNameRow{2}={'Zero','CL','MI','CO'};
varNameRow{3}={'Zero','CL','CO','PL'};
varNameRow{4}={'Zero','CL','MI','PL'};

varNameCol{1}={'MAT','MTCM','TCQ','MAP','PWETM','PWETQ'};
varNameCol{2}={'NDVI','LAI','EVI','Input'};
varNameCol{3}={'Fe_{o}+Al_{o}','Fe_{p}+Al_{p}','Fe_{d}+Al_{d}','Ca_{exe}','Mg_{exe}'};
varNameCol{4}={'Polysa','Phenol','Lignin','N','Lipid','PAH','MAH','HIX'};


% 参数预定义 ===============================================================
% 文本所占比例
sepRatio=15/100; 

% 定义配色和颜色范围
CMap=[9,100,203
33,118,199
61,137,200
93,156,200
123,174,201
156,193,199
182,209,199
217,230,200
251,249,200
249,226,184
251,203,167
250,176,149
249,151,130
251,126,114
252,100,95
250,76,78
249,52,61]./255;
% CMap=slanCM(141);
CLim=[-1,1];

% 角度范围
theta1=pi;
theta2=-pi;
% 半径范围
R1=4.5;
R2=8;
R3=9;
R4=10;

% 着重强调值大于0.35或小于-0.35着重强调
thresholdValue=[-.35,.35];

% 计算间隙
ringRatio=zeros(1,length(Data));
for i=1:length(Data)
    ringRatio(i)=size(Data{i},2);
end
txtRatio=sepRatio./length(Data);
ringRatio1=1./sum(ringRatio).*(1-sepRatio);
ringRatio2=ringRatio./sum(ringRatio).*(1-sepRatio);

% 图窗和坐标区域定义
fig=figure('Units','normalized','Position',[0,0,1,1]);
fig.Color=[1,1,1];
ax=axes(fig);hold on
ax.XLim=[-10,10];
ax.YLim=[-10,10];
ax.DataAspectRatio=[1,1,1];
ax.XColor='none';
ax.YColor='none';



% 绘图部分 =================================================================
% 绘制热图及热图上文字
x=linspace(CLim(1),CLim(2),size(CMap,1))';
y1=CMap(:,1);y2=CMap(:,2);y3=CMap(:,3);
colorFunc=@(X)[interp1(x,y1,X,'pchip'),interp1(x,y2,X,'pchip'),interp1(x,y3,X,'pchip')];
tS=linspace(0,1,50);
for k=1:length(Data)
    theta3=theta1+(theta2-theta1).*(k*txtRatio+sum(ringRatio2(1:(k-1))));
    tData=Data{k};
    for i=1:size(Data{k},1)
        for j=1:size(Data{k},2)
            tT=theta3+[j-1,j].*ringRatio1.*(theta2-theta1);
            tTd=tT(2)-tT(1);
            tT=[tT(1)+tTd/30,tT(2)-tTd/30];
            tR=R2+(R1-R2).*[i-1,i]./size(Data{k},1);
            tRd=tR(2)-tR(1);
            tR=[tR(1)+tRd/30,tR(2)-tRd/30];
            tT=[tT(1)+(tT(2)-tT(1)).*tS,tT(2)+(tT(1)-tT(2)).*tS];
            tR=[tR(1).*ones(1,50),tR(2).*ones(1,50)];
            if tData(i,j)>thresholdValue(2)||tData(i,j)<thresholdValue(1)
                fill(ax,tR.*cos(tT),tR.*sin(tT),colorFunc(tData(i,j)),'EdgeColor',[0,0,0],'LineWidth',1.2,'EdgeAlpha',.8)
            else
                fill(ax,tR.*cos(tT),tR.*sin(tT),colorFunc(tData(i,j)),'EdgeColor',[1,1,1],'LineWidth',1.2)
            end
        end
    end
    for i=1:size(Data{k},1)
        for j=1:size(Data{k},2)
            tT=theta3+[j-1,j].*ringRatio1.*(theta2-theta1);
            tR=R2+(R1-R2).*[i-1,i]./size(Data{k},1);
            tR=mean(tR);
            tT=mean(tT);
            if tT<0&&tT>-pi
                text(ax,tR.*cos(tT),tR.*sin(tT),num2str(tData(i,j)),'Rotation',tT./pi.*180+90,...
                    'Color',[0,0,0],'HorizontalAlignment','center')
            else
                text(ax,tR.*cos(tT),tR.*sin(tT),num2str(tData(i,j)),'Rotation',tT./pi.*180-90,...
                    'Color',[0,0,0],'HorizontalAlignment','center')
            end
        end
    end
end
text(ax,0,0,titleName,'HorizontalAlignment','center','FontSize',18)
% -------------------------------------------------------------------------
% 绘制标签
% 添加文本1
for k=1:length(Data)
    tT=theta1+(theta2-theta1).*((k-.5)*txtRatio+sum(ringRatio2(1:(k-1))));
    for i=1:size(Data{k},1)
        tR=R2+(R1-R2).*[i-1,i]./size(Data{k},1);
        tR=mean(tR);
        tVarNameRow=varNameRow{k};
        if tT<0&&tT>-pi
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameRow{i},'FontSize',14,...
                'Color',[0,0,0],'HorizontalAlignment','center','Rotation',tT./pi.*180+90)
        else
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameRow{i},'FontSize',14,...
                'Color',[0,0,0],'HorizontalAlignment','center','Rotation',tT./pi.*180-90)
        end
    end
end
% 添加文本2
for k=1:length(Data)
    theta3=theta1+(theta2-theta1).*(k*txtRatio+sum(ringRatio2(1:(k-1))));
    tR=(R2*3+R3*2)/5;
    tVarNameCol=varNameCol{k};
    for j=1:size(Data{k},2)
        tT=theta3+[j-1,j].*ringRatio1.*(theta2-theta1);
        tT=mean(tT);
        if tT<0&&tT>-pi
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameCol{j},'Rotation',tT./pi.*180+90,...
                'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
        else
            text(ax,tR.*cos(tT),tR.*sin(tT),tVarNameCol{j},'Rotation',tT./pi.*180-90,...
                'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
        end
    end
end
% 添加文本3
tS=linspace(0,1,100);
for k=1:length(Data)
    theta3=theta1+(theta2-theta1).*((k-1)*txtRatio+sum(ringRatio2(1:(k-1))));
    theta4=theta1+(theta2-theta1).*(k*txtRatio+sum(ringRatio2(1:k)));
    tT=[theta3,theta4];
    tT=[tT(1)-2*pi/40/length(Data),tT(2)];
    tR=[R3,R4];
    ttT=mean(tT);ttR=mean(tR);
    tT=[tT(1)+(tT(2)-tT(1)).*tS,tT(2)+(tT(1)-tT(2)).*tS];
    tR=[tR(1).*ones(1,100),tR(2).*ones(1,100)];
    fill(ax,tR.*cos(tT),tR.*sin(tT),[1,1,1],'EdgeColor',[.3,.3,.3],'LineWidth',1.2,'EdgeAlpha',.8)
    if ttT<0&&ttT>-pi
        text(ax,ttR.*cos(ttT),ttR.*sin(ttT),className{k},'Rotation',ttT./pi.*180+90,...
            'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
    else
        text(ax,ttR.*cos(ttT),ttR.*sin(ttT),className{k},'Rotation',ttT./pi.*180-90,...
            'Color',[0,0,0],'HorizontalAlignment','center','FontSize',14)
    end
end
% -------------------------------------------------------------------------
% colorbar绘制并修饰
colormap(colorFunc(linspace(-1,1,256)'))
clim(CLim)
cb=colorbar();
cb.Location="southoutside";
cb.LineWidth=1;
cb.TickDirection='out';
cb.TickLength=.005;
cb.FontSize=11;
cb.Label.String={'Correlation';'coefficient r'};
cb.Label.Position=[-.9,3.5,0];
cb.Label.FontSize=13;

完整代码

链接:
https://pan.baidu.com/s/1mmr5bTA_jnMwJjiisjNQ3A?pwd=slan

提取码:slan

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/137569.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

node.js创建网站实例1

1.node.js安装 我的电脑环境&#xff1a;win10 网址&#xff1a;https://nodejs.org/en/ 我下载了18.12.1版本 一路next默认安装&#xff0c;安装完成后&#xff0c;运行cmd&#xff0c;查看版本号 会同时安装npm&#xff0c;也可以同时查看版本号 2.创建第一个网站实例hell…

内卷对于2022是一种无奈,也是一种修行

其实我们谁也不知道2023年对于我们普通的开发人员来说会有什么样的试炼&#xff0c;因为2022年身边有太多的人&#xff0c;为了工作&#xff0c;为了生活&#xff0c;为了家庭&#xff0c;为了理想&#xff0c;不得不选择走向别人看似很卷的那条路。 对于我们周围的人来说&…

【Vim】基本操作及命令集详解

概述 Vim 是从 vi 发展出来的一个文本编辑器。vi 内置在Linux系统中&#xff0c;是vim的简化版编辑器&#xff0c;vim则需要进行安装使用。Vim代码补全、编译及错误跳转等方便编程的功能特别丰富&#xff0c;可以实现高效率移动和高效的输入&#xff0c;在程序员中被广泛使用。…

CPT203-Software Engineering(3)

文章目录9. Software Design9.1 Architecture Design9.1.1 Architectural patterns9.2 Component-level Design9.2.1 Component9.2.2 Views of component9.2.3 Component-level design process9.3 User Interface Design9.3.1 Interface Design Process9.3.2 Interface Design …

蓝桥杯Python练习题16-最大最小公倍数

资源限制   内存限制&#xff1a;256.0MB C/C时间限制&#xff1a;1.0s Java时间限制&#xff1a;3.0s Python时间限制&#xff1a;5.0s 问题描述   已知一个正整数N&#xff0c;问从1~N中任选出三个数&#xff0c;他们的最小公倍数最大可以为多少。 输入格式   输入一…

三维数学(一)

视频教程&#xff1a;https://www.bilibili.com/video/BV12s411g7gU?p155 向量 一个数字列表&#xff0c;表示各个维度上的有向位移&#xff1b;同时也是一个有大小有方向的物理量&#xff0c;大小及向量的模长&#xff0c;而方向即空间中向量的指向&#xff0c;可以表示物体…

TikTok Shop 越南站点收入已达Lazada 的 80%

让我们一起来看看今日都有哪些新鲜事吧&#xff01;01 TikTok Shop 越南站点收入已达Lazada 的 80% 据越南电商平台数据分析软件Metric.vn 统计&#xff0c;Shopee、Lazada、Tiki 和 Sendo 仍然主导着越南电子商务市场&#xff0c;1-11 月&#xff0c;共销售了 13 亿件产品。其…

简化开发小技巧-Mybatis-Plus的使用和常用操作

目录 简介 快速使用 pom 代码 mapper service 使用 常用操作 简单或操作查询 多条件或查询 更新字段为null 方法一&#xff0c;如果要更新的字段是String类型&#xff0c; 方法二&#xff0c; 使用mybatis-plus的字段注入。 方法三&#xff0c;使用UpdateWrapper…

基于R的Bilibili视频数据建模及分析——预处理篇

基于R的Bilibili视频数据建模及分析——预处理篇 文章目录基于R的Bilibili视频数据建模及分析——预处理篇0、写在前面1、项目介绍1.1 项目背景1.2 数据来源1.3 数据集展示2、数据预处理2.1 删除空数据2.2 增加id字段2.3 处理数值字段3、参考资料0、写在前面 实验环境 Python版…

Stable Diffusion背后原理(Latent Diffusion Models)

前言 2023年第一篇博客&#xff0c;大家新年好呀~ 这次来关注一下Stable Diffusion背后的原理&#xff0c;即 High-Resolution Image Synthesis with Latent Diffusion Models 这篇论文。 之前关注的那些工作只能工作到 256256256 \times 256256256 像素(resize成这个后才输…

设计模式简介

一、设计模式简介 编写软件过程中&#xff0c;程序员面临着来自耦合性&#xff0c;内聚性 以及可维护性&#xff0c;可扩展性&#xff0c;重用性&#xff0c;灵活性等多方面的挑战&#xff0c;设计模式是为了让程序&#xff08;软件&#xff09;&#xff0c;具有更好的&#xf…

04SpringCloudAlibaba服务注册中心—Consul

目录 Consul简介 Consul是什么What is Consul? | Consul by HashiCorp Consul能做什么 Consul下载&#xff1a;Downloads | Consul by HashiCorp Consul使用&#xff1a;Spring Cloud Consul 中文文档 参考手册 中文版 安装并运行Consul 1、官网安装说明&#xff1a;In…

开发板测试手册——系统启动、文件传送操作步骤详解(1)

目 录 前 言 4 1 评估板快速测试 5 1.1 系统启动测试 5 1.2 文件传送测试 11 1.2.1 通过 Linux 系统启动卡 11 1.2.2 通过 OpenSSH 12 1.3 LED 测试 15 1.4 KEY 测试 15 1.5 DDR 读写测试 16 1.6 SD 卡读写测试 17 1.7 eMMC 读写测试 18 前 言 本指导文档适用开发…

2022 CSDN年度报告已出炉

2022年已过&#xff0c;我们迎来了2023年&#xff0c;那么在2022年&#xff0c;你在CSDN平台都做了些什么&#xff0c;收获了什么呢&#xff1f;2022 CSDN年度报告已出炉&#xff0c;来看看你的2022年度报告吧。 点此查看2022年度报告 或扫码查看你的2022 CSDN年度报告哦&…

23种设计模式(三)——策略模式【组件协作】

文章目录意图什么时候使用策略真实世界类比策略模式的实现策略模式的优缺点亦称&#xff1a;Strategy 意图 定义了一组策略&#xff0c;分别在不同类中封装起来&#xff0c;每种策略都可以根据当前场景相互替换&#xff0c;从而使策略的变化可以独立于操作者。比如我们要去某个…

Type-challenges: tuple to object / union

type-challenges/README.zh-CN.md at main type-challenges/type-challenges GitHub https://github.com/TIMPICKLE/type-challenges/blob/main/questions/00010-medium-tuple-to-union/README.zh-CN.md lets do it , mate! 首先概念澄清&#xff1a; JS&#xff1a; con…

TKE 注册节点,IDC 轻量云原生上云的最佳路径

林顺利&#xff0c;腾讯云原生产品经理&#xff0c;负责分布式云产品迭代和注册节点客户扩展&#xff0c;专注于云原生混合云新形态的推广实践。 背景 企业在持续业务运维过程中&#xff0c;感受到腾讯云 TKE 带来的便捷性和极致的使用体验&#xff0c;将新业务的发布以及老业…

回答问题】ChatGPT上线了!给我推荐20个比较流行的图像全景分割模型

给我推荐20个比较流行的图像全景分割模型 好的&#xff0c;这是 20 个比较流行的图像全景分割模型&#xff1a;DeepLabv3 PSPNet FCN U-Net Mask R-CNN UNet SegNet ENet ICNet ENet GCN DANet BiSeNet DenseASPP DenseASPPv2 DenseASPPv3 DenseASPPv4 DenseASPPv5 DenseASPPv…

Redis数据持久化

数据持久化 RDB (Redis DataBase) 在指定的时间间隔内将内除中的数据集快照写入磁盘&#xff0c;即Snapshot快照。 备份如何执行 Redis会单独创建&#xff08;fork&#xff09;一个子进程来执行持久化&#xff0c;会先将数据写入到一个临时文件&#xff0c;待持久化过程结束…

【嵌入式Linux环境搭建-02】虚拟机安装Ubuntu20系统

虚拟机安装 Ubuntu 系统 前面用的VMware15.5&#xff0c;安装完Ubuntu20.04报错&#xff0c;试了以下方法都不行。 建议直接安装VMware16.2&#xff0c;步骤和上面一样 报错 解决&#xff1a;VMware Workstation 与 Device/Credential Guard 不兼容_山顶夕景的博客-CSDN博客…