Lidar Lite v3をRaspberry piのI2Cで制御する
Overview
Lidar Lite V3の連携方法です。
Lidar Lite V3は小型かつ高性能なレーザーを利用した光学式測距モジュール。搭載可能面積が少ない小型ロボットや、ドローン、無人走行車などに最適です。
接続
データシートより、以下の画像を参照してください。

  - 赤色
 
  - 5V入力(+)
 
  - オレンジ
 
  - 今回は使用しません
 
  - 黄色
 
  - 今回は使用しません
 
  - 緑色
 
  - I2CのSCLに接続
 
  - 青色
 
  - I2CのSDAに接続
 
  - 黒色
 
  - グラウンド(GND)
 
\
Raspberry piに接続されているシールドのI2Cコネクタに接続する。なお、きちんと接続がされていればRaspberry pi上のTerminalにてコマンド
 
などを打てば。

このようにきちんと接続がされているということが分かります。
また、Lidar Lite v3のアドレスが 0x62 であるということもわかります。
Support
LidarLiteV3 Datasheet
回路図

I2Cの設定
あらかじめRaspberry pi側の設定としてI2Cを有効化しておきます。
(参考)
Terminal上で
 
と入力、メニューの中から 5 Interfacing Options を選び、P5 I2C を選択 Would you like the ARM I2C interface to be enable?と問われるので <Yes>を選択すると、有効化が可能。
smbusをインストール
 
 | $ sudo apt-get install python-smbus
  | 
データシートより、距離を知るためにすることは以下の3つ

- 0x00のレジスタに0x04のレジスタの内容を書き込む
 
- 0x01を読み出し、最下位bitが0になるまで繰り返す。
 
- Highは0x0f、lowは0x10より、2byte読み込んで16bitの測定距離をcm単位で取得する。
 
Sample
 
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38  | # coding: utf-8
#lider lite v3
import smbus
import time
bus = smbus.SMBus(1)  #I2Cのバス番号
address = 0x62  #Lider Lite v3のアドレス
ACQ_COMMAND = 0x00
STATUS = 0x01
FULL_DELAY_HIGH = 0x0f
FULL_DELAY_LOW = 0x10
while True:
#0x00に0x04の内容を書き込む
     bus.write_block_data(address,ACQ_COMMAND,[0x04])
#0x01を読み込んで、最下位bitが0になるまで読み込む
     value = bus.read_byte_data(address, STATUS)
     while value & 0x01==1:
         value = bus.read_byte_data(address, STATUS)
#0x8fから2バイト読み込んで16bitの測定距離をcm単位で取得する
     high = bus.read_byte_data(address, FULL_DELAY_HIGH)
     low = bus.read_byte_data(address,FULL_DELAY_LOW)
     val = (high << 8) + low
     dist = val
     print "Dist = {0} cm , {1} m".format(dist,dist/100)
#cmを100倍してmに直す。
     time.sleep(1)
#time.sleep(1)で1秒ごとに距離を出力する。
  | 
アドレスの変更方法
Lidar Lite V3 を一つだけ接続する場合ならば、I2Cのアドレスは0x62であり、普通に動作する。
しかし、複数個つける場合、Lidar Lite V3はI2Cに接続されると、自動的にアドレスが0x62に設定されてしまうので競合状態になってしまう。
これを防ぐため、複数個接続する場合はLidar Lite V3のアドレスを変更しなければならない。
Sample
 
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34  | # coding: utf-8
# lidar lite v3のアドレスを変更する
# lidar lite v3のアドレスはraspberry piに接続すると自動的に 0x62になる
# これは2つ繋げてもどちらもアドレスが0x62になってしまうので誤作動の原因となる
# これを解決するために下のようにアドレスを変更しなければいけない
#lider lite v3
 import smbus
 bus = smbus.SMBus(1)  #I2Cのバス番号
 address = 0x62
 #Lider Lite v3のアドレス
 #アドレスは接続すると自動的に 0x62 になるので注意
 High_address = 0x16
 Low_address = 0x17
 target_high = 0x18
 target_low = 0x19
 new_address = 0x56
 # このプログラムを実行すると new_address が lidar のI2Cのアドレスになる。
 # アドレスが奇数だと自動的に偶数のアドレスに格納されるので注意
 high = bus.read_byte_data(address, High_address)
 low = bus.read_byte_data(address, Low_address)
 bus.write_byte_data( address,target_high , high )
 bus.write_byte_data( address,target_low , low  )
 bus.write_block_data(address , 0x1a , [new_address])
 bus.write_block_data(address , 0x1e , [0x08])
  |