メモです

メモです

tf-pose-estimationの各座標の表示

tf-pose-estimationの各座標はrun.pyでcommon.CocoPart.Background.valueとhuman.body_partsをfor文でまわして取得する。一枚の写真に複数人いることを考慮した設計なので注意。

座標のリストは以下

list= ["鼻","首","右肩","右ひじ","右手首","左肩", "左ひじ", "左手首","左臀部","左ひざ","左足首","右臀部","右ひざ","左足首","右目","左目","右耳","左耳"]

素人が思いつく国債を減らす方法がダメな理由

現状での理解をまとめた。

提案1

日本銀行を大量に刷って借金を返す

基本的な知識

日本銀行券は日銀にとって借金である。いつでも貨幣に交換できることが国民に求められている。

日本銀行券が日銀の資産だとするとおかしくなる。サラ金で金を借りてそのまま自分の口座に預金したものを友達に見せて「俺、金持ってますよ」ということはなんかおかしい。

提案2

国債を全部日銀に買い取ってもらう。そして日銀はそれをずっと売らずにもっておく。

・国民の預金が死ぬ

・現状600兆もっててもいけるやん…

提案3

貨幣を発行して借金を返す

・インフレになって貨幣価値が下がる。

Mask R-CNNのDemoをGoogleColaboratoryでやった。

Mask_RCNN/demo.ipynb at master · matterport/Mask_RCNN · GitHub
をGoogleColaboratoryでやった。

※!を行頭につけるとLinuxのコマンドを実行できる
※%が行頭についているのはIPythonのマジックコマンド

Mask R-CNN(keras)で人物検出 on Colaboratory - Qiita
を参考にしてGoogleColaboratoryに入ってないやつを入れる。

!git clone https://github.com/matterport/Mask_RCNN.git
!cd Mask_RCNN
!pip install -r requirements.txt
%run -i setup.py install
!wget https://github.com/matterport/Mask_RCNN/releases/download/v2.0/mask_rcnn_coco.h5
!git clone https://github.com/waleedka/coco.git
!cd coco/PythonAPI
%run -i setup.py build_ext --inplace
%run -i setup.py build_ext install
#Mask_RCNNディレクトリまで戻る
cd ../../

matplotlibの設定

%matplotlib inline 
import os
import sys
import random
import math
import numpy as np
import skimage.io
import matplotlib
import matplotlib.pyplot as plt

# Root directory of the project
#GoogleColaboratoryのディレクトリに合わせる
ROOT_DIR = "/content/Mask_RCNN"

# Import Mask RCNN
sys.path.append(ROOT_DIR)  # To find local version of the library
from mrcnn import utils
import mrcnn.model as modellib
from mrcnn import visualize
# Import COCO config
sys.path.append(os.path.join(ROOT_DIR, "samples/coco/"))  # To find local version
import coco


# Directory to save logs and trained model
MODEL_DIR = os.path.join(ROOT_DIR, "logs")

# Local path to trained weights file
COCO_MODEL_PATH = os.path.join(ROOT_DIR, "mask_rcnn_coco.h5")
# Download COCO trained weights from Releases if needed
if not os.path.exists(COCO_MODEL_PATH):
    utils.download_trained_weights(COCO_MODEL_PATH)

# Directory of images to run detection on
IMAGE_DIR = os.path.join(ROOT_DIR, "images")

#エラーが出るので足す
from samples.coco import coco

class InferenceConfig(coco.CocoConfig):
    # Set batch size to 1 since we'll be running inference on
    # one image at a time. Batch size = GPU_COUNT * IMAGES_PER_GPU
    GPU_COUNT = 1
    IMAGES_PER_GPU = 1

config = InferenceConfig()
config.display()
# Create model object in inference mode.
model = modellib.MaskRCNN(mode="inference", model_dir=MODEL_DIR, config=config)

# Load weights trained on MS-COCO
model.load_weights(COCO_MODEL_PATH, by_name=True)
# COCO Class names
# Index of the class in the list is its ID. For example, to get ID of
# the teddy bear class, use: class_names.index('teddy bear')
#BGはBackgroundの略。常に0番目に来る。
class_names = ['BG', 'person', 'bicycle', 'car', 'motorcycle', 'airplane',
               'bus', 'train', 'truck', 'boat', 'traffic light',
               'fire hydrant', 'stop sign', 'parking meter', 'bench', 'bird',
               'cat', 'dog', 'horse', 'sheep', 'cow', 'elephant', 'bear',
               'zebra', 'giraffe', 'backpack', 'umbrella', 'handbag', 'tie',
               'suitcase', 'frisbee', 'skis', 'snowboard', 'sports ball',
               'kite', 'baseball bat', 'baseball glove', 'skateboard',
               'surfboard', 'tennis racket', 'bottle', 'wine glass', 'cup',
               'fork', 'knife', 'spoon', 'bowl', 'banana', 'apple',
               'sandwich', 'orange', 'broccoli', 'carrot', 'hot dog', 'pizza',
               'donut', 'cake', 'chair', 'couch', 'potted plant', 'bed',
               'dining table', 'toilet', 'tv', 'laptop', 'mouse', 'remote',
               'keyboard', 'cell phone', 'microwave', 'oven', 'toaster',
               'sink', 'refrigerator', 'book', 'clock', 'vase', 'scissors',
               'teddy bear', 'hair drier', 'toothbrush']
# Load a random image from the images folder
file_names = next(os.walk(IMAGE_DIR))[2]
image = skimage.io.imread(os.path.join(IMAGE_DIR, random.choice(file_names)))

をそのままやるとGoogleColaboratoryだとStopiterationのエラーが出るので

image = skimage.io.imread(os.path.join(IMAGE_DIR, "1045023827_4ec3e8ba5c_z.jpg"))

にした。(file_namesのところはMask_RCNN/imagesから適当に選ぶ)
後は

# Run detection
results = model.detect([image], verbose=1)

# Visualize results
r = results[0]
visualize.display_instances(image, r['rois'], r['masks'], r['class_ids'], 
                            class_names, r['scores'])

で表示する。

CSSフレームワーク「Bulma」でnavbarの高さを変える

navbarのclassに「is-spaced」をつけると大きくなる

.navbarのstyleにpaddingを設定すれば自由な高さになる

.navbar {
        padding: 1rem 2rem;
      }

CSSフレームワーク「Bulma」でスマホでもnav-itemを表示したい

スマホ版でも表示したいnav-itemはnav-brandで囲む

<div class="navbar-brand">
<a class="navbar-item" href="https://bulma.io">
<img
src="https://bulma.io/images/bulma-logo.png"
width="112"
height="28"
/>
</a>

<a class="navbar-item"> 重要情報 </a>
</div>

CSSフレームワーク「Bulma」でのdiv要素の中央寄せ

テンプレートを何個か見たが

<div class="column is-8 is-offset-2">

<div class="column is-3 is-offset-3">

でやっている気がする。

coloumを使おうが使わまいがとりあえず中央寄せしたいdiv要素にclass="column is-8 is-offset-2"を適用させて中央寄せが楽っぽい

慈善信託について

①日本のオリジネーターケイマン諸島のSPCに無議決権優先株式を与える

②SPCがケイマン諸島の信託会社に株式を全て譲渡(慈善信託)

③SPCが用済みになると残余財産(1000ドル程度の資本金が残る)を慈善団体に寄付する

 

ケイマン諸島の信託会社はSPCに何も指図はしない

オリジネーター倒産の際に差し押さえ回避目的でSPCに資産を移したと破産管財人に主張されるのをさけるために、SPCの株主は第三者の信託会社

・信託会社の株主はケイマン諸島の弁護士

 

目的

・倒産隔離

・コスト節約

 

なぜケイマン諸島でSPCを設立するか

・設立が容易

・コストが低い