浏览代码

clean up code

/hh-develop-ragdoll-testing
HH 5 年前
当前提交
d6d3e16b
共有 7 个文件被更改,包括 60 次插入116 次删除
  1. 158
      Project/Assets/ML-Agents/Examples/Crawler/Scripts/CrawlerAgent.cs
  2. 2
      Project/Assets/ML-Agents/Examples/SharedAssets/Prefabs/OrientationCube.prefab.meta
  3. 6
      Project/Assets/ML-Agents/Examples/Walker/Scripts/WalkerAgent.cs
  4. 10
      Project/Assets/ExpertWalkerDyn.demo.meta
  5. 0
      /Project/Assets/ML-Agents/Examples/SharedAssets/OrientationCube.prefab.meta
  6. 0
      /Project/Assets/ML-Agents/Examples/SharedAssets/OrientationCube.prefab

158
Project/Assets/ML-Agents/Examples/Crawler/Scripts/CrawlerAgent.cs


[RequireComponent(typeof(JointDriveController))] // Required to set joint forces
public class CrawlerAgent : Agent
{
[Header("Target To Walk Towards")]
[Space(10)]
public Transform target;
public float maximumWalkingSpeed = 999; //The max walk velocity magnitude an agent will be rewarded for
[Space(10)]
[Header("Orientation Cube")]
[Space(10)]
//This will be used as a stable observation platform for the ragdoll to use.
GameObject m_OrientationCube;
[Header("Target To Walk Towards")] [Space(10)]
public Transform target; //Target the agent will walk towards.
public float targetSpawnRadius; //The radius in which a target can be randomly spawned.
public bool detectTargets; //Should this agent detect targets
public bool respawnTargetWhenTouched; //Should the target respawn to a different position when touched
public Transform ground;
public bool detectTargets;
public bool targetIsStatic;
public bool respawnTargetWhenTouched;
public float targetSpawnRadius;
public Transform ground; //Ground gameobject. The height will be used for target spawning
[Header("Body Parts")] [Space(10)] public Transform body;
public Transform leg0Upper;

public Transform leg3Upper;
public Transform leg3Lower;
[Header("Joint Settings")] [Space(10)] JointDriveController m_JdController;
float m_MovingTowardsDot;
float m_FacingDot;
[Header("Reward Functions To Use")]
[Space(10)]
public bool rewardMovingTowardsTarget; // Agent should move towards target
[Header("Orientation")] [Space(10)]
//This will be used as a stable reference point for observations
//Because ragdolls can move erratically, using a standalone reference point can significantly improve learning
public GameObject orientationCube;
JointDriveController m_JdController;
[Header("Reward Functions To Use")] [Space(10)]
public bool rewardMovingTowardsTarget; // Agent should move towards target
[Header("Foot Grounded Visualization")]
[Space(10)]
[Header("Foot Grounded Visualization")] [Space(10)]
public bool useFootGroundedVisualization;
public MeshRenderer foot0;

public Material groundedMaterial;
public Material unGroundedMaterial;
Quaternion m_LookRotation;
Matrix4x4 m_TargetDirMatrix;
//Spawn an orientation cube
Vector3 oCubePos = body.position;
oCubePos.y = -.45f;
m_OrientationCube = Instantiate(Resources.Load<GameObject>("OrientationCube"), oCubePos, Quaternion.identity);
m_OrientationCube.transform.SetParent(transform);
UpdateOrientationCube();
m_JdController = GetComponent<JointDriveController>();

m_JdController.SetupBodyPart(leg3Upper);
m_JdController.SetupBodyPart(leg3Lower);
}
/// <summary>
/// Add relevant information on each body part to observations.
/// </summary>

//Get velocities in the context of our orientation cube's space
//Note: You can get these velocities in world space as well but it may not train as well.
sensor.AddObservation(m_OrientationCube.transform.InverseTransformDirection(bp.rb.velocity));
sensor.AddObservation(m_OrientationCube.transform.InverseTransformDirection(bp.rb.angularVelocity));
sensor.AddObservation(orientationCube.transform.InverseTransformDirection(bp.rb.velocity));
sensor.AddObservation(orientationCube.transform.InverseTransformDirection(bp.rb.angularVelocity));
sensor.AddObservation(m_OrientationCube.transform.InverseTransformPoint(bp.rb.position));
// sensor.AddObservation(m_OrientationCube.transform.InverseTransformDirection(bp.rb.position - body.position));
// sensor.AddObservation(m_OrientationCube.transform.InverseTransformPoint(bp.rb.position));
sensor.AddObservation(orientationCube.transform.InverseTransformDirection(bp.rb.position - body.position));
if (bp.rb.transform != body)
{

}
// /// <summary>
// /// Add relevant information on each body part to observations.
// /// </summary>
// public void CollectObservationBodyPart(BodyPart bp, VectorSensor sensor)
// {
// var rb = bp.rb;
// sensor.AddObservation(bp.groundContact.touchingGround ? 1 : 0); // Whether the bp touching the ground
//
// var velocityRelativeToLookRotationToTarget = m_TargetDirMatrix.inverse.MultiplyVector(rb.velocity);
// sensor.AddObservation(velocityRelativeToLookRotationToTarget);
//
// var angularVelocityRelativeToLookRotationToTarget = m_TargetDirMatrix.inverse.MultiplyVector(rb.angularVelocity);
// sensor.AddObservation(angularVelocityRelativeToLookRotationToTarget);
//
// if (bp.rb.transform != body)
// {
// var localPosRelToBody = body.InverseTransformPoint(rb.position);
// sensor.AddObservation(localPosRelToBody);
// sensor.AddObservation(bp.currentXNormalizedRot); // Current x rot
// sensor.AddObservation(bp.currentYNormalizedRot); // Current y rot
// sensor.AddObservation(bp.currentZNormalizedRot); // Current z rot
// sensor.AddObservation(bp.currentStrength / m_JdController.maxJointForceLimit);
// }
// }
sensor.AddObservation(Quaternion.FromToRotation(body.forward, m_OrientationCube.transform.forward));
sensor.AddObservation(Quaternion.FromToRotation(body.forward, orientationCube.transform.forward));
sensor.AddObservation(m_OrientationCube.transform.InverseTransformPoint(target.position));
sensor.AddObservation(orientationCube.transform.InverseTransformPoint(target.position));
sensor.AddObservation(hit.distance/maxRaycastDist);
sensor.AddObservation(hit.distance / maxRaycastDist);
// public override void CollectObservations(VectorSensor sensor)
// {
// m_JdController.GetCurrentJointForces();
//
// // Update pos to target
// m_DirToTarget = target.position - body.position;
// m_LookRotation = Quaternion.LookRotation(m_DirToTarget);
// m_TargetDirMatrix = Matrix4x4.TRS(Vector3.zero, m_LookRotation, Vector3.one);
//
// RaycastHit hit;
// if (Physics.Raycast(body.position, Vector3.down, out hit, 10.0f))
// {
// sensor.AddObservation(hit.distance);
// }
// else
// sensor.AddObservation(10.0f);
//
// // Forward & up to help with orientation
// var bodyForwardRelativeToLookRotationToTarget = m_TargetDirMatrix.inverse.MultiplyVector(body.forward);
// sensor.AddObservation(bodyForwardRelativeToLookRotationToTarget);
//
// var bodyUpRelativeToLookRotationToTarget = m_TargetDirMatrix.inverse.MultiplyVector(body.up);
// sensor.AddObservation(bodyUpRelativeToLookRotationToTarget);
//
// foreach (var bodyPart in m_JdController.bodyPartsDict.Values)
// {
// CollectObservationBodyPart(bodyPart, sensor);
// }
// }
/// <summary>
/// Agent touched the target

bpDict[leg2Lower].SetJointStrength(vectorAction[++i]);
bpDict[leg3Lower].SetJointStrength(vectorAction[++i]);
}
m_WalkDir = target.position - m_OrientationCube.transform.position;
m_WalkDir = target.position - orientationCube.transform.position;
m_OrientationCube.transform.position = body.position;
m_OrientationCube.transform.rotation = m_WalkDirLookRot;
orientationCube.transform.position = body.position;
orientationCube.transform.rotation = m_WalkDirLookRot;
void FixedUpdate()
{
if (detectTargets)

TouchedTarget();
}
}
UpdateOrientationCube();
}

/// </summary>
void RewardFunctionMovingTowards()
{
m_MovingTowardsDot = Vector3.Dot(m_OrientationCube.transform.forward, m_JdController.bodyPartsDict[body].rb.velocity);
AddReward(0.03f * m_MovingTowardsDot);
var movingTowardsDot =
Vector3.Dot(orientationCube.transform.forward, m_JdController.bodyPartsDict[body].rb.velocity);
AddReward(0.03f * movingTowardsDot);
}
/// <summary>

{
AddReward(0.01f * Vector3.Dot(m_OrientationCube.transform.forward, body.forward));
AddReward(0.01f * Vector3.Dot(orientationCube.transform.forward, body.forward));
}
/// <summary>

{
bodyPart.Reset(bodyPart);
}
if (detectTargets && !targetIsStatic)
if (detectTargets && respawnTargetWhenTouched)
{
{
Gizmos.matrix = m_OrientationCube.transform.localToWorldMatrix;
Gizmos.DrawWireCube(Vector3.zero, m_OrientationCube.transform.localScale);
Gizmos.matrix = orientationCube.transform.localToWorldMatrix;
Gizmos.DrawWireCube(Vector3.zero, orientationCube.transform.localScale);
Gizmos.DrawRay(Vector3.zero, Vector3.forward);
}
}

2
Project/Assets/ML-Agents/Examples/SharedAssets/Prefabs/OrientationCube.prefab.meta


fileFormatVersion: 2
guid: 41960beaa3d8041e19d82b5160042e55
guid: 72f745913c5a34df5aaadd5c1f0024cb
PrefabImporter:
externalObjects: {}
userData:

6
Project/Assets/ML-Agents/Examples/Walker/Scripts/WalkerAgent.cs


Quaternion m_WalkDirLookRot; //Will hold the rotation to our target
[Header("Target To Walk Towards")] [Space(10)]
public float targetSpawnRadius; //The radius in which a target can be randomly spawned.
public Transform ground; //Ground gameobject. The height will be used for target spawning
public float targetSpawnRadius; //The radius in which a target can be randomly spawned.
public Transform ground; //Ground gameobject. The height will be used for target spawning
[Header("Body Parts")] [Space(10)] public Transform hips;
public Transform chest;

10
Project/Assets/ExpertWalkerDyn.demo.meta


fileFormatVersion: 2
guid: 48304968c270e4e998199f64b2a18b4e
ScriptedImporter:
fileIDToRecycleName:
11400000: Assets/ExpertWalkerDyn.demo
externalObjects: {}
userData: ' (Unity.MLAgents.Demonstrations.DemonstrationSummary)'
assetBundleName:
assetBundleVariant:
script: {fileID: 11500000, guid: 7bd65ce151aaa4a41a45312543c56be1, type: 3}

/Project/Assets/ML-Agents/Examples/SharedAssets/Resources/OrientationCube.prefab.meta → /Project/Assets/ML-Agents/Examples/SharedAssets/OrientationCube.prefab.meta

/Project/Assets/ML-Agents/Examples/SharedAssets/Resources/OrientationCube.prefab → /Project/Assets/ML-Agents/Examples/SharedAssets/OrientationCube.prefab

正在加载...
取消
保存