Matlab 绘制函数切线(annotation函数法)

annotation函数使用的数据为归一化数据,及将整个图像窗口看做1*1的大小,所以需要对所有数据进行归一化处理(包括坐标轴和函数图像坐标)

%%annotation函数学习 画切线(使用归一化的数据绘制)
clear
clc
syms x y y1   %建立符号变量来指代符号方程
y=x^3+2*x;
y1=diff(y,x);  %对y求关于x的导数
x1=-5:0.5:5;    %定义x轴范围
y=double(subs(y,x,x1));  %subs(s,old,new)  符号变量的赋值
y1=double(subs(y1,x,x1));
sita=atan(y1);  %求每个点的actan值 即角度
tx=y1.*cos(sita);
ty=y1.*sin(sita);
p=plot(x1,y);
axis([-5 10 -150 200]);   %坐标轴进行扩大处理,因为切线可能超出坐标轴范围,程序报错
hold on
xlim=get(p.Parent,'XLim');    %图像的父类就是它的坐标轴  得到x轴的坐标范围
ylim=get(p.Parent,'YLim');
po=get(p.Parent,'Position');   %得到坐标系相对于窗口的位置信息
[~,px]=mapminmax(xlim,po(1),po(1)+po(3));    %对x轴数据进行归一化处理  px是一个结构体,存储的是如何将x坐标进行归一化处理,可以使对图像的归一化处理和坐标轴同一处理方式
[~,py]=mapminmax(ylim,po(2),po(2)+po(4));
xx1=mapminmax('apply',x1,px);  %对图像进行和坐标轴一样的归一化
yy1=mapminmax('apply',y,py);
ttx=mapminmax('apply',x1+tx,px);%切线为一矢量,所以有起点有终点
tty=mapminmax('apply',y+ty,py);
for i=1:length(x1)
    ann=annotation('arrow',[xx1(i),ttx(i)],[yy1(i),tty(i)]);
    
end

在这里插入图片描述

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值