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

文章目录


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
相关推荐
YaraMemo1 天前
数学优化问题中的三大转化:多目标转化为单目标,多变量转化为单变量,有约束转化为无约束
人工智能·算法·5g·信息与通信·信号处理
Ailan_Anjuxi1 天前
【附Python源码】使用minGPT训练自己的小型GPT语言模型
算法
QuZero1 天前
StampedLock Mechanism
java·算法
云泽8081 天前
二叉树高阶笔试算法题精讲(二):非递归遍历与序列构造全解析
c++·算法·面试
小O的算法实验室1 天前
2026年ESWA,基于固定机巢的无人机输电杆塔、变电站与配电杆混合巡检任务分配与路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
AI科技星1 天前
全域数学三元公理体系下π的射影几何本源阐释 - 基于兵棋推演框架改造:常温超导仿真验证【乖乖数学】
人工智能·线性代数·机器学习·量子计算·agi
sali-tec1 天前
C# 基于OpenCv的视觉工作流-章60-点点距离
图像处理·人工智能·opencv·算法·计算机视觉
nlpming1 天前
OpenCode Skills 文档
算法
无限进步_1 天前
二叉搜索树完全解析:从概念到实现与应用场景
c语言·开发语言·数据结构·c++·算法·github·visual studio
05候补工程师1 天前
深度解构 ROS 2:如何手动调通 Nav2 A* 路径规划引擎
linux·人工智能·经验分享·算法·机器人