LoginSignup
6
4

日本初レビュー⁉ DAX Optimizerをさわってみたよ~😎

Posted at

はじめに

Power BIユーザーおなじみのSQLBIを運営しているMarco Russoさんが、6月22日にポストしたDax Optimizerのウェイトリスト。ポストを見つけてすぐに申し込み、8月20日頃にようやく利用可能通知がありました。早速さわってみましょ~👍

image.png

Dax Optimizer ホームページ

ウェイトリストへの登録はこちらから。

Dax Optimizer Blog

Dax Optimizer ってなに?

  • DAX Optimizerとは:DAX Optimizerは、DAXコードの性能やボトルネックを診断し、解決策を提案し、優先順位を付けるツールです。Power BIやAnalysis Servicesのモデルの最適化を目指します。
  • DAX Optimizerのメリット:DAX Optimizerは、静的解析によってDAXコードの問題点を検出し、ベストプラクティスに従った改善案を示します。また、最も影響の大きい変更に集中できるように、問題点を重要度順にランク付けします。
  • DAX Optimizerの学習効果:DAX Optimizerは、アンチパターンを強調し、より良いコーディング技術について洞察を与えることで、チームのDAX学習を促進します。また、ベンダーに対して高いコーディング基準を守るように品質チェックポイントとして機能します。

ライセンス

2023年10月15日までは30%オフ。

割引期間中は、起動ごとに課金されるプランは1回ごとに月額約30$だから大体4500円ほど。ただしこれは年払いの場合。1日20回まで起動できるプランは、デスクトップのモデルにのみ使えるのが月額 約48$(約7,000円)、Power BI Serviceのモデルにも使えるほうが月額 約70$(約10,000円)。すべて年払いになるので、Service版を使用すると、年間10万円程度はかかる。

割引期間が終わるとServiceモデルは月額99$になるから、約15,000円。年額18万円ほど。

※月払いにするともう少し高くなる。

image.png

さわってみる

ライセンスコードの登録を終えると、データの置き場所を決める必要がある。

  • West Europe
  • East US
  • Australia East

現在は上記3つ。

image.png

image.png

  1. Dax Studio
  2. Bravo
  3. Tabular Editor 3

モデルを読み込むためには上記3ついずれかの外部ツールが必要です。
今回はDax Studioを使用してVPAXファイルをエクスポートします。

モデルを読み込んでから、エクスポートをします。

image.png

VPAXファイルを保存します。

image.png

このファイルをアップロードして分析を進めます。

image.png

読み込むと、モデルの容量や、メジャーの数、テーブルの数などが表示されます。分析しますか?とボタンが表示されるので、ここで 「Analyze」 をクリックすると分析が開始します。

image.png

少し待つと、1日20回のチケットが1つ減っていることがわかると思います。
そして、8個の問題を抱えていることが表示されます。

image.png

イシューは以下の通り、今回は優先度Lowが6個表示されています。

image.png

そのうち一つをクリックしてみます。
問題のあるメジャーが表示され、具体的にどこに問題があるのか赤くなっています。
また、上部には、何が問題なのか詳しく書いてあります。

image.png

このメジャーに対する指摘事項はこれ↓

Function result invariant to current iterator

The function within an expression argument of an iterator function does not use the iterator's row context and can therefore be optimized using a variable.
The part of an expression executed in a row context that do not depend on the row context might require redundant evaluations of the formula engine, resulting in additional CPU cost. In this case, the function call is identified as part of such redundant expression.

A possible optimization is to store the result of the function call in a variable, and then reference the variable. It is important to assign the variable only when the execution scope guarantees that the variable is used at least once, otherwise the result could be counterproductive and slow down the execution time instead of improving it.

日本語訳

現在のイテレータに対して不変な関数結果

イテレータ関数の式引数内の関数は、イテレータの行コンテキストを使用しないため、変数を使用して最適化することができます。

行コンテキストで実行される式のうち、行コンテキストに依存しない部分は、数式エンジンの冗長な評価を必要とする可能性があり、その結果、追加の CPU コストが発生します。この場合、関数呼び出しはそのような冗長な式の一部として識別されます。

可能な最適化は、関数呼び出しの結果を変数に格納し、その変数を参照することです。実行スコープが、その変数が少なくとも一度は使用されることを保証している場合にのみ、その変数を代入することが重要である。

Example を押すと例も出してくれます。直接修正してくれるわけではないっていうのは抑えておいた方がいいですね。

image.png

image.png

なるほどっ🤔

FILTER (
    ALL ( 'Date'[Date] ),
    VAR _start = MIN ( highlight_calender[Date] )
    VAR _end = MAX ( highlight_calender[Date] )
    RETURN 'Date'[Date] >= _start && 'Date'[Date] <= _end
)

FILTER関数の中で、定数を定義しているため、これがFILTER関数の実行時(イテレーター処理)に毎回計算されている。だけど、定数なんだからFILERの外にだして最初に定義しておけばいいよねってことか。

修正してみる

Tabular Editor 3 を開いて

このメジャーを、

image.png

こう修正してみる。

image.png

Tabular Editor 3 でエクスポート

VPAXファイルはTabular Editor 3でもエクスポートできます。下のタブのVertipaq Analyzerから。

image.png

再度アップロードする

Versionというボタンがあるので、そこからアップロード。

image.png

比較する

修正前、修正後のメジャーを比較すると、CPU COSTという項目が大幅に下がっているのがわかるかと思います!たった数行の違いだけなのに、こんなに大きく変わるとは思ってもみなかった…!

image.png

まとめ

まず、今はやりのAIを使用して、自動的に DAXを最適化してくれるツールではないことはおさえておかないといけません。名前だけみて勘違いしている人もいるのでは。私もそうでした笑

金額もそれなりにするし、推奨事項を読み取って自分で修正をいれていかないといけないことから、初心者が使って効果のあるツールではない印象。

ただ、開発者にとっては、どんどん増えていくメジャーを、ひとつひとつを最適化しておくことはパフォーマンスを担保するためにはとても大事なことなので、とても有用なのではと感じました👌あとはコストとメリットの天秤ですね。

まだまだプレビュー中のService、今のところ無料版はなさそうなので試すのはハードル高いですが、BlogやXを通して発信される内容を今後も要チェックが必要なサービスだなと感じました!

6
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
4