【Gano剣】第11回 ROBO-剣(アーム型) 参加報告 – 画像処理編 –

この記事はrogy Advent Calender 2020 14日目の記事です。

こんにちは、15 の nomo ( @nomotech )です。

この記事は昨日 Loop 君が書いてくれた 【Gano剣】第11回 ROBO-剣(アーム型) 参加報告 – 機構編 – の続きです。
今回は画像処理について解説していきます。

はじめに

私は動きの速いものに対する画像処理は高速である必要があると思っています。しかし大抵のロボコンではロボットは高速に動くのに対して画像処理の高速性にはあまり注目されていないような気がします。
そこで私はこのROBO剣で高速に画像処理をして相手の技をすべて見切ってやろうと考えていました。
が、残念ながら今年のROBO-剣はオンライン開催になり、ロボット同士の剣道の試合ではなく制限時間内にダミーロボットにどれだけ技を決めることができたかを競うルールになってしまいました。

残念ながら認識する相手は動かないダミーロボットですが、来年のことも見据えて高速なリアルタイム画像処理を実装しました。
“【Gano剣】第11回 ROBO-剣(アーム型) 参加報告 – 画像処理編 –” の続きを読む

【Gano剣】第11回 ROBO-剣(アーム型) 参加報告 – 機構編 –

この記事はrogy Advent Calender 2020 13日目の記事です.

こんにちは、15の谷です。

昨日12月12日に開催された「第11回 ROBO-剣(アーム型)」に参加しましたので、その報告と出場ロボットの紹介をします。チーム「ロギ剣」として、3人で参加いたしました。

まず結果として、私達はこの大会で優勝することができました。
加えて、制御技術賞、近藤科学賞も受賞することができました。

初めての出場ではありましたが、私達のロボットが活躍できたこと、またその技術を評価していただけたこと、大変嬉しく思います。
応援してくださった皆様、大会に関わる運営の皆様、選手の皆様に感謝いたします。ありがとうございました。

今回の記事では大会の概要、そして「機構編」としてロボットのメカ部分について紹介させていただきます。
明日明後日は各担当者による制御、画像処理についての記事を予定しています。

“【Gano剣】第11回 ROBO-剣(アーム型) 参加報告 – 機構編 –” の続きを読む

見たいYouTubeの動画を見逃さないために

初めまして、17のバンル( @17_bnr )です。

この記事はrogy Advent Calendar 2020の12日目になってます。

ところでみなさん,声優の夏川椎菜さんを知っていますか?
ハイスクール・フリートの岬明乃

©AIS/海上安全整備局

アイドルマスターミリオンライブの望月杏奈

©窪岡俊之 ©BANDAI NAMCO Entertainment Inc.

などそれ以外にも多くの作品に出演しています。
本業の声優以外にもtrysailというユニットを組んでいたり,
個人アーティストとしても活動しています。
(ところで来年1月6日に新曲,クラクトリトルプライドが出ますね!
サブスクなどでは先行配信されているのでぜひ聴いてみてください)

それ以外にも自信のブログを書いたり,自身のYouTubeチャンネルに毎週動画を配信したりと多方面で活躍しています。

その中で特に自分が好きなのはファミ通TUBEで配信されているゲーム実況です!

これだけは見逃したくないのですが,少し問題がありまして,
ファミ通TUBEは,下の画像にあるように幅広くゲーム関連の動画を配信しています。

そのため,YouTubeの通知機能だとファミ通チャンネルの動画がアップロードされるごとに通知が来てしまいます。
他の動画も面白いのですが,個人的には
ファミ通TUBE夏川椎菜さんの動画だけの通知が欲しい!
でもない……
”ないなら作ればいい”

ってことで作成開始です。

※夏川椎菜さんはファミ通.comでもゲーム実況と同じタイトルのGAMEISCOOLというブログを書いていますので,よければそちらも読んでみてください。

“見たいYouTubeの動画を見逃さないために” の続きを読む

絶縁ICを使ってみた

皆さんこんばんは.アクア研17の煎餅の人です.

こちらはrogy Advent Calender 2020 2日目 まだ寝てないからセーフ! の記事です.昨日の記事でかなり雑に紹介されましたが,ご期待に添えるかな…?

現在アクア研で動いているプロジェクトの片方で,個人的に初めて電源系を絶縁するという試みをしたので,その簡単な報告をします.

作成中の回路.水中ロボットなので防水ケースの中に回路を納める必要があります

書いている人は回路の勉強をしっかりした訳ではないので,内容に誤り等あれば指摘して頂けると嬉しいです.

絶縁ってなにしたの?

作成したパワーモジュール.見た目は完全にただの塩ビパイプだが,中にはモータとバッテリ,マイコンに無線通信機まで入っていて,独立したモータモジュールを構成している.

“絶縁ICを使ってみた” の続きを読む

rogy Advent Calendar 2020 始まりの儀

この記事はrogy Advent Calender 2020 1日目の記事です.

こんにちは.部長のHitomosiです.

rogy Advent Calender 2020が始まります!!!!!!!

毎年恒例のADCでございます.

最近似たようなイベントをやったような気がしますが,そこは気にしない方向で行きましょう.

新入生への勧誘的な話はここ(リンクです)でしたので,リンクでも踏んでください.

そういえば,ADCといえば集まらないもん(だと思ってる)んですが,今年はどうかな?

大いなる可能性を秘めていますね.

明日は先代部長の記事なので,多分すごいと思います.以上です.

アクア研の紹介2020秋

この記事はロ技研秋のブログリレー2020の記事です。

こんにちは。18-Thunderです。ロ技研秋のブログリレー2020ということで自分の所属するアクア研について書いていきます。

アクア研とは

知らない人もいると思うので研究室について紹介します。
名前にもあるとおり、水や流体に関することを対象にします。
水中ロボットだったり水上船を作ったりしてます。

去年主に開発していたもの 増築を重ねた結果がこちら

ここ数年は例年夏に開催される水中ロボットコンベンションへの参加を目標にしています。
特定のタスクがあるわけでもないので、自由に技術を生かしていきます。
水中の自動機を目指して作ることが多いです。

 

水中ということで、地上で元気に動く機体も水没させれば(おそらく)お亡くなりになると思います。水中で元気に動かすために、本研究室では以下のようなことをしています。

  • 回路などの防水
    基板やマイコン、バッテリーなど、すべての電子部品は水が入らないように処理します。
    お弁当箱や塩ビ管を使って密閉することが多いです。(基板をコーティングして直付けしたこともあるが)

    一昨年の機体ですが
    右上がお弁当箱。マイコンや基盤が入っている。 左や下が塩ビ管。左はバッテリー、下はモーターが入っている。

    配線のためのケーブルやメンテナンス時の開閉に気を付けます。
    浸水センサーや緊急停止スイッチもあります。

  • モータの防水
    モーターは防水のほかに回転軸をどうするかを考えなければなりません。
    大きく分けて2つの方法があり、軸を油などで覆う方法と非接触で回す方法です。
    本研究室では磁石による非接触式が多いです。
  • センサー
    手動機なら人が見てやればいいですが、自動機の場合はセンサーで外部の情報を得る必要があります。
    超音波センサーやカメラ、加速度センサー、ジャイロセンサーを使います。
    ブイタッチやゲートくぐりなどのタスクが多いため、カメラで目標を認識することが多いです。
    減衰の関係で画像だけではなく、深度を測るRealSense(出来た)や減衰の少ない音波を用いたソナー(実験中)で補助します。

    カメラの水中画像 真ん中に青い風船があり、上はより水深が深い領域になる
    深度画像 風船の部分が青(近い)に、水深が深い部分が赤(遠い)になっている

    制御にも絡んできますが、壁や床が常に使えるわけではないので真面目に自己位置を取ろうとすると大変です。

  • 機体設計
    船や水底走行機ならともかく、水中ロボットは三次元的に動くため、いろいろ考えることがあります。
    例えば、機体の重心は下に、浮力と重力が釣り合うようにして、静止状態が安定になるようにすること、目的に合うスラスターの位置および個数を決めることがあります。
    水の抵抗の影響を考え、進行方向に垂直な面を減らしたり、横や上から見たときに滑らかな楕円形なるようにしたりもします。

今年度の活動について

コロナの関係で前期は機体製作が難しく、構想、設計や家でできる作業をしていました。
水中ロボコンが12月に延期になったので、現在はそれを目指して機体制作に取り組んでいます。
今年は2チーム参加します。結果が出次第ブログにも報告します。

水冷ファンの補強をしようと思ったのですが…

この記事はロ技研秋のブログリレー9回目の記事です。

皆さんこんにちは、最近PCの自作・改造ばかりしている17-yotaです。今週の自作PC界隈はRTX3070発売やRDNA2(RX6000番台)発表、そしてZen3のベンチマークの噂などで熱いですね。ですが今回はCPUやGPUなどのPCパーツではなく、とある補強パーツを作成した話をしようと思います。

ここまでの大まかな経緯

私が3か月前に組み立てたPC ですが、こちらの記事でも触れた通り7月中旬に一応ほぼ完成したものの、1つだけ3Dプリンタで作成したい補強パーツが残っており、10月になってようやく着手することにしました。

そのパーツですが、実はPCケースが140mmファンに対応していないのにも関わらず、冷却システムに280mm簡易水冷を採用しました。当然ファンとマザボが物理干渉したので、図のように手前にずらして適当に固定した結果、ファンの取り付けが不安(は?)だったので作ることにしました。

ただ補強するといっても既に接する面でネジ止めしたので外側から固定する必要があります。結果的に図のようにケース(左上のコの字型で固定)とファン(右下の爪で固定)を挟むクランプのようなパーツになりました。できればコの字と爪を別に作成し、ネジで圧着したかったのですが…

部品設計

他の工作機械は扱える自信が全くなかったので3Dプリンタを選びましたが、こちらも使用経験が少なく確実に1回は失敗するだろうと思い、まずはプロトタイプを印刷することにして、PCに嵌まることを優先しサイズ的には少し緩めに作成しました。

1回目

出来上がったものを見てなんか小さい気がしたので取り付けようとしたら…縮尺間違えてました。察してください。

(上 : 2回目, 下 : 1回目)

2回目

縮尺に関してはstl変換前と後で辺の長さを比較した結果、10倍に拡大するのが正解だったようです(cmがmmに変換されたのかも?)。他にも、

  • 上面メッシュフィルタとラジエータの間隔を測ったらとても狭かったのでパーツの該当部分を薄く
  • フィレット(辺を直角ではなく丸くする処理)加工を追加
  • 爪の設計をより細かく

などの修正をしました。

1回目は入力こそ違ったものの印刷自体は正常だったので、ひとまずプロトタイプとして完成するかと思ってました。しかし、印刷が終わったので部室に行ったら…何これ??

3回目

どうやら幅2mmだと積層できないっぽいので3mmに戻しました。爪側は思ったように印刷できたのでPCに取り付けて細かい調整をしました。

結果的に1回目の細部変更バージョンになったので積層では失敗しないと思いながら印刷していたのですが…プリンタの隣で祈りながら記事を書いてたら突然バリバリ!と音を立てたので、何かと思って中をみたら前回失敗した面と同じ箇所が割れていました。1回目は上手く印刷できた箇所なのに、無念。

 

まとめ

結局3連続で失敗したため目標の10月中には完成できませんでしたが、今後は薄く積層できるようにサポート材をつけたり肉抜きをしたりしつつ、上手くいったら上下別で作成しネジで圧着する仕組みに変えようと思います。

まあ、たまには失敗した話をするのも現実的でいいですよね(逃避)

 

画像処理&機械学習で水の世界を鮮やかに!~Sea-thru法~

皆様こんにちは.18のhiraと申します.普段は水中ロボットを作るアクア研で活動し,情報通信系の平均点を底から支えています(引きずり下ろしているともいう).

さて,海で泳いだことがある人も多いかと思いますが,水の中はどうも見えにくいですよね.特に「青緑がかっていて暗い」と感じるのではないでしょうか.そして肉眼だけでなく,カメラで撮った写真も同様に色味の無く暗い写真になってしまいます.

この画像の様に水中においては,それも遠ければ遠いほど急速に青緑がかり暗く写ってしまいます.せっかく極彩色で美しいサンゴ礁を撮っても,見直したくなる画像とはならないでしょう.

せっかくダイビングをしたというのに真っ暗な写真ばっかりでは面白くありません.理系が恥も外聞も耐え忍びキラキラした海に繰り出すというのなら,桃色のサンゴ,真っ黄色の魚,紫の貝殻などなど,ただ海を楽しみに来た至極真っ当な方々の目では見ることのできない総天然色の「本物の色」を見てみたいですよね?

“画像処理&機械学習で水の世界を鮮やかに!~Sea-thru法~” の続きを読む

ニコ生の予定をGoogleカレンダーと同期するやつ

この記事はロ技研秋のブログリレー6回目の記事です

こんにちは、16のマッキーです。
みなさんはアイドルマスターシャイニーカラーズをやっていますでしょうか?やっていない方は今すぐ始めよう!→ https://shinycolors.idolmaster.jp/

現在そのアイドルマスターシャイニーカラーズの声優さんが個人で出演されているニコ生の番組が無限に増えています。今年に入ってから新しいニコニコチャンネルが10個以上できて、元からあったチャンネル内の番組としても10個ほど番組が新しくできています。
つまり何がいいたいのかというと
_人人人人人人人人人_
> 時間が足りない <
 ̄Y^Y^Y^Y^Y^Y^Y ̄
そして番組のスケジュールが把握しきれないという問題があります。
(番組にもいろいろあって毎週完全に時間が決まっている番組もあれば、月一回で時間は不定の番組も数多くあるのです)

そこでニコニコ生放送の予定をGoogleカレンダーと同期するやつを作りました。

Googleカレンダーがこんな感じになります。明らかに番組被りすぎてるところがあるんだよなぁ…

やることは簡単
1.Googleカレンダーから現在登録されている番組を取得
2.チェックするチャンネルのこれからの番組をニコニコのAPIから取得
3.未登録の番組をGoogleカレンダーに追加

この3つです。今回はこれをPythonでやってみました(Pythonを選んだ理由は自分が慣れていただけなので深い理由は特にないです)

今回解説するのは・PythonからGoogleカレンダーにアクセスする部分とニコ生APIから番組の取得する部分です。

Googleカレンダー

最初にGoogleカレンダーについてですが、GoogleカレンダーのAPIのページにいろいろ書いてあります。 https://developers.google.com/calendar/quickstart/python
またこちらのページを参考にしました。
https://non-dimension.com/python-googlecalendarapi/

1.Google Calender APIの有効化Google Calender APIよりEnable the Google Calendar APIボタンから
credentials.json
をダウンロード

2.以下のコマンドよりクライアントライブラリのインストールする
pip install --upgrade google-api-python-client google-auth-httplib2 google-auth-oauthlib

3.以下のコードを実行するとGoogleカレンダーの権限を要求されるので許可するとtoken.pickleというファイルが生成されます。
このファイルがあると次回から何も聞かれずカレンダーにアクセスできます。
操作したいGoogleカレンダーの操作したいカレンダーの”設定と共有”からカレンダーIDをコピーしてきてgoogle_calendarIdに代入して操作するカレンダーを指定します。
以下Googleカレンダーの読み書きをする例です。

import os
import pickle
import os.path

from googleapiclient.discovery import build
from google_auth_oauthlib.flow import InstalledAppFlow
from google.auth.transport.requests import Request

from datetime import datetime, timezone, timedelta

TIMEZONE = '+09:00'

google_calendarID='ここにカレンダーID'
SCOPES = ['https://www.googleapis.com/auth/calendar']

## Add calender
creds = None
if os.path.exists('token.pickle'):
with open('token.pickle', 'rb') as token:
creds = pickle.load(token)
print(creds)
# If there are no (valid) credentials available, let the user log in.
if not creds or not creds.valid:
if creds and creds.expired and creds.refresh_token:
creds.refresh(Request())
else:
flow = InstalledAppFlow.from_client_secrets_file(
'credentials.json', SCOPES)
creds = flow.run_local_server(port=0)
# Save the credentials for the next run
with open('token.pickle', 'wb') as token:
pickle.dump(creds, token)
print(token)
service = build('calendar', 'v3', credentials=creds)
event = {
'summary': 'title',
'location': 'location',
'description': 'description',
'start': {
'dateTime': '2020-10-27T20:00:00+09:00',
'timeZone': 'Japan'
},
'end': {
'dateTime': '2020-10-27T21:00:00+09:00',
'timeZone': 'Japan'
}
}

print(event)
event = service.events().insert(calendarId=google_calendarID,body=event).execute()

## Read calender
creds = None
if os.path.exists('token.pickle'):
with open('token.pickle', 'rb') as token:
creds = pickle.load(token)
# If there are no (valid) credentials available, let the user log in.
if not creds or not creds.valid:
if creds and creds.expired and creds.refresh_token:
creds.refresh(Request())
else:
flow = InstalledAppFlow.from_client_secrets_file(
'credentials.json', SCOPES)
creds = flow.run_local_server(port=0)
# Save the credentials for the next run
with open('token/token.pickle', 'wb') as token:
pickle.dump(creds, token)

service = build('calendar', 'v3', credentials=creds)

timefrom=datetime.now().isoformat()+TIMEZONE
timeto= (datetime.now() + timedelta(days=60))
timeto=timeto.isoformat()+TIMEZONE

events_result = service.events().list(calendarId=google_calendarID,
timeMin=timefrom,
timeMax=timeto,
singleEvents=True,
orderBy='startTime').execute()
events = events_result.get('items', [])

print(events)

ニコ生API

次にニコニコのAPIについてです。例えば

https://api.search.nicovideo.jp/api/v2/live/contents/search?q=%E4%B8%80%E8%88%AC%28%E3%81%9D%E3%81%AE%E4%BB%96%29&targets=tags&fields=contentId,channelId,title,startTime,liveEndTime,description&filters[channelId][0]=2644423&filters[liveStatus][0]=reserved&_sort=-startTime&_context=nico%20live%20to%20google%20calendar&_limit=60

のようにAPIエンドポイントhttps://api.search.nicovideo.jp/api/v2/live/contents/search
の後ろにクエリパラメータをいろいろ付けてあげるとデータが返ってきます。これをブラウザなどのURLを入れるところに入れれば検索結果が返ってきます。

pythonでの例は以下の通り

import requests
import urllib.parse

nicolive_API_endpoint='https://api.search.nicovideo.jp/api/v2/live/contents/search'
q_='一般(その他)' #タグ
q=urllib.parse.quote(q_)
targets='tags' #タグ検索

fields='contentId,channelId,title,startTime,liveEndTime,description'
filters_channelId='&filters[channelId][0]='+str('2644423') #チャンネルのID
filters_liveStatus='&filters[liveStatus][0]=reserved' #enum('past','onair','reserved')

_sort='-startTime'
_context='nico live to google calendar'
_limit=str(60)

url=nicolive_API_endpoint+'?q='+q+'&targets='+targets+'&fields='+fields+filters_channelId+filters_liveStatus+'&_sort='+_sort+'&_context='+_context+'&_limit='+_limit 
res = requests.get(url).json()
print(res)

ニコニコのAPIの説明はこちら
https://site.nicovideo.jp/search-api-docs/search.html

基本的にはこれでいろいろ取得できるはずです。

最終的にできたもの

以上の2つを使っていろいろ見やすくしたり、LINE LIVEに対応したりして実際に使ってるのはこちら↓

https://github.com/mmaakkyyii/NicoLive2GoogleCalendar

私はこれを毎日自動で実行するようにしているので最新のニコ生の情報が同期するようになって最高になりました(番組を見る時間は足りない)