C++ 课程设计,图片元素的获取,拟合椭圆

WX: help-assignment

C++ 课程设计,图片元素的获取,拟合椭圆

代码实现步骤:

  1. 读取.jpg 图片(259219443),将图片中的x∈(700,1450)y∈(1,1944)的像素值置为0;

  2. 提取图片的r、g、b 通道,按照(1r-0.6g-0.3*b)对图像中的每个像素值进行重置;

  3. 二值化图片,二值化阈值人为可调(暂定0.2);

  4. 提取二值化后灰度值为1 的所有白点的横纵坐标,将所有坐标保存到数组A 中;

  5. 利用4 中的所有点,拟合椭圆,得到椭圆参数x0,y0,a,b,phi,求出拟合椭圆的两焦点坐标;

  6. 计算4 中所有[(点到椭圆两焦点距离之和)-2a)]的值d;定义可变阈值u=15,找出满足d>u和d<-u 的所有点,将这些满足条件的点的横纵坐标和d 值保存到数组B1(满足d>u)和B2(满足d<-u);

  7. 再将6 中满足条件的点B1、B2 从4 的数组A 中删除,利用剩下的点再拟合一次椭圆,定义角度deg=2(°),按照极坐标将拟合椭圆的(0,deg+50)、(125-eg,235+deg)、(310-deg,360)三个范围内的圆弧,以点的形式保存到数组C 中,定义变量-总点数N=1000 控制点的密度;

  8. 按照极坐标,根据7 拟合椭圆的圆心将360°圆周均分为36 个区域(如下图所示),根据B1、B2 点坐标与7 拟合椭圆圆心的相对位置分别对B1、B2 中的点进行分区,将坐标和
    d 值保存到两个数组D1、D2 中;
    在这里插入图片描述

  9. 将36 个区域的第1 个区域移动到第36 个区域,其他区域前移一位,然后将相邻的两区的点坐标和d 值合并,将18 个区的结果保存到数组E1、E2 中;

  10. 找到每个区域中d 值的最大值(舍弃其他坐标和d 值),将最大d 值对应的点坐标保存到数组F1、F2 中;

  11. 找到F1、F2 数组中的非零点,在椭圆点的数组C 中,找到每个F1、F2 数组中非零点的最近点,将其坐标保存到数组G1、G2 中;
    定义变量
    fx=1.225864026416392e+03、
    fy=1.222035920702631e+03、
    cx=1.262867786018872e+03、
    cy=9.965525461409534e+02、
    数组
    distor=[-0.062350435204761,0.084767499824599,-2.758193383474388e-04,0.001373886815629,
    -0.031851981006323]、
    k1=-0.062350435204761、
    k2=0.084767499824599、
    数组
    p=[-3.216993173751905e-26,-3.160339026653889e-26,1.091798484384938e-26,9.32639128826
    0196e-28,-7.223471162545130e-27,2.253257582218905e-27,-1.091261397869860e-24,2.930349
    684261594e-25,4.866930211908356e-26,-9.193306331385255e-24]、
    dx = 1.4e-03、
    dy = 1.4e-03;

  12. 将G1、G2 和F1、F2 中的横坐标-cx(=ximg),纵坐标-cy(=yimg);将上述横纵坐标和11 中的参数代入下列方程组,得到xc,yc,zc,保存到数组M1、M2 和N1、N2 中;
    在这里插入图片描述

  13. 计算数组M1(点)和数组N1 对应点(最近点)的空间距离,将空间距离每个空间距离×sin(26.5°),将距离不为0 的值保存到数组DIST_1、DIST_2 中;

WX: help-assignment

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/324487.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【QA】Java集合常用的函数

文章目录 前言Collection接口通用函数 | Collections工具类通用函数 | List接口 Set接口List接口ArrayListLinkedList Set接口TreeSetHashSetLinkedHashSet Map接口通用函数TreeMapHashMapLinkedHashMap 前言 本文介绍Java集合中常用的函数。 Collection接口 通用函数 | Co…

林更新博士之路星途璀璨再启航

林更新&#xff1a;博士之路&#xff0c;星途璀璨再启航在这个充满机遇与挑战的时代&#xff0c;有一位演员以其出色的演技和不懈的努力&#xff0c;赢得了无数观众的喜爱。他&#xff0c;就是林更新。今日&#xff0c;一条消息如重磅炸弹般在娱乐圈炸开&#xff0c;让无数粉丝…

Android Studio(AS)使用别人的项目与gradle包并运行项目

一、问题描述 在进行AS开发时&#xff0c;我们可能会使用到别人的项目&#xff0c;但发现别人把项目发给我们后会发现gradle项目同步失败o(≧口≦)o&#xff0c;此时计有三&#xff1a; 1.横行霸道、豪取抢夺&#xff1a;直接空降到项目人那里&#xff0c;强他的电脑占为己有…

Mac电脑安装打开APP显示问题已损坏 问题解决

当MAC电脑安装完软件打开时&#xff0c;显示文件已损坏&#xff0c;无法打开。搜了很多教程终于找到解决方案&#xff0c;记录下方便以后再用。 我的mac电脑是intel芯片的&#xff0c;如果你遇到这个问题&#xff0c;可以参考我的这个方案。 1.首先当打开软件后出现 “xx软件已…

PG 检查点管理与Oracle的比较

之前介绍过&#xff0c;在任何数据库中&#xff0c;一条DML操作执行都需要在内存中执行&#xff0c;但当操作越来越多&#xff0c;总有时候内存会写满&#xff0c;这时候就需要把内存中的块写入到磁盘&#xff0c;释放内存&#xff0c;保存数据。 写入到磁盘这一步&#xff0c;…

PHP高级教程

&#x1f40c;博主主页&#xff1a;&#x1f40c;​倔强的大蜗牛&#x1f40c;​ &#x1f4da;专栏分类&#xff1a;PHP &#x1f4da;参考教程&#xff1a;菜鸟\编程网❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 目录 一、PHP 多维数组 二、PHP date&#xff08;&#…

pyqt 按钮常用格式Qss设置

pyqt 按钮常用格式Qss设置 QSS介绍按钮常用的QSS设置效果代码 QSS介绍 Qt Style Sheets (QSS) 是 Qt 框架中用于定制应用程序界面样式的一种语言。它类似于网页开发中的 CSS&#xff08;Cascading Style Sheets&#xff09;&#xff0c;但专门为 Qt 应用程序设计。使用 QSS&am…

Sora惊艳亮相:AI技术掀起创作革命,影视产业迎来新风貌!

Sora平台近期发布了名为"Sora首次印象"的更新&#xff0c;为用户带来了令人瞩目的变化。该更新不仅展示了Sora平台的发展方向&#xff0c;还介绍了其在电影制作、广告宣传等领域的潜在应用。 同时&#xff0c;Sora的首席执行官Sam Altman与好莱坞影视工作室进行了会…

Nginx Location配置详解

目录 一、Location语法结构1、语法结构说明2、各个标识的含义和优先级3、配置请求的根目录4、替换请求的uri 二、Location具体示例1、精确匹配2、正则匹配3、常规字符串匹配 三、调试Location的小技巧 一、Location语法结构 1、语法结构说明 在Nginx官方文档中定义的location…

Linux进程——Linux下常见的进程状态

前言&#xff1a;在进程学习这一块&#xff0c;我们主要学习的就是PCB这个进程控制块&#xff0c;而PBC就是用来描述进程的结构体&#xff0c;而进程状态就是PCB结构体中的一个变量。 本篇主要内容&#xff1a; 操作系统中的进程状态Linux下的进程状态 在开始之前&#xff0c;我…

C++细节,可能存在的隐患,面试题03

文章目录 11. C编译过程12. const vs #define12.1. 全局const vs 局部const 13. C内存分区14. C变量作用域14.1. 常量 vs 全局变量 vs 静态变量 15. C类型转换16. 函数指针17. 悬空指针 vs 野指针18. 为什么使用空指针&#xff0c;建议使用nullptr而不是NULL&#xff1f; 11. C…

噪声嵌入提升语言模型微调性能

在自然语言处理&#xff08;NLP&#xff09;的快速发展中&#xff0c;大模型&#xff08;LLMs&#xff09;的微调技术一直是研究的热点。最近&#xff0c;一篇名为《NEFTUNE: NOISY EMBEDDINGS IMPROVE INSTRUCTION FINETUNING》的论文提出了一种新颖的方法&#xff0c;通过在训…

Gitlab搭建

Gitlab搭建 一.gitlab安装二.gitlab安装目录三.gitlab常用命令汇总四.gitlab访问测试1.登录gitlab2.配置默认访问密码3.登陆自己创建的账户 五.gitlab图形化操作1.gitlab关闭自动注册2.gitlab免密登录3.gitlab创建项目4.使用管理员创建账户5.gitlab 添加邮箱设置5.1开启SMTP功能…

【直观对比】RTX3090和RTX4090的计算能力的参数对比

1. 引言 随着大模型的火热&#xff0c;越来越多的人希望可以购买一个硬件进行大模型的推理&#xff0c;特别是在3090和4090显卡的对比上&#xff0c;需求比较大。目前已有的显卡对比&#xff0c;大多面向于高端的A/H100或者800系列的对比和分析&#xff0c;如图所示。 项目A1…

Minimal-Supervised Medical Image Segmentation via Vector Quantization Memory

文章目录 Minimal-Supervised Medical Image Segmentation via Vector Quantization Memory摘要方法实验结果 Minimal-Supervised Medical Image Segmentation via Vector Quantization Memory 摘要 辅助重构分支&#xff1a;该分支通过提供额外的监督并产生学习视觉表示所需…

ios实现拍摄视频与显示在界面上

1、添加录音和拍摄权限 NSMicrophoneUsageDescription Privacy - Camera Usage Description 2、代码 #import "ViewController.h" #import <AVFoundation/AVFoundation.h> #import <MobileCoreServices/MobileCoreServices.h>// 接下来是你的 ViewCont…

nginx--tcp负载均衡

mysql负载均衡 安装mysql yum install -y mariadb-server systemctl start mariadb systemctl enable mariadb ss -ntl创建数据库并授权 MariaDB [(none)]> create database wordpress; Query OK, 1 row affected (0.00 sec)MariaDB [(none)]> grant all privileges o…

快速搭建webase-front并且部署合约

PS: 因为我开发时候要用到fisco和webase-front,避免官方文档粘贴, 因此直接整理下面的笔记。开发的时候,好粘贴。1.搭建4节点联盟链 前提 curl 一种命令行工具 apt install -y openssl curl创建操作目录, 下载安装脚本 cd ~ && mkdir -p fisco && cd fisco…

uniapp百度地图聚合

// loadBMap.js ak 百度key export default function loadBMap(ak) {return new Promise((resolve, reject) > {//聚合API依赖基础库,因此先加载基础库再加载聚合APIasyncLoadBaiduJs(ak).then(() > {// 调用加载第三方组件js公共方法加载其他资源库// 加载聚合API// Ma…

《ESP8266通信指南》15-MQTT连接、订阅MQTT主题并打印消息(基于Lua|适合新手|非常简单)

往期 《ESP8266通信指南》14-连接WIFI&#xff08;基于Lua&#xff09;-CSDN博客 《ESP8266通信指南》13-Lua 简单入门&#xff08;打印数据&#xff09;-CSDN博客 《ESP8266通信指南》12-Lua 固件烧录-CSDN博客 《ESP8266通信指南》11-Lua开发环境配置-CSDN博客 《ESP826…