How to plot a 2nd Yaxis on a 2D plot

I am wanting to plot a second Y axis on my 2D plot.
I need to include 'Elevation' from the textread line
So my plot should be, left yaxis = Bougeur Anomaly, right Yaxis = Elevation, Xaxis = Profile
My code so far
%% Program for reading data from txt file
clear all;
close all;
main_path = 'C:\Users\user\Documents\';
print_check = 1;
data_path= strcat(main_path, 'Data\gobs_elevation_2021.txt');
scriptname = mfilename( 'fullpath' );
%% Read data file
[Profile Elevation gobs]=textread(data_path,'%f %f %f', 'headerlines', 1);
FreeAir = 3.086*Elevation;
Bouguer = 0.4192*2.65*Elevation;
gLat = -8.108*sind(2*52);
gBAnom = gobs+gLat+(FreeAir-Bouguer);
%%Simple Plot
fig1=figure('Position',[10 10 550 550])
hold on
plot(Profile, gobs,'.k','Markersize',8)
plot(Profile, gBAnom,'.r','Markersize',8)
% hold on
% plot(depth,fit,'Linewidth', 2,'LineStyle','--','Color',[0.17 0.3 0.34])
grid on
%xlim([0 100])
%ylim([-10 10])
%set(gca,'YDir','reverse')
set(gca,'YDir','reverse')
set(gca,'XDir','reverse')
xlabel('Profile [m]','FontSize',16)
ylabel('Bougeur Anomaly','FontSize',16)
thetitle = 'Effect of a Sphere';
title(thetitle,'FontSize',16);

Réponses (4)

Star Strider
Star Strider le 28 Mar 2021

0 votes

If you have R2016a or later, use the yyaxis function. For earlier versions, use plotyy.

3 commentaires

First, the ylim call must be:
ylim([45 70])
With that change, the code in this Comment should work.
nicholas moran
nicholas moran le 29 Mar 2021
Thank you
Star Strider
Star Strider le 29 Mar 2021
My pleasure!
If my Answer helped you solve your problem, please Accept it!
.

Connectez-vous pour commenter.

nicholas moran
nicholas moran le 28 Mar 2021

0 votes

I will give it a go
nicholas moran
nicholas moran le 28 Mar 2021

0 votes

So far I can't get the third variable;
%% Program for reading data from txt file
clear all;
close all;
main_path = 'C:\Users\user\\';
print_check = 1;
data_path= strcat(main_path, 'Data\gobs_elevation_2021.txt');
scriptname = mfilename( 'fullpath' );
%% Read data file
[Profile Elevation gobs]=textread(data_path,'%f %f %f', 'headerlines', 1);
FreeAir = 3.086*Elevation;
Bouguer = 0.4192*2.65*Elevation;
gLat = -8.108*sind(2*52);
gBAnom = gobs+gLat+(FreeAir-Bouguer);
%%Simple Plot
fig1=figure('Position',[10 10 550 550])
hold on
x = Profile;
y = Bouguer;
yyaxis left
plot(Profile,Bouguer)
z = Elevation;
yyaxis right
plot(x,z)
ylim([70 45])
% hold on
% plot(depth,fit,'Linewidth', 2,'LineStyle','--','Color',[0.17 0.3 0.34])
grid on
%xlim([0 100])
%ylim([-10 10])
%yylim9([45 75])
%set(gca,'YDir','reverse')
set(gca,'YDir','reverse')
set(gca,'XDir','reverse')
xlabel('Profile [m]','FontSize',16)
ylabel('Bougeur Anomaly','FontSize',16)
yylabel('Elevation''FontSize',16)
thetitle = 'Effect of a Sphere';
title(thetitle,'FontSize',16);
Error using ylim (line 31)
Limits must be a 2-element vector of increasing numeric values.
Error in Test (line 32)
ylim([70 45])
nicholas moran
nicholas moran le 28 Mar 2021
Modifié(e) : nicholas moran le 28 Mar 2021

0 votes

Trying to achieve this but with Elevation on the other Yaxis:

Catégories

En savoir plus sur Integration with Online Platforms dans Centre d'aide et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by