M
M
MWX Library
検索…
axis_xyzt
3軸の加速度センサーの値を格納するための構造体ですが、コンテナクラスに格納したときの利便性を上げるための手続きを追加しています。
1
struct axis_xyzt {
2
int16_t x;
3
int16_t y;
4
int16_t z;
5
uint16_t t;
6
};
Copied!

get_axis_{x,y,z}_iter()

1
/*戻り型は長いテンプレート型名なのでauto&&と記載します*/
2
auto&& get_axis_x_iter(Iter p)
3
auto&& get_axis_y_iter(Iter p)
4
auto&& get_axis_z_iter(Iter p)
Copied!
axis_xyztを格納したコンテナクラスのイテレータをパラメータとして、X, Y, Z 軸のいずれかの要素にアクセスするイテレータを生成します。
以下の例では、buf.begin(), buf.end()をX軸用のイテレータとしてアルゴリズムstd::minmax_elementに用いています。
1
#include <algorithm>
2
3
void myfunc() {
4
// コンテナクラス
5
smplbuf_local<axis_xyzt, 10> buf;
6
7
// テスト用にデータを投入
8
buf[0] = { 1, 2, 3, 4 };
9
buf[1] = { 2, 3, 4, 5 };
10
...
11
12
// 最大、最小値を得るアルゴリズム
13
auto&& minmax = std::minmax_element(
14
get_axis_x_iter(buf.begin()),
15
get_axis_x_iter(buf.end()));
16
17
Serial << "min=" << int(*minmax.first)
18
<< ",max=" << int(*minmax.second) << mwx::crlf;
19
}
Copied!

get_axis_{x,y,z}()

1
/*戻り型は長いテンプレート型名なのでauto&&と記載します*/
2
auto&& get_axis_x(T& c)
3
auto&& get_axis_y(T& c)
4
auto&& get_axis_z(T& c)
Copied!
axis_xyztを格納したコンテナクラスのXYZ軸のいずれかの軸を取り出した仮想的なコンテナクラスを生成する関数です。この生成したクラスにはbegin()end()メソッドのみ実装されています。このbegin()end()メソッドで取得できるイテレータは前節get_axis_{x,y,z}_iter()のイテレータと同じものになります。
1
#include <algorithm>
2
3
void myfunc() {
4
// コンテナクラス
5
smplbuf_local<axis_xyzt, 10> buf;
6
7
// テスト用にデータを投入
8
buf[0] = { 1, 2, 3, 4 };
9
buf[1] = { 2, 3, 4, 5 };
10
...
11
12
// キューの中の X 軸を取り出す
13
auto&& vx = get_axis_x(que);
14
15
// 範囲for文の利用
16
for (auto&& e : vx) { Serial << int(e) << ','; }
17
18
// 最大、最小値を得るアルゴリズム
19
auto&& minmax = std::minmax_element(
20
vx.begin(), vx.end());
21
22
Serial << "min=" << int(*minmax.first)
23
<< ",max=" << int(*minmax.second) << mwx::crlf;
24
}
Copied!
最終更新 1yr ago
PDFに出力
リンクのコピー