Moderator: physicalattraction
Ja... met ondergrens x=a is de kromtestraal te berekenen maar hoe volgt de waarde van de ondergrens uit deze vergelijking?
Code: Selecteer alles
from scipy.optimize import root_scalar
from scipy.misc import derivative
from sympy import *
from sympy.abc import x, c
from sympy import *
from scipy import integrate
sol = root_scalar(lambda x: 30-(x**3)/250000-5*(cos(0.05*x)), x0=205, bracket = [200,210])
xa = sol.root
def df(x):
return derivative(lambda x: 30-(x**3)/250000-5*(cos(0.05*x)),x)
def ddf(x):
return derivative(lambda x: 30-(x**3)/250000-5*(cos(0.05*x)),x)
def fbooglengte(a):
return integrate.quad(lambda x: (1+(-3*(x**2)/250000 + 0.25*(sin(0.05*x)))**2)**(0.5), a, xa)[0]
sol = root_scalar(lambda x: fbooglengte(x)-175, x0=35, bracket = [30,40])
xc = sol.root
afstandab = integrate.quad(lambda x: (1+(-3*(x**2)/250000 + 0.25*(sin(0.05*x)))**2)**(0.5), 160, xa)[0]
print(f"Afstand van A tot B {afstandab}" )
afstandcb = 175 - afstandab
print(f"Afstand van B tot C {afstandcb}" )
sol = root_scalar(lambda t: 15*t+ 0.4*t**2-afstandcb, x0=35, bracket = [5,10])
tijdbc = sol.root
print(f"Tijd van B tot C {tijdbc}" )
vc = 15 + 0.8*tijdbc
print(f"Snelheid bij C {vc}" )
kromtestraal = ((1+df(xc))**1.5 / ddf(xc))
print(f"Kromtestraal bij C {kromtestraal}")
acent = (vc**2)/kromtestraal
print(f"a centripetaal bij C {acent}")
atot = (0.8**2 + acent**2 )**0.5
print(f"a bij C {atot}")
Code: Selecteer alles
from scipy.optimize import root_scalar
from scipy.misc import derivative
from sympy import *
from sympy.abc import x, c
from sympy import *
from scipy import integrate
sol = root_scalar(lambda x: 30-(x**3)/250000-5*(cos(0.05*x)), x0=205, bracket = [200,210])
xa = sol.root
def df(x):
return derivative(lambda x: 30-(x**3)/250000-5*(cos(0.05*x)),x)
def ddf(x):
return derivative(lambda x: 30-(x**3)/250000-5*(cos(0.05*x)),x)
def fbooglengte(a):
return integrate.quad(lambda x: (1+(-3*(x**2)/250000 + 0.25*(sin(0.05*x)))**2)**(0.5), a, xa)[0]
sol = root_scalar(lambda x: fbooglengte(x)-175, x0=35, bracket = [30,40])
xc = sol.root
afstandab = integrate.quad(lambda x: (1+(-3*(x**2)/250000 + 0.25*(sin(0.05*x)))**2)**(0.5), 160, xa)[0]
print(f"Afstand van A tot B {afstandab}" )
afstandcb = 175 - afstandab
print(f"Afstand van B tot C {afstandcb}" )
sol = root_scalar(lambda t: 15*t+ 0.4*t**2-afstandcb, x0=35, bracket = [5,10])
tijdbc = sol.root
print(f"Tijd van B tot C {tijdbc}" )
vc = 15 + 0.8*tijdbc
print(f"Snelheid bij C {vc}" )
kromtestraal = ((1+df(xc)**2)**1.5 / ddf(xc))
print(f"Kromtestraal bij C {kromtestraal}")
acent = (vc**2)/kromtestraal
print(f"a centripetaal bij C {acent}")
atot = (0.8**2 + acent**2 )**0.5
print(f"a bij C {atot}")