CavalierContours 二维线操作

CavalierContours 二维线操作

2D polyline library for offsetting, combining, etc.
用于偏移、交并补等组合等操作的 2D 多折段线库。

Polyline Structure 多段线结构

Polylines are defined by a sequence of vertexes and a bool indicating whether the polyline is closed or open. Each vertex has a 2D position (x and y) as well as a bulge value. Bulge is used to define arcs, where bulge = tan(theta/4). theta is the arc sweep angle from the starting vertex position to the next vertex position. If the polyline is closed then the last vertex connects to the first vertex, otherwise it does not (and the last vertex bulge value is unused). See for more details regarding bulge calculations.

多段折线由一系列顶点和一个布尔值定义,该布尔值指示折线是闭合的还是开放的。每个顶点都有一个 2D 位置(x 和 y)以及一个凸起值。凸起用于定义弧,其中凸起 = tan(theta/4)。θ 是从起始顶点位置到下一个顶点位置的弧扫描角。如果折线闭合,则最后一个顶点连接到第一个顶点,否则不连接(并且最后一个顶点凸起值未使用)。

示例

#include "cavc/polylineoffset.hpp"

// input polyline
cavc::Polyline<double> input;
// add vertexes as (x, y, bulge)
input.addVertex(0, 25, 1);
input.addVertex(0, 0, 0);
input.addVertex(2, 0, 1);
input.addVertex(10, 0, -0.5);
input.addVertex(8, 9, 0.374794619217547);
input.addVertex(21, 0, 0);
input.addVertex(23, 0, 1);
input.addVertex(32, 0, -0.5);
input.addVertex(28, 0, 0.5);
input.addVertex(39, 21, 0);
input.addVertex(28, 12, 0);
input.isClosed() = true;

// compute the resulting offset polylines, offset = 3
std::vector<cavc::Polyline<double>> results = cavc::parallelOffset(input, 3.0);

输入多线段(包含弧段)
在这里插入图片描述
结果:
在这里插入图片描述

Demo

//
git clone https://github.com/jbuckmccready/CavalierContours.git
//

vcpkg install gtest:x64-windows
// 试用vcpkg安装Qt环境和相关库
vcpkg install qt5[core,quickcontrols2]:x64-windows

cmake -B build -S . -DCMAKE_TOOLCHAIN_FILE=D:\vcpkg\scripts\buildsystems\vcpkg.cmake
cmake --build build --config Release

在这里插入图片描述

Polyline Offset

在这里插入图片描述

Polyline Combine 交并补

在这里插入图片描述
在这里插入图片描述

Polyline Offset Islands

在这里插入图片描述

Hilbert Curve 希尔伯特曲线

在这里插入图片描述
在这里插入图片描述

Algorithm Complexity and 2D Spatial Indexing算法复杂度和二维空间索引

该算法需要查找自相交,测试点与原始折线之间的距离,测试新线段与原始折线之间的相交,以及将开放的折线首尾相连。这些步骤的幼稚方法通常会导致 O(n2) 算法复杂性,其中每个段必须针对其他每个段进行测试,并且必须针对每个段测试每个点。
该库使用的方法是使用打包的 Hilbert R-Tree [4]空间索引。有关 c++ 实现,请参阅 staticspatialindex.hpp。这导致典型输入的算法复杂度为 O(n log n),病理输入的算法复杂度为 O(n2)。

Packed Hilbert R-Tree 希尔伯特 R-Tree

Here is an image of a closed polyline approximating a circle using 100 line segments (blue lines and red vertexes) with spatial index bounding boxes made visible (magenta, orange, and light green boxes). The root of the R-Tree is the light green box, its children are the orange boxes, and its grand children are the magenta boxes.
这是使用 100 个线段(蓝线和红色顶点)近似圆的闭合折线图像,空间索引边界框(洋红色、橙色和浅绿色框)可见。R-Tree 的根是浅绿色的盒子,它的子是橙色的盒子,它的孙子是洋红色的盒子。

在这里插入图片描述

UE 集成

直接以源码的形式集成。
在这里插入图片描述

在这里插入图片描述

参考

1、https://github.com/jbuckmccready/CavalierContours.git
2、https://jbuckmccready.github.io/CavalierContoursWebDemo/
3、https://www.lee-mac.com/bulgeconversion.html
4、https://en.wikipedia.org/wiki/Hilbert_R-tree#Packed_Hilbert_R-trees
5、https://github.com/jbuckmccready/CavalierContoursDev.git
6、https://blog.csdn.net/mrbaolong/article/details/121887605【空间填充曲线】
7、https://blog.csdn.net/mrbaolong/article/details/120854261【RTree 空间索引】

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度学习入门简单实现一个神经网络

实现一个三层神经网络 引言测试数据 代码 引言 今天我们实现一个简单的神经网络 俩个输入神经元 隐藏层两个神经元 一个输出神经元 激活函数我们使用sigmoid 优化方法使用梯度下降 我们前期准备是需要把这些神经元的关系理清楚 x1&#xff1a;第一个输入 x2&#xff1a;第二个…

Linux系统----------探索mysql数据库MHA高可用

目录 一、MHA概述 1.1 什么是 MHA 1.2MHA 的组成 1.2.1MHA Node&#xff08;数据节点&#xff09; 1.2.2MHA Manager&#xff08;管理节点&#xff09; 1.3MHA 的特点 1.4MHA工作原理 1.5数据同步的方式 1.5.1同步复制 1.5.2异步复制 1.5.3半同步复制 二、搭建 MySQ…

8.6 循环神经网络的简洁实现

每个步长共用参数 加载数据 虽然 8.5节 对了解循环神经网络的实现方式具有指导意义&#xff0c;但并不方便。 本节将展示如何使用深度学习框架的高级API提供的函数更有效地实现相同的语言模型。 我们仍然从读取时光机器数据集开始。 import torch from torch import nn from…

华为流量整形配置

组网需求 如图1所示&#xff0c;企业网内部LAN侧的语音、视频和数据业务通过Switch连接到RouterA的Eth2/0/0上&#xff0c;并通过RouterA的GE3/0/0连接到WAN侧网络。 不同业务的报文在LAN侧使用802.1p优先级进行标识&#xff0c;在RouterA上根据报文的802.1p优先级入队列&…

Flutter环境搭建及版本管理

前言 Flutter已成为移动应用开发的主流选择&#xff0c;其跨平台优势日益凸显&#xff0c;使学习Flutter成为现代开发者的必备技能。越来越多的公司和团队选择Flutter构建应用&#xff0c;这为开发者提供了更广阔的就业机会和职业发展空间。Flutter的热度源自其强大的特性和生…

【动手学深度学习-pytorch】-9.3深度循环神经网络

到目前为止&#xff0c;我们只讨论了具有一个单向隐藏层的循环神经网络。 其中&#xff0c;隐变量和观测值与具体的函数形式的交互方式是相当随意的。 只要交互类型建模具有足够的灵活性&#xff0c;这就不是一个大问题。 然而&#xff0c;对一个单层来说&#xff0c;这可能具有…

WebCopilot:一款功能强大的子域名枚举和安全漏洞扫描工具

关于WebCopilot WebCopilot是一款功能强大的子域名枚举和安全漏洞扫描工具&#xff0c;该工具能够枚举目标域名下的子域名&#xff0c;并使用不同的开源工具检测目标存在的安全漏洞。 工具运行机制 WebCopilot首先会使用assetsfinder、submaster、subfinder、accumt、finddom…

layui laydate日期初始化的一些坑

layui laydate日期初始化的一些坑 背景坑一&#xff1a;利用class属性初始化时间控件失败坑二&#xff1a;后加载页面时间控件初始化失败坑三&#xff1a;结束时间需要默认追加23:59:59 背景 在日常开发中&#xff0c;总是会不可避免的用到日期插件&#xff0c;不同的日期插件…

IoT网关在智能制造工厂生产线监控与管理中的应用-天拓四方

随着工业4.0时代的到来&#xff0c;智能制造已成为工业发展的重要方向。IoT网关在智能制造工厂中扮演着关键角色&#xff0c;它能够实现设备间的互联互通、数据的实时采集与处理&#xff0c;以及生产线的智能监控与管理。本案例将详细介绍IoT网关在智能制造工厂生产线监控与管理…

100 个 Kotlin 面试问题及答案(其二)

尤其是在Android开发中&#xff0c;Kotlin已经成为一种流行的编程语言。为了帮助您在 Kotlin 面试中取得成功&#xff0c;我们为您简化了 100 个最常见的面试问题。本指南涵盖了广泛的主题&#xff0c;包括基本语言概念和高级功能。每个问题都附有简单的答案和实际示例&#xf…

Spring原理

这次我们来研究Bean的相关知识和spring boot自动配置的相关流程 1.Bean的作用域 1概念 在SpringIoC&DI阶段,我们学习了Spring是如何帮助我们管理对象的. 1. 通过 Controller ,Service , Repository , Component , Configuration , Bean 来声明…

Android R 广播注册与发送流程分析

静态广播注册时序图 动态广播注册时序图 发送广播时序图 前言 广播接收器可以分为动态和静态&#xff0c;静态广播接收器就是在 AndroidManifest.xml 中注册的&#xff0c;而动态的广播接收器是在代码中通过 Context#registerReceiver() 注册的。 这里先从静态广播的流程开始…

Pygame基础6-旋转

6-旋转 当我们想要旋转一个图片的时候&#xff0c; 我们可以使用pygame.transform.rotozoom获得旋转后的图片&#xff1a; kitten pygame.transform.rotozoom(kitten, angle, 1)问题是&#xff0c;每次旋转都会降低图片的质量。如果旋转很多次后&#xff0c;图片的质量会变得…

农村集中式生活污水分质处理及循环利用技术指南

立项单位&#xff1a;生态环境部土壤与农业农村生态环境监管技术中心、山东文远环保科技股份有限公司、北京易境创联环保有限公司、中国环境科学研究院、广东省环境科学研究院、中铁第五勘察设计院集团有限公司、中华环保联合会水环境治理专业委员会 本文件规定了集中式村镇生活…

【动手学深度学习-pytorch】9.2长短期记忆网络(LSTM)

长期以来&#xff0c;隐变量模型存在着长期信息保存和短期输入缺失的问题。 解决这一问题的最早方法之一是长短期存储器&#xff08;long short-term memory&#xff0c;LSTM&#xff09; (Hochreiter and Schmidhuber, 1997)。 它有许多与门控循环单元&#xff08; 9.1节&…

婚恋交友APP小程序H5源码交付-支持二开!实名制交友,可服务器审核,亦可后台自己审核!同城交友,多人语音!

一、需求分析 在征婚交友网站开发初期&#xff0c;需求分析是至关重要的环节。这需要深入了解目标用户的需求和期望&#xff0c;包括他们的年龄、职业、兴趣爱好、交友条件等方面。通过收集和分析这些信息&#xff0c;开发团队可以明确网站的目标用户&#xff0c;并为他们提供…

东特科技现已加入2024第13届国际生物发酵产品与技术装备展

参展企业介绍 温州东特科技有限公司是一家集设计、生产、销售及服务为一体的卫生级流体设备企业。专业从事各种乳食品、制药、化工、啤酒设备、不锈钢卫生级阀门&#xff0c;管件&#xff0c;视镜&#xff0c;及非标配件定制等产品的销售与服务。先进的设计理念专业的技术优势一…

深度思考:雪花算法snowflake分布式id生成原理详解

雪花算法snowflake是一种优秀的分布式ID生成方案&#xff0c;其优点突出&#xff1a;它能生成全局唯一且递增的ID&#xff0c;确保了数据的一致性和准确性&#xff1b;同时&#xff0c;该算法灵活性强&#xff0c;可自定义各部分bit位&#xff0c;满足不同业务场景的需求&#…

使用html实现图片相册展示设计

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>图片&#xff08;相册&#xff09;展示设计</title><link rel"stylesheet" href"./style.css"> </head> <b…

SQL--报错注入(join无列名注入)

SQL报错注入 平时在做SQL题时&#xff0c;如果发生语法的错误时&#xff0c;就会产生报错&#xff0c;报错的信息就会显示在前端 报错注入大多是利用函数会报错的特性&#xff0c;将需要的信息通过报错信息回显出来 报错注入函数&#xff08;后面主要的还有一个floor函数暂时…