RSS Twitter Facebook


« 2016年11月 | 2016年12月のアーカイブ | 2017年01月 »

2016/12/30

サイトリニューアル


年末ですけど、サイトを大幅に書き直したりしています。
なかなか手が回らない英語版のページとかどうしようかと思っていたのですが、ここは、googleのウェブサイト翻訳ツールという奴に頼って統合するという方向でいってみます。↓これですね。

ウェブサイト翻訳ツール - Google Translate

これは楽だ。

ただ、先日google翻訳の精度が飛躍的に上がったという話があったのだけど、それはこのウェブサイト翻訳ツールにはまだ適用されていない模様で、ちょっと残念な英語になってたりします。

googleウェブサイト翻訳:
「年末ですけど、サイトを大幅に書き直したりしています。」 ⇒ 「But is the end of the year, has been or substantially rewrite the site. 」

google翻訳:
「年末ですけど、サイトを大幅に書き直したりしています。」 ⇒ 「Although it is the end of the year, I am rewriting the site drastically.」

まあ、ウェブサイト翻訳の方もそのうち精度が上がる事を期待しているんだけどどうなんでしょ。


後問題なのはソースコードなんかを載せている所で、ソースコードをいじられちゃったり、SyntaxHighliterを使っているとよくわからない文字化け状態になる事があります。こんな感じ...

これを避けるには、DOMエレメントのクラス名に"notranslate"を付ければその内部は翻訳対象から外れるという仕組みがあるのでソースコードを書いている所にこれを付けて回避できます。

ただしこれも少し注意点があって適当なタグに"notranslate"を付けても認識してくれない事があります。挙動がいまいち掴めていないのですが、確実なのは翻訳を回避したい所全体を<div class="notranslate">で囲んでしまうのが安定するようです。

何にしても言語毎に分けていて何か書き直そうとする度にあっちこっち何か所も直さなきゃいけないという事から解放されるというのは素晴らしいです。ネイティブの人が読んでどう思うのかはわからないけど、翻訳精度の向上をただただ期待...


posted by g200kg : 6:30 PM : PermaLink

2016/12/21

最近のWebAudio APIでちょっと書いてみる



このところハードウェアばかりいじってて、たまに触らないとWebAudio APIの使い方を忘れそうなのでちょっと書いてみた。 スコアを演奏するのを最近のWebAudio APIでどれだけ簡単に書けるか、という試みです。
actx=new AudioContext();
score=[
  10,7,-3,12,-1,10,-2,7,3,-6,  10,7,-3,12,-1,10,-2,7,3,-6,
  17,8,-4,17,8,-2,14,8,-6,     15,7,-4,15,7,-2,10,7,-6,
  12,8,-4,12,8,-2,15,12,-3,14,10,-1,12,8,-2,  10,7,-3,12,8,-1,10,7,-2,7,3,-6,
  12,8,-4,12,8,-2,15,12,-3,14,10,-1,12,8,-2,  10,7,-3,12,8,-1,10,7,-2,7,3,-6,
  17,14,-4,17,14,-2,20,17,-3,17,14,11,-1,14,11,-2,15,12,-4,15,12,-2,19,15,-6,
  15,-2,10,-2,7,-2,10,-3,8,-1,5,-2,15,3,-6,
];
p=-1;
t=actx.currentTime;
setInterval(()=>{
  while(actx.currentTime>t-2){
    n=score[p=++p%score.length];
    if(n>0){
      o=new OscillatorNode(actx,{frequency:220,detune:n*100});
      g=new GainNode(actx,{gain:.3});
      o.connect(g).connect(actx.destination);
      o.start(t);
      o.stop(t+4);
      g.gain.setTargetAtTime(0,t,.9);
    }
    else
      t-=n*.4;
  }
},100);
こんな感じになりました。まあ世間はクリスマスのようですしそれっぽい感じになっています。 なお最近 WebAudio APIに色々と追加されている機能を使っていますので Chrome でしか動きません。

デモはこちらにあります。 test-kiyoshi.html
ちょっと解説。
2行目。 score という配列に入っているのが演奏データです。プラスの値とマイナスの値が混じっていますが、プラスは発音の指示、マイナスは指定の時間だけ待ついわゆるステップタイムになります。単音の演奏ではプラスとマイナスの値を交互に指定する事になりますが、プラスの値を複数続ける事で和音の発生も可能です。

11行目。 t=actx.currentTime がありますが、この t は現在時刻ではなく、次に発音するタイミングを先読み処理するために使用します。処理全体は setInterval() で回っていますが、音の発生タイミングは後で start()、stop()、setTargetAtTime() に渡されるこの t で決まります。この先読み処理をしないと処理が重くなったりタブが裏に回ったりした時にテンポが崩れる事になります。while(actx.currentTime>t-2) というループで2秒先のデータまで読んでいます。

16行目。1つの発音に対し、OscillatorとGainをそれぞれ作成し、setTargetAtTime()で音の減衰を作っています。WebAudio APIを触り始めた人が最初にはまる罠として、一度止めたOscillatorは再使用できないという仕様があるのですが、元々の設計が意図していたのは、発音1回に対してOscillatorを1つ生成するというこんな感じの使い方だったと思われます。まあ、シンセ的なものを作ろうとするとそれじゃすまないんですけどね。

さて、ノードを作るのにactx.createOscillator()じゃなくてnew OscillatorNode(actx,...)を使っています。これが使えるのは今は Chrome だけですが、一緒にパラメータの値を {frequency:220, detune:n*100} のように渡せるのが楽でいいですね。

ここでscoreから読みだした発音データを detune に渡しています。楽譜上の音の高さ(MIDIノート番号とか)を周波数に変換するには、
440*Math.pow(2,(note-69)/12)
なんていう式が良く使われてたりするのですが、オシレータには detune というcent (100セント=半音) 単位のパラメータがあり、そちらを使うとノートの番号から簡単に駆動できます。1200セントで1オクターブです。

そして18行目の
o.connect(g).connect(actx.destination)
こういう風にノードの接続を繋げて書けるのが最近の WebAudio API です。うん、書きやすい。

23行目。さて、scoreから読んだ値がマイナスの場合には、発音すべきタイミングを進めます。これで、実時間 currentTime が t の 2秒前まできた時にオシレータが準備される事になります。

WebAudio API、扱うための予備知識みたいなものが結構色々必要なのでとっつきにくいかなぁとは思うのですが、慣れてくれば簡単に書けますよ。

※なお、「きよしこの夜」って楽曲と英語歌詞の著作権は消滅してるんですが、日本語歌詞はまだ著作権残ってるんですよね。音楽系扱う時はこのあたり注意しましょう。

posted by g200kg : 1:42 AM : PermaLink

2016/12/20

TFoM Cafe Deluxe


2016年12月18日(日)、「TFoM Cafe Deluxe」が六本木スーパーデラックスで開催されました。
Tokyo Festival of Modular が主催する新しいイベントシリーズでメーカーの製品ブースとモジュラーのライブが行われます。という事で、私も協賛してブースを出してきました。


ブース準備中の会場の様子です

準備したg200kgブース。 こじんまりと新製品 SUSHI の先行販売体制で行きます

お隣にブースを出していたCentreさん。ASBS2016にも出されていたCDジャケットサイズのシーケンサ「C_Quencer」とか機能強化版のプロトタイプとか。http://centrevillage.net/

Hikari Instrumentsさん。新製品のアッテネータ/ミキサーも展示しています。http://www.hikari-instruments.com/

キッコサウンドさん。楽器フェアにも出てましたがユーロラック界に進出です。mi.1e は Bluetooth 接続でCV/GATEを出すというモジュールです。http://quicco.co.jp/

X-Fade Modularさん。ADSR-1とかコンパクトシーケンサMi-Ko-Cとか

米本電音研究所さん。ユーロラックに搭載されたいつもの謎ガジェットSYSTEM-Yを展示。ツクダオリジナルのスライムは電気を通すという謎豆知識をゲットw。
http://yonemotominoru.com/

ユーロラックケースを作る Vivicat Green木工所さん。どうしても価格上の比重が高くなるユーロラックのレールを木工技術でカバーしているのでとても安くなっています。
http://www.vivicat-green.net/

ElectroGraveさん。ユーロラックフォームファクターではありませんが、4Chパンとか特徴的な機材を展示。http://electrograve.com/


Sputnik Modular さんの Spectral Processor。16バンドのフィルターバンクとエンベロープフォロワ、VCAが入っていてボコーダーにもなります。


ライブの方も盛りだくさんです。タイムテーブルはこんな感じで、マーケットタイムと製品デモをはさみつつモジュラーライブが行われます。


TFoM主催のDave Skipper氏


こちらも主催のHATAKEN氏。


トリは電子海面のお三方でした




こんな感じで無事終了しました。g200kgブースにお立ち寄り頂いた方、ありがとうございました。
新製品 SUSHI は会場限定先行販売という形を取らさせていただきましたが、年明け早いうちに体制を整えたいと思います。

posted by g200kg : 2:12 AM : PermaLink

« 2016年11月 | 2016年12月のアーカイブ | 2017年01月 »


-->

g200kg