ScalaMatsuri 2019に参加してきました。毎年何気に楽しみにしているお祭りです。今年も面白い発表がたくさんあり、お祭り気分も充分に味わえたので満足の行くカンファレンスでした。
(本記事は自分のブログからの転載記事(一部抜粋)です。)
ScalaMatsuriとは
プログラミング言語Scalaをテーマにした日本最大級のカンファレンスです。今年は「Scala Conference in Japan 2013」から数えて6回目の開催になります。ScalaMatsuriの特色としてはセッションの決定がチケット購入者の投票によって決まること、海外スピーカの招待に力を入れておりセッションに日英同時通訳が入っていること、アンカンファレンスがあることなどが挙げられます。また、その名の通り「お祭り」の雰囲気を出すための工夫が随所に見られ、非常に親しみやすいカンファレンスとなっています。
会場について
日時と場所は以下のとおりです。自分は6/28のカンファレンスから参加しました1。場所はお台場です。ビッグサイトの近くと言ったほうが分かる人にはわかるかもしれません(笑)。新橋からゆりかもめに乗って行ったのですが、東京国際クルーズターミナル駅
と言う聞き慣れないアナウンスが流れて来て仰天しました。どうやら最寄り駅の駅名が変わっていたみたいです・・・2
- 日時
- 6/27(木) - 6/29(土) 10:00〜
- 場所
- 東京国際交流館
行動規範
到着したのは10:00頃で、ちょうど行動規範のアニメが流れているときでした3。このアニメは毎年クマくんのところで笑ってしまいます。アニメが流れ終わったところで、次のオススメ動画に子供向け動画(3匹の子豚?)が出てきて会場が爆笑していました。
カンファレンスDAY
ScalaMatsuriは27日(金)がカンファレンスDAYでした。ScalaMatsuriで凄いと思うのは3本のセッションが並行して走っていてそのうち2つの部屋では同時通訳が行われていたことです。そのため翻訳レシーバを借りれば英語のセッションでも問題なく楽しめました。4。
以下が27日に自分が聴講したセッション一覧です。ちょっとこじらせているので関数型プログラミングに偏っています(笑)。
- Scala 3って、私にはどんな影響があるの?
@joang38
(Joan Goyeau) - 再帰:スキーム,代数,finally tagless,データ型. 統合されたビジョン
@alexknvl
(Alexander Konovalov) - プロジェクトで引き回す型をEffにするメリット
@wing_007
(ma2k8) - こんなに違う!<-ScalaとKotlin-> @kaelaela (前川裕一)
- DOT計算をやさしく説明する @kmizu (水島宏太)
- Making Logic Monad @halcat0x15a (ねこはる)
- sbt コア・コンセプト
@eed3si9n
(Eugene Yokota) - 継続とDI @gakuzzzz (中村学(がくぞ))
ここからは少し長くなりますがセッションの感想を一つずつ述べていきます。
Scala 3って、私にはどんな影響があるの? @joang38
(Joan Goyeau)
Scala3(Dotty)の影響についての発表でした。以下が言及があった機能一覧です5。概ね知っていましたが、いくつか新しい発見もあったので有意義なセッションでした。
-
Enumerations, Algebraic Data Types
- やっとScalaにまともなEnumurationが来るといった話です。今までは
case object
で書いていたものがenum
キーワードで大分シンプルに書けるようになります6。
- やっとScalaにまともなEnumurationが来るといった話です。今までは
-
交差型, 合併型
- ようやくTypeScriptでできた型表現がScalaでもできるようになりました
- 交差型に関しては
with
もあったけど交換可能でなかったので、ようやく本物がDottyにも入ったということです
- NULLは100万ドルの間違い
- たぶん#5747の話だったと思います
- 現在でもOptionがありヌルポを見る機会はあまりありませんが、将来的には本当に見る機会がなくなるかもしれません
-
Opaque 型エイリアス
-
AnyVal
は、いけてないよねという話7。opaque
で本物の型エイリアス(いわゆるゼロコスト抽象化)が手に入ります
-
-
拡張メソッド
- 型が定義された後にメソッドを追加できる機能
- 拡張メソッドの構文はすごいGo言語チックだと思いました8
-
デリゲート
- 今までの型クラスのためのハックがまともな構文として定義されましたというお話
- マルチバーサル等価性
-
トレイトパラメータ
- givenが使えるのは大きいです
-
Parameter Untupling
- mapでcaseのあのパターンがいらなくなるお話。これは地味に便利
- TASTy
- コンパイル時の成果物の新しいフォーマットです
- クロスコンパイルが容易になります
上記の機能のいくつかは過去の自分の記事でも言及しているので参考にしてください。
再帰:スキーム,代数,finally tagless,データ型. 統合されたビジョン @alexknvl
(Alexander Konovalov)
ScalaMatsuriでは例年話される関数型プログラミングネタです。最初の方はずっと同型(Isomorphism)について話していたので、どこに向かうのかよく分かりませんでしたが終わってみれば関数型プログラミングの流行りのテクニックの総集編みたいな内容でした。結論は以下のような感じです。
folds(畳み込み) ≈ 再帰スキーム ≈ Final Tagless ≈ Free
「folds(畳み込み) ≈ 再帰スキーム」と「Final Tagless ≈ Free」は予想は付いていましたが全てが同型だとは思っていませんでした。まぁ「代数」というくくりで見ると確かに同じ気がします。
プロジェクトで引き回す型をEffにするメリット @wing_007
(ma2k8)
この話も毎年恒例になってきたEff(Extensible Effects)のお話です。Effを簡単に説明するとモナドの合成と評価を柔軟に行うためのテクニックです。
上記スライドでEffと対比されていた型は以下です。
Future[A]
Future[Try[A]]
Future[E Either A]
EitherT[Future, E, A]
Eff[R,A]
この中で自分がよく使うのは1です。2,3,4は使ったことはありますが型合わせが面倒なので部分的にしか使ったことはないです。5はEffそのものですが写経したくらいで実践で使ったことはありません。いずれ使って見たいと思いますが、問題はチーム全員が使いこなせるかどうかですね・・・
こんなに違う!<-ScalaとKotlin-> @kaelaela (前川裕一)
ScalaをコンパイルするとシンプルでKotlinをデコンパイルすると複雑だというのが面白かったです。あと似ている型も注意が必要そうです。デコンパイルしよう。
DOT計算をやさしく説明する @kmizu (水島宏太)
kmizuさん9によるScala3の理論基盤であるDOT計算のお話です。現実のプログラミング言語を厳密に理論基盤に載せるのは難しいので、妥当な言語のサブセットを作ってモデル化したものを「核計算」というらしいです。DOTはScala3の核計算であり、健全性が厳密に証明されているようです。残念ながらDOT計算の詳細は時間がなかったので翌日のアンカンファレンスに持ち越されました。
Making Logic Monad @halcat0x15a (ねこはる)
論理プログラミング言語としてはPrologが有名ですが、その一部の機能をScalaで実現しようというものでした。自分は論理プログラミングはあまり知らなかったのですが、論理的に可能な組み合わせが全て解として求めることができるというのは面白いと思いました。
具体的なモナドの構成はスライドを見たほうがいいと思いますが、印象に残ったパワーワード
は以下の2つです。
- バックトラッキングはモナドプラス
- FizzBuzzは実践的アプリケーション
あとはType-aligned sequenceというデータ構造も知らなかったので後で調べて見ようと思います。
sbt コア・コンセプト @eed3si9n
(Eugene Yokota)
scalaで最もよく使われているビルドツールであるsbtの解説でした。いつもお世話になっているsbtですが、いつもなんとなくというかその場しのぎで調べて動かしていたので、いろいろと勉強になりました。内容はおそらく6/11-23に開催されていた Scala Days 2019で発表されたものと同じではないかと思います。
以下はメモです。
- 空でも動く
- 流れを堰き止めるのがcommand
- commandよりtaskがオススメ
- キーは4次元
- デリゲーションルール
- Zero
- キーは最も広いスコープで定義して、最も狭いスコープで参照
継続とDI @gakuzzzz (中村学 (がくぞ))
継続渡しスタイル(Continuation Passing Style/CPS)とDI(Dependency Injection)を比較する非常に興味深いセッションでした。自分の継続のイメージはSchemeから来ていてどちらかと言うとgoto
と比較されるプリミティブだったのですが10、確かに言われて見ればDIだなと納得しました。あとSchemeでCPSを使うとネストが深くなりますが継続モナドを使うとネストを潰せてDSLっぽくなるのも面白かったです。CPSとDIのどちらを使うべきかという問いに対しては、使い分けが必要でCPSはアドホックな場面で使いましょうということでした。個人的に気になった点は似たような使い方ができるリーダーモナドやMinimal Cake PatternやEffなどと比較した場合はどうなんだろうということでした。また時間があったら自分で考察してみたいと思います。そういえば大昔にScala本体にも継続が実装されていていつの間にか標準から切り離されていたけど今も息をしているのだろうか・・・
アンカンファレンスDAY
アンカンファレンスはカンファレンスのカウンターパートです。つまり、カンファレンスほど形式張らずにアドホックにセッションを決定しようという比較的軽いノリですが、まさしく「お祭り」の雰囲気に相応しいワイワイした感じがとても印象的です。
アンカンファレンスが具体的にどのように進むかというと、前日から用意されたホワイトボードに付箋で聞きたいネタや喋りたいネタを貼って、セッションに参加したいと思ったら赤いシールを貼ります。そして当日の朝会や昼会で投票が多くて発表者やファシリテータがいるものを優先してセッション枠を埋めていきます。
以下参加したセッションです。どれも非常に面白かったのですが長くなるのでメモベースの記載になります。
-
仕事でScalaを使おう - Arm Treasure DataでのAirframe活用事例
@taroleo
- 最近よく聞く Airframeのお話です
- AirframeはDIコンテナだと思いこんでいましたが、どうやらDIだけではなく様々な便利ツールの集合体のようです
- MessagePackがTreasure Data発だと初めて知りました。MessagePackを使いたくなったらAirframe
- logとlauncherは後で試してみよう
- Bengal: Dotty Cats @ Walter Chang
- Bengal: A less than minimal functional library in the spirit of cats in Scala 3.
- Scala Taiwanから来日された方の発表です
- Scalaで型クラスを使う場合に広く使われているcatsライブラリをScala 3で実装するとどうなるかという発表でした
- 個人的に面白かったのは shapelessを使って型クラスを導出する部分でした
- DOT Calculus I didn't explain yesterday @kmizu
- DOTは難しいということが分かりました
- 特にサブタイプは鬼門だと・・・
- DOTは健全らしいです (参考: dot soundness)
-
Fast & Functional
- 最初の1時間だけ聴講しました
- パワーワード「
制限は開放し、自由は制限する
」
-
WiFi x Scala: Implementing Captive Portal in Scala and deploy into #ScalaMatsuri @ kuro_m88
- Captive Portalという仕組みを初めてしり勉強になりました
- 今回のWifi事情はおそらく他のカンファレンスと比べても非常に良かったと言えるくらい安定して繋がりやすかったです
- その裏舞台を聞けて非常によかったです
- Write stacksafe non-tailrec recursions @jooohn1234
- 再帰 is cool
- Stack overflowを避けるためにトランポリンを使おうという話
- Fujitask meets Extensible Effects @yyu
- Extensible Effectsでトランザクションモナド“Fujitask”を作る - Qiita
- トランザクションを型レベルの計算に落とせるというのは面白い
- kits-effを利用している
- 進捗大陸05にねこはるさんのkits-effの記事があります。自分も前回の技術書典で購入していました
- From Go To Scala Easy vs Simple
- 個人的にはアンカンファレンスのなかで一番熱いプロレスでした
- KotlinやC++やSwiftも参戦してきて、カオスな雰囲気がいい味を出していました
- Applicative Functor - Selective Functor - Monad
- Selective Functorという聞き慣れない言葉に誘われて聴講しました
- なんとなく仕組みはわかりましたが、どういうときに使うものかイマイチわからなかったので後で勉強します・・・
聞きたかったけど聞けなかったセッションたち
あとで見るために資料のリンクだけ載せておきます。
- Using Akka Cluster for a payment service
- Running Scala on AWS Lambda in a Snappy Way
- 同僚の登壇資料作成をScalaで手伝った話
- How we replaced a 10-year-old Perl product using Scala
- ScalaのOSSに貢献しよう ~ Phil Bagwell Award記念講演
- High Performance Scala/high_performance_scala
- How to build an Event-Sourcing system using Akka with EKS
- [Running in 'PRODUCTION' Reactive Systems with cloud services
- ScalaでGANをスクラッチ開発した話@ScalaMatsuri
- コードで理解するPlayframeworkの脆弱性
- Functional Concurrency in Scala 101
- 悩める開発者に贈る〜 サービスの継続的な成長を支える分析設計手法
- Clean Architecture in Practice
- Intro to typeclass in Scala
- Scala Driven Management
- Case of Ad Delivery System is Implemented by Scala and DDD
- ピュアなドメインを支える技術/pure domain model and the technology behind it
- How to test proper{t,l}y (Scala Matsuri edition)
まとめ
ScalaMatsuriは本格的なカンファレンスでありながらその名の通り「お祭り」気分が味わえる素晴らしいカンファレンスです。もっとScalaMatsuriを知りたい方はScalaMatsuri運営ブログやTwitterのハッシュタグ #ScalaMatsuriもチェックしてみてください。
この記事を読んでくれた方に、少しでもScalaMatsuriの楽しさをお伝えできたなら幸いです。
参加者、関係者の皆様、お疲れ様でした!
もう少し「祭り」の雰囲気を知りたい方向け
ブログの方には会場や食事や懇親会の写真が掲載してあります。また、Qiitaではできないスライドや動画の埋め込みもしてあります。興味がある方はブログの方をご参照ください。
-
6/27はワークショップDAYです。 お絵かきで学ぶScala教室と OSS ハッカソンが開催されていました。OSSハッカソンはよく見たらチューターがガチですね。どんなコントリビュートがされたのか気になります。 ↩
-
2019年3月16日に「船の科学館駅」から「東京国際クルーズターミナル駅」に改称したようです。また「東京国際展示場正門駅」も「東京ビッグサイト駅」に変更されています。こちらはまだ分かりやすい気がしますが、東京国際クルーズターミナルの開業は2020年7月ということらしいので、寝耳に水でした。 ↩
-
行動規範(Code of Conduct/Universal Access)はカンファレンス参加者が守るべきルールです。内容はハラスメントフリーで参加者全員を尊重しつつ、みんなが気持ちよくカンファレンスを楽しめるようにするための取り決めになっています。行動規範はイベントごとに微妙に違うので事前に目を通しておくことをおすすめします。 ↩
-
この同時通訳は日本語->英語だけではなく、英語->日本語も行われています。したがって英語話者に対して日本語で質問ができたりその逆も可能です。RubyKaigiでも同時通訳はありましたが日本語->英語だけだったので、その点ScalaMatsuriの方が英語が苦手な人でも楽しめると思います。またスライドに日本語訳が付いているのも有難かったです。 ↩
-
軽くメモしただけなので間違っているかもしれません。Dottyドキュメントのリンクは自分調べて貼りました。 ↩
-
Enumerationクラスは本当に使えない子なので見なかったことにしてあげてください。 ↩
-
拡張メソッドの構文は#6760で変わるかもしれません・・・マージされずにクローズされました。ただまたいつかこの話題が再燃するかもしれません・・・ ↩ -
Schemeでは継続が第一級オブジェクトで、機能名から
call/cc
ともよく呼ばれています。goto
(またはsetjmp
/longjmp
)と呼ばれる理由は「Scheme/継続の種類と利用例 - Wikibooks」を参照するとよく分かると思います。 ↩