智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 6612|回复: 16
打印 上一主题 下一主题

参加完比赛的你,是否还愿意继续研究技术?

  [复制链接]

44

主题

1485

帖子

0

精华

版主

早川队队长

Rank: 9Rank: 9Rank: 9

积分
20210

资源大师奖章论坛骨干奖章推广达人奖章论坛元老奖章活跃会员奖章优秀会员奖章在线王奖章优秀版主奖章

QQ
威望
5864
贡献
12698
兑换币
630
注册时间
2009-8-18
在线时间
824 小时
跳转到指定楼层
1#
发表于 2011-8-26 18:02:28 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
本帖最后由 sonwendi 于 2011-8-26 18:07 编辑

比完了,轻松了一下,感觉有失有得,自己也打了不少的酱油,好多新想法新技术都闷在肚子里,现在挺后悔没有早点尝试。

准备开学了继续做一做没有做完的工作,再钻研一下,没有了比赛,做做技术也是很快乐的

祝大家在能够享受到工作的快乐

另外,大家用的摄像头估计多多少少有点失真,斜着放会有梯形失真,用广角会有桶形失真,下面是解决桶形失真的一段matlab算法和C++代码,可以解决失真问题,但是会把图像拉小,可以在此基础上改进一下移植单片机也可以。仅供参考:

matlab代码:
  1. %% 镜头桶形失真校正(短焦镜头)

  2. img_origin1 = imread('cap56.bmp');
  3. img_origin = rgb2gray(img_origin1);

  4. k1 = -0.00000037;   % 形变参数,根据实际情况调整
  5. k2 = -0.00000037;

  6. img_size = size( img_origin );
  7. img_undist = zeros( img_size );
  8. img_undist = uint8( img_undist );


  9. for l1 = 1:img_size(1)  % 垂直方向
  10.    
  11.     y = l1 - img_size(1)/2;
  12.    
  13.     for l2 = 1:img_size(2)  % 水平方向
  14.         
  15.         x = l2 - img_size(2)/2;
  16.         
  17.         x1 = round( x * ( 1 + k1 * x * x + k2 * y * y ) );
  18.         y1 = round( y * ( 1 + k1 * x * x + k2 * y * y ) );
  19.         y1 = y1 + img_size(1)/2;
  20.         x1 = x1 + img_size(2)/2;
  21.         
  22.         img_undist(l1,l2) = img_origin(y1, x1);
  23.         
  24.     end
  25. end


  26. figure(1);
  27. subplot(121); imshow(img_origin);
  28. subplot(122); imshow(img_undist);
复制代码
C++代码:
  1. // 镜头校正查找表
  2. CvPoint CorrInd[480][640];

  3. // 镜头径向畸变校正初始化
  4. void LensCorrectInit( double k1 = -0.00000035, double k2 = -0.00000035 );


  5. // 镜头径向畸变校正初始化
  6. void LensCorrectInit( double k1, double k2 )
  7. {
  8.         int imgWidth = camera.GetWidth();   // 获得摄像头图像尺寸
  9.         int imgHeight = camera.GetHeight();

  10.         int imgWd2 = imgWidth>>1;
  11.         int imgHd2 = imgHeight>>1;

  12.         int it;
  13.         int jt;
  14.         int it2;
  15.         int jt2;

  16.         for( int i=0; i<imgHeight; i++ )
  17.         {
  18.                 it = ( i + 1 ) - imgHd2; // (i+1) 是其真正的图像坐标
  19.                 for( int j=0; j<imgWidth; j++ )
  20.                 {
  21.                         double temp;

  22.                         jt = ( j + 1 ) - imgWd2; // (j+1) 是其真正的图像坐标
  23.                         temp = 1 + k1*it*it + k2*jt*jt;
  24.                         it2 = (int)(temp * it);
  25.                         jt2 = (int)(temp * jt);

  26.                         it2 = it2 + imgHd2 + 1;
  27.                         jt2 = jt2 + imgWd2 + 1;

  28.                         CorrInd[i][j].x = jt2;
  29.                         CorrInd[i][j].y = it2;
  30.                 }
  31.         }
  32. }




  33. // 镜头径向畸变校正
  34. void LensCorrect( IplImage* src, IplImage* dst )
  35. {
  36.         int imgWidth = dst->width;
  37.         int imgHeight = dst->height;

  38.         int it2;
  39.         int jt2;

  40.         for( int i=0; i<imgHeight; i++ )
  41.         {
  42.                 uchar *pdstdata = (uchar*)(dst->imageData) + i*dst->widthStep;

  43.                 for( int j=0; j<imgWidth; j++ )
  44.                 {
  45.                         it2 = CorrInd[i][j].y;
  46.                         jt2 = CorrInd[i][j].x;

  47.                         uchar * psrcdata = cvPtr2D( src, it2, jt2 );

  48.                         *(pdstdata++) = *(psrcdata++);
  49.                         *(pdstdata++) = *(psrcdata++);
  50.                         *(pdstdata++) = *(psrcdata++);
  51.                 }
  52.         }
  53. }
复制代码

0

主题

4

帖子

0

精华

注册会员

Rank: 2

积分
196
威望
130
贡献
52
兑换币
22
注册时间
2012-6-15
在线时间
7 小时
17#
发表于 2013-7-11 21:01:29 | 只看该作者
回复 支持 反对

使用道具 举报

2

主题

97

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2755
威望
1363
贡献
656
兑换币
452
注册时间
2011-11-8
在线时间
368 小时
16#
发表于 2013-3-17 08:06:18 | 只看该作者
多谢大神。昨晚刚提完速,这几天去试试矫正。
回复 支持 反对

使用道具 举报

1

主题

9

帖子

0

精华

注册会员

Rank: 2

积分
191
威望
137
贡献
42
兑换币
14
注册时间
2012-6-12
在线时间
6 小时
毕业学校
涟水中学
15#
发表于 2012-6-27 23:43:12 | 只看该作者
很喜欢
回复 支持 反对

使用道具 举报

11

主题

61

帖子

0

精华

高级会员

Rank: 4

积分
592
QQ
威望
417
贡献
111
兑换币
0
注册时间
2011-2-24
在线时间
32 小时
14#
发表于 2012-6-26 18:42:26 | 只看该作者
唉!!!不懂啊
回复 支持 反对

使用道具 举报

13

主题

226

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2448
威望
1293
贡献
539
兑换币
109
注册时间
2011-10-6
在线时间
308 小时
13#
发表于 2011-12-15 12:44:10 | 只看该作者
参考一下,以后要学的东西多着呢
回复 支持 反对

使用道具 举报

44

主题

1485

帖子

0

精华

版主

早川队队长

Rank: 9Rank: 9Rank: 9

积分
20210

资源大师奖章论坛骨干奖章推广达人奖章论坛元老奖章活跃会员奖章优秀会员奖章在线王奖章优秀版主奖章

QQ
威望
5864
贡献
12698
兑换币
630
注册时间
2009-8-18
在线时间
824 小时
12#
 楼主| 发表于 2011-12-14 23:36:43 | 只看该作者
回复 11# zy317409314


    还没有研究到这个地步……
回复 支持 反对

使用道具 举报

5

主题

366

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2124
威望
1227
贡献
555
兑换币
29
注册时间
2011-7-23
在线时间
171 小时
11#
发表于 2011-12-13 11:41:58 | 只看该作者
今年检测 在两边了呀,新手遇摄像头容易丢线问题,用广角就得处理楼主提到的矫正算法了。。。楼主还有没有什么好的建议解决拐弯丢线的问题啊。。。
回复 支持 反对

使用道具 举报

13

主题

177

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1886

优秀会员奖章活跃会员奖章

威望
755
贡献
903
兑换币
62
注册时间
2011-10-23
在线时间
114 小时
10#
发表于 2011-10-30 13:13:40 | 只看该作者
好东西啊
回复 支持 反对

使用道具 举报

44

主题

1485

帖子

0

精华

版主

早川队队长

Rank: 9Rank: 9Rank: 9

积分
20210

资源大师奖章论坛骨干奖章推广达人奖章论坛元老奖章活跃会员奖章优秀会员奖章在线王奖章优秀版主奖章

QQ
威望
5864
贡献
12698
兑换币
630
注册时间
2009-8-18
在线时间
824 小时
9#
 楼主| 发表于 2011-9-28 20:32:35 | 只看该作者
木有人对摄像头标定感兴趣么?你们都是怎么解决广角镜头的?
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-13 08:59 , Processed in 0.121970 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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