摄影测量学:用Python完成影像内定向

2023-10-24 03:10

本文主要是介绍摄影测量学:用Python完成影像内定向,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        影像内定向能够将影像架坐标系(框标坐标系)变换为影像上像主点为原点的像坐标系中的坐标。(对于数字化影像则是扫描坐标系到像坐标系的转换)

  1. 量测上述图像上框标的扫描坐标(即行列号)。
  2. 根据仿射变换公式列出误差方程,并用程序实现。实现从扫描坐标系(行列号)到像平面坐标系的转换。

仿射变换公式:

        得到:

        验证过程如下,选择验证点X5,用其框标坐标系中的行列号代替A变换矩阵中的随意一组数值,然后在使用K=A*K 公式进行计算。

        得到K矩阵结果,为像平面坐标系的坐标(mm)第二张图中的。

# -*- coding: utf-8 -*-
import numpy as np
import math# 定义mat_A  8行1列     mat_k 8行6列两个矩阵
mat_K = np.mat(np.zeros((8, 1)))
mat_A = np.mat(np.zeros((8, 6)))
# 验证点
xh5 = 5002
yh5 = 2559
# 通过手动输入Xh 和 Yh 确定矩阵·
mat_A = np.mat([[1, 4913, 4913, 0, 0, 0],[0, 0, 0, 1, 4913, 4913],[1, 4913, 205, 0, 0, 0],[0, 0, 0, 1, 4913, 205],[1, 205, 205, 0, 0, 0],[0, 0, 0, 1, 205, 205],[1, 205, 4913, 0, 0, 0],[0, 0, 0, 1, 205, 4913]])mat_K = np.mat([[106.003],[-106.005],[-106.003],[-106.003],[-106.001],[106.003],[106.001],[106.001]])
X_mat = np.mat(np.zeros((6, 1)))
# 利用K=A*X 输出X=A^-1*K
# X_mat是最终内定向结果,含有仿射变换公式中的未知数(a1~3,b1~3)
X_mat = (mat_A.I) * mat_K# 输出X_mat
print("X=[[%f],\n [%f],\n [%f],\n [%f],\n [%f],\n [%f]" % (X_mat[0], X_mat[1], X_mat[2], X_mat[3], X_mat[4], X_mat[5]))
print("检验过程如下:")
print("点位5 坐标:",xh5,yh5)
#mat_A2 矩阵是包含检验点的A变换矩阵
mat_A2 = np.mat(np.zeros((8, 6)))
mat_A2 = np.mat([[1, 4913, 4912, 0, 0, 0],[0, 0, 0, 1, 4913, 4912],[1, 4913, 205, 0, 0, 0],[0, 0, 0, 1, 4913, 205],[1, 205, 205, 0, 0, 0],[0, 0, 0, 1, 205, 205],[1, xh5, yh5, 0, 0, 0],[0, 0, 0, 1, xh5, yh5]])
k_mat = np.mat(np.zeros((8, 1)))
k_mat = mat_A2 * X_mat
#输出
print("X=[[%f],\n  [%f]\n" % (k_mat[6], k_mat[7]))

得到计算和验证结果:

这篇关于摄影测量学:用Python完成影像内定向的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/272299

相关文章

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

Python Faker库基本用法详解

《PythonFaker库基本用法详解》Faker是一个非常强大的库,适用于生成各种类型的伪随机数据,可以帮助开发者在测试、数据生成、或其他需要随机数据的场景中提高效率,本文给大家介绍PythonF... 目录安装基本用法主要功能示例代码语言和地区生成多条假数据自定义字段小结Faker 是一个 python

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建