码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Python小知识点汇集——1


    Python小知识点汇集——1

    文章目录

    • Python小知识点汇集——1
      • 一、plt.show()和plt.imshow()的区别
      • 二、cv2或io将mask读入
      • 三、轮廓填充
        • 3.1轮廓内填充
        • 3.2 轮廓外填充
      • 四、keras加载权重出现`axes don't match array`问题

    一、plt.show()和plt.imshow()的区别

    plt.show 显示的是图像的函数
    plt.imshow 显示的是图像本身

    二、cv2或io将mask读入

    在读取mask以后,如果是二类,ROI和背景,ROI为255(白色),背景为0(黑色),一定要检查读取后的mask是否真的unique为[0,255]
    因为实验室另一位同学给我的mask,我以为他已经处理好的了,结果调试的时候出现了异常,后来检查存在这个问题
    我的解决方案是小于127置为0,大于127置为255。

    # demo
    import numpy as np
    import cv2
    from skimage import io
    
    fpath='D:/Python/mask-vae-recontruct/FaceReconstructionWithVAEAndFaceMasks-main/patch/masks/1918240018_OD_156_5.jpg'
    mask=io.imread(fpath)
    io.imshow(mask)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    • io读入和显示
      在这里插入图片描述
    • cv2读入和显示
      在这里插入图片描述
    • 没有处理的mask 在这里插入图片描述
    import numpy as np
    import cv2
    from skimage import io
    
    fpath='D:/Python/mask-vae-recontruct/FaceReconstructionWithVAEAndFaceMasks-main/patch/masks/1918240018_OD_156_5.jpg'
    mask=io.imread(fpath)
    mask[mask<127]=0
    mask[mask>=127]=255
    io.imshow(mask)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 处理后的mask
      在这里插入图片描述
      在这里插入图片描述

    三、轮廓填充

    thickness 为正表示线的粗细

    import numpy as np
    import cv2
    
    fpath='D:\sever\circle\zebra.jpg'
    img=cv2.imread(fpath)
    cv2.circle(img,(150,150),100,(0,0,0))
    cv2.imshow('zebra.jpg',img)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    3.1轮廓内填充

    thickness为-1表示填充轮廓以内的区域

    import numpy as np
    import cv2
    
    fpath='D:\sever\circle\zebra.jpg'
    img=cv2.imread(fpath)
    cv2.circle(img,(150,150),100,(0,0,0),thickness=-1)
    cv2.imshow('zebra.jpg',img)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述

    3.2 轮廓外填充

    import numpy as np
    import cv2
    
    def create_circular_mask(h, w, center=None, radius=None):
    
        if center is None: # use the middle of the image
            center = (int(w/2), int(h/2))
        if radius is None: # use the smallest distance between the center and image walls
            radius = min(center[0], center[1], w-center[0], h-center[1])
    
        Y, X = np.ogrid[:h, :w]
        dist_from_center = np.sqrt((X - center[0])**2 + (Y-center[1])**2)
    
        mask = dist_from_center <= radius
        return mask
    
    fpath='D:\sever\circle\zebra.jpg'
    img=cv2.imread(fpath)
    h,w= img.shape[:2]
    
    mask=create_circular_mask(h, w , center=(150,150),radius= 100)
    masked_img=img.copy()
    masked_img[~mask]=0
    cv2.imshow('masked',masked_img)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    在这里插入图片描述

    四、keras加载权重出现axes don't match array问题

    Question :training后test的时候想要加载预训练的权重,但是出现了axes don't match array字样
    Answer : keras加载权重 model.load_weights(modelpath),适用于训练和测试时使用相同的模型,如果训练时候使用的模型和测试时候使用的模型不完全相同(例如:在训练的过程中有两个输入,测试的时候只有一个输入),这是在加载的过程中要加参数,让权重不完全加载,而是根据现在模型的状况进行加载。model.load_weights(modelpath,by_name=True,skip_mismatch=True)

  • 相关阅读:
    尚好房 04_服务拆分
    容器内的Linux诊断工具0x.tools
    低代码,助力中小企业快速实现信息化
    处理机的调度与死锁
    【笔记】文献阅读[SORT]-SIMPLE ONLINE AND REALTIME TRACKING
    SwiftUI 精品源码之学习可视化应用程序基于SceneKit,AVSpeechSynthetizer 文字转语音功能tts(教程)
    计算机毕业设计ssm全美旅行社网站3ircv系统+程序+源码+lw+远程部署
    STM32+USB3300复位枚举异常的问题
    灵性图书馆:好书推荐-《巴夏:来自未来的生命讯息》
    【JavaEE初阶】线程安全的集合类
  • 原文地址:https://blog.csdn.net/qq_43368987/article/details/126467431
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号