【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

相关文章

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后