智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 7326|回复: 12
打印 上一主题 下一主题

求线性CCD中线提取参考例程

[复制链接]

6

主题

26

帖子

0

精华

高级会员

Rank: 4

积分
762
威望
404
贡献
206
兑换币
236
注册时间
2013-11-17
在线时间
76 小时
跳转到指定楼层
1#
发表于 2014-3-9 19:43:16 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
5贡献

望各位不吝赐教,给个程序参考一下,实在无从下手。

回复

使用道具 举报

4

主题

215

帖子

0

精华

高级会员

Rank: 4

积分
950
威望
490
贡献
234
兑换币
314
注册时间
2013-11-5
在线时间
113 小时
毕业学校
棣棠中心校
2#
发表于 2014-3-10 23:54:47 | 只看该作者
由中向两边提取,或者由上次中点向两边提取,,如果左没上升沿,右没下降沿,返回提取左下降沿,右上升沿,然后判断偏差,,不要想有现成的程序,,可能技术报告上有
回复

使用道具 举报

4

主题

73

帖子

0

精华

高级会员

Rank: 4

积分
552
威望
315
贡献
145
兑换币
110
注册时间
2012-11-1
在线时间
46 小时
3#
发表于 2014-3-14 16:55:33 | 只看该作者
for(i=start_lie; i>=10; i--)

{

////////////////////////////////////////找左邊界點

for(j=pre_left_point-3;j<=pre_left_point+10;j++)

{

if((image_data[i][j]|image_data[i][j+1]|image_data[i][j+2]|image_data[i][j+3]==1)&&(image_data[i][j-1]&image_data[i][j-2]&image_data[i][j-3]&image_data[i][j-4]==0))

{

Left_point=j;

pre_left_point=j;

border_line[i][left_border]=j;

}

}
回复

使用道具 举报

6

主题

26

帖子

0

精华

高级会员

Rank: 4

积分
762
威望
404
贡献
206
兑换币
236
注册时间
2013-11-17
在线时间
76 小时
4#
 楼主| 发表于 2014-3-20 12:39:10 | 只看该作者
stxhb 发表于 2014-3-10 23:54
由中向两边提取,或者由上次中点向两边提取,,如果左没上升沿,右没下降沿,返回提取左下降沿,右上升沿, ...

请问一下从上次中线向两边搜寻左右黑线,偏移量是用现在求出的中线与上次中线的差值来确定吗?而且我车子跑起来在比较急的弯道过程中会出现丢线问题,能说一下怎样解决吗?
回复

使用道具 举报

6

主题

26

帖子

0

精华

高级会员

Rank: 4

积分
762
威望
404
贡献
206
兑换币
236
注册时间
2013-11-17
在线时间
76 小时
5#
 楼主| 发表于 2014-3-20 12:39:50 | 只看该作者
stxhb 发表于 2014-3-10 23:54
由中向两边提取,或者由上次中点向两边提取,,如果左没上升沿,右没下降沿,返回提取左下降沿,右上升沿, ...

请问一下从上次中线向两边搜寻左右黑线,偏移量是用现在求出的中线与上次中线的差值来确定吗?而且我车子跑起来在比较急的弯道过程中会出现丢线问题,能说一下怎样解决吗?
回复

使用道具 举报

4

主题

215

帖子

0

精华

高级会员

Rank: 4

积分
950
威望
490
贡献
234
兑换币
314
注册时间
2013-11-5
在线时间
113 小时
毕业学校
棣棠中心校
6#
发表于 2014-3-20 19:58:26 | 只看该作者
yangjie1995 发表于 2014-3-20 12:39
请问一下从上次中线向两边搜寻左右黑线,偏移量是用现在求出的中线与上次中线的差值来确定吗?而且我车子 ...

我是用的与64的差值,我也丢线,现在正在换算法
回复

使用道具 举报

9

主题

106

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1198
威望
548
贡献
290
兑换币
308
注册时间
2014-2-22
在线时间
180 小时
7#
发表于 2014-3-20 20:14:51 | 只看该作者
#define LINEBREADTH    10
#define LINECONCAT     8
void AccommodFondLine(s8 *PixelAryy ,u8 PixelCount , s16 *LastLeftPixelStation,s16 *LastRingtPixelStation,u8 FAVAULE)
{
  static u8 NOLeftCount,NORingtCout ;
  s16 temp0B ,temp1B,temp2B,temp3B;
  u8 *LineStation ,LineCount ,*LineLeftStation,*LineRingtStation;
  s16 LeftMIN,LeftMAX,RingtMIN,RingtMAX;
  LineCount = 0 ;
  for(temp0B = 0 ; temp0B < PixelCount ; temp0B ++)
  {
    temp1B = temp0B ;
    temp2B = 0 ;
    /***********
    查找左边凹槽
    ***********/
    while(temp2B <= LINEBREADTH)
     {
      temp1B -- ;
      if(temp1B < 0)
        break ;
      if( PixelAryy[temp1B] -  PixelAryy[temp0B] > FAVAULE )
      { temp2B ++ ;}
      else if(temp2B)
      { break ; }

    }

    /***********
    查找右边凹槽
    ***********/
    temp1B = temp0B ;
    temp3B = 0 ;
    while(temp3B <= LINEBREADTH)
    {
      temp1B ++ ;
      if(temp1B > PixelCount)
      { break ; }
      if( PixelAryy[temp1B] -  PixelAryy[temp0B] > FAVAULE )
      { temp3B ++ ;}
      else if(temp3B)
      { break ; }
    }
    /***********
    记录黑线位置
    ***********/   
    if(temp2B >= LINEBREADTH ){
      *LineStation = temp0B ;
      LineCount ++ ;
    }else if(temp3B >= LINEBREADTH ){
      *LineStation = temp0B ;
      LineCount ++ ;
    }


  }
  /**********
  根据连续性查找左右黑线位置
  **********/
  if(LineCount)
  {
    temp2B = PixelCount >> 1 ;
    temp1B = NOLeftCount << 1;
    temp1B += LINECONCAT;
    LeftMIN = *LastLeftPixelStation - temp1B ;
    LeftMAX = *LastRingtPixelStation + temp1B ;
    if(LeftMIN < 0)
      LeftMIN = 0 ;

    if(LeftMAX > (temp2B + 1))
      LeftMAX  = temp2B + 1 ;

    RingtMIN = *LastRingtPixelStation - temp1B ;
    RingtMAX = *LastRingtPixelStation + temp1B ;
    if(RingtMAX > PixelCount)
       RingtMAX = PixelCount ;
    if(RingtMIN < (temp2B - 1)){
       RingtMIN = temp2B - 1 ;
    }
    temp2B = 0 ;
    temp3B = 0 ;
   for(temp1B = 0 ;temp1B < LineCount ;temp1B ++ )
   {
     if( (LeftMIN < LineStation[temp1B])&&(LineStation[temp1B]<LeftMAX))
     {
       LineLeftStation[temp2B] = LineStation[temp1B] ;
       temp2B ++ ;
     }else if( (RingtMIN < LineStation[temp1B])&&(LineStation[temp1B]<RingtMAX))
     {
       LineRingtStation[temp3B] = LineStation[temp1B] ;
       temp3B ++ ;
     }

   }

  }else
  {
    NOLeftCount ++ ;
    NORingtCout ++ ;
  }

  if(temp2B)
  {
    NOLeftCount = 0 ;

}
}
回复

使用道具 举报

7

主题

68

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1061
威望
550
贡献
307
兑换币
352
注册时间
2013-10-31
在线时间
102 小时
毕业学校
中大
8#
发表于 2014-3-22 20:57:51 | 只看该作者
无线电—— 发表于 2014-3-14 16:55
for(i=start_lie; i>=10; i--)

{

表示看不太懂!能否解释一下start_lie,pre_left_point,image_data,Left_point=j,border_line是表示什么呢?谢谢
回复

使用道具 举报

7

主题

68

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1061
威望
550
贡献
307
兑换币
352
注册时间
2013-10-31
在线时间
102 小时
毕业学校
中大
9#
发表于 2014-3-22 21:03:13 | 只看该作者
隐逸流光 发表于 2014-3-20 20:14
#define LINEBREADTH    10
#define LINECONCAT     8
void AccommodFondLine(s8 *PixelAryy ,u8 PixelC ...

呵呵!表示看不太懂,是否可以解释一下变量的意思呢!谢谢
回复

使用道具 举报

5

主题

37

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1190
威望
547
贡献
339
兑换币
346
注册时间
2014-10-7
在线时间
152 小时
毕业学校
安徽工业大学
10#
发表于 2015-1-12 20:18:01 | 只看该作者
隐逸流光 发表于 2014-3-20 20:14
#define LINEBREADTH    10
#define LINECONCAT     8
void AccommodFondLine(s8 *PixelAryy ,u8 PixelC ...

能否解释一下的意思*PixelAryy
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

关于我们|联系我们|小黑屋|智能车制作 ( 黑ICP备2022002344号

GMT+8, 2024-12-29 01:52 , Processed in 0.082876 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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