Zrobiłem funkcję Matlab i chciałbym przekonwertować ją do Pythona do użycia z moją aplikacją internetową.Od Matlaba do Pythona - funkcja Rozwiązywania
Konwertowałem (plik .m do pliku .py) prawie wszystko za pomocą OMPC. Nie mogę jednak uruchomić funkcji solve()
(używam biblioteki sympy).
Jest to linia Matlab:
SBC = solve(sqrt((xa-x)^(2)+(ya-y)^(2))-sqrt((xb-x)^(2)+(yb-y)^(2))-D12==0,sqrt((xa-x)^(2)+(ya-y)^(2))-sqrt((xc-x)^(2)+(yc-y)^(2))-D13==0,[x,y]);
I to jest linia Python gdzie x
i y
są symbole (z x = Symbol('x')
i y = Symbol('y')
):
sbc = solve(
sqrt((xa - x) ** (2) + (ya - y) ** (2))
- sqrt((xb - x) ** (2) + (yb - y) ** (2))
- D12 == 0,
sqrt((xa - x) ** (2) + (ya - y) ** (2))
- sqrt((xc - x) ** (2) + (yc - y) ** (2))
- D13 == 0,
[x, y]
)
Z tym kodem Pythona, jestem otrzymywanie False
zamiast wyniku (działa dobrze z kodem Matlaba).
Czy brakuje mi czegoś?
EDIT:
I z tego jestem coraz []
:
# -*- coding: utf-8 -*-
from sympy import *
def alg(xa=None, ya=None, za=None, Ta=None, xb=None, yb=None, zb=None, Tb=None, xc=None, yc=None, zc=None, Tc=None, xd=None, yd=None, zd=None, Td=None, RSSIA=None, RSSIB=None, RSSIC=None, RSSID=None, txPower=None, n=None):
n = 2
c = 3 * 10 ** 8
TOA12 = Ta - Tb
TOA13 = Ta - Tc
TOA14 = Ta - Td
D12 = TOA12 * c
D13 = TOA13 * c
D14 = TOA14 * c
x, y = symbols('x y')
eqs = [sqrt((xa - x) ** (2) + (ya - y) ** (2)) - sqrt((xb - x) ** (2) + (yb - y) ** (2)) - D12,
sqrt((xa - x) ** (2) + (ya - y) ** (2)) - sqrt((xc - x) ** (2) + (yc - y) ** (2)) - D13]
print solve(eqs, [x, y])
alg(3,1,0,21.8898790015,4,6,0,21.8898790005,10,4,0,21.88987900009,9,0.5,0,21.889879000105,23.9,23.85,23.9,23.95,24,1)
Oh widzę. Dzięki za to. Właśnie zobaczyłem, że zostało to napisane na pierwszych liniach części Solvers w dokumencie Sympy :(Jednak nadal mam problem, ponieważ wynikiem jest '[]', zamiast '{x: ..., y: ...} 'Każdy pomysł? – Anthony
Czy możesz edytować pytanie i dodać kod, który daje' [] '?! Jak napisałem, również nie dostałem wyniku, ponieważ moja sesja Pythona zostaje zabita po kilku minutach, próbujesz rozwiązać zbyt trudne równania ...;) – Cleb
Zrobione! :) Moja sesja nie została zabita, ale zajmuje "5 sekund", aby "rozwiązać". – Anthony