[解決済み] C++11、14、17、20では、円周率の標準定数は導入されていますか?
質問
CとC++における数字のπについて、かなりくだけた問題があります。私の知る限りでは
M_PI
で定義されている
math.h
は、どの規格でも要求されていない。
新しいC++標準は、標準ライブラリに多くの複雑な数学、つまり双曲線関数を導入しました。
std::hermite
と
std::cyl_bessel_i
とか、乱数発生器の違いとか、いろいろあるんです。
新しい」規格の中に、円周率の定数を持ち込んだものがありますか?もしそうでなければ、それはなぜですか?定数がなければ、この複雑な数学はどのように機能するのでしょうか?
C++の円周率に関する同様の問題(数年前の規格)を知っているので、この問題の現状を知りたい。
にも非常に興味があります。 なんでやねん C++はまだ円周率定数を持たないが、もっと複雑な計算がたくさんある。
円周率を自分で定義できることは知っているのですが、それを
4*atan(1)
または
acos(-1)
または
double pi = 3.14;
. しかし、なぜそれをしなければならないのでしょうか?円周率なしで標準的な数学の関数はどのように機能するのでしょうか?
どうすれば解決するの?
C++17まで 円周率 は言語に導入された定数ではないので、めんどくさいです。
私は幸いにも
ブースト
を定義しており
円周率
は、128ビットでも十分に大きな小数点以下の桁数を持つ
long double
.
Boostを使わないのであれば、自分でハードコードしてください。三角関数で定義するのは魅力的ですが、そうすると、それを
constexpr
. 三角関数の精度も、私が知る限りどの規格でも保証されていません (
cf
.
std::sqrt
ということで、このような関数に頼るのは危険です。
を取得する方法があります。
constexpr
の値は
円周率
メタプログラミングを使用しています。
http://timmurphy.org/2013/06/27/template-metaprogramming-in-c/
C++20からいくつかの良いニュースです。それは
は
の定義があります。
円周率
. C++20 では、いくつかの数学定数が
<numbers>
. 例えば
std::numbers::pi
は
double
型になります。
参考にしてください。 https://en.cppreference.com/w/cpp/numeric/constants
関連
-
[解決済み】C++ - 解放されるポインタが割り当てられていないエラー
-
[解決済み】CMakeエラー at CMakeLists.txt:30 (project)。CMAKE_C_COMPILER が見つかりませんでした。
-
[解決済み] explicit キーワードの意味は?
-
[解決済み] C++11では、標準化されたメモリモデルが導入されました。その意味するところは?そして、C++プログラミングにどのような影響を与えるのでしょうか?
-
[解決済み] 0.1fを0にすると、なぜ10倍もパフォーマンスが落ちるのですか?
-
[解決済み] C++11のT&&(ダブルアンパサンド)の意味とは?
-
[解決済み] C++の規格では、初期化されていないboolがプログラムをクラッシュさせることは可能ですか?
-
[解決済み】画像処理。コカ・コーラ缶」認識のためのアルゴリズム改良
-
[解決済み】高放射能環境下で使用するアプリケーションのコンパイルについて
-
[解決済み】標準C++で変数の型を表示することは可能ですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】コンストラクターでのエラー:識別子を期待されますか?
-
[解決済み] [Solved] Error C1083: Cannot open include file: 'stdafx.h'
-
[解決済み】C++の変数はイニシャライザーを持っているが、不完全な型?
-
[解決済み】デバッグアサーションに失敗しました。C++のベクトル添え字が範囲外
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み】エラー:strcpyがこのスコープで宣言されていない
-
[解決済み】リンカーエラーです。"リンカ入力ファイルはリンクが行われていないため未使用"、そのファイル内の関数への未定義参照
-
[解決済み】CMakeエラー at CMakeLists.txt:30 (project)。CMAKE_C_COMPILER が見つかりませんでした。
-
[解決済み】C++ - 適切なデフォルトコンストラクタがない [重複]。
-
[解決済み】システムが指定されたファイルを見つけられませんでした。