[Maths] Gravitate towards target point?

LurkerAspect

Now officially a Super Lurker
Reaction score
118
Hi there :D I wasn't sure where to post this, so it's ended up here.

Complete overhaul: New problem: my object now gets stuck in orbit around it's target, even if the target is stationary. Does anyone know how I can fix that?
 

s3rius

Linux is only free if your time is worthless.
Reaction score
130
I'm not a math whizz, but you need to be a little more specific about what you're doing and how you're doing it.
 

UndeadDragon

Super Moderator
Reaction score
448
I'm not a math whizz, but you need to be a little more specific about what you're doing and how you're doing it.

s3rius is right, we need more information. Also if you could post your current code (or even the maths in pseudo code) it would be very useful.
 

LurkerAspect

Now officially a Super Lurker
Reaction score
118
Yeah sorry I realised that now >.<

Here's what I'm doing:
Code:
target(object)  = target of projectile
projectile(object) = the projectile
velocityX(real) = X velocity of projectile
velocityY(real) = Y velocity of projectile
speed(real) = projectile's current speed = SquareRoot(velocityX^2+velocityY^2)
angle = angle towards target from projectile
acceleration(real) = the amount the projectile accelerates per second
maxSpeed(real) = the Maximum speed/terminal velocity the projectile is allowed to acheive = 900
interval(real) = periodic tick duration = 0.02

every interval {
   if speed < maxSpeed {
      set velocityX = velocityX+acceleration*(interval^2)*Cos(angle)
      set velocityY = velocityY+acceleration*(interval^2)*Sin(angle)
   }
}
I guess you would call this pseudo code.

Anyway, basically the problem now is that if the projectile misses it's target on the first run, it gets stuck in an infinite orbit trying to hit the target. The target, in this case, is stationary. The projectile is also launched with an initial velocityX and velocityY, which is why this problem occurs.
 

GFreak45

I didnt slap you, i high 5'd your face.
Reaction score
130
Should the gravitational pull be within a certain range of the object? Also seeing as a gravitational pull should increase in the direction of the object, you cant calculate the velocity in an x/y method, you calculate the velocity and angle, then calculate the x/y, if you calculate the x/y first the object will continue in the wrong direction if it moves slightly (Assuming objects can fight the gravitational pull), also shouldnt the pull be based on the distance from the object rather than an accelaration?
 

UnknowVector

I come from the net ... My format, Vector.
Reaction score
144
I'm assuming the "angle towards target from projectile" is measured counterclockwise from the positive x-axis, with the origin at the position of the projectile (i.e. atan2(target-projectile)). (For future reference: two points never defines an angle. Always make your third reference point explicit, in this case it's any old point along the x-axis and directly to the right of the projectile.) (Had to edit this paragraph because I said it wrong too XD)

Maybe you could try describing what you _want_, instead of what you're doing.

To the best of my understanding: you want a completely undodgable single-minded guided-rocket that is guarenteed to eventually hit whatever you shoot it at. You want this rocket to turn gradually in order to head towards it's target as close to straight on as it can get.

Code:
every interval {
  if speed < maxSpeed {
      set velocityX = velocityX+acceleration*(interval^2)*Cos(angle)
      set velocityY = velocityY+acceleration*(interval^2)*Sin(angle)
  }
}

This code is _very_ close. You are accelerating the projectile along the vector towards the target. You are also capping the projectiles speed. However, you should be multiplying the acceleration by the interval, not the square of the interval.

The fact that your homing missile can circle it's target is a natural consequence of this method.

Here's a good thread on this. Check the first post by MerlinJim.

Perhaps the best solution for you is too combine the absolute vectoring he talks about with your method, which he also mentions. After you calculate a new velocity for the missile and calcuate it's movement based on that velocity for the next timestep, apply a small absolute displacement in the direction of the target. Even if the missile circles the circles will get tighter and tighter over time. Possibly make the size of this displacement scale up depending on how close you are to the target or how long the missile has been in flight.

The result might look sorta strange, you'll have to test that out.
 

GFreak45

I didnt slap you, i high 5'd your face.
Reaction score
130
I have a good idea for how to combine the absolute velocity and movement based velocity, 1 total velocity and based on the distance from the object the absolute or the movement will have more effect, ie: far away movement has a much larger effect (0-100), getting closer it switches to more absolute (50-50) and really close it would be pure absolute (100-0), you could have this based on the original position of the object when the order was issued plus a certain amount to insure the absolute will have more effect if the original position is close
 
General chit-chat
Help Users
  • No one is chatting at the moment.

      The Helper Discord

      Members online

      No members online now.

      Affiliates

      Hive Workshop NUON Dome World Editor Tutorials

      Network Sponsors

      Apex Steel Pipe - Buys and sells Steel Pipe.
      Top