找回密码
 注册
关于网站域名变更的通知
查看: 334|回复: 3
打印 上一主题 下一主题

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

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

    [LV.1]初来乍到

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

    EDA365欢迎您登录!

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

    x
    请问下面的代码,为什么在使用double函数后,I图像就变成的二值图像,而不需要对X的值进行阈值判断来实现二值化,而double函数的功能不应该是转换成双精度吗?求解释,谢谢8 W' {: `8 M* Y! Q" [. ]
    x=imread('test2.jpg');
    9 k+ P1 r6 c( M% lI0=x;
    , ]2 ]/ M4 T) x+ n) w, tR=x(:,:,1);
    5 a8 n7 j9 H, pG=x(:,:,2);7 f; _0 y5 s; ]
    x=R-G;
    1 E8 N0 \* E* }I=double(x);
    # Q+ j4 ~/ {" Lfigure;' L8 P1 d6 P1 j% r5 s- @
    imshow(I);+ x3 z  k) C, R, q2 G- j
  • TA的每日心情
    奋斗
    2022-1-21 15:15
  • 签到天数: 1 天

    [LV.1]初来乍到

    2#
    发表于 2022-11-29 13:12 | 只看该作者
    如果图像数据是double类型的,那么取值范围是[0,1],如果是uint8类型,则是[0,255]。你这里最后一句应该改成
    1 `/ g+ ?2 r% @3 z8 A  rimshow(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* p! Y" Y; X2 V
    如果图像数据是double类型的,那么取值范围是[0,1],如果是uint8类型,则是[0,255]。你这里最后一句应该改成 ...

    # z3 y! e* [- J# c' Q& _) \3 \8 E1 m但我的问题是为什么用double函数能将R-G处理后的图像变成了二值图像,& c- J: n: ^+ @, A: u
    之前需要设定一个阈值来进行二值化的,但现在不需要就可以实现,这是什么原因如,如何解释?
    / h# p0 H6 N7 ]& r0 h& S2 G" E$ Q3 g  C
  • 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-8-24 07:18 , Processed in 0.109375 second(s), 27 queries , Gzip On.

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

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

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