码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • opencv dots_image_kernel


    1,opencv dots_image_kernel 

    1. // halcon dots_image kernel估算(d=5)
    2. cv::Mat getDotKernel(int d = 5){
    3. // 保证d为正的奇数
    4. d |= 0x01;
    5. cv::Mat kernel = cv::Mat::zeros(d + 2, d + 2, CV_8UC1);
    6. int cx = kernel.cols / 2;
    7. int cy = kernel.rows / 2;
    8. int cnt255 = 0, cnt128 = 0, cnt0 = 0;
    9. for (int row = 0; row < kernel.rows; ++row) {
    10. for (int col = 0; col < kernel.cols; ++col) {
    11. float dis = std::sqrt(std::pow(col - cx, 2) + std::pow(row - cy, 2));
    12. if (dis < d / 2.0){
    13. kernel.at(row, col) = 255;
    14. cnt255++;
    15. }
    16. else if (dis < d / 2.0 + 1.0){
    17. kernel.at(row, col) = 128;
    18. cnt128++;
    19. }
    20. else {
    21. kernel.at(row, col) = 0;
    22. cnt0++;
    23. }
    24. }
    25. }
    26. //
    27. cv::imwrite("kernel8u.0.png", kernel);
    28. //
    29. for (int row = 0; row < kernel.rows; ++row) {
    30. for (int col = 0; col < kernel.cols; ++col){
    31. switch (kernel.at(row, col))
    32. {
    33. case 255:
    34. kernel.at(row, col) = cnt128;
    35. break;
    36. case 128:
    37. kernel.at(row, col) = -cnt255;
    38. default:
    39. break;
    40. }
    41. }
    42. }
    43. cv::imwrite("kernel8u.1.png", kernel);
    44. //
    45. if (cnt255 *cnt128){
    46. kernel.convertTo(kernel, CV_32F, 1.0 / (cnt255*cnt128));
    47. }
    48. return kernel;
    49. }

    2,单元测试

    3,结果

  • 相关阅读:
    PAM从入门到精通(十五)
    vscode中格式化C++代码缩进的方法
    Go微服务: 关于消息队列的选择和分类以及使用场景
    “乘风而上,谋远共赢”润和软件HopeStage2023秋季渠道商会议圆满举行 润和软件 润和软件
    Nginx优化与防盗链
    期待重磅升级的梅李大梦想城亲子游乐园!第三代黄桥大梦想城先让你一饱眼福!
    【Rust日报】2023-09-28 egui 0.23 发布
    ImmunoChemistry艾美捷高级钙素AM细胞活力试剂盒方案
    数据结构初阶之排序(四)
    【论文记录】Boosting Detection in Crowd Analysis via Underutilized Output Features
  • 原文地址:https://blog.csdn.net/mylaf/article/details/134526719
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号