Фактор / собрать выражение в Sympy
У меня есть уравнение как:
R₂⋅V₁ + R₃⋅V₁ - R₃⋅V₂
i₁ = ─────────────────────
R₁⋅R₂ + R₁⋅R₃ + R₂⋅R₃
определены, и я хотел бы разделить его на факторы, которые включают только одну переменную - в данном случае V1 и V2.
В результате я ожидаю
-R₃ (R₂ + R₃)
i₁ = V₂⋅───────────────────── + V₁⋅─────────────────────
R₁⋅R₂ + R₁⋅R₃ + R₂⋅R₃ R₁⋅R₂ + R₁⋅R₃ + R₂⋅R₃
Но лучшее, что я мог получить, это
-R₃⋅V₂ + V₁⋅(R₂ + R₃)
i₁ = ─────────────────────
R₁⋅R₂ + R₁⋅R₃ + R₂⋅R₃
с помощью equation.factor(V1,V2)
, Есть ли какой-то другой вариант для разложения или другого метода для разделения переменных еще дальше?
2 ответа
Если бы можно было что-то исключить из факторного алгоритма (в данном случае знаменателя), это было бы легко. Я не знаю, как это сделать, поэтому вот ручное решение:
In [1]: a
Out[1]:
r₁⋅v₁ + r₂⋅v₂ + r₃⋅v₂
─────────────────────
r₁⋅r₂ + r₁⋅r₃ + r₂⋅r₃
In [2]: b,c = factor(a,v2).as_numer_denom()
In [3]: b.args[0]/c + b.args[1]/c
Out[3]:
r₁⋅v₁ v₂⋅(r₂ + r₃)
───────────────────── + ─────────────────────
r₁⋅r₂ + r₁⋅r₃ + r₂⋅r₃ r₁⋅r₂ + r₁⋅r₃ + r₂⋅r₃
Вы также можете посмотреть параметры оценки =False в Add и Mul, чтобы построить эти выражения вручную. Я не знаю хорошего общего решения.
В [3] может быть понимание списка, если у вас много терминов.
Вы также можете проверить, можно ли рассматривать это как многовариантный многочлен в v1 и v2. Это может дать лучшее решение.
Здесь у меня есть sympy 0.7.2
установлен и sympy.collect()
работает для этого:
import sympy
i1 = (r2*v1 + r3*v1 - r3*v2)/(r1*r2 + r1*r3 + r2*r3)
sympy.pretty_print(sympy.collect(i1, (v1, v2)))
# -r3*v2 + v1*(r2 + r3)
# ---------------------
# r1*r2 + r1*r3 + r2*r3