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

文章目录


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
相关推荐
带多刺的玫瑰1 小时前
Leecode刷题C语言之切蛋糕的最小总开销②
java·数据结构·算法
robin_suli2 小时前
动态规划回文串问题系列一>回文子串
算法·动态规划
观测云2 小时前
日志聚类算法 Drain 的实践与改良
算法·聚类·日志
心软且酷丶2 小时前
leetcode:面试题 17.01. 不用加号的加法(python3解法)
python·算法·leetcode
hjyowl2 小时前
矩阵Matrix(POJ2155)
算法
Dream it possible!3 小时前
LeetCode 热题 100_将有序数组转换为二叉搜索树(42_108_简单_C++)(二叉树;递归)
c++·算法·leetcode·深度优先
MYT_flyflyfly3 小时前
计算机视觉之三维重建-摄像机标定
人工智能·算法·计算机视觉
XiaoLeisj3 小时前
【优选算法 & 分治】深入理解分治算法:分治算法入门小专题详解
算法·leetcode·决策树·深度优先·哈希算法·剪枝·推荐算法
蒲公英的孩子3 小时前
DCU异构程序——带宽测试
c++·分布式·算法·架构
ShuQiHere3 小时前
【ShuQiHere】算法的开枝散叶:从机器学习到深度学习的模型总结
深度学习·算法·机器学习