【MATLAB基础绘图第15棒】绘制三元相图

2024-02-18 02:40

本文主要是介绍【MATLAB基础绘图第15棒】绘制三元相图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三元相图(Ternary Plot)

三元相图(Ternary Plot)是一种用于表示三个变量之间关系的图表。它通常被用于化学、地质、生态学、环境科学等领域,用于表示三种组分或属性在一个系统中的相对量或比例。
三元相图以一个三角形为基础,其中每个顶点代表系统中的一种组分或属性,因此三元相图也被称为三角图或三角坐标图。

方法1:函数alchemyst/ternplot

下载一:MATLAB中文帮助-alchemyst/ternplot
在这里插入图片描述
下载二:GitHub-alchemyst/ternplot

1.1 案例1:

方法2:STernary在这里插入图片描述

MATLAB代码如下:

%% 基础设置:figure(2);
% 初始化三元相图(Init ternary plot)
STA2=STernary();% 设置刻度值/网格值/刻度标签
% 'GridValues'/'TickValues'
% 'MinorGridValues'/'MinorTickValues'
% 'A_TickLabelStr'/'B_TickLabelStr'/'C_TickLabelStr'
STA2.set('MinorGridValues',5:5:100)
STA2.set('MinorTickValues',2.5:2.5:100)
STA2.set('A_TickLabelStr',{'20%','40%','60%','80%','100%'})% 设置轴刻度标签字体和颜色
set(STA1,'A_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')
set(STA1,'B_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')
set(STA1,'C_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')

2.1 案例1:散点图

成图如下:
在这里插入图片描述
MATLAB代码如下:

clc
close all
clear
%% 基础设置
pathFigure= '.\Figures\' ;%% 开始绘图-散点图A=rand(1,20);
B=rand(1,20);
C=rand(1,20);figure(1);
% 初始化三元相图(Init ternary plot)
STA1=STernary();% 绘制散点图(Draw scatter plot)
STA1.SScatter(A,B,C,40,'filled','CData',[0,0,0]);% 背景色变为灰色(Set the background color to gray)
set(STA1,'Color',[.9,.9,.9]);
hl = legend("Scatter Plot");
set(hl,'Box','off','location','NorthEast','FontSize',12,'FontName','Times New Roman');    % 设置A轴刻度标签字体和颜色
set(STA1,'A_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')
set(STA1,'B_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')
set(STA1,'C_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')% 设置标签文本(Set Label string)
set(STA1,'A_Label','String','LabelA','fontname','Times New Roman');
set(STA1,'B_Label','String','LabelB','fontname','Times New Roman');
set(STA1,'C_Label','String','LabelC','fontname','Times New Roman');
% 将标签移动到侧边(Move the label to the side)
STA1.label2Side();str= strcat(pathFigure, "Figure1", '.tiff');
print(gcf, '-dtiff', '-r600', str);

2.2 案例2:折线图

成图如下:
在这里插入图片描述

MATLAB代码如下:

%% 绘图-折线图figure(3);
% 初始化三元相图(Init ternary plot)
STA3=STernary();% 初始化三元相图(Init ternary plot)
STA3=STernary();% 绘制折线图及散点(Draw lines and scatter)
STA3.SPlot([2,2],[3,0],[5,8],'LineWidth',4,'Color',[.8,0,0]);
STA3.SPlot([2,7],[3,3],[5,0],'LineWidth',4,'Color',[0,.8,0]);
STA3.SPlot([2,0],[3,5],[5,5],'LineWidth',4,'Color',[0,0,.8]);
STA3.SScatter(2,3,5,180,'filled','CData',[1,1,1],'MarkerEdgeColor',[0,0,0],'LineWidth',2);% 绘制文本(Draw text)
STA3.SText(2+1,3,5,'(20%,30%,50%)','FontSize',16,'FontName','Times New Roman')% 设置轴刻度标签字体和颜色
set(STA1,'A_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')
set(STA1,'B_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')
set(STA1,'C_TickLabel','Color',[0,0,0],'FontSize',14,'fontname','Times New Roman')

参考

MATLAB | 如何用MATLAB如何绘制各式各样精致的三元相图(ternary plot)

另:其它语言绘制三元相图

公众号文章-我汇总了所有三元相图(ternary plots)的绘制方法,超实用!!

这篇关于【MATLAB基础绘图第15棒】绘制三元相图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/719795

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【WebGPU Unleashed】1.1 绘制三角形

一部2024新的WebGPU教程,作者Shi Yan。内容很好,翻译过来与大家共享,内容上会有改动,加上自己的理解。更多精彩内容尽在 dt.sim3d.cn ,关注公众号【sky的数孪技术】,技术交流、源码下载请添加微信号:digital_twin123 在 3D 渲染领域,三角形是最基本的绘制元素。在这里,我们将学习如何绘制单个三角形。接下来我们将制作一个简单的着色器来定义三角形内的像素

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显