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

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

新規登録して質問してみよう
ただいま回答率
85.47%
Python 3.x

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

pandas

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

Q&A

解決済

3回答

223閲覧

python 方程式の解をdfに格納していく

python_beginner

総合スコア13

Python 3.x

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

pandas

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

0グッド

0クリップ

投稿2024/03/30 00:58

実現したいこと

三次方程式の解をdfに格納したい

発生している問題・分からないこと

①三次方程式
X3 + A*X2 + B = 0
のA,Bそれぞれにdf["A"],df["B"]を与えた時の解Xを、df["X1"],df["X2"],df["X3"]のように格納したい
解の公式を用いるしかないでしょうか

②またその場合 連立方程式
u3 + v3 + 2*q = 0 , u * v + p = 0
のp,qそれぞれにdf["p"],df["q"]を与えた時の解u,vを、df["u"],df["v"]のように格納したい

普通に連立方程式を解く分にはsympy.solveでできるそうですが
for文を使って1行ずつ計算ではなく、以下のように簡潔にできないかと考えています
df["C"] = df["A"] + df["B"]

該当のソースコード

特になし

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

似た内容にたどり着くことができませんでした

補足

特になし

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

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

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

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

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

guest

回答3

0

ベストアンサー

変数のまま sympy で解いてしまって、それを lambdify で関数化するといいのではないでしょうか。

python

1import pandas as pd 2import sympy 3 4df = pd.DataFrame(...) 5 6a, b, x = sympy.symbols('a b x') 7x1, x2, x3 = sympy.solve(x**3 + a * x**2 + b, x) 8 9func_x1 = sympy.lambdify([a, b], x1) 10func_x2 = sympy.lambdify([a, b], x2) 11func_x3 = sympy.lambdify([a, b], x3) 12 13df['X1'] = func_x1(df['A'], df['B']) 14df['X2'] = func_x2(df['A'], df['B']) 15df['X3'] = func_x3(df['A'], df['B'])

for を使って書くほうがすっきり見えるかもしれません。

python

1a, b, x = sympy.symbols('a b x') 2ans = sympy.solve(x**3 + a * x**2 + b, x) 3funcs = [sympy.lambdify([a, b], ans_x) for ans_x in ans] 4 5for i, func in enumerate(funcs, 1): 6 df[f'X{i}'] = func(df['A'], df['B'])

2 もだいたい同じです。(試しにやったとき nan になったので complex に変換しています)

python

1u, v, p, q = sympy.symbols('u v p q') 2ans = sympy.solve([u**3 + v**3 + 2 * q, u * v + p], [u, v]) 3funcs = [(sympy.lambdify([p, q], ans_u), sympy.lambdify([p, q], ans_v)) 4 for (ans_u, ans_v) in ans] 5 6for i, (func_u, func_v) in enumerate(funcs, 1): 7 df[f'u{i}'] = func_u(df['p'].astype(complex), df['q'].astype(complex)) 8 df[f'v{i}'] = func_v(df['p'].astype(complex), df['q'].astype(complex))

投稿2024/03/30 04:37

bsdfan

総合スコア4578

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

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

python_beginner

2024/04/01 05:49

皆様回答ありがとうございました。 そのままでは解がNanとなりましたが、a,bともにpositive=Trueとすることで解決しました! 私の扱っているデータが5000行くらいあるせいか、1行ずつ方程式を解いてたら時間がかなりかかってしまったこともあり、「先に変数のまま解いてしまって後から代入」を提案してくださった方をベストアンサーに選ばせていただきました。
guest

0

それぞれこんな感じですかね

python

1import pandas as pd 2import sympy 3 4x = sympy.Symbol('x') 5 6df = pd.DataFrame(columns=['A', 'B'], data =[[1, 1], [2, 1], [3, 1], [1, 2], [1, 5], [2, 3]]) 7display(df) 8 9ans = df.apply(lambda row: sympy.solve(x**3 + row['A'] * x**2 + row['B']), axis=1) 10df['X1'] = [a[0] for a in ans] 11df['X2'] = [a[1] for a in ans] 12df['X3'] = [a[2] for a in ans] 13 14display(df)

python

1import pandas as pd 2import sympy 3 4u = sympy.Symbol('u') 5v = sympy.Symbol('v') 6 7df = pd.DataFrame(columns=['p', 'q'], data =[[1, 1], [2, 1], [3, 1], [1, 2], [1, 5], [2, 3]]) 8display(df) 9 10ans = df.apply(lambda row: sympy.solve([u**3 + v**3 + 2 * row['q'], u * v + row['p']]), axis=1) 11df['u'] = [a[0] for a in ans] 12df['v'] = [a[1] for a in ans] 13 14display(df) 15

投稿2024/03/30 02:43

aokikenichi

総合スコア2218

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

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

python_beginner

2024/04/01 05:50

回答ありがとうございました。
guest

0

記述例を下記に示します。

①(3次元方程式)の解を求めるには numpy.roots() を用い,②(3次元連立方程式)の解を求めるには sympy.solve() を用いました。

Python

1import pandas as pd 2import numpy as np 3import sympy as sy 4 5df = pd.DataFrame({'c0': [1, 1, 1], 6 'A': [1, 0, 1], 7 'c2': [0, 0, 0], 8 'B': [0, 1, 1]}, dtype=float) 9 10df[['X1', 'X2', 'X3']] = [np.roots(c) for c in df.to_numpy()] 11 12print(df) 13# c0 A c2 B X1 X2 X3 14# 0 1.0 1.0 0.0 0.0 -1.000000+0.000000j 0.000000+0.000000j 0.000000+0.000000j 15# 1 1.0 0.0 0.0 1.0 -1.000000+0.000000j 0.500000+0.866025j 0.500000-0.866025j 16# 2 1.0 1.0 0.0 1.0 -1.465571+0.000000j 0.232786+0.792552j 0.232786-0.792552j 17 18 19df2 = pd.DataFrame({'p': [1, 0, 1], 20 'q': [0, 1, 1]}, dtype=float) 21 22sy.var('u v'); 23result = [sy.solve([u**3 + v**3 + 2 * q, u * v + p]) 24 for p, q in df2.to_numpy()] 25df2[['u', 'v']] = [[[complex(d[u]) for d in rs], [complex(d[v]) for d in rs]] 26 for rs in result] 27 28for id in df2.index: 29 print("p =", df2.loc[id, 'p'], " q =", df2.loc[id, 'q']) 30 print("u:", df2.loc[id, 'u']) 31 print("v:", df2.loc[id, 'v']) 32# p = 1.0 q = 0.0 33# u: [(-1+0j), (1+0j), (-0.5-0.8660254037844386j), (-0.5+0.8660254037844386j), (0.5-0.8660254037844386j), (0.5+0.8660254037844386j)] 34# v: [(1+0j), (-1+0j), (0.5-0.8660254037844386j), (0.5+0.8660254037844386j), (-0.5-0.8660254037844386j), (-0.5+0.8660254037844386j)] 35# p = 0.0 q = 1.0 36# u: [(-1.2599210498948732+0j), 0j, 0j, 0j, (0.6299605249474366-1.0911236359717214j), (0.6299605249474366+1.0911236359717214j)] 37# v: [0j, (-1.2599210498948732+0j), (0.6299605249474366-1.0911236359717214j), (0.6299605249474366+1.0911236359717214j), 0j, 0j] 38# p = 1.0 q = 1.0 39# u: [(-1.3415037626305777+0j), (0.7454321246472562+0j), (-0.3727160623236281-0.6455631567415321j), (-0.3727160623236281+0.6455631567415321j), (0.6707518813152888-1.1617763377104897j), (0.6707518813152888+1.1617763377104897j)] 40# v: [(0.7454321246472562+0j), (-1.3415037626305777+0j), (0.6707518813152888-1.1617763377104897j), (0.6707518813152888+1.1617763377104897j), (-0.3727160623236281-0.6455631567415321j), (-0.3727160623236281+0.6455631567415321j)]

投稿2024/03/31 12:05

little_street

総合スコア319

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

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

python_beginner

2024/04/01 05:50

回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問