-
Data: 2011-12-09 20:35:02
Temat: Re: ? vs ?
Od: " " <f...@W...gazeta.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]bartekltg <b...@g...com> napisał(a):
> W dniu 2011-12-09 20:34, SĹawomir Szczyrba pisze:
> > Quidquid MsgId est, timeo profesor fire et dona ferentem...
> >
> >> 1) MATEMATYKA /metoda statyczna
> >> albo dac duze kroki-skoki pozycji kulek w kazdej
> >> iteracji i wyznaczac dokladnie punkty kolizji z
> >> matematyki (i probowalem tak robic bo nie jest to az
> >> tak trudne by sie nie dalo przynajmniej zaczac -
> >> trzeba przepisac na kod rownanie "dist(x,y,nx,ny) == 2*R"
> >> (jest to rownanie kwadratowe liczy sie pierwiastki)
> >>
> > Moment.
> > Twierdzisz, Ĺźe â(a²+b²) jest rĂłwnaniem kwadratowym?
>
> Takim zakamuflowanym...
>
> > W ktĂłrym miejscu, przepraszam...
>
> ( Dist(x,y) )^2 = 4R^2
> juĹź jest w peĹni.
>
tu chodzi o wzor na dist(x1,y1,x2,y2):
sqrt((x2-x1)*(x2-x1) + (y2-y1)*(y2-y1))
dokladniej to chodzi o przyrownanie do 2*R odleglosci miedzy
poruszajaca sie kulka (ja rozwiazywalem wzgledem parametru t
gdzie t jest miedzy 0 a 1)
dist(x+t*vx, y+t*vy , ox, oy) = 2*R
jest to rownanie kwadratowe wzgledem t,
dokl. kawalek kodu na brudno z krtorym probowalem:
float px = prev_ball_x ; //poruszajaca sie kulka
float py = prev_ball_y ;
float vx = ball[i].vx ; // jej predkosc
float vy = ball[i].vy ;
float ox = ball[jn].x ; // kulka kolizyjna
float oy = ball[jn].y ;
float R = 10.0;
// px+t*vx-ox;
// py+t*vy-oy;
// (px-ox)*(px-ox)+t*2.0*vx*(px-ox)+t*t*vx*vx+
// (py-oy)*(py-oy)+t*2.0*vy*(py-oy)+t*t*vy*vy-R*R=0;
float a = vx*vx+vy*vy;
float b = 2.0*vx*(px-ox)+2.0*vy*(py-oy);
float c = (px-ox)*(px-ox)+(py-oy)*(py-oy)-R*R;
// c*=-1;
float delta = b*b-4.0*a*c;
float t1=-1;
float t2=-1;
if(delta>=0)
{
t1= (-b+sqrt(delta))/(2*a);
t2= (-b-sqrt(delta))/(2*a);
}
t2 jest zdaje sie zawsze blizszym przecieciem, t1 mozna wogole
nie liczyc; (jak mowie to zdaje sie ze dzialalo (wygladalo ze dziala)
ale natrafilem na dalsze komplikacje w zwiazku z tym ze trzebato by puszczac
rekurencyjnie dla wielokrotnych odbic, a poniewaz trzebabylo
ciagac pare paramatrow nie chcialo mi sie z tym babrac i
przeszedlem na 'metode iteracyjna' po tej wczesnej probie (kod na
brudno po prostu przepisany wzorek z kartki dlugopisem))
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
- 09.12.11 22:54 bartekltg
Najnowsze wątki z tej grupy
- Popr. 14. Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
Najnowsze wątki
- 2025-02-01 Śmierć mózgu a narządy do pobrania
- 2025-01-31 A niektórym to naprawdę zależy na ekologi w miastach LPG POWRACA ;-)
- 2025-01-31 Lublin => Programista Delphi <=
- 2025-01-31 Łódź => Programista NodeJS <=
- 2025-01-31 Wrocław => Senior SAP Support Consultant (SD) <=
- 2025-01-31 Warszawa => Full Stack web developer (obszar .Net Core, Angular6+) <=
- 2025-01-31 Gdańsk => iOS Developer (Swift experience) <=
- 2025-01-31 Kraków => UX Designer <=
- 2025-01-31 Warszawa => Data Engineer (Tech Leader) <=
- 2025-01-31 Gliwice => Business Development Manager - Dział Sieci i Bezpieczeńst
- 2025-01-31 Gliwice => Business Development Manager - Network and Network Security
- 2025-01-31 Warszawa => Architekt rozwiązań (doświadczenie w obszarze Java, AWS
- 2025-01-31 Warszawa => Full Stack .Net Engineer <=
- 2025-01-31 Warszawa => Programista Full Stack (.Net Core) <=
- 2025-01-31 Gdańsk => Programista Full Stack .Net <=