- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 564698 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174632
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
2 C" y7 {+ H' ^! ]* x R' M: H* |( J; v" b7 K# E: a6 U9 \# s
" A" Y& {( x# x( i% h* y* Q4 S#初期试探
* L0 [1 Y: U% p: H5 v拿到题目后,反复读了题目。首先队内结合网上资料形成了两种方案,原理相同就是利用光信号到达的强度来定位。两者差距在于算法不同而已,一种利用计算得出位置,另一种就是经过测量得到一种位置与光强对应的表,然后通过查表得到位置。
7 _1 {5 j# S, a$ b0 l) Y##方法
$ c* x8 |* H) t( |0 O( x! Q产生三个不同频率的方波作为信号驱动三个LED灯发亮,然后再用光电二极管接收。(这里光电二极管、光电三极管、光敏电阻都考虑过。我们的光电三极管识别角度太小,光敏电阻形状不规整,容易造成旋转不对称不利于计算和精度的实现)。接收到的信号经过FFT(快速傅里叶变换)将频率幅度信息还原回来,就像下图
; j" a4 J, z4 R
. P, u7 a) G. P! R $ L( j8 K- r% A, Q9 U, f
这是我做过的最漂亮的一次,之后做的是后都有很大的杂波。(最后发现这个应该不是我们的实验数据而是直接用三个正弦波叠加做的fft,orz)' {1 r) w8 O/ Y" Z
" X6 B4 `& M+ ]3 g: V7 c' d
! C$ R# R4 j O2 n3 l我们想通过不同频段对应幅度与距离的关系,确定LED距离传感器(光电二极管)的位置从而实现定位。: L$ o* |; L: z8 ~' _$ X# P& |
/ K' j8 H, {! Z: n* B7 w% q5 @4 J8 @国赛----可见光室内定位
) ^! f1 l* i. D/ v5 k+ w2 G+ I4 {4 ~# f) P9 {2 G) D
% A {6 j- A0 Z, M
但这些是在极度理想的情况下,事实上灯的亮度很难保证是一个定值,这种装置也不一定具有旋转对称性(距离相同,不同方位强度可能不同),二极管以及发光装置都存在这一定程度的不对称性。
: _+ W8 {1 g4 @) m; h根据实际的测试发现,FFT的结果有很大的抖动,相同的测试环境下幅值甚至会有30%的差别,当然这里有一些是我们自身做的不到位,但是这种方法经过实验证明精度十分的堪忧。于是我们舍弃了这种方法。
& A/ U# g) N6 b# Y2 N9 X: B- v1 t1 ?4 z2 M3 s6 L4 F
#最终方案----摄像头定位! E2 l1 Y" |; y: V
上一个方法我们尝试了接近了两天,最后抛弃了。于是我们的时间仅剩下了一天半,我们有先见之明提前买了摄像头当我们宣布上一个方案死亡时,我们就去尝试了摄像头的方案 摄像头是openmv 附带一个F7的芯片作为处理器,内部跑Python代码。
- R) V% G4 [% A! [5 P) w( ~7 H( H4 |- K8 }2 f' {- a
![]()
& M. Y! h9 }; l3 S! `剩下的就是算法; b+ j7 n, c* V
##算法
( y) y# {3 }* K) ~9 ?7 i# J核心是定位到光源的位置。然后自己(传感器)的位置就是图像中心的位置,已知三个点的位置和自已与三个点的相对位置,剩下的计算就不难了。
9 n% c, Z- t0 U4 y, T
( A, y: r/ o0 K: }' ?: O) [4 ^##障碍
9 ~. Z# W. Q y/ I" V6 X当然实际上不可能只有这么简单,但也不难克服9 W; r* C: y. J+ w
我们的方案是,让摄像头的方向固定,然后利用算法,消除一些固定不准确造成的误差
0 p/ h; R Y* ~) J/ P a2 n5 C/ @1. 摄像头旋转造成的误差- p5 t# J4 Y6 W N9 A7 a
2. 摄像头位置不水平造成的误差
' V0 v# ?* k1 K* r8 w3. 摄像头没有拍到全部光源,特殊情况的处理
( ~7 P, x. R6 I+ P. n) N6 C4. 外界光源的干扰5 m, q0 c5 @. t1 V. l4 f
3 s2 r8 @* S" H4 W6 x
前两个使用算法消除,后两个则是考虑到漏光面只有一处,还有相对的光源几何关系来消除。
9 q$ w+ S, C8 L1 T. \7 Y* @--------------------- : Z; ]! I9 Q) T% r. [7 D" {
作者:丁林夕 ) c. G: ?, h J
来源:CSDN
4 A4 j+ W8 N$ r' l% G
" C h- k0 o% Q0 ], a4 I
; }0 c) d6 ^* y- T" j( ^! E& {, _% B9 j5 Y; h. ?* A9 R
|
zan
|