当前位置: 首页 > article >正文

【python】Plot a Square

在这里插入图片描述

文章目录

  • 1、功能描述
  • 2、代码实现
  • 3、效果展示
  • 4、完整代码
  • 5、涉及到的库函数


更多有趣的代码示例,可参考【Programming】


1、功能描述

用 python 实现,以 A和B两个点为边长,方向朝 C 绘制正方形

思路:

  • 计算向量 AB 和 AC。
  • 使用向量 AB 的长度作为正方形的边长。
  • 确定正方形的旋转方向,使得一边朝向点 C。
  • 计算正方形的四个顶点。

2、代码实现

导入必要的库函数

import numpy as np
import matplotlib.pyplot as plt

定义绘制函数 draw_square,先将点转换为 numpy 数组,然后计算向量 AB 和 AC,接着计算 AB 的长度(正方形的边长)

def draw_square(A, B, C):# 将点转换为 numpy 数组A = np.array(A)B = np.array(B)C = np.array(C)# 计算向量 AB 和 ACAB = B - AAC = C - A# 计算 AB 的长度(正方形的边长)side_length = np.linalg.norm(AB)

单位化向量 AB,并计算垂直于 AB 的单位向量,分顺时针 90° 和逆时针 90° 两个方向

    # 单位化向量 AB,并计算垂直于 AB 的单位向量AB_unit = AB / side_length# 顺时针 y,-x 逆时针 -y,xperpendicular_unit1 = np.array([AB_unit[1], -AB_unit[0]])  # 顺时针旋转 90 度perpendicular_unit2 = np.array([-AB_unit[1], AB_unit[0]])  # 逆时针旋转 90 度

计算以 A 为原点,两个方向的单位向量与 AC向量的夹角,以确定绘制正方形的朝向

    A1 = A + perpendicular_unit1A2 = A + perpendicular_unit2A1C = np.dot(AC, A1)A2C = np.dot(AC, A2)

分如下几种情况,注意 A1C 和 A2C 相等的时候,说明 AC 与 AB 垂直,此时可以进一步根据距离去判断,如果连距离都相等,说明 C 在 AB(或者延长线) 上,此时方向不明确,打印提示错误信息

    if A1C > A2C:perpendicular_unit = perpendicular_unit1elif A1C< A2C:perpendicular_unit = perpendicular_unit2else:distance1 = np.sqrt((A1[0]-C[0])**2 + (A1[1]-C[1])**2)distance2 = np.sqrt((A2[0] - C[0]) ** 2 + (A2[1] - C[1]) ** 2)if distance1 < distance2:perpendicular_unit = perpendicular_unit1elif distance1 > distance2:perpendicular_unit = perpendicular_unit2else:print("Error: C 与 AB 重合!")return

计算顶点

    # 计算正方形的四个顶点# 起点是 Avertex1 = Avertex2 = A + AB_unit * side_length  # A 沿着 AB 方向移动vertex3 = vertex2 + perpendicular_unit * side_length  # 从 vertex2 沿着垂直方向移动vertex4 = vertex1 + perpendicular_unit * side_length  # 从 vertex1 沿着垂直方向移动

绘制正方形

    # 绘制正方形square_vertices = [vertex1, vertex2, vertex3, vertex4, vertex1]  # 回到起点以闭合square_vertices = np.array(square_vertices)plt.figure()plt.plot(square_vertices[:, 0], square_vertices[:, 1], 'b-')  # 绘制正方形边框plt.scatter([A[0], B[0], C[0]], [A[1], B[1], C[1]], color=['red', 'green', 'orange'])  # 绘制点 A, B, Cplt.text(A[0], A[1], ' A', fontsize=12, verticalalignment='bottom')plt.text(B[0], B[1], ' B', fontsize=12, verticalalignment='bottom')plt.text(C[0], C[1], ' C', fontsize=12, verticalalignment='bottom')plt.axis('equal')  # 保持比例plt.title('Square with side AB oriented towards C')plt.show()

3、效果展示

A = (0, 1)
B = (1, 0)
C = (-1, -1)

在这里插入图片描述
A = (0, 1)
B = (1, 0)
C = (1, 1)
在这里插入图片描述

A = (-1, 0)
B = (1, 0)
C = (0, -1)
在这里插入图片描述

A = (-1, 0)
B = (1, 0)
C = (0, 1)
在这里插入图片描述
A = (-1, -1)
B = (1, 1)
C = (-1, 1)

在这里插入图片描述
A = (-1, -1)
B = (1, 1)
C = (1, -1)

在这里插入图片描述
A = (0, -1)
B = (0, 1)
C = (-1, 0)

在这里插入图片描述

A = (0, -1)
B = (0, 1)
C = (1, 0)
在这里插入图片描述
A = (1, -1)
B = (-1, 1)
C = (-1, -1)

在这里插入图片描述
A = (1, -1)
B = (-1, 1)
C = (1, 1)

在这里插入图片描述
A = (1, 0)
B = (-1, 0)
C = (0, 1)
在这里插入图片描述

A = (1, 0)
B = (-1, 0)
C = (0, -1)

在这里插入图片描述
A = (1, 1)
B = (-1, -1)
C = (1, -1)

在这里插入图片描述
A = (1, 1)
B = (-1, -1)
C = (-1, 1)

在这里插入图片描述

A = (0, 1)
B = (0, -1)
C = (-1, 0)
在这里插入图片描述

A = (0, 1)
B = (0, -1)
C = (1, 0)
在这里插入图片描述

A = (0, 1)
B = (0, 3)
C = (0, 2)

输出

Error: C 与 AB 重合!

4、完整代码

import numpy as np
import matplotlib.pyplot as pltdef draw_square(A, B, C):# 将点转换为 numpy 数组A = np.array(A)B = np.array(B)C = np.array(C)# 计算向量 AB 和 ACAB = B - AAC = C - A# 计算 AB 的长度(正方形的边长)side_length = np.linalg.norm(AB)# 单位化向量 AB,并计算垂直于 AB 的单位向量AB_unit = AB / side_length# 顺时针 y,-x 逆时针 -y,xperpendicular_unit1 = np.array([AB_unit[1], -AB_unit[0]])  # 顺时针旋转 90 度perpendicular_unit2 = np.array([-AB_unit[1], AB_unit[0]])  # 逆时针旋转 90 度A1 = A + perpendicular_unit1A2 = A + perpendicular_unit2A1C = np.dot(AC, A1)A2C = np.dot(AC, A2)if A1C > A2C:perpendicular_unit = perpendicular_unit1elif A1C< A2C:perpendicular_unit = perpendicular_unit2else:distance1 = np.sqrt((A1[0]-C[0])**2 + (A1[1]-C[1])**2)distance2 = np.sqrt((A2[0] - C[0]) ** 2 + (A2[1] - C[1]) ** 2)if distance1 < distance2:perpendicular_unit = perpendicular_unit1elif distance1 > distance2:perpendicular_unit = perpendicular_unit2else:print("Error: C 与 AB 重合!")return# 计算正方形的四个顶点# 起点是 Avertex1 = Avertex2 = A + AB_unit * side_length  # A 沿着 AB 方向移动vertex3 = vertex2 + perpendicular_unit * side_length  # 从 vertex2 沿着垂直方向移动vertex4 = vertex1 + perpendicular_unit * side_length  # 从 vertex1 沿着垂直方向移动# 绘制正方形square_vertices = [vertex1, vertex2, vertex3, vertex4, vertex1]  # 回到起点以闭合square_vertices = np.array(square_vertices)plt.figure()plt.plot(square_vertices[:, 0], square_vertices[:, 1], 'b-')  # 绘制正方形边框plt.scatter([A[0], B[0], C[0]], [A[1], B[1], C[1]], color=['red', 'green', 'orange'])  # 绘制点 A, B, Cplt.text(A[0], A[1], ' A', fontsize=12, verticalalignment='bottom')plt.text(B[0], B[1], ' B', fontsize=12, verticalalignment='bottom')plt.text(C[0], C[1], ' C', fontsize=12, verticalalignment='bottom')plt.axis('equal')  # 保持比例plt.title('Square with side AB oriented towards C')plt.show()if __name__ == "__main__":# 示例使用A = (0, 1)B = (0, -1)C = (1, 0)draw_square(A, B, C)

5、涉及到的库函数

  • numpy
  • matplotlib

更多有趣的代码示例,可参考【Programming】

相关文章:

【python】Plot a Square

文章目录 1、功能描述2、代码实现3、效果展示4、完整代码5、涉及到的库函数 更多有趣的代码示例&#xff0c;可参考【Programming】 1、功能描述 用 python 实现&#xff0c;以 A和B两个点为边长&#xff0c;方向朝 C 绘制正方形 思路&#xff1a; 计算向量 AB 和 AC。使用向…...

实战打靶集锦-37-Wpwnvm

文章目录 1. 主机发现2. 端口扫描&服务枚举3. 服务探查4. 系统提权 靶机地址&#xff1a;https://download.vulnhub.com/wpwn/wpwnvm.zip 1. 主机发现 目前只知道目标靶机在192.168.37.xx网段&#xff0c;通过如下的命令&#xff0c;看看这个网段上在线的主机。 $ nmap -…...

三、GPIO

一、GPIO简介 GPIO&#xff08;General Purpose Input Output&#xff09;通用输入输出口GPIO引脚电平&#xff1a;0V&#xff08;低电平&#xff09;~3.3V&#xff08;高电平&#xff09;&#xff0c;部分引脚可容忍5V 容忍5V&#xff0c;即部分引脚输入5V的电压&#xff0c;…...

Guava Cache 实战:构建高并发场景下的字典数据缓存

一、场景背景 在系统开发中&#xff0c;字典数据&#xff08;如状态类型、分类数据&#xff09;具有以下特点&#xff1a; 高频读取&#xff08;每个请求都可能涉及&#xff09;低频变化&#xff08;管理员修改后才会变更&#xff09;数据一致性要求适中&#xff08;允许分钟…...

混杂模式(Promiscuous Mode)与 Trunk 端口的区别详解

一、混杂模式&#xff08;Promiscuous Mode&#xff09; 1. 定义与工作原理 定义&#xff1a;混杂模式是网络接口的一种工作模式&#xff0c;允许接口接收通过其物理链路的所有数据包&#xff0c;而不仅是目标地址为本机的数据包。工作层级&#xff1a;OSI 数据链路层&#x…...

rknn_convert的使用方法

rknn_convert是RKNN-Toolkit2提供的一套常用模型转换工具&#xff0c;通过封装上述API接口&#xff0c;用户只需编辑模型对应的yml配置文件&#xff0c;就可以通过指令转换模型。以下是如何使用rknn_convert工具的示例命令以及支持的指令参数&#xff1a; python -m rknn.api.…...

Turtle综合案例实战(绘制复杂图形、小游戏)

在学习了 Turtle 基本的绘图技巧后,我们可以通过结合多个概念和技巧,绘制复杂的图形或实现简单的小游戏。本章将介绍两个实战案例: 绘制复杂图形:结合前面所学的知识,绘制一个精美的多层次复杂图案。简单的游戏:利用 Turtle 实现一个简单的小游戏——蛇形游戏,这是一个经…...

[dp5_多状态dp] 按摩师 | 打家劫舍 II | 删除并获得点数 | 粉刷房子

目录 1.面试题 17.16. 按摩师 题解 2.打家劫舍 II 题解 3.删除并获得点数 题解 4.粉刷房子 题解 一定要有这样的能力&#xff0c;碰到一个新题的时候&#xff0c;可以往之前做过的题方向靠&#xff01; 打家劫舍问题模型: 不能选择相邻的两个数&#xff0c;并且要最终…...

DM数据库配置归档模式的两种方式

归档模式&#xff0c;联机日志文件中的内容保存到硬盘中&#xff0c;形成归档日志文件(REDO日志)。 采用归档模式会对系统的性能产生些许影响&#xff0c;然而系统在归档模式下运行会更安全&#xff0c;当 出现故障时其丢失数据的可能性更小&#xff0c;这是因为一旦出现介质故…...

Leetcode 2440 -- dfs | 枚举

题目描述 创建价值相同的连通块 思路 代码 class Solution { public:int componentValue(vector<int>& nums, vector<vector<int>>& edges) {// get max_val and sum_valint n nums.size();int max_val -1, sum_val 0;for(auto &x : nums) m…...

Vue 中 this.$emit(“update:xx“,value) 和 :xx.sync 实现同步数据的做法

在 Vue 2.x 中&#xff0c;this.$emit(update:xx, value) 和 xx.sync 都是用来实现父子组件之间的数据同步的方式&#xff0c;它们背后的工作原理有些相似&#xff0c;但语法上有所不同。让我们逐个详细解释这两者的使用方式。 xx.sync&#xff08;语法糖&#xff09; xx.syn…...

Agent TARS与Manus的正面竞争

Agent TARS 是 Manus 的直接竞争对手&#xff0c;两者在 AI Agent 领域形成了显著的技术与生态对抗。 一、技术架构与功能定位的竞争 集成化架构 vs 模块化设计 Agent TARS 基于字节跳动的 UI-TARS 视觉语言模型&#xff0c;将视觉感知、推理、接地&#xff08;grounding&#…...

【Tauri2】013——前端Window Event与创建Window

前言 【Tauri2】012——on_window_event函数-CSDN博客https://blog.csdn.net/qq_63401240/article/details/146909801?spm1001.2014.3001.5501 前面介绍了on_window_event&#xff0c;这个在Builder中的方法&#xff0c;里面有许多事件&#xff0c;比如Moved&#xff0c;Res…...

创建Linux虚拟环境并远程连接,finalshell自定义壁纸

安装VMware 这里不多赘述。 挂载Linux系统 1). 打开Vmware虚拟机&#xff0c;打开 编辑 -> 虚拟网络编辑器(N) 选择 NAT模式&#xff0c;然后选择右下角的 更改设置。 设置子网IP为 192.168.100.0&#xff0c;然后选择 应用 -> 确定。 解压 CentOS7-1.zip 到一个比较大…...

DBAPI设置服务器开机自启动

在 /etc/systemd/system 目录下创建一个新的服务文件&#xff0c;例如 dbapi.service [Unit] Descriptiondbapi standalone Service Afternetwork.target[Service] ExecStart/your-path/dbapi-enterprise-4.2.2/bin/dbapi.sh start standalone Restartalways Userroot[Install…...

基于pycharm的YOLOv11模型训练方法

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、前期准备1.1 软件环境配置1.2 训练集参考 二、训练步骤2.1 打开文件夹2.2 打开文件2.3 data.yaml最终代码 三、train.py四、最终结果五、detect.py六、 拓展…...

预测分析(三):基于机器学习的分类预测

文章目录 基于机器学习的分类预测分类任务逻辑回归分类树分类树的工作原理 随机森林多元分类朴素贝叶斯分类器贝叶斯公式回到分类问题**1. 算法原理****2. 主要类型****(1) 高斯朴素贝叶斯****(2) 多项式朴素贝叶斯****(3) 伯努利朴素贝叶斯** **3. 优缺点****4. 应用场景****5…...

基于大模型预测升主动脉瘤的多维度诊疗研究报告

目录 一、引言 1.1 研究背景 1.2 研究目的与意义 二、升主动脉瘤概述 2.1 定义与分类 2.2 发病原因与机制 2.3 流行病学现状 三、大模型技术原理及应用现状 3.1 大模型基本原理 3.2 在医疗领域的应用进展 3.3 针对升主动脉瘤预测的独特价值 四、术前大模型预测方案…...

解决Spring参数解析异常:Name for argument of type XXX not specified

前言 在开发 Spring Boot 应用时&#xff0c;我们常遇到类似 java.lang.IllegalArgumentException: Name for argument not specified 的报错。这类问题通常与方法参数名称的解析机制相关&#xff0c;尤其在使用 RequestParam、PathVariable 等注解时更为常见。 一、问题现象与…...

基数排序算法解析与TypeScript实现

基数排序&#xff08;Radix Sort&#xff09;是一种高效的非比较型整数排序算法&#xff0c;通过逐位分配与收集的方式实现排序。本文将深入解析其工作原理&#xff0c;并给出完整的TypeScript实现。 一、算法原理 1. 核心思想 多关键字排序&#xff1a;将整数按位数切割成不同…...

034-QSharedMemory

QSharedMemory 以下为针对 QSharedMemory 的技术调研及实现方案&#xff0c;包含原理、优化策略、完整代码实现及流程图解&#xff1a; 一、QSharedMemory 核心原理 1.1 共享内存机制 共享内存流程图 &#xff08;注&#xff1a;此处应为共享内存IPC流程图&#xff0c;因文本…...

在 Ubuntu 上离线安装 Prometheus 和 Grafana

在 Ubuntu 上离线安装 Prometheus 和 Grafana 的步骤如下&#xff1a; 一.安装验证 二.安装步骤 1.准备离线安装包 在一台可以访问互联网的机器上下载 Prometheus 和 Grafana 的二进制文件。 Prometheus 下载地址&#xff1a;Prometheus 官方下载页面Grafana 下载地址&#…...

Ansible:playbook的高级用法

文章目录 1. handlers与notify2. tags组件3. playbook中使用变量3.1使用 setup 模块中变量3.2在playbook 命令行中定义变量3.3在playbook文件中定义变量3.4使用变量文件3.5主机清单文件中定义变量主机变量组&#xff08;公共&#xff09;变量 1. handlers与notify Handlers&am…...

【C++进阶九】继承和虚继承

【C进阶九】继承和虚继承 1.什么是继承2.继承关系2.1protected和private的区别2.2通过父类的函数去访问父类的private成员2.3默认继承 3.基类和派生类对象的赋值转换4.继承中的作用域5.子类中的默认成员函数6.继承与静态成员7. 菱形继承8.虚继承9.继承和组合 1.什么是继承 继承…...

近日八股——计算机网络

一.c. TCP握手为什么三次、不能是二次、或四次? i.不能是两次: 防止已经失效的连接报文突然又传到了服务端&#xff0c;产生错误 如果不采用三次握手&#xff0c;服务端直接建立连接&#xff0c;会白白浪费资源 三次握手告诉服务端&#xff0c;客户端有没有收这个数据&#…...

HOW - Axios 拦截器特性

目录 Axios 介绍拦截器特性1. 统一添加 Token&#xff08;请求拦截器&#xff09;2. 处理 401 未授权&#xff08;响应拦截器&#xff09;3. 统一处理错误信息&#xff08;响应拦截器&#xff09;4. 请求 Loading 状态管理5. 自动重试请求&#xff08;如 429 过载&#xff09;6…...

自适应信号处理任务(过滤,预测,重建,分类)

自适应滤波 # signals creation: u, v, d N = 5000 n = 10 u = np.sin(np.arange(0, N/10., N/50000...

电子电气架构 --- 面向服务的体系架构

我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 周末洗了一个澡&#xff0c;换了一身衣服&#xff0c;出了门却不知道去哪儿&#xff0c;不知道去找谁&am…...

TypeScript 装饰器类型详解

TypeScript 装饰器类型详解 一、类装饰器 // 参数&#xff1a;类的构造函数 function ClassDecorator(constructor: Function) {Object.defineProperty(constructor.prototype, timestamp, {value: Date.now()}); }ClassDecorator class DataService {// 装饰后自动添加times…...

Nyquist内置函数-杂项函数

1 Nyquist内置函数-杂项函数 1.1 杂项函数 这些函数对于日常使用来说都是安全且推荐的。 1.1.1 to-mono(sound) [SAL] (to-mono sound) [LISP] 如果 sound 是多声道声音&#xff0c;返回其所有声道的总和&#xff1b;如果 sound 本身就是单声道声音&#xff0c;则直接返回&…...