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

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

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

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

1回答

2193閲覧

Pythonとexcelで計算結果が異なる。

8960

総合スコア108

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2022/04/07 09:55

前提

Pythonでデータ分析をしている初学者です。
以下のようにランダムで作成したスコアをもとに、一部スコアを使って逆関数の計算をしています。

#df["angleΘ"] = np.arccos(df["Adj"]**2 + df["Hyp"]**2 - df["Opp"]*2)/2(df["Adj"]*df["Hyp"])
の箇所、excelで同様の計算をしたところ計算結果が大きく異なりました。

原因を特定するために、↑の前半のところだけで比較してみましたが、この時点で数値に若干のずれが生じておりました。
小数点でいうと、第2位の数字が違うかのどうかのレベルですのでもしかしたら切り捨て/切り上げの違いかもしれませんが、0.02異なる場合もありましたのでどうなのかなと。

https://keisan.casio.jp/exec/system/1260283160
試しに上記のサイトでも計算してみたところ、excelの値と同じものが算出されましたので
Pythonコードの方に、何か問題があるのかと思いますが
イメージ説明

すみません…説明がわかりにくいですが、このangleΘの値が異なる原因について
分かる方いましたらご教授いただけたらと思います。
よろしくお願いいたします。

発生している問題

Pythonとexcelでアークコサインの計算結果が微妙に違う

該当のソースコード

Python

1## test 2import pandas as pd 3import numpy as np 4 5pd.options.display.float_format="{:.2f}".format 6 7# Create a randomdata frame 8start,end = "2022/3/29","2022/4/5" 9dates = pd.date_range(start=start,end=end,freq="D") 10players =[(f"Player{i+1}",np.random.uniform(1.60,1.91)) for i in range(0,15)] 11N = 1000 12dates = np.random.choice(dates,size=N) 13dates.sort() 14p_pos = np.random.choice(range(len(players)),size=N) 15df = pd.DataFrame({ 16 "Date":dates, 17 "Player":[players[pos][0] for pos in p_pos], 18 "Height":[players[pos][1] for pos in p_pos], 19 "Score1":np.random.sample(N) * 0.30 + 1.50, 20 "Score2":np.random.sample(N) * 0.80 + 0.80, 21 "Score3":np.random.sample(N) * 0.40 + 1.50 22}) 23 24df["Adj"] = df["Score1"] - df["Height"]*0.7 25df["Opp"] = abs(df["Score2"]) 26df["Hyp"] = np.sqrt(df["Adj"]**2 + df["Opp"]**2) 27 28# 計算がexcelと合わない 29# df["angleΘ"] = np.arccos(df["Adj"]**2 + df["Hyp"]**2 - df["Opp"]**2)/2*(df["Adj"]*df["Hyp"]) 30 31# 前半部分だけ切り取って確認 32df["angleΘ"] = np.arccos(df["Adj"]**2 + df["Hyp"]**2 - df["Opp"]**2) 33df 34 35

補足情報(FW/ツールのバージョンなど)

python3.9、VSCode

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

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

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

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

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

meg_

2022/04/07 11:03

エクセルを見ると小数点第2位までの数値のように見えます。どうやってエクセルに値をコピーしましたか?元の数値はもっと小数点以下の桁数が多いのではないでしょうか?
8960

2022/04/07 11:08

これはnp.random.uniform(1.60,1.91)で作成したものです。 VSCodeで出力されたものを貼り付けました。
meg_

2022/04/07 11:51

エクセルで計算したものはデータが桁落ちしてるので計算結果が合わないように見えるだけでは?違いますか?
8960

2022/04/07 12:01

なるほど、勘違いしておりました。 Score等ランダムで作成した値は、小数点第二位の値レベルでランダムに作成されると思っていましたが、実際には第二位以下も数値が入っているのですね。 pd.options.display.float_format="{:.5f}".format にしてみて気づきました。 ありがとうございました。
guest

回答1

0

自己解決

小数点第二位以下の値の違いによる桁落ち。

投稿2022/04/07 12:02

8960

総合スコア108

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問