質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Rust

Rustは、MoFoが支援するプログラミング言語。高速性を維持しつつも、メモリ管理を安全に行うことが可能な言語です。同じコンパイル言語であるC言語やC++では困難だったマルチスレッドを実装しやすく、並行性という点においても優れています。

Q&A

解決済

1回答

898閲覧

rust-ndarrayのstride_equivalentについて

BoKuToTuZenU

総合スコア51

Rust

Rustは、MoFoが支援するプログラミング言語。高速性を維持しつつも、メモリ管理を安全に行うことが可能な言語です。同じコンパイル言語であるC言語やC++では困難だったマルチスレッドを実装しやすく、並行性という点においても優れています。

0グッド

0クリップ

投稿2021/10/05 03:11

strides_equivalentについて質問させていただきます。

この関数はDocumentにあるとおり、stride1とstride2がselfのstrideにequivalentかどうかを判断するメソッドだと思います。
その関数内で

rust

1&& izip!(self.slice(), strides1.slice(), strides2.slice()) 2 .all(|(&d, &s1, &s2)| d <= 1 || s1 as isize == s2 as isize)

長さ>1の各軸について、ストライドが等しい場合、そのストライドは等価である。
と書いてありますが、長さ1以下で場合分けする理由がわかりません。

このメソッドが使用されているのは、zip_mut_with_same_shapeなどがあります。他のものは見つけられませんでしたので、この部分でのみ利用されていると考えられます。

この中では、最初にselfrhsのdimを比較しています(shapeメソッドはdimをスライスの参照にしたものを戻り値としています。)
そのため、dimが同じであるとわかっているならば、strideの比較のみをすればいいと主ます。なので、

rust

1&& izip!(strides1.slice(), strides2.slice()) 2 .all(|(&s1, &s2)| s1 as isize == s2 as isize)

で事足りると思いました。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

strides_equivalentは、2つのBaseArrayのデーターが同じレイアウトでメモリーに格納されているかを調べるもののようです。そして、同じレイアウトならzip_mut_with_same_shapeは高速な実装を選択し、そうでない場合は低速な実装にフォールバックします。

このことから、できる限り高速な実装を使いたいから、長さ1以下の場合はストライドの違いを無視するのではないかと予想しました。ストライドは2番目以降の要素にアクセスするときに使われますので、長さ1以下の軸ではストライドが違っていても、それは使用されず、結局は同じメモリーレイアウトになります。

その予想が正しいか調べるために、GitHubの機能を以下のように使ってみました。

  1. Blameでstrides_equivalentメソッドを追加したコミットを表示
  2. そのコミットを含むPull Request(PR)を表示

するとこのPRレビューコメントに行きつきました。rust-ndarray/ndarray #754 review 318583231

  • PRの元々の実装ではif self.strides() == rhs.strides()としていた
  • そのレビューコメントで、この条件が必要以上に厳しいとの指摘があり、現在のコードが提案された
  • 必要以上に厳しい理由として、長さ1以下の軸ではストライドの違いは関係ないことが説明されている(以下)

This is a little more restrictive than necessary. For axes with length <= 1, the stride doesn't matter. For example, if we have two arrays like this:

  • shape: [1, 5], strides: [42, 1]
  • shape: [1, 5], strides: [3, 1]

their memory layout is the same even though the strides for axis 0 are not equal (since the length of axis 0 is <= 1).

私はndarrayを使っていないので、同じshapeなのにストライドが異なるというケースがどういうときに起こるのかはわかりません。しかし、レビューコメントから、長さ1以下の軸についてはストライドの違いは無視してかまわないことが確認できました。そのために現在の実装になっています。

投稿2021/10/09 17:10

tatsuya6502

総合スコア2046

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問