パソコン・インターネット

2017年2月 1日 (水)

Orange Pi Zero original Expansion board

Orange Pi Zero用に拡張ボードを作って見ました。

CPUと云うかSOCの発熱が半端じゃないのでファンを乗っけた。その為「純正?」ボードの使用を諦めた。
とりあえず、必要なUSB、Audioコネクタ、赤外線レシーバしか実装してませんが。

| | コメント (0) | トラックバック (0)

2017年1月17日 (火)

RPi1114FDH Raspberry Pi 電源制御モジュール からアナログ温度センサの値を得る

10(?)分間コーディングです。

に手持ちのアナログ温度センサ MCP9701 を繋げて値を取得してみました。
まぁ、それっぽい値です。アバウトなセンサなんで。。
[code]
#!/usr/bin/env python
import smbus
bus = smbus.SMBus(1)
bus.write_i2c_block_data(0x28, 0x30, [0x02, 0x00 ])
adResult = bus.read_word_data(0x28, 0x30 )
print ("MCP9701 ADC i2c start")
volt= adResult * 3.3 / 1023.0
print(volt),
print(" volt")
temp = (volt*1000.0 - 400.0)/19.5  # convertr volt to temp
print(temp),
print(" C")
print ("MCP9701 ADC i2c done")
[result]
# ./RPi1114_MCP9701.py
MCP9701 ADC i2c start
0.761290322581  volt
18.5277088503  C
MCP9701 ADC i2c done

| | コメント (0) | トラックバック (0)

2017年1月16日 (月)

python i2c sample code 4 RPi ver.3

python i2c sample code 4 RPi  改定版です。
指定した 時分での電源制御機能を追加しました。
============================================
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import smbus    # sudo apt-get install python-smbus
import time
import os
import sys
import argparse
import re
class i2cLPC1114:
    i2c = smbus.SMBus(1)    #  B, B+ 512MB ...2B,3B,Zero
#    i2c = smbus.SMBus(0)    #  B 256MB
    addr = 0x28
    def __init__(self):
        pass
    def led_off(self):
        self.i2c.write_i2c_block_data(self.addr, 0x20, [0x00, 0x00])
    def led_on(self):
        self.i2c.write_i2c_block_data(self.addr, 0x20, [0x00, 0x01])
    def led_flash(self):
        self.i2c.write_i2c_block_data(self.addr, 0x20, [0x00, 0x02])
    def down(self, time):
        st=(time-60)/60
        os.system("/sbin/shutdown -h " "+" + str(st) )
        lt=[ord(c) for c in str(time)]
        lt.insert(0,0x00)
        lt.insert(1,0x10)
        lt.append(0x00)
        self.i2c.write_i2c_block_data(self.addr, 0x11, lt)
    def up(self, time):
        lt=[0x00, 0x10]
        lt.extend([ord(c) for c in str(time)])
        lt.append(0x00)
        self.i2c.write_i2c_block_data(self.addr, 0x10, lt)
def hm2s(hm):
    from datetime import datetime
    n=datetime.now()
    try:
#      t=hm.split(":")
      m = re.match(r"^([1]?[0-9]|2[0-3]):([1-5]?[0-9])$", hm)
#      print m.group(1)
#      print m.group(2)
#      print m.group(0)
      t=[""]*2
      if m.group(0):
        t[0] = m.group(1)
        t[1] = m.group(2)
#        print t[0]
#        print t[1]
      else:
        raise
      t=datetime(datetime.now().year,datetime.now().month,datetime.now().day, int(t[0]),int(t[1]),0)
    except:
      print "require -ft hh:mm",
      print " hh value is 0..23",
      print " mm value is 0..59"
      quit();
    r = (t-n).total_seconds()
    if r <0:
      print " It is past time. Please specify the future time."
      quit();
    return int(r)
if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument('cmd', choices=('loff','lon','lb','down','up', 'fdown','fup'))
    parser.add_argument('-t', '--time', type=int, help="Specified units are minutes")
    parser.add_argument('-ft', '--ftime',  help="Please specify hour:minute")
    parser.add_argument('--version', action='version', version='%(prog)s 0.3')
    args = parser.parse_args()
#    print(args)
#    print(args.cmd)
#    print(args.time)
    if args.cmd=="down" or args.cmd=="up":
       if not args.time:
          print "require -t [time(min)]"
          quit();
       else:
          mt=args.time * 60
    if args.cmd=="down":
       if args.time >=2:
          pass
       else:
          print "Please specify more than 2 minutes"
          quit();
    if args.cmd=="fdown" or args.cmd=="fup":
       if not args.ftime:
          print "require -ft [hh:mm]"
          quit();
    m = i2cLPC1114()
    if args.cmd=="loff":
       m.led_off()
    elif args.cmd=="lon":
       m.led_on()
    elif args.cmd=="lb":
       m.led_flash()
    elif args.cmd=="down":
       m.down(int(mt))
    elif args.cmd=="up":
       m.up(int(mt))
    elif args.cmd=="fdown":
       tt=hm2s(args.ftime)
       if tt >=2*60:
          pass
       else:
          print "Please specify the time after 2 minutes"
#       print tt
       m.down(tt)
    elif args.cmd=="fup":
       tt=hm2s(args.ftime)
       m.up(tt)
#       print tt
    else:
       pass
=======================================
[使い方]
# ./RPi1114_set3.py -h
usage: RPi1114_set3.py [-h] [-t TIME] [-ft FTIME] [--version]
                       {loff,lon,lb,down,up,fdown,fup}
positional arguments:
  {loff,lon,lb,down,up,fdown,fup}
optional arguments:
  -h, --help            show this help message and exit
  -t TIME, --time TIME  Specified units are minutes
  -ft FTIME, --ftime FTIME
                        Please specify hour:minute
  --version             show program's version number and exit
[使用例]
2分後に電源断(指定1分前にshutdownを実行)
# ./RPi1114_set3.py down -t  2
10分後に電源投入(OS起動)
# ./RPi1114_set3.py up -t  10
15:30分に電源断(指定1分前にshutdownを実行)
# ./RPi1114_set3.py fdown -ft 15:30
9:00分に電源投入(OS起動)
# ./RPi1114_set3.py fup -ft 9:00

| | コメント (0) | トラックバック (0)

2017年1月14日 (土)

python i2c sample code 4 RPi ver.2

python  i2c sample code 4  RPi  改定版です。

============================================
#!/usr/bin/env python
# -*- coding:utf-8 -*-
 
import smbus    # sudo apt-get install python-smbus
import time
import os
import sys
import argparse
 
class i2cLPC1114:
    i2c = smbus.SMBus(1)    #  B, B+ 512MB ...2B,3B,Zero
#    i2c = smbus.SMBus(0)    #  B 256MB
    addr = 0x28
    def __init__(self):
        pass
    def led_off(self):
        self.i2c.write_i2c_block_data(self.addr, 0x20, [0x00, 0x00])   
    def led_on(self):
        self.i2c.write_i2c_block_data(self.addr, 0x20, [0x00, 0x01])   
    def led_flash(self):
        self.i2c.write_i2c_block_data(self.addr, 0x20, [0x00, 0x02])   
    def down(self, time):
        st=(time-60)/60
        os.system("/sbin/shutdown -h " "+" + str(st) )
 
        lt=[ord(c) for c in str(time)]
        lt.insert(0,0x00)   
        lt.insert(1,0x10)   
        lt.append(0x00)   
        self.i2c.write_i2c_block_data(self.addr, 0x11, lt)   
    def up(self, time):
        lt=[0x00, 0x10]   
        lt.extend([ord(c) for c in str(time)])
        lt.append(0x00)   
        self.i2c.write_i2c_block_data(self.addr, 0x10, lt)   
if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument('cmd', choices=('loff','lon','lb','down','up'))       
    parser.add_argument('-t', '--time', type=int, help="Specified units are minutes")
    parser.add_argument('--version', action='version', version='%(prog)s 0.1')
    args = parser.parse_args()
#    print(args)
#    print(args.cmd)
#    print(args.time)
    if args.cmd=="down" or args.cmd=="up":
       if not args.time:
          print "require -t [time(min)]"
          quit();
       else:
          mt=args.time * 60
    if args.cmd=="down":
       if args.time >=2:
          pass
       else:
          print "Please specify more than 2 minutes"
          quit();
    m = i2cLPC1114()
    if args.cmd=="loff":
       m.led_off()
    elif args.cmd=="lon":
       m.led_on()
    elif args.cmd=="lb":
       m.led_flash()
    elif args.cmd=="down":
       m.down(int(mt))
    elif args.cmd=="up":
       m.up(int(mt))
    else:
       pass
=======================================
[使い方]
# ./RPi1114_set2.py -h
usage: RPi1114_set2.py [-h] [-t TIME] [--version] {loff,lon,lb,down,up}
positional arguments:
  {loff,lon,lb,down,up}
optional arguments:
  -h, --help            show this help message and exit
  -t TIME, --time TIME  Specified units are minutes
  --version             show program's version number and exit
[使用例]
2分後に電源断(指定1分前にshutdownを実行)
# ./RPi1114_set2.py down -t 2

| | コメント (0) | トラックバック (0)

2017年1月12日 (木)

python i2c sample code 4 RPi

RPiとmbedで i2c通信するpython sample codeです。

コマンドで十分なんですがね。。
=========================================================
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import smbus    # sudo apt-get install python-smbus
import time
import os
import sys
import argparse
class i2cLPC1114:
    i2c = smbus.SMBus(1)    #  B, B+ 512MB ...2B,3B,Zero
#    i2c = smbus.SMBus(0)    #  B 256MB
    addr = 0x28
    def __init__(self):
        pass
    def led_off(self):
        self.i2c.write_byte_data(self.addr, 0x6c, 0x30)
    def led_on(self):
        self.i2c.write_byte_data(self.addr, 0x6c, 0x31)
    def led_flash(self):
        self.i2c.write_byte_data(self.addr, 0x6c, 0x66)
    def down(self, time):
#        [self.i2c.write_byte_data(self.addr, 0x64, ord(c)) for c in str(time)]
#        lt=[time]
        lt=[ord(c) for c in str(time)]
#        self.i2c.write_block_data(self.addr, 0x64, lt)
        self.i2c.write_i2c_block_data(self.addr, 0x64, lt)
    def up(self, time):
        [self.i2c.write_byte_data(self.addr, 0x75, ord(c)) for c in str(time)] 
if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument('cmd', choices=('loff','lon','lb','down','up'))
    parser.add_argument('-t', '--time', type=int)
    parser.add_argument('--version', action='version', version='%(prog)s 0.1')
    args = parser.parse_args()
#    print(args)
#    print(args.cmd)
#    print(args.time)
    if args.cmd=="down" or args.cmd=="up":
       if not args.time:
          print "require -t [time(sec)]"
          quit();
    m = i2cLPC1114()
    if args.cmd=="loff":
       m.led_off()
    elif args.cmd=="lon":
       m.led_on()
    elif args.cmd=="lb":
       m.led_flash()
    elif args.cmd=="down":
#       m.down(120)
       m.down(int(args.time))
    elif args.cmd=="up":
#       m.up(120)
       m.up(int(args.time))
================================================      
#  ./RPi1114_set.py -h
usage: RPi1114_set.py [-h] [-t TIME] [--version] {loff,lon,lb,down,up}
positional arguments:
  {loff,lon,lb,down,up}
optional arguments:
  -h, --help            show this help message and exit
  -t TIME, --time TIME
  --version             show program's version number and exit
 
#  ./RPi1114_set.py
usage: RPi1114_set.py [-h] [-t TIME] [--version] {loff,lon,lb,down,up}
RPi1114_set.py: error: too few arguments
#  ./RPi1114_set.py --v
RPi1114_set.py 0.1

| | コメント (0) | トラックバック (0)

2016年7月 1日 (金)

Raspberry Pi Zero でとりあえずAudio

Raspberry Pi Zero でとりあえずAudio再生出来ました。

[参考サイト]
http://niccloud.niandc.ne.jp/?p=2115
https://learn.adafruit.com/adding-basic-audio-ouput-to-raspberry-pi-zero/pi-zero-pwm-audio
AMPは、余っていた秋月のHT82V739使用ミニモノアンプ基板を使用
20160708_063440_2

| | コメント (0) | トラックバック (0)

2016年6月22日 (水)

Raspberry Pi ZERO USB壊れる(-1)

春先に、英国の店から購入したRaspberry Pi ZERO v1.2 が到着から1w足らずに
肝心のUSBが壊れた。
電源は流れるのだが、一切のUSB機器を認識しない。
色々対応をしたつもりですが、結局駄目で放置してましたが、
とりあえず10-BASEで繋げてみました。(今更ながら)
まぁそこそこ速い(!?)
参考サイト
http://raspi.tv/2015/ethernet-on-pi-zero-how-to-put-an-ethernet-port-on-your-pi
20160616_151431

| | コメント (0) | トラックバック (0)

Raspberry Pi ZERO USB壊れる(1)

春先に、英国の店から購入したRaspberry Pi ZERO v1.2 が到着から1w足らずに

肝心のUSBが壊れた。
電源は流れるのだが、一切のUSB機器を認識しない。
色々対応をしたつもりですが、結局駄目で放置してましたが、
MagPiのおまけの奴は同様な症状が多いらしいです。。
最近
ESP-12E でのWiFi接続が出来るようになったよ。
参考サイト
https://hackaday.io/project/8678-rpi-wifi#j-discussions-title
http://oshlab.com/esp8266-raspberry-pi-gpio-wifi/
max   Bit Rate=72.2 Mb/s 出たよ。
20160627_134308

| | コメント (0) | トラックバック (0)

2015年2月21日 (土)

Raspberry Pi 2 Model B やっと入手

例によって、RS版は入手出来なかったので、Element14製です。
要らないけど紙のマニュアルが付いてる。

流石に、WiFiドングル差すとパソコンのUSBポート電源じゃ動かないな。。

写真写真

| | コメント (0) | トラックバック (0)

2015年2月 1日 (日)

Windows 10のTP版グラボのdriverが無い

Windows 10のTP版ですが、古いグラボ(nVidia GeForce 7300 LE)のdriverが標準で無いのでwin7-8用driverをinstallしました。
これでやっとFull HD表示になりました。

| | コメント (0) | トラックバック (0)

より以前の記事一覧