【10月更文挑战第15天】「Mac上学Python 26」小学奥数篇12 - 图形变换与坐标计算

本文涉及的产品
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
实时计算 Flink 版,5000CU*H 3个月
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
简介: 本篇将通过 Python 和 Cangjie 双语实现图形变换与坐标计算。这个题目帮助学生理解平面几何中的旋转、平移和对称变换,并学会用编程实现坐标变化。

本篇将通过 PythonCangjie 双语实现图形变换与坐标计算。这个题目帮助学生理解平面几何中的旋转、平移和对称变换,并学会用编程实现坐标变化。

geometricgeometric.png


关键词
  • 小学奥数
  • Python + Cangjie
  • 图形变换
  • 坐标计算

一、题目描述

编写一个程序,模拟以下三种图形变换:

  1. 平移变换:将点 (x, y) 平移 dxdy 个单位。
  2. 旋转变换:将点 (x, y) 绕原点顺时针旋转 θ 度。
  3. 对称变换:计算点 (x, y) 关于 x轴y轴 的对称点。

输入格式

  • 平移变换:输入 x, y, dx, dy
  • 旋转变换:输入 x, y, θ(角度)。
  • 对称变换:输入 x, y

输出格式:输出变换后的坐标,保留两位小数。


解题思路
  1. 平移变换公式x' = x + dxy' = y + dy
  2. 旋转变换公式
    • x' = x * cos(θ) + y * sin(θ)
    • y' = -x * sin(θ) + y * cos(θ)
  3. 对称变换
    • 关于 x 轴对称:y' = -y
    • 关于 y 轴对称:x' = -x

二、Python 实现

import math

# 平移变换
def translate(x, y, dx, dy):
    return x + dx, y + dy

# 旋转变换
def rotate(x, y, theta):
    rad = math.radians(theta)
    x_new = x * math.cos(rad) + y * math.sin(rad)
    y_new = -x * math.sin(rad) + y * math.cos(rad)
    return round(x_new, 2), round(y_new, 2)

# 对称变换
def reflect(x, y):
    return -x, -y

# 输入测试
x, y = map(float, input("请输入点的坐标 (x, y): ").split())
dx, dy = map(float, input("请输入平移量 (dx, dy): ").split())
theta = float(input("请输入旋转角度 θ: "))

# 输出结果
print("平移后的坐标:", translate(x, y, dx, dy))
print("旋转后的坐标:", rotate(x, y, theta))
print("关于原点的对称点:", reflect(x, y))

三、Cangjie 实现

package cjcDemo

import std.convert.*    // 导入数据转换模块
import std.console.*    // 导入控制台输入输出模块
import std.format.*     // 导入格式化模块
import std.math.*       // 导入数学函数模块

// 定义函数接收并转换用户输入为 Float64
func inputFloat(info: String): Float64 {
    print(info)  // 输出提示信息
    let number: Float64 = Float64.parse(Console.stdIn.readln().getOrThrow())  // 读取并转换输入
    return number
}

func inputFloat2(info: String): (Float64, Float64) {
    print(info)  // 输出提示信息
    var arr: Array<String> = Console.stdIn.readln().getOrThrow().split(' ')
    return (Float64.parse(arr[0]), Float64.parse(arr[1]))
}

// 自定义角度转弧度的函数
func toRadians(degrees: Float64): Float64 {
    let pi = 3.1415
    return degrees * pi / 180.0
}

// 平移变换
func translate(x: Float64, y: Float64, dx: Float64, dy: Float64): (Float64, Float64) {
    return (x + dx, y + dy)
}

// 旋转变换
func rotate(x: Float64, y: Float64, theta: Float64): (Float64, Float64) {
    let rad = toRadians(theta)  // 调用自定义的 toRadians 函数
    let x_new = x * cos(rad) + y * sin(rad)
    let y_new = -x * sin(rad) + y * cos(rad)
    return (x_new, y_new)
}

// 对称变换
func reflect(x: Float64, y: Float64): (Float64, Float64) {
    return (-x, -y)
}

// 主程序
main(): Int64 {
    let (x, y) = inputFloat2("请输入点的坐标 (x, y): ")
    let (dx, dy) = inputFloat2("请输入平移量 (dx, dy): ")
    let theta = inputFloat("请输入旋转角度 θ: ")

    let translated = translate(x, y, dx, dy)
    let rotated = rotate(x, y, theta)
    let reflected = reflect(x, y)

    println("平移后的坐标: (${translated[0].format("0.1")}, ${translated[1].format("0.1")})")
    println("旋转后的坐标: (${rotated[0].format("0.1")}, ${rotated[1].format("0.1")})")
    println("关于原点的对称点: (${reflected[0].format("0.1")}, ${reflected[1].format("0.1")})")

    return 0
}

四、图形展示(扩展部分)

以下代码使用 Python 生成一个图形,展示了图形的平移、旋转和对称变换。本部分为进阶内容,当前阶段不要求理解

from PIL import Image, ImageDraw, ImageFont

# 创建画布
img = Image.new('RGB', (600, 400), color='white')
draw = ImageDraw.Draw(img)
font = ImageFont.load_default()

# 绘制平移、旋转和对称变换的结果
draw.text((10, 10), "平移后的坐标: (3.0, 4.0)", fill="black", font=font)
draw.text((10, 50), "旋转后的坐标: (1.0, -1.0)", fill="black", font=font)
draw.text((10, 90), "关于原点的对称点: (-1.0, -1.0)", fill="black", font=font)

# 保存图像
img_path = "geometric_transformations.png"
img.save(img_path)
print(f"图形已保存为 {img_path}")

生成的图像如下:
geometric_transformations.pnggeometric_transformations.png


五、示例执行

示例 1

输入:
x, y = 1, 1
dx, dy = 2, 3
θ = 90
输出:
平移后的坐标: (3.0, 4.0)
旋转后的坐标: (1.0, -1.0)
关于原点的对称点: (-1.0, -1.0)

六、小结

通过这道图形变换与坐标计算的题目,学生学习了平移、旋转和对称的变换规则,并掌握了如何用编程实现这些几何计算。


上一篇: 「Mac上学Python 25」小学奥数篇11 - 最大公约数与最小公倍数

下一篇: 「Mac上学Python 27」小学奥数篇13 - 动态规划入门


目录
相关文章
|
9天前
|
编解码 Java 程序员
写代码还有专业的编程显示器?
写代码已经十个年头了, 一直都是习惯直接用一台Mac电脑写代码 偶尔接一个显示器, 但是可能因为公司配的显示器不怎么样, 还要接转接头 搞得桌面杂乱无章,分辨率也低,感觉屏幕还是Mac自带的看着舒服
|
1天前
|
SQL 人工智能 安全
【灵码助力安全1】——利用通义灵码辅助快速代码审计的最佳实践
本文介绍了作者在数据安全比赛中遇到的一个开源框架的代码审计过程。作者使用了多种工具,特别是“通义灵码”,帮助发现了多个高危漏洞,包括路径遍历、文件上传、目录删除、SQL注入和XSS漏洞。文章详细描述了如何利用这些工具进行漏洞定位和验证,并分享了使用“通义灵码”的心得和体验。最后,作者总结了AI在代码审计中的优势和不足,并展望了未来的发展方向。
|
11天前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1574 11
|
15天前
|
存储 人工智能 缓存
AI助理直击要害,从繁复中提炼精华——使用CDN加速访问OSS存储的图片
本案例介绍如何利用AI助理快速实现OSS存储的图片接入CDN,以加速图片访问。通过AI助理提炼关键操作步骤,避免在复杂文档中寻找解决方案。主要步骤包括开通CDN、添加加速域名、配置CNAME等。实测显示,接入CDN后图片加载时间显著缩短,验证了加速效果。此方法大幅提高了操作效率,降低了学习成本。
2127 7
|
1月前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
3天前
|
人工智能 关系型数据库 Serverless
1024,致开发者们——希望和你一起用技术人独有的方式,庆祝你的主场
阿里云开发者社区推出“1024·云上见”程序员节专题活动,包括云上实操、开发者测评和征文三个分会场,提供14个实操活动、3个解决方案、3 个产品方案的测评及征文比赛,旨在帮助开发者提升技能、分享经验,共筑技术梦想。
608 78
|
16天前
|
人工智能 Serverless API
AI助理精准匹配,为您推荐方案——如何快速在网站上增加一个AI助手
通过向AI助理提问的方式,生成一个技术方案:在网站上增加一个AI助手,提供7*24的全天候服务,即时回答用户的问题和解决他们可能遇到的问题,无需等待人工客服上班,显著提升用户体验。
1409 9
|
14天前
|
人工智能 Rust Java
10月更文挑战赛火热启动,坚持热爱坚持创作!
开发者社区10月更文挑战,寻找热爱技术内容创作的你,欢迎来创作!
846 28
|
8天前
|
并行计算 PyTorch TensorFlow
Ubuntu安装笔记(一):安装显卡驱动、cuda/cudnn、Anaconda、Pytorch、Tensorflow、Opencv、Visdom、FFMPEG、卸载一些不必要的预装软件
这篇文章是关于如何在Ubuntu操作系统上安装显卡驱动、CUDA、CUDNN、Anaconda、PyTorch、TensorFlow、OpenCV、FFMPEG以及卸载不必要的预装软件的详细指南。
650 3
|
1天前
|
SQL Java API
Apache Flink 2.0-preview released
Apache Flink 社区正积极筹备 Flink 2.0 的发布,这是自 Flink 1.0 发布以来的首个重大更新。Flink 2.0 将引入多项激动人心的功能和改进,包括存算分离状态管理、物化表、批作业自适应执行等,同时也包含了一些不兼容的变更。目前提供的预览版旨在让用户提前尝试新功能并收集反馈,但不建议在生产环境中使用。
207 4
Apache Flink 2.0-preview released