找回密码
 注册
查看: 292|回复: 3
打印 上一主题 下一主题

double函数的功能中有转化为二值的功能吗?

[复制链接]
  • TA的每日心情
    开心
    2022-1-29 15:05
  • 签到天数: 2 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2022-11-29 11:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    请问下面的代码,为什么在使用double函数后,I图像就变成的二值图像,而不需要对X的值进行阈值判断来实现二值化,而double函数的功能不应该是转换成双精度吗?求解释,谢谢+ Y5 b6 O4 I0 v$ S, j4 n/ M0 c+ h
    x=imread('test2.jpg');8 z- I' G- V5 Y5 g- t, F
    I0=x;( v: E5 x! n* @8 g' c
    R=x(:,:,1);
    ; b8 u2 K  s& T* `/ ^G=x(:,:,2);9 E3 m( m2 t8 g! o
    x=R-G;- a, {2 X4 @: d; X
    I=double(x);
    3 @5 R4 ]4 x0 l" c0 n$ ifigure;
    8 s+ Q" l: {6 n% I) ^% R3 E9 dimshow(I);( C1 M& [$ J; M) i% s$ R
  • TA的每日心情
    奋斗
    2022-1-21 15:15
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2022-11-29 13:12 | 只看该作者
    如果图像数据是double类型的,那么取值范围是[0,1],如果是uint8类型,则是[0,255]。你这里最后一句应该改成8 }+ U( C3 _2 V5 ]$ A2 z
    imshow(I/255)

    点评

    但我的问题是为什么用double函数能将R-G处理后的图像变成了二值图像, 之前需要设定一个阈值来进行二值化的,但现在不需要就可以实现,这是什么原因如,如何解释?  详情 回复 发表于 2022-11-29 13:19
  • TA的每日心情
    开心
    2022-1-29 15:05
  • 签到天数: 2 天

    [LV.1]初来乍到

    3#
     楼主| 发表于 2022-11-29 13:19 | 只看该作者
    nocturne 发表于 2022-11-29 13:12: G7 y1 \& b2 U& O% Y4 J
    如果图像数据是double类型的,那么取值范围是[0,1],如果是uint8类型,则是[0,255]。你这里最后一句应该改成 ...
    ' v% w# E/ |2 H2 N) ?+ O
    但我的问题是为什么用double函数能将R-G处理后的图像变成了二值图像,
    $ N% ~: A4 K# ^) ]( M之前需要设定一个阈值来进行二值化的,但现在不需要就可以实现,这是什么原因如,如何解释?, N3 c6 J2 b. T
  • TA的每日心情
    奋斗
    2022-1-21 15:15
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2022-11-29 13:29 | 只看该作者
    你还没理解我上面的解释。因为R-G的元素是uint8类型数据,你把它变成double类型后就直接调用imshow了,这是不应该的。因为imshow的输入参数如果是uint8类型时,0是黑色,255是白色,介于0和255之间是灰度色;但是如果imshow输入参数是double类型,0是黑色,1是白色(大于1的数也都是白色),介于0~1之间的小数是灰度色。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-5-23 22:44 , Processed in 0.078125 second(s), 28 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表