[matlab]过一点与椭圆的切线

最近用到二次曲线切点的知识,在丘维声老师的《解析几何》一书上找到一些公式,在计算机视觉中书上也有相关的介绍。

配极映射:
若p是曲线C上一点,则 l=Cp确定平面上一条直线。
若p是曲线C外一点,则过点p的两条切线 l与m 所构成的退化二次曲线的矩阵表示为

T=[p]x  inv(c) [p]x = l'm+m'l

配极对应:
给定一条二次曲线C,对平面上一点p,l=p'C确定一条直线。
直线l为点p关于C的极线,P为极点。
如果p在C上,则极线为过点p的切线。
一般来说,极线l 即是 过点p的两条切线的切点q1和q2的连线。
公式比较简单,可以用matlab实现,做了一个配极对应的小例子
%椭圆极线test
clc
clear all
x1 = 0;
y1 = 0;
l1 = 10;
s1 = 5;
seita1 = -0;
[A1,B1,C1,D1,E1,F1,Elli1]=get_elli_C( x1,y1,l1,s1,seita1 );
elli = [A1 B1/2 D1/2;
        B1/2 C1 E1/2;
        D1/2 E1/2 F1];
e=[40;-0.01;1];
line=e'*elli;
ezplot(subs('A1*x^2+B1*x*y+C1*y^2+D1*x+E1*y+F1'),[-50,50]);
grid on;axis([-50 50 -50 50]);  hold on;axis square;
x=0:0.1:60;y=-(line(1)/line(2))*x-(line(3)/line(2));plot(x,y,'b')
图中的直线是椭圆的极线,从左到右分别是(50,0)   ( 40,0)    (30,0)三个点对应的极线
如果画切线可以求直线与椭圆的交点,然后与极点相连即为切线
  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MATLAB中,可以使用以下步骤来绘制椭圆切线: 1. 定义椭圆的参数:椭圆的中心坐标、长轴长度、短轴长度和旋转角度。 2. 计算椭圆上某一点的坐标:通过参数方程计算椭圆上的点的坐标。 3. 计算椭圆上某一点的切线斜率:通过求导数的方式计算椭圆上某一点的切线斜率。 4. 根据切线斜率和椭圆上某一点的坐标,确定切线方程。 5. 绘制切线:使用plot函数绘制切线。 下面是一个示例代码,用于绘制椭圆切线: ```matlab % 定义椭圆参数 center = [0, 0]; % 椭圆中心坐标 a = 3; % 长轴长度 b = 2; % 短轴长度 angle = pi/4; % 旋转角度 % 计算椭圆上某一点的坐标 theta = linspace(0, 2*pi, 100); % 参数t x = center(1) + a*cos(theta)*cos(angle) - b*sin(theta)*sin(angle); y = center(2) + a*cos(theta)*sin(angle) + b*sin(theta)*cos(angle); % 计算椭圆上某一点的切线斜率 dx = -a*sin(theta)*cos(angle) - b*cos(theta)*sin(angle); dy = -a*sin(theta)*sin(angle) + b*cos(theta)*cos(angle); slope = dy ./ dx; % 选择一个点绘制切线 point_index = 50; % 选择第50个点 x_point = x(point_index); y_point = y(point_index); k = slope(point_index); % 切线方程:y - y_point = k*(x - x_point) x_line = linspace(x_point-2, x_point+2, 100); y_line = y_point + k*(x_line - x_point); % 绘制椭圆切线 figure; hold on; plot(x, y, 'b'); % 绘制椭圆 plot(x_line, y_line, 'r'); % 绘制切线 axis equal; legend('椭圆', '切线'); ``` 这段代码会绘制一个椭圆和选择的点处的切线。你可以根据需要修改椭圆的参数和选择的点来绘制不同的椭圆切线

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值