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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

1回答

758閲覧

timespecの計測結果について

退会済みユーザー

退会済みユーザー

総合スコア0

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2020/06/01 13:34

ナノ秒単位の測定を行っております。
計測範囲に"測定コードなし"の状態で計測を実施すると"75nsec"となりました。
これは,clock_gettime関数の処理に"75nsec"かかっているということでしょうか。
どなたかご教授いただければと思います。

■構成
H/W:Raspberry Pi 4 Model B/4GB
OS :Ubuntu Server

#include <stdio.h> #include <time.h> #define nanosec 1000000000 int main(void){ unsigned long long res, ullstart, ullend, min; double test; struct timespec start, end; for(int i = 0; i<500000; i++){ clock_gettime(CLOCK_MONOTONIC, &start); //計測範囲 clock_gettime(CLOCK_MONOTONIC, &end); ullstart = (unsigned long long)(start.tv_sec * nanosec) + (unsigned long long)(start.tv_nsec); ullend = (unsigned long long)(end.tv_sec * nanosec) + (unsigned long long)(end.tv_nsec); res = ullend - ullstart; if(min > res){ min = res; } } printf("res: %llu \n", res); }

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

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

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

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

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

guest

回答1

0

その前に、そのクロックの分解能がどんだけか、というのをはっきりさせておく必要があります
それがわからないと、計測結果の時間というのは意味を持ちません。

これは,clock_gettime関数の処理に"75nsec"かかっているということでしょうか。

まあ、そういうことなんでしょうけど、果たしてホンマに75nsかどうかはどうやって確かめましょうか。

#実測してみる?

投稿2020/06/01 13:50

y_waiwai

総合スコア87749

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問