惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

Jina AI
Jina AI
NISL@THU
NISL@THU
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
GbyAI
GbyAI
SecWiki News
SecWiki News
Microsoft Azure Blog
Microsoft Azure Blog
J
Java Code Geeks
B
Blog RSS Feed
Blog — PlanetScale
Blog — PlanetScale
Schneier on Security
Schneier on Security
V
Vulnerabilities – Threatpost
C
CXSECURITY Database RSS Feed - CXSecurity.com
V
Visual Studio Blog
宝玉的分享
宝玉的分享
Recent Announcements
Recent Announcements
T
True Tiger Recordings
F
Full Disclosure
Martin Fowler
Martin Fowler
D
Docker
Stack Overflow Blog
Stack Overflow Blog
Security Latest
Security Latest
A
About on SuperTechFans
雷峰网
雷峰网
Know Your Adversary
Know Your Adversary
Application and Cybersecurity Blog
Application and Cybersecurity Blog
Hacker News: Ask HN
Hacker News: Ask HN
B
Blog
V
V2EX - 技术
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google DeepMind News
Google DeepMind News
S
Security Archives - TechRepublic
Google DeepMind News
Google DeepMind News
人人都是产品经理
人人都是产品经理
Malwarebytes
Malwarebytes
C
Check Point Blog
美团技术团队
P
Privacy International News Feed
Recorded Future
Recorded Future
博客园 - 司徒正美
T
The Blog of Author Tim Ferriss
L
LangChain Blog
Project Zero
Project Zero
P
Proofpoint News Feed
有赞技术团队
有赞技术团队
P
Proofpoint News Feed
Scott Helme
Scott Helme
C
CERT Recently Published Vulnerability Notes
云风的 BLOG
云风的 BLOG
T
ThreatConnect
F
Fox-IT International blog

博客园_首页

GoF设计模式——代理模式 上位机程序集的反编译与加壳保护 基于 Blazor 实现的电梯运行监测系统 - known 【Agentic RL / 强化学习 / OPD】OpenClaw-RL 源码阅读笔记 --- (3)--- 总体思考 用 ESP32 做了一个 AI Agent 桌面状态核心,科技感直接拉满 马能否走遍棋盘的可达性证明 PortSwigger SQL注入LAB10 从 Harness Engineering 到 Trellis:AI 编程助手的工程化落地实践 信息化运维项目费用测算全指南:政策边界、三大方法与实操要点 Claude Code 实战 400 万 Tokens:接入 DeepSeek V4,从$26降到$2 Docker--容器常用命令 Dify — Chatflow - 数据库 零基础认识大语言模型工作原理 不繁花 写页面时别再把 Element Plus 整个搬进来啦!Vue3按需加载的坑我帮你踩平了 一条命令让你这辈子彻底解决"LF will be replaced by CRLF"(建议收藏) Miller Rabin:概率之下,证据成群 - Ofnoname Nessus 2026.5.9 更新升级:企业级漏扫工具的全能进阶与实战应用 Agent Harness 架构真相:Prompt Cache 如何决定 Skill、MCP 与 SubAgent 设计 Claude Code 支持 LSP 指南(C#/JAVA等) [翻译] 为什么我要用 C# 构建数据库引擎 DeepSeek V4 + Claude Code thinking mode 400 错误修复方案 云原生 CI/CD 平台架构设计 模板方法模式实战:重构Agent工具审批,告别重复代码 Ubuntu修改主机名操作指南 [MAF的Agent管道详解-03]连接LLM的IChatClient对象 《HelloGitHub》第 122 期 AI Agent 到底是做什么的?优势在哪里? 完整学习LLM(六):上下文窗口是什么,为什么模型会忘东西 和AI一起搞事情#6. 如何实现AI生图文字可编辑? 洛谷-P11105 [ROI 2023] 解密 题解 入门:我的第一个Vibe Coding实践程序 【Agentic RL / 强化学习 / OPD】OpenClaw-RL 源码阅读笔记 --- (2)--- On-Policy Distillation OpenHuman、OpenClaw、Hermes Agent 傻傻分不清楚?一篇说清三者定位 一个前端股票行情 SDK 的开源进化:从周刊收录到 v1.10.0 Claude Code 装了一堆 Skill,用了三个月,我删掉了 80% Claude Code Skill的介绍与使用 AI 漫剧账号运营教程 Hadoop(CDH6、CDP7)在Qwen3.7大模型训练中的作用,(含部署、运行操作步骤) Dify — 创建聊天机器人 -- 知识库 未来十年的数据工程:从 Modern Data Stack 到 Data Engineering Harness Java 泛型解析太痛苦?你可能需要一枚「蛋」 RAG系列:#5 RAG中的11种分块策略 看完《低智商犯罪》,学习Cypher构建知识图谱 临时邮箱的实现原理 记录一下我的 Gradle 开发环境配置过程 使用容器提供postgresql RESTful API服务 在Vue/Nuxt、React/Next/TanstackStart、RazorPages折腾一圈后,还是回到了Blazor,但这回有SSR+HTMX+Alpine的加持 把坏运气关在门外:哈希的随机化之路 agent工作模式之ReAct实战 元数据驱动开发 - 面向对象编程思想的补充 计算机科学/数据科学/人工智能/安全笔记 2026.3 前端包管理咋选?我从npm叛逃到pnpm的血泪史(附避坑指南) 深入 .NET AI Agent 开发:利用 Microsoft.Agents.AI 提取思考、调用工具与执行脚本 vibe coding(二)Where you go:一个微型 windows 桌面覆盖工具 [MAF的Agent管道详解-02]IChatClient管道如何完美连接大模型? [送码] 用 AI Coding 做了一个 App,谈谈 AI Coding 的真实体验 Claude Code 9 大神级 Skills,开发效率直接翻倍(安装、使用场景、踩坑经验) Claude Code 如何压缩上下文:Microcompact、Prompt Cache 与 cache_edits 工程拆解 Docker--Docker引擎与镜像相关命令 AScript定制left/right join查询语法 - rockey627 【学习笔记】《Python编程 从入门到实践》第3章:Python列表完全指南——创建、修改、删除与排序 - lunzi_fly PolyMarket Ghost Fills(幽灵订单)探究 - ACai_sec 面试官:说一下 Agent 的常见范式,如何选型? - 一枫说码 基于ONNXRuntime C#实现的高性能YOLO推理框架 基于 SkiaSharp 的 WPF & AvaloniaUI 极简动图播放方案 贩卖焦虑的时代,我终于接住了真实的焦虑 西安交大最新综述!一文带你读懂大模型智能体及其组网与安全 【Application Insights】采样率对Function App日志收集的影响和解决方法 Excel考勤公式-上班与休息日 完整学习LLM(五):Embedding是什么,为什么文本能变成向量 深度拆解 OpenCoWork:一个本地多智能体桌面平台的架构设计与实现 在影子里验证比较对象:随机指纹和哈希的数学原理 mysql备份恢复详解 HAProxy 学习总结 Mysql事物的持久性及原子性 应用内隐私信息被窥视?防窥保护自动感知一键防护 uni-app 实现视频聊天、屏幕分享,支持Android、HarmonyOS、iOS 做共享目录实时同步,踩过这些坑 华为公司发布半导体演进新范式 - “韬(τ)定律”(Tau Law) Linux时区修改为CST Go 语言入门学习笔记基础版 给热水器装上“电量显示”:用 Shelly Gen4 脚本实现零改装水量预测 踩坑实录:接口正常Feign调用字段值为空 耿同学学术打假,就是学术版《狂人日记》;学术打假,就是清扫垃圾 浙江事业编笔试上周出分!面试进入倒计时,该如何高效冲刺 - 里奥不吃奥利奥 FastApiAdmin 后端接口开发好了,前端管理界面怎么调用与显示? 我写了 50 个 Claude Code Skill 才发现,前 30 个都白写了 告别 "cd /var/log" !用 journalctl 统一掌控 Linux 日志 我用自己的微信聊天记录,微调了一个“数字分身” AI运动APP开发的常见问题集锦一 复盘梳理-如何深入并抽象 告别手动复制!公众号文章批量导出工具,极致提升内容运营效率 【学习笔记】《Python编程 从入门到实践》第2章:变量命名规则、字符串操作与数值类型详解 Docker--Docker简介及系统架构 别再瞎搞 AI 了!大厂AI业务落地的五个关键环节!(建议新手直接照搬) [MAF的Agent管道详解-01]塑智能体边界,从AIAgent抽象类开始 平台智能化到了分水岭:为什么配置代码化才是 AI Coding 的下一代接口 P.4文本统计工具 高光谱拼接算法(二)Harris 角点探测 - 哥布林学者
《GIS基础原理与技术实践》配套案例(Python版)
charlee44 · 2026-05-28 · via 博客园_首页

🚀 快速开始

1️⃣ 安装 Conda 环境

本项目依赖 Conda 进行环境隔离与包管理。如果您尚未安装 Conda,请根据个人习惯选择以下任意一种发行版进行安装:

  • Anaconda:功能全面的科学计算发行版(如果您已安装 Anaconda,可跳过此步骤)。
  • Miniconda:仅包含 Conda 和 Python 的轻量级发行版,推荐追求简洁环境的用户。

2️⃣ 获取项目代码

克隆或下载本项目到本地目录,在根目录的 Python 子目录中找到并确保包含核心配置文件 environment.yml

3️⃣ 创建专属环境

在终端(Terminal / CMD / PowerShell)中进入 Python 目录文件夹,运行以下命令一键创建名为 gis-basic 的虚拟环境:

conda env create -f environment.yml

💡 注意:首次创建可能需要几分钟时间,请耐心等待依赖包下载与解析完成。

4️⃣ 激活环境

环境创建成功后,执行以下命令切换至该环境:

conda activate gis-basic

5️⃣ 配置环境变量

本项目的部分案例需要读取外部数据路径。请在运行代码前设置全局环境变量 GISBasicRepo,指向您的项目根目录

  • Windows (PowerShell):
    $env:GISBasicRepo = "D:\Github\GISBasic"
    
  • macOS / Linux:
    export GISBasicRepo="/path/to/GISBasic"
    

上述命令仅在当前终端会话中有效。为了获得最佳体验,建议您将其配置为系统的持久化全局环境变量,这样在任何位置启动项目都能自动识别路径。

⚠️ 注意Python版案例与原书案例(C++版案例)设置的环境变量不同,请注意区分。

6️⃣ 运行示例

环境准备就绪后,您可以运行任意示例代码进行测试:

python example-3-1-srs.py

📌 运行说明

由于开源生态的持续演进,第三方依赖库的版本迭代较快,加之网络环境的差异,严格按照“快速开始”中的步骤有时可能会遇到不可预见的兼容性问题。因此,本项目的运行并不强制绑定特定的 Conda 环境。

如果您在复现过程中遇到阻碍,完全可以采用本地已有的 Python 环境或其他包管理工具进行替代。无论使用何种环境构建方案,请确保您的系统中已正确安装并配置了以下核心依赖库:

  • 空间数据处理: GDAL, GEOS, PROJ
  • 科学计算: NumPy, SciPy
  • 几何算法: triangle (约束三角剖分), trimesh
  • 计算机视觉: OpenCV

若您使用的依赖库版本与本项目存在较大差异,部分代码可能需要根据新版 API 进行微调即可正常运行。

在实际的 GIS 开发与学习中,单纯依赖终端命令往往不够高效。建议您使用专业的集成开发环境(IDE)来查阅代码、断点调试及可视化输出。Visual Studio Code (VS Code) 凭借其轻量级和高扩展性,是运行本书案例(Python版)的理想选择。具体的 VS Code 安装与 Python 运行教程,网络上已有海量优质资源,建议读者按需检索学习。

🔍 版本差异

由于底层语言生态与运行机制的根本性不同,本书的 Python 案例版本与 C++ 案例版本在实现细节上存在一定差异。这些差异主要体现在以下三个方面:

1️⃣ 生态限制与替代方案

部分在 C++ 领域极为专业的第三方库(如 CGALOpenSceneGraph),官方并未提供完善的 Python 绑定接口。为了兼顾案例的可运行性与代码复杂度,笔者在 Python 版本中采用了功能相近的开源库进行替代。另外,存在极少数案例找不到第三方库的替代方案,无法实现 Python 版本的案例。

2️⃣ 数据处理机制差异

Python 作为解释型语言,在处理大规模栅格数据(数字图像处理)时,其内存访问效率远低于编译型的 C++。如果在 Python 中直接沿用 C++ 式的多重 for 循环去遍历像素矩阵,将会产生巨大的性能开销,导致程序运行极慢,从而使教学案例失去实际运行的意义。为了解决这一痛点,Python 版本部分案例采用了 NumPy 向量化操作。这种机制将底层的循环交由高度优化的 C/Fortran 库去执行,实现了真正的并行加速。

举例说明

假设我们需要对一幅栅格影像的所有像素值统一乘以系数 0.5(例如进行亮度衰减处理):

  • C++ 风格(基于内存缓冲区的多重循环)
    // C++ 可以直接操作底层内存缓冲区,通过双重循环逐像素计算
    for (int y = 0; y < height; ++y) {
        for (int x = 0; x < width; ++x) {
            buffer[y * width + x] *= 0.5; 
        }
    }
    
  • Python 风格(NumPy 向量化操作)
    import numpy as np
    
    # Python 严禁使用嵌套循环遍历大数组,而是直接将整个矩阵视为一个整体进行数学运算
    # 这行代码背后会自动触发高度优化的底层并行计算,速度比循环快数百倍
    raster_array = raster_array * 0.5
    

3️⃣ 维度对齐机制

除了向量化操作,另一个 Python 空间计算的核心机制是广播机制(Broadcasting)。在 C++ 中,如果要对两个形状不同的矩阵进行加法运算,开发者通常需要手动编写复杂的嵌套循环来扩展维度或对齐索引;而在 NumPy 中,广播机制能够自动根据一定的规则将较小维度的数组“拉伸”以匹配较大维度的数组,从而在不实际复制内存数据的前提下完成高效的逐元素运算。

广播机制的核心逻辑可以概括为以下两点:

  1. 右对齐与补位原则:当两个数组的维度数量不一致时,NumPy 会从最右边的维度开始向前比对。如果某个数组的维度较少,系统会自动在其左侧(即前面)补充尺寸为 1 的维度,直到两者的维度数相同。
  2. 兼容扩展原则:在对应维度的尺寸上,只有满足以下两种情况之一,才能进行广播运算:
    1. 两个数组在该维度上的尺寸完全相等;
    2. 其中一个数组在该维度上的尺寸为 1(此时该维度会被隐式拉伸以匹配另一个数组的尺寸)。

举例说明

假设我们有一个代表高程数据的二维矩阵(3行4列),需要给每一行分别加上一个特定的偏移量(长度为4的一维数组):

import numpy as np

# 定义一个 3x4 的高程矩阵
elevation = np.array([
    [100, 101, 102, 103],
    [200, 201, 202, 203],
    [300, 301, 302, 303]
])

# 定义一个长度为 4 的行偏移向量
offset = np.array([1, 2, 3, 4])

# 直接使用加法!NumPy 会自动将 offset “广播”成 3x4 的矩阵,然后与 elevation 相加
result = elevation + offset

print(result)
# 输出结果:
# [[101 103 105 107]
#  [201 203 205 207]
#  [301 303 305 307]]

在这个例子中,二维矩阵 elevation 的形状是 (3, 4),而一维偏移向量 offset 的形状是 (4,)。根据广播规则,NumPy 首先在 offset 的左侧补一个 1,使其形状变为 (1, 4);随后发现其第一个维度为 1,便将其沿行方向隐式拉伸了 3 次,最终完美匹配成 (3, 4) 的形状完成加法运算。理解并熟练运用这些规则,将帮助读者在处理多维空间数据时,彻底告别繁琐的手动循环与维度拼接。

❓常见问题 (FAQ)

Q: 运行 conda env create 时速度极慢或报错怎么办?
A: 这可能是由于网络连接问题导致。environment.yml 中已经添加了清华源,您可以试试去掉使用代理,或者添加其他国内镜像源。

Q: 提示找不到 GISBasicRepo 环境变量?
A: 请确认您在第 5 步中正确设置了该变量。如果是在 IDE(如 VS Code 或 PyCharm)中运行代码,请记得在 IDE 的运行配置(Run Configuration)中手动添加该环境变量。

Q: 为什么 Python 版本的案例不完整?
A: 这些案例使用的第三方库找不到 Python 环境的替代方案,使用原生 Python 代码实现难度太高,这属于语言生态问题。

💻 配套开源项目GitHub | GitCode