前提
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

回答1件
あなたの回答
tips
プレビュー