过圆外一点与圆相切的直线

文章目录


1.问题描述

过定点与圆相切的直线,一般分为三种情况,a 定点在圆上(一个解)。b 定点在圆内(无解)。c 定点在圆外(两个解)。前面一节讨论了过圆上一点与圆相切的直线问题,该文接着讨论过圆外的一点,与圆相切的情况。

2.已知条件

圆心C,半径r,圆外点P。求过点P与圆相切的直线。Q为切点。

3.求解

4.code

matlab 复制代码
clc;
close all;
clear;

%% Point P on the line is outside circle
rng default;
C = rand(1,2);
r = rand()*3;
theta = rand()*2*pi;
r_out = r + rand();
P = C+[r_out*cos(theta), r_out*sin(theta)];
u = P - C;
r_2 = r*r;
u_2 = u.^2;
delta = sqrt(-r_2^2*u_2(1) + r_2*u_2(1)^2 + r_2*u_2(1)*u_2(2));
x1 = (r_2 - r_2*u_2(2)/sum(u_2) - u(2)*delta/sum(u_2))/u(1);
y1 = (r_2*u(2) + delta)/sum(u_2);

x2 = (r_2 - r_2*u_2(2)/sum(u_2) + u(2)*delta/sum(u_2))/u(1);
y2 = (r_2*u(2) - delta)/sum(u_2);



u = linspace(0,2*pi,50);
circle = C + [r*cos(u'), r*sin(u')];
t = linspace(-5,5,50);
n = [-y1, x1];
L = P + t'*n;
n2 = [-y2, x2];
L2 = P + t'*n2;


figure;
plot(circle(:,1),circle(:,2));
hold on
plot(L(:,1), L(:,2));
hold on
plot(L2(:,1), L2(:,2));
hold on
scatter(P(1), P(2),'filled','o')
axis equal
grid on
相关推荐
2401_8971905512 小时前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!
java·c++·算法
多加点辣也没关系13 小时前
数据结构与算法|第十一章:跳表
数据结构·算法
晚风叙码13 小时前
归并排序:从原理到非递归实现,一文搞定
数据结构·算法
悲伤小伞13 小时前
LeetCode 热题 100_3-128. 最长连续序列
c++·算法·leetcode·哈希算法
多加点辣也没关系13 小时前
数据结构与算法|第十三章:递归与分治
数据结构·算法
书中玉13 小时前
【矩阵的秩系列2】极大线性无关组向量个数唯一
线性代数·高等代数·极大线性无关组
m0_6294947313 小时前
LeetCode 热题 100-----21.搜索二维矩阵 II
数据结构·算法·leetcode
初心未改HD14 小时前
AI应用开发之矩阵运算详解
人工智能·线性代数·矩阵
平行侠14 小时前
018二进制GCD(Stein算法)- 用位运算代替除法的最大公因数
数据结构·算法
月疯14 小时前
卡尔曼滤波的数学计算流程
算法