Artariel Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 2d alemde worms armageddonun ninja rope fiziğini taklit etmeye çalışıyorum da sarkaç ile ilgili bir ton şey buldum ama anlık ivme, anlık hız , t anında x, t anında y gibi olayları bir türlü çıkaramadım. yardım gerekiyor
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 Onlar normal pendulum kullanmıyordur, normal pendulum kullansalar sonsuza kadar sallanmaya devam eder. Damped pendulum kullanıyorlardır. Small angle approximation yapmıyorlarsa da çözümü o kadar basit olmayabilir. Ama direk çözmek yerine deneme yanılma ile ona benzeyen basit bir dinamik yapmak isteyebilirsin. Açı = Maximum Açı * cos(wt) Hız = -w*Maximum Açı * sin(wt) şeklinde başlarsan bu "small oscillation" limitinde, sürtünme olmadan pendulum. w = kök(g/L), hareket periyodu 2*pi/w. Bunda sürtünmeye benzer bir efekt yaratmak istiyorsan zamanla maximum açı denen değişkeni azaltman lazım. Yani maximum açı(t) = maximum açı - f(t) f(t)'yi burda deneme yanılma ile bulabilirsin ve doğal olan bişeyler seçersin. Eğer böyle yapmayıp da illa tam çözümü istiyorsan ama baya numerikle uğraşman lazım.
di Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 Degisen ya da sabit bir ruzgar faktoru ekleyip onu formulune surtunme katsayisi olarak ekleyebilirsin. Isin daha rahat olur.
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 maximum açı 60 olduğunda, - 60 ve 60 arasında gidip gelecek anlamında mı yoksa 0 - 30 - 60 mıdır ?
barnacle Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 http://kisi.deu.edu.tr//zeki.kiral/Mekanik_Titresimler.html burda sarkac programları vardı ama kodları var mı hatırlamıyorum
codename_curse Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 ikinci derece diferansiyel denklem çıkacak mx'' + bx' + kx = F(t) F(t) nin ne olduğuna bağlı deneme yanılma ya da Fourierle birşeyler çıkarabilirsin ama matlabla grafik almak daha kolay olur
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 oh tamamdır temelini attım sarkacın. biraz daha geliştireyim kafama soru takılırsa sorarım biraz daha. çalıştığım ortam(dil), her ne kadar sevmesem de processing, grafik açısından şimdilik kolaylık olsun formülleri de uydurabileyim diye.
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 maximum açı ilk başladığın açı (zaten maksimum olmasının sebebi de o, orayı asla geçemez sürtünmeden vs dolayı). onu koyduğun zaman cos=1 olduğunda ilk açı durumu cos=-1 olduğunda tam tersi açı
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 codename_curse said: ikinci derece diferansiyel denklem çıkacak mx'' + bx' + kx = F(t) F(t) nin ne olduğuna bağlı deneme yanılma ya da Fourierle birşeyler çıkarabilirsin ama matlabla grafik almak daha kolay olur evet değişkenler sabit olduğu için farklı başlama açıları için numerik olarak çözersen bir kere, ordan gelen çözümleri kullanabilirsin daha sonra. Ama bu başta çok fazla iş gerektiyor ama sonrası için en optimize kod bu. Adam sallanacağı zaman ilk açısını veriyorsun sallıyorum -60, diğer tüm katsayılar sabit olduğu için -60 için daha önceden numerik olarak bulduğun değerler ile yolu belirleyebilirsin. daha ciddi projelerde bu tarz şeyleri tercih edebilirsin.
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 evet evet anladım teşekkürler. bu işi açısal olarak yaptım tabi, FPS ile oranladım w.t kısmını, hız olarak yapmam gerekiyor. diğer fizik kurallarını da çiğnememem için. ancak hızı kullanmam için bileşenlerine ayırmam gerekiyor bakılan yönü, cismin o anda gitmesi gereken açı tam olarak hangisi oluyor?
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 v_x = vcos(açı), v_y= -vsin(açı) olması lazım aklındam yaptım şimdi ama basit trigonometri. hız vektörü ipe dik. hız vektörü ile ipin kesiştiği noktadan yere paralel bi çizgi çiz. o çizgi ile hız vektörü arasındaki açının senin açın olması lazım. burdan dediğim gibi çıkıyor o zaman (yalnız burda artı eksi seçimini biraz daha dikkatli incelemen lazım)
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 yok aslında o anlamda sormadım, trigonometri elbette biliyorum da geometri kısmında biraz çöküş var. şimdi yukarıdaki Açı= formülü sarkaçtaki ip ile cisim arasındaki açı mı yoksa ip ile cisim arasındaki + 90 şeklinde mi ?
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 . . . . . . . -- . . açı . . . . . . . solucan y-ekseni
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 açı konvansiyonunu kendin belirle işte onun doğru olması için biraz uğraşman lazım, artılara eksilere dikkat etmen lazım, geniş açı olduğunda sorun olmadığından emin olman lazım vs
huun Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 o ip esnemiyor mu hiç? en kral metal olsa gene esner, eğilir, bükülür. bu model görüldüğü üzere aramızda bilimadamı sıfatıyla gezenlerin bizleri uyutmak için ortaya koyduğu bir model. kabul etmeyelim arkadaşlar.
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 esnesin nolcak onun diferansiyel denklemi daha zor ama ip uzunluğunu L = L(t) şeklinde uygun bir fonksiyonla ayarlarsan o da zamanla uzar. Oyun yaparken illa her durumda gerçek fizik denklemlerini çözmene gerek yok bence. Eğer olacak şeyi geometrik olarak az çok biliyorsan, daha basit fonksiyonlarla onu taklit etmek daha akıllıca. Sudan ışık yansımalarını gerçek fizik kurallarına göre yapıyor olsalar bugün oyunlarda su yansıması göremezdik sdf
codename_curse Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 eylemsizlik momentini t nin fonksyonu olarak belirlemek lazım. mesela çok kaba bir yaklaşım olarak I(t) = I(0) + esin(w't) gibi bir denklem kötü bir sonuç vermez gibi geliyor. denklem çözülemezse bile matlabda sonuç alınır grafik çözdürülür ha ipi çok çekersen thetayı büyük alırsan eliptik integral giriyordu işin içine T = 2pikök(L/g)(1+(ilkaçı/2)^2+...) terimlerle gidiyor seri açarak çözülen bir denklem
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 işin içine integral girdi ben kaçıyom. en iyisi lise bilgisi basit harmonik hareketle başlamak işe asdf. ordan yavaş yavaş kat çıkarım. yoksa kafayı yedirtir bu küçücük şey.
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 integral yok benim dediğime benzer yolla yap. küçük açılı sarkacı çöz, maksimum açıyı zamanla azaltan bi fonksiyon koy. denemedim ama gerçek sarkaca benzer diye düşünüyorum. eğer elinde analitik bir çözüm yoksa integral alman gerekir (bu sistemi tamamen çözmek istiyorsan yapman gereken şey de o ama diyorum ki gerek yok). ya da codename'in dediği gibi bir kereye mahsus numerik olarak çöz sonra verileri kullan. orda yontemler farklı farklı, numerik integrasyon olabilir, seri açılımı olabilir.
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 peki worms tahminen hangi yöntemle yapılmıştır ? gayet gelişkin bir sarkaç olayı vardı sekmeli mekmeli falan
Ardeth Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 valla hiç fizik motoru kodlamadığım için tahmin edemiyorum onu ama onlar benim sana söylediğim basit olanı kullanmamıştır, bence adam gibi başta numerik çözmüşlerdir o dataları kullanmışlardır diye düşünüyorum. bu arada iyi yazılmış bir kod için o denklemi gerektiği anda numerik olarak da çözmek çok zor değil, bugünki bilgisayarların onu yapması saniye bile sürmez. ama sen basit birşey istiyorsun diye sana bunu önerdim.
Artariel Mesaj tarihi: Ocak 18, 2012 Konuyu açan Mesaj tarihi: Ocak 18, 2012 Ardeth said: integral yok benim dediğime benzer yolla yap. küçük açılı sumerik olarak çöz sonra verileri kullan. orda yontemler farklı farklı, numerik integrasyon olabilir, seri açılımı olabilir. şu an yaptığım şey bu, güzel çalışıyor ama işte bu açılı. 1. sayfada verdiğin hız olayı tam olmadı gibi bi bozukluklar falan oldu. said: float centerx; float centery; float x,y,L,w,aci,acimax; float g; void setup() { size(500, 500); centerx=200; centery=100; L=150; g=9.81; acimax=PI; } void draw() { background(10); w=sqrt(g/L)/10; aci=acimax * cos(w*frameCount) + PI/2; x=centerx + L*cos(aci); y=centery + L*sin(aci); acimax -= PI/1500; // sahte sürtünmemsi if (acimax < 0) acimax=0; ellipse(centerx,centery,10,10); ellipse(x,y,10,10); }
codename_curse Mesaj tarihi: Ocak 18, 2012 Mesaj tarihi: Ocak 18, 2012 yapılmışı var: http://www.physics.unlv.edu/~pang/cp_c.html Program 3.2: Pendulum solved with the fourth order Runge-Kutta algorithm.
Ardeth Mesaj tarihi: Ocak 19, 2012 Mesaj tarihi: Ocak 19, 2012 2. dereceden runge kutta nelerine yetmemiş ya ben moleküler mekaniği bile ikinci dereceden yapıyorum
Ardeth Mesaj tarihi: Ocak 19, 2012 Mesaj tarihi: Ocak 19, 2012 Artariel said: şu an yaptığım şey bu, güzel çalışıyor ama işte bu açılı. 1. sayfada verdiğin hız olayı tam olmadı gibi bi bozukluklar falan oldu. hız olayı derken? eğer hızın bileşenlerini bulmayı diyorsan otur çiz diyagramını bul çok zor değil
Öne çıkan mesajlar