Skip to content

Latest commit

 

History

History
38 lines (24 loc) · 3.82 KB

README.md

File metadata and controls

38 lines (24 loc) · 3.82 KB

evo-quad

TODO:

  • Replace absolute state with relative state. Instead of x, y, z position of quadruped we should only have rate of change or orientation.

Working Notes:

Static poses issue

Model very quickly converges to actors that adopt static positions and stay in those positions. I think the reason this happens for this model and not the openai ones is because here the model is outputting the positions of the motors rather than there torques. This we're much more likely to see static poses as each of those is at least a stable solution to the problem, especially if there is a fall penalty. Using torque means the network governs rate of change which means it's more likely to suggest dynamic solutions rather than static ones. This essentially injects noise into the model which acts as exploration.

Couple of potential solutions:

  • Add oscillatory state inputs or nodes somewhere in the model. This should add some noise of the type we want as the model will be better able to convert oscillations into gate patterns than just the state inputs.
  • Restrict action complexity. Currently there are 12 degrees of freedom, 4 legs * 3 joints in each. OpenAi ant env has 8. Supposing we reduce each action to moving the leg join one way or another this means there are 2^12 = 4096 options for each time step which is significantly more than the 2^8 = 256 for 8 variables. If we assume that the majority of the work done while walking is in the hip joints then we can restrict to just those joints and train on those 4, once the model has some suboptimal performance on them we can add the knee joins and so on.

Other things:

  • Try different learning rates.
  • Try different oscillation rates.
  • Replace POSITION_CONTROL with VELOCITY_CONTROL
  • Replace VELOCITY_CONTROL with TORQUE_CONTROL
  • increase torque

Appears the torque applied to the motor wasn't strong enough which meant the default outcome was for the quadruped to fall over and be unable to get back up.

Network Output volatility

So the network outputs and extremely volatile signal. I checked to see if this was the same as in the ant case and it was. In fact evo-ants network is basically a very chaotic signal that's then squashed down onto [-1, 1] by the tanh output layer into essentially a square wave with different frequencies. I think our issue is that if a network output for a specific action is distributed around a mean sufficiently far outside of [-1, 1] then we end up with a signal that's mostly just takes value 1. The parameter updates are unlikely to move this signal by much and the end result will likely be that the model can't learn anything for that signal. This is the notable difference between ant and quad network outputs, namely that the mean of the network outputs is around 0 for the ant but outside of [-1, 1] for quad.

  • Find a way to centre the output. Turns out the solution to this is to use activation functions across the network that take values between [-1, 1] rather than [0, 1]
  • It may be useful to increase the force or at least the joint acceleration/or just use TORQUE_CONTROL. The issue here is that if the impulse is not great enough then the joint is likely to get latched in one and only one position.
    • I think the ideal combination is having the robot able to move it's limbs quickly but not apply to much force? If the limbs are too forceful then the robot's trajectory becomes too chaotic.

lateral Friction of feet

So the robot does a pretty good impression of trying to run. However I think the weights are all completely off as are the frictional constants, hence it sort of gallops on the spot.

  • Replace mass, force and frictional values with those in here quadruped