当前位置: 首页 > wzjs >正文

连云港公司网站优化服务有限责任公司的设立条件有哪些

连云港公司网站优化服务,有限责任公司的设立条件有哪些,营销型网站建设方案演讲ppt,网站服务名词解释原始的需求是使用OpenCV的直线检测算法(例如LSD)之后,得到一组线段。然后需要从这些线段得到类似矩形的四边形,用于检测经过透视变换的矩形物体。这些线段不一定首尾相接,彼此之间可能相交或有一定距离。 以下是需求图…

原始的需求是使用OpenCV的直线检测算法(例如LSD)之后,得到一组线段。然后需要从这些线段得到类似矩形的四边形,用于检测经过透视变换的矩形物体。这些线段不一定首尾相接,彼此之间可能相交或有一定距离。

以下是需求图:

使用从线段中寻找四边形的算法之后,得到了以下结果:

算法的步骤为:

1、从线段中挑出4条,顺序不同的组合只有3种。

2、对于每一种组合,由于每一条线段都有2个方向,那么就会有8种组合。

3、对于每一个组合,首先检查相邻线段的夹角,排除太小或太大的(相对于90度)。

4、继而检查相邻线段的顶点距离,排除距离太远的。

5、最后,求出四条相邻线段的交点,以这4个交点作为最终透视矩形的四个顶点。

算法代码如下:

/// <summary>
/// 线段组成四边形
/// </summary>
/// <param name="segs">线段列表</param>
/// <param name="maxDistSum">最大距离和</param>
/// <returns>四边形列表</returns>
public static List<PolygonScore> FormQuadrangle(Segment2D[] segs, double maxDistSum)
{int len = segs.Length;List<int[]> combines = new List<int[]>();for (int i = 0; i < len - 3; i++){for (int j = i + 1; j < len - 2; j++){for (int k = j + 1; k < len - 1; k++){for (int l = k + 1; l < len; l++){combines.Add(new int[] { i, j, k, l });combines.Add(new int[] { i, j, l, k });combines.Add(new int[] { i, k, j, l });}}}}List<RectInfo> rects = new List<RectInfo>();for (int i = 0; i < combines.Count; i++){int[] combine = combines[i];var seg1 = segs[combine[0]];var seg2 = segs[combine[1]];var seg3 = segs[combine[2]];var seg4 = segs[combine[3]];double cos1 = CosAngle(seg1.Vec, seg1.Length, seg2.Vec, seg2.Length);if (Math.Abs(cos1) > 0.5){continue;}double cos2 = CosAngle(seg2.Vec, seg2.Length, seg3.Vec, seg3.Length);if (Math.Abs(cos2) > 0.5){continue;}double cos3 = CosAngle(seg3.Vec, seg3.Length, seg4.Vec, seg4.Length);if (Math.Abs(cos3) > 0.5){continue;}double cos4 = CosAngle(seg4.Vec, seg4.Length, seg1.Vec, seg1.Length);if (Math.Abs(cos4) > 0.5){continue;}var doubleSegs = new Segment2D[] { seg1, seg1.Reverse(), seg2, seg2.Reverse(), seg3, seg3.Reverse(), seg4, seg4.Reverse() };bool found = false;for (int i1 = 0; i1 < 2; i1++){for (int i2 = 2; i2 < 4; i2++){double d1 = PointPoint(doubleSegs[i1].P2, doubleSegs[i2].P1);if (d1 > maxDistSum){continue;}for (int i3 = 4; i3 < 6; i3++){double d2 = PointPoint(doubleSegs[i2].P2, doubleSegs[i3].P1) + d1;if (d2 > maxDistSum){continue;}for (int i4 = 6; i4 < 8; i4++){double d3 = PointPoint(doubleSegs[i3].P2, doubleSegs[i4].P1);double d4 = PointPoint(doubleSegs[i4].P2, doubleSegs[i1].P1);double dd = d2 + d3 + d4;if (dd < maxDistSum){rects.Add(new RectInfo(new Segment2D[] { doubleSegs[i1], doubleSegs[i2], doubleSegs[i3], doubleSegs[i4] }, dd));found = true;}if (found){break;}}if (found){break;}}if (found){break;}}if (found){break;}}}rects.Sort();List<PolygonScore> polygons = new List<PolygonScore>();foreach (RectInfo rect in rects){polygons.Add(new PolygonScore(new Point2D[] {Intersect(rect.Segments[0],rect.Segments[1]),Intersect(rect.Segments[1],rect.Segments[2]),Intersect(rect.Segments[2],rect.Segments[3]),Intersect(rect.Segments[3],rect.Segments[0])}, rect.DistSum));}return polygons;
}

使用上面的代码对下图进行简单测试:

得到如下结果:

http://www.dtcms.com/wzjs/551532.html

相关文章:

  • 中国知名的建网站的公司威海城乡建设局网站
  • 销售网站排名排版设计工作内容
  • 手机网站淘宝客怎么做安徽省建设工程招投标信息网
  • 英雄联盟网站模板做网站的费用属于哪个科目
  • 网站风格设计原则刷推广链接人数的软件
  • 网站怎么做子网页线上装修设计
  • 潍坊做电商的网站wordpress 首页无法访问
  • wordpress网站新闻专业新站整站快速排名公司
  • 网站开发开发需求文档网络营销推广经验总结
  • iis网站权限配置wordpress视频网站
  • asp化妆品网站短视频代运营方案模板
  • 百度网站建设技术前端代码做招新网站
  • 网站解除域名绑定一起装修网北京总部官网
  • 河南城市建设招标类网站久久建筑网登录入口
  • 家政公司网站的建设建各公司网站要多少钱
  • 推广网站的广告怎样做下载站用什么网站系统
  • 那种限时购的网站如何做普陀区网站建
  • 只有域名如何做网站建设网站建设什么挣钱
  • 中国林业工程建设协会网站湖南省房管局官网
  • 佛山中小企业网站建设网站免费建站方法
  • 网站图片都是站外连接对seo汕头高端模板建站
  • 怎么快速优化网站注册查询官方网站
  • 在线免费货源网站网站后台管理系统怎么上传
  • 前端企业网站开发wordpress 生成 app
  • 装修网站建设方案百度文库鲅鱼圈网站建设
  • 网站建设的费用包括网上商城制作
  • 怎么在百度创建网站西安做兼职网站设计
  • 网页 网站 站点的区别微信小程序怎么做教程
  • 电子商城网站开发项目经验给企业做网站 内容需要对方提供
  • 学校网站建设的好处山西建设网站的公司