深層学習第2回マルコフ連鎖・自動歌詞生成
2020.12.19 / 2022.02.05更新
YouTube でも紹介しています。画像をクリックすると再生できます。
深層学習第2回では、既存の歌詞データを集めて、新たな歌詞を自動生成します。
楽曲情報サイトからスクレイピングして、深層学習によりアイドルソングを自動生成するという内容です。
スクレイピングまでは、PHPで行い、その後の深層学習はPythonに任せています。
多角的に理解しやすいように、今回は「暮らしの小さじ」さんの「アイドルソングを自動生成してみた (1)歌詞生成」と
同じデータソースを用いて、深層学習の実験をしてみました。
深層学習の目的のはっきりしない入門書よりも、「暮らしの小さじ」さんの記事は非常に役に立つと思いますので、ぜひ一読してみてください。
→ 暮らしの小さじ - アイドルソングを自動生成してみた (1)歌詞生成
■スクレイピング
国内最大級の歌詞コードサイト「楽器.me」から、アイドルグループ「BiSH」を検索してみます。
→ 楽器.me - 「BiSH」のコード譜一覧 ( 66件 )
ブラウザのソース表示機能で、ソースコードを表示してhtmlタグのツリー構造を確認します。
楽曲名とその詳細情報へのリンク情報を表記したタグを探します。
<div id="ranking_list">
<!--<meta LIST-START>-->
<div class="wrap">
<div class="detail">
<div class="box">
<!--<p class="catch">リクエスト掲載曲</p>-->
<p class="mname">
<a href="/m/data/RQ05803.html">「オーケストラ」</a>
<small><a href="/search/?mode=list&word=AT:BiSH">BiSH</a></small>
</p>
</div>
</div>
</div>
<!--<meta LIST-END>-->
****meta LIST の繰り返し****
</div>
楽曲名とその詳細情報へのリンク情報を取得するプログラムを作ります。
gakufumelink.php
<?php
$url = 'https://gakufu.gakki.me/search/?mode=list&word='.$_REQUEST['word'];
$dom = new DOMDocument;
@$dom->loadHTMLFile($url);
$xpath = new DOMXPath($dom);
$entries = [];
foreach ($xpath->query('//div[@class="box"]') as $node) {
$entries[] = [
'url' => $xpath->evaluate('string(.//p[@class="mname"]/a/@href)', $node),
'mname' => $xpath->evaluate('string(.//p[@class="mname"]/a)', $node),
];
}
foreach($entries as $entry) {
echo $entry['url']."<br />\n";
echo $entry['mname']."<br />\n";
}
?>
上記プログラムを第1回で環境設定したWEBサーバーのドキュメントルートに配置して、ブラウザから
http://127.0.0.1/gakufumelink.php?word=AT:BiSH
楽器.meサイトから楽曲名とその楽曲情報へのリンク情報を取得して、結果をブラウザに表示しています
/m/data/RQ05803.html
「オーケストラ」
/m/data/N07715.html
「プロミスザスター」
/m/data/KC00245.html
「BiSH-星が瞬く夜に」
....
続いて、ブラウザ上から楽曲名「オーケストラ」の情報にアクセスしてみます。
楽器meのドキュメントルート(https://gakufu.gakki.me)に、gakufumelink.php で取得したリンク情報(/m/data/RQ05803.html)を付加してアクセスします。
https://gakufu.gakki.me/m/data/RQ05803.html
コード進行とその下に歌詞が表示されています。先ほどと同様にツリー構造を解析します。
<div class="cd_1line">
<div class="cd_pic cd_font" style="border:1px solid #fff; height:68px;">
<div class="cd_width4 cd_style cd_font">
<span class="cd_fontpos">E<br /><img src="/img/codet/E/E_low.gif" class="cd_img"></span>
</div>
</div>
<div class="cd_pic blue" style="border:1px solid #fff; height:26px;">
<div class="cd_txt cd_width cd_style">見</div>
<div class="cd_txt cd_width cd_style">上</div>
<div class="cd_txt cd_width cd_style">げ</div>
<div class="cd_txt cd_width cd_style">た</div>
<div class="cd_txt cd_width cd_style">あ</div>
</div>
</div>
**** 繰り返し ****
<div class="cd_1line">
・・・・・・
</div>
今度は、コードと歌詞の部分を抽出するプログラムを作ります。
gakufumenote.php
<?php
function getLyrics($url) {
$dom = new DOMDocument;
@$dom->loadHTMLFile($url);
$xpath = new DOMXPath($dom);
$codes =null;
$lyrics =null;
foreach ($xpath->query('//div[@class="cd_1line"]') as $node) {
foreach ($xpath->query('.//div[@class="cd_pic cd_font"]/div/span',$node) as $subNode) {
if ($codes) $codes .='>';
$codes .= $subNode->nodeValue;
}
foreach ($xpath->query('.//div[@class="cd_pic blue"]/div',$node) as $subNode) {
$lyrics .= $subNode->nodeValue;
}
}
// 半角、全角空白どちらも削除
$lyrics = preg_replace("/( | )/", "", $lyrics );
// NO-BREAK SPACE (C2A0)削除
$lyrics = str_replace( "\xc2\xa0", "", $lyrics );
return array($codes,$lyrics);
}
$url = $_REQUEST['url'];
list($codes,$lyrics) = getLyrics($url);
echo $codes."<br />\n";
echo $lyrics."<br />\n";
?>
ブラウザから
http://127.0.0.1/gakufumenote.php?url=https://gakufu.gakki.me/m/data/RQ05803.html
「オーケストラ」のコード進行と、歌詞を整形してブラウザ画面に表示させています。
E>B>C#m>A>E>B>C#m>A>E>E>A>A>EonG#>F#m>F#m>B>B>E>E>A>A>EonG#>F#m>F#m>B>B>E>B>C#m>D>Bsus4>B>E>B>C#m>D>B>A>BonA>G#m>C#m>F#m>B>E>F#m>B>G#m>C#m>F#m>G#m>A>F#onA#>B>E>B>C#m>Bm>A>G#m>C#>C#onB>F#m>G#m>Am>B>E>B>C#m>Bm>A>G#m>C#>C#onB>F#m>G#m>Am>B>E>E>A>A>EonG#>F#m>F#m>B>B>E>B>C#m>D>Bsus4>B>E>B>C#m>D>B>A>BonA>G#m>C#m>F#m>B>E>F#m>B>G#m>C#m>F#m>G#m>A>F#onA#>B>E>B>C#m>Bm>A>G#m>C#>C#onB>F#m>G#m>Am>B>E>B>C#m>Bm>A>G#m>C#>C#onB>F#m>G#m>Am>B>EonG#>EonG#>A>A>EonG#>EonG#>A>A>EonG#>EonG#>A>A>F#m>F#m>B>B>B>B>E>B>C#m>Bm>A>G#m>C#>C#onB>F#m>G#m>Am>B>E>B>C#m>Bm>A>G#m>C#>C#onB>F#m>G#m>Am>B>E>E>A>A>EonG#>F#m>F#m>B>B>E>E>A>A>EonG#>F#m>F#m>B>B>E
見上げたあの夜空に浮かぶ星達ふと君の声があの頃輝いてたかな?今になってはずっと分からないままあの時君がついた嘘問いただせずに泣いたあの坂道この先君と会えないの離れ離れに身を任せてたいつもの後悔が風に消えてく誰にもみせないその姿をもうちょっとだけ見てたかったんだ時がそっと睨んでいるその手と手繋いで笑いあった声忘れはしないよこんなにも流してた涙も語る声もオーケストラやがて訪れたよねさよならの声忘れはしないよあんなにも近くにいたはずが今では繋がりなんてあの空だけ夜空の交換をしよう馬鹿らしくなって投げた午前3時この先君と何年も時の流れに身を任せてもいつものジョークが街に消えてく誰にも見せない僕の姿をもうちょっとだけ見せたかったんだ時がそっと睨んでいるこの目と目合わせてはっきりとしたいもうできないかなこんなにもどかしくて辛いのが音を立てるオーケストラどこで何をしてるの?分からないのは僕のせいなんだね永遠にこんな日がくるなんて神様イタズラなら呪いたいぐらいその手と手繋いで笑いあった声忘れはしないよこんなにも流してた涙も語る声もオーケストラやがて訪れたよねさよならの声忘れはしないよあんなにも近くにいたはずが今では繋がりなんてこの空だけ
プログラムが正常に動作することを確認しましたら、2つのプログラムを纏めて、BiSHの登録楽曲すべてを取得して、JSON形式のファイルに保存するように書き換えます。
gakufume.php
<?php
function getLyrics($url) {
$dom = new DOMDocument;
@$dom->loadHTMLFile($url);
$xpath = new DOMXPath($dom);
$codes =null;
$lyrics =null;
foreach ($xpath->query('//div[@class="cd_1line"]') as $node) {
foreach ($xpath->query('.//div[@class="cd_pic cd_font"]/div/span',$node) as $subNode) {
if ($codes) $codes .='>';
$codes .= $subNode->nodeValue;
}
foreach ($xpath->query('.//div[@class="cd_pic blue"]/div',$node) as $subNode) {
$lyrics .= $subNode->nodeValue;
}
}
// 半角、全角空白どちらも削除
$lyrics = preg_replace("/( | )/", "", $lyrics );
// NO-BREAK SPACE (C2A0)削除
$lyrics = str_replace( "\xc2\xa0", "", $lyrics );
return array($codes,$lyrics);
}
$url = 'https://gakufu.gakki.me/search/?mode=list&word='.$_REQUEST['word'];
$dom = new DOMDocument;
@$dom->loadHTMLFile($url);
$xpath = new DOMXPath($dom);
$entries = [];
foreach ($xpath->query('//div[@class="box"]') as $node) {
$entries[] = [
'url' => $xpath->evaluate('string(.//p[@class="mname"]/a/@href)', $node),
'mname' => $xpath->evaluate('string(.//p[@class="mname"]/a)', $node),
];
}
$notes = array();
foreach($entries as $entry) {
$link = 'https://gakufu.gakki.me'.$entry['url'];
$mname = $entry['mname'];
list($codes,$lyrics) = getLyrics($link);
$note = array('title'=>$mname,'codes'=>$codes,'lyrics'=>$lyrics);
$notes[] = $note;
}
$json = json_encode($notes);
$fp = fopen('lyrics.json', 'w');
fwrite($fp,$json);
fclose($fp);
?>
ブラウザから
http://127.0.0.1/gakufume.php?word=AT:BiSH
ちゃんと保存されたか確認してみましょう。
show_json.php
<?php
$filename = 'lyrics.json';
$fp = fopen($filename, 'r');
$json = fread($fp, filesize($filename));
fclose($fp);
$obj = json_decode($json,true);
foreach ($obj as $notes) {
foreach ($notes as $key=>$value) {
echo $key."=>".$value."<br>\n";
}
}
?>
ブラウザから
http://127.0.0.1/show_json.php
■わかち書き
文章を単語に分割することをわかち書きといいます。
日本語に対応したわかち書きとして広く利用されているのが、MeCab(和布蕪/めかぶ)です。
MeCabインストール
$ sudo apt install mecab libmecab-dev mecab-ipadic
$ sudo pip3 install mecab-python3
Successfully installed mecab-python3-1.0.3
MeCab辞書の文字コードを確認します。
$ mecab -D
filename: /var/lib/mecab/dic/debian/sys.dic
version: 102
charset: EUC-JP
type: 0
size: 392127
left size: 1316
right size: 1316
辞書をEUC-JPからutf8に再構築します。
まずは、MeCabのgithub:(http://taku910.github.io/mecab/)からIPA辞書をダウンロードします。
MeCab用の辞書/IPA 辞書:mecab-ipadic-2.7.0-20070801.tar.gz
$ tar zxfv mecab-ipadic-2.7.0-20070801.tar.gz
$ cd mecab-ipadic-2.7.0-20070801
$ ./configure --with-charset=utf8 --enable-utf8-only
$ make
To enable dictionary, rewrite /etc/mecabrc as "dicrc = /usr/lib/arm-linux-gnueabihf/mecab/dic/ipadic"
$ sudo make install
$ sudo vi /etc/mecabrc
dicdir = /var/lib/mecab/dic/debian
↓変更
dicdir = /usr/lib/arm-linux-gnueabihf/mecab/dic/ipadic
※Raspberry Pi OS (64bit/Bullseye)の場合(2022.02.07)
dicdir = /usr/lib/aarch64-linux-gnu/mecab/dic/ipadic
MeCab辞書の文字コードを確認します。
$ mecab -D
filename: /usr/lib/arm-linux-gnueabihf/mecab/dic/ipadic/sys.dic
(filename: /usr/lib/aarch64-linux-gnu/mecab/dic/ipadic/sys.dic)
version: 102
charset: utf8
type: 0
size: 392127
left size: 1316
right size: 1316
それでは試しに、先に保存した楽曲データファイル lyrics.json から1曲目の「オーケストラ」の歌詞を取り出して、わかち書きしてみます。
ここからは、プログラムをpython で記述しています。
mecab-node.py
import json
import MeCab
tagger = MeCab.Tagger()
# 文章を単語に分割してリスト出力する
def tokenize(text):
node = tagger.parseToNode(text)
tokens = []
while node:
if node.surface != '':
tokens.append(node.surface)
node = node.next
return tokens
# JSON形式のテキストファイルを読み込む
path = './lyrics.json'
jsonText = open(path, 'r').read().encode('utf-8')
notes = json.loads(jsonText)
lyrics = notes[0]['lyrics']
words = tokenize(lyrics)
for word in words:
print(word)
実行してみましょう。
$ python3 mecab-node.py
見上げ
た
あの
夜空
に
浮かぶ
星
達
~~~(省略)~~~
繋がり
なんて
この
空
だけ
■歌詞データを学習させる (マルコフ連鎖)
ここでは3階マルコフ連鎖により学習させてみます。
3つの連続する単語を1組として、文章の先頭から1単語ずつずらしながら、辞書型の連想配列に登録していきます。
例えば、「見上げたあの夜空に浮かぶ星達」という文章は
の6つの連想配列として記録されます。
下記のプログラムでは、先のJSON形式で保存した歌詞データを読み込んで、辞書型の連想配列を生成しています。
すでに、学習済の連想配列がある場合は、そこに追加されるようになっています。
生成された辞書はJSON形式のファイルに保存されます。
markov.py
import json
import MeCab
import os
import re
tagger = MeCab.Tagger()
# 文章を単語に分割してリスト出力する
def tokenize(text):
node = tagger.parseToNode(text)
tokens = []
while node:
if node.surface != '':
tokens.append(node.surface)
node = node.next
return tokens
# 辞書を更新
def updateDic(words):
tmp = []
for word in words:
if word == "" or word == "\r\n" or word == "\n": continue
tmp.append(word)
if len(tmp) < 3: continue
if len(tmp) > 3: tmp = tmp[1:]
setWord3(tmp)
# 三要素のリストを辞書として登録
def setWord3(s3):
global dic
w1, w2, w3 = s3
if not w1 in dic: dic[w1] = {}
if not w2 in dic[w1]: dic[w1][w2] = {}
if not w3 in dic[w1][w2]: dic[w1][w2][w3] = 0
dic[w1][w2][w3] += 1
def dumpDic(dic):
for key_1st, value_1st in dic.items():
for key_2nd, value_2nd in value_1st.items():
for key_3rd, value_3rd in value_2nd.items():
print(key_1st,"→",key_2nd,"→",key_3rd,"=",value_3rd)
return
# JSON形式の楽曲ファイルを読み込む
path = './lyrics.json'
jsonText = open(path, 'r').read().encode('utf-8')
notes = json.loads(jsonText)
# JSON形式の辞書ファイルを読み込む
path = './markov-lyrics.json'
if(os.path.exists(path)):
jsonText = open(path, 'r').read().encode('utf-8')
dic = json.loads(jsonText)
else:
dic = {}
for note in notes:
lyrics = note['lyrics']
lyrics = re.sub(r'[A-z]+', "", lyrics) #アルファベットの削除
lyrics = re.sub(r'[\r\n]', "", lyrics) #改行などの削除
words = tokenize(lyrics)
updateDic(words)
dumpDic(dic)
json.dump(dic, open("markov-lyrics.json", "w", encoding="utf-8"))
このプログラムのロジックでは、並び順も考慮した3つの単語の組合せは、連想配列上に重複して存在することはありません。
def setWord3(s3):
global dic
w1, w2, w3 = s3
if not w1 in dic: dic[w1] = {}
if not w2 in dic[w1]: dic[w1][w2] = {}
if not w3 in dic[w1][w2]: dic[w1][w2][w3] = 0
dic[w1][w2][w3] += 1
3つの単語の並びが同じものは、3階層目のキーの値を利用して、出現頻度としてカウントアップしています。
それでは、学習させたBishの歌詞から、Bishっぽい新しい歌詞を生成してみましょう。
ソースコードの、変数 keyword に歌詞の先頭に使用する単語を設定してください。
make-lyrics.py
import json
import random
def word_choice(sel):
keys = sel.keys()
ran = random.choice(list(keys))
return ran
def make_sentence(dic,keyword):
ret = []
if not keyword in dic: return "no dic"
w1 = keyword
w2 = word_choice(dic[keyword])
ret.append(w1)
ret.append(w2)
while True:
w3 = word_choice(dic[w1][w2])
ret.append(w3)
if len(ret)>100 : break
w1, w2 = w2, w3
return "".join(ret)
dic = open("markov-lyrics.json" , "r")
dic = json.load(dic)
random.seed()
keyword = '見上げ'
s = make_sentence(dic,keyword)
print(s)
$ python3 make-lyrics.py
乱数を使用しているので、実行するたびに生成される歌詞が変わります。
見上げても逃げてくよ戻れないが嬉しさにそれじゃ乾杯☆言いたいけれど心で文字を打ってみてない でくれすべて届けるよ胸の奥を感じてどんな時でも傷が開いてたいわたしまだまだ足んない心ぜんぶ うめたいだけおいでおいでここまでおいで正直になってんだつらいんだひどく寂しいじゃないただイ ヤフォン耳に轟音再度よこす幻影茶適当言えなんじゃんねほら未熟者青春ビリーバーですありのまま で
さて、ここで重要になるのが1番目と2番目の単語から3番目の単語を選ぶ部分です。
w3 = word_choice(dic[w1][w2])
辞書に学習させる過程では、出現頻度をカウントアップしていました。
この出現頻度が多いほど、その単語の並びの結び付きが強いことになります。
見上げ→た →あの = 1
見上げ→て →た = 2
見上げ→て →も = 1
見上げ→たら→いつも= 3
1番目の単語「見上げ」、2番目の単語「て」に続く単語は「た」あるいは「も」の2つです。
現時点では学習データが少ないので、3番目に選ばれる単語は2つの中からランダムに選んでいます。
しかし、学習が進んでデータ数が増えたときには、この出現頻度も考慮して3番目の単語を選ぶようにロジックを変更すると、より自然な歌詞になるかもしれません。
マルコフ連鎖を理解すれば、他の深層学習も、この相関関係をより進化させたものも多いので、容易に理解を進めることができると思います。
■初心者向け参考文献
・PHPネイティブのDOMによるスクレイピング入門
・Python プログラミング「Pythonの基礎1」
・マルコフ連鎖を使って文章生成をしてみる
・辞書型、コツがわかると難しくない階層の辞書型、REST API→JSON→辞書型
|
Raspberry Pi(ラズベリー パイ)は、ARMプロセッサを搭載したシングルボードコンピュータ。イギリスのラズベリーパイ財団によって開発されている。
Arduinoで学ぶ組込みシステム入門(第2版)
●Arduinoを使って組込みシステム開発を理解する
・ハードウェアやソフトウェアなどの基礎知識/
・設計から実装までを系統的に説明するモデルベース開発/
・Arduinoを用いた実際の開発例
最新 使える! MATLAB 第3版
◆◆すぐに「使える!」 全ページフルカラー!◆◆
・MATLAB R2022bに対応し、解説もより詳しく!/
・コマンド・スクリプトの例が豊富で、動かして学べる!/
・超基本から解説。これから使いはじめる人にぴったり!/
・全編フルカラー、スクリーンショットも豊富!
Amazon Web Services基礎からのネットワーク&サーバー構築改訂4版
1.システム構築をインフラから始めるには/
2.ネットワークを構築する/
3.サーバーを構築する/
4.Webサーバーソフトをインストールする/
5.HTTPの動きを確認する/
6.プライベートサブネットを構築する/
7.NATを構築する/
8.DBを用いたブログシステムの構築/
9.TCP/IPによる通信の仕組みを理解する
C言語は第二の母国語: 独学学生時代から企業内IT職人時代に培った、独立のための技術とノウハウ 平田豊著
学生時代から独学でプログラミングをはじめ、企業内でデバイスドライバを開発し、そして独立後もたくさんのアプリケーション開発や技術書制作に携わってきた著者。その筆者が大事に使い続ける「C言語」の“昔と今”について、気づいたことや役立つ知識、使ってきたツールなどについて、これまで記してきたことを整理してまとめました。
本書では、現役プログラマーだけでなく、これからプログラミングを学ぶ学生などにも有益な情報やノウハウを、筆者の経験を元に紹介しています。
1冊ですべて身につくJavaScript入門講座
・最初の一歩が踏み出せる! 初心者に寄り添うやさしい解説
・最新の技術が身につく! 今のJavaScriptの書き方・使い方
・絶対に知っておきたい! アニメーションとイベントの知識
・プログラミングの基本から実装方法まですべて学べる
図解! Git & GitHubのツボとコツがゼッタイにわかる本
ソフトウェア開発では欠かすことのできないGit、GitHub。
これからGit、GitHubを使いたいという入門者の方でも、実際に手を動かしながら使い方を学べます。
C自作の鉄則!2023 (日経BPパソコンベストムック)
メーカー製のパソコンはスペックが中途半端で、自分が本当に欲しい機種がない――。そう思っている人には、ぜひ自作パソコンをお薦めします。自作パソコンのパーツは進化が速く、しかも驚くほど種類が豊富。価格も性能も、幅広く用意されているため、満足度100%の“自分だけの1台”を手に入れることができます。
Interface 2023年6月号
特集:第1部 フィルタ設計 基礎の基礎/
第2部 係数アプリや波形観測アプリで合点!FIR&IIRフィルタ作り/
第3部 配布プリント基板で体験!マイコンで動くフィルタ作り
日経Linux 2023年5月号
【特集 1】 AI時代の最強フリーソフト ~ 25のやりたいを実現!
【特集 2】 AWS、Azureのうまみを無料で体感!面倒なことはクラウドに任せよう
【特集 3】 新しいRaspberry Pi Cameraで遊んでみよう
【特集 4】 Linuxで旧型PCを復活! 1kg切るモバイルPCを「ChromeOS Flex」でChromebook化
ラズパイマガジン2022年秋号
特集:5大人気ボード 電子工作超入門
「半導体不足で在庫が不足し、電子工作のボードがなかなか買えない…」。そんな今にふさわしい特集を企画しました。5種の人気ボードにすべて対応した電子工作の入門特集です。「GPIO」や「I2C」を使った電子パーツの制御方法は、どのボードでも同じです。手に入れられたボードを使って、今こそ電子工作を始めましょう。
地方で稼ぐ! ITエンジニアのすすめ
学歴、理系の知識、専門スキル……全部なくてもITエンジニアになれる!
地方でも高収入でやりがいをもって働ける!ITエンジニアの魅力を一挙大公開
Raspberry Piのはじめ方2022
本書は、ラズパイやPicoの買い方やインストール、初期設定といった基本から、サーバー、電子工作、IoT、AIといったラズパイならではの活用方法まで、1冊でお届けします。
ラズパイをこれから始める方向けに、全36ページの入門マンガ「女子高生とラズベリーパイ」も巻末に掲載。これを読むだけでラズパイがどんなものなのか、すぐに分かって触れるようになります。
ハッカーの学校 IoTハッキングの教科書
生活にとけこみ、家電機器を便利にするIoT技術。
Webカメラなど、便利の裏側に潜むセキュリティの危険性をハッキングで検証。
専門家がパケットキャプチャからハードウェアハッキングまで、その攻撃と防御を徹底解説。
本書は2018年7月に刊行された「ハッカーの学校IoTハッキングの教科書」に一部修正を加えた第2版です。
攻撃手法を学んで防御せよ! 押さえておくべきIoTハッキング
本書は、経済産業省から2021年4月にリリースされた、IoTセキュリティを対象とした『機器のサイバーセキュリティ確保のためのセキュリティ検証の手引き』の『別冊2 機器メーカに向けた脅威分析及びセキュリティ検証の解説書』をもとに、IoT機器の開発者や品質保証の担当者が、攻撃者の視点に立ってセキュリティ検証を実践するための手法を、事例とともに詳細に解説しました。
ポチらせる文章術
販売サイト・ネット広告・メルマガ・ブログ・ホームページ・SNS…
全WEB媒体で効果バツグン!
カリスマコピーライターが教える「見てもらう」「買ってもらう」「共感してもらう」すべてに効くネット文章術
プログラマーは世界をどう見ているのか 西村博之著
イーロン・マスク(テスラ)、ジェフ・べゾス(Amazon)、ラリー・ペイジ(Google)…etc.
世界のトップはなぜプログラマーなのか?
ニーア オートマタ PLAY ARTS改 <ヨルハ 二号 B型 DX版> PVC製 塗装済み可動フィギュア
「NieR:Automata」より、ヨルハ二号B型こと2BがPLAY ARTS改に新たに登場!
高級感の感じられるコスチュームや髪の質感、洗練されたボディバランス、細かなデティールに至るまでこだわり抜かれた逸品。
DX版には通常版のラインナップに加え2Bの随行支援ユニット ポッド042などをはじめ“純白の美しい太刀"白の約定やエフェクトパーツ、自爆モードを再現できる換装用ボディパーツ、シーンに合わせて変えられる顔パーツ2種も付属する豪華な仕様に。
作中のあらゆるシーンを再現することが可能なファン必見の一品となっている。
Newtonライト2.0 ベイズ統計
ベイズ統計は,結果から原因を推定する統計学です。AIや医療などの幅広い分野で応用されています。その基礎となるのは18世紀に考えだされた「ベイズの定理」です。
この本では,ベイズ統計学のきほんをやさしく紹介していきます。
白光(HAKKO) ダイヤル式温度制御はんだ吸取器 ハンディタイプ FR301-81
無水エタノールP 500mlx2個パック(掃除)
ケイバ(KEIBA) マイクロニッパー MN-A04
サンハヤト SAD-101 ニューブレッドボード
白光(HAKKO) HEXSOL 巻はんだ 精密プリント基板用 150g FS402-02
[Amazon限定ブランド]【指定第2類医薬品】PHARMA CHOICE 解熱鎮痛薬 解熱鎮痛錠IP 100錠
|