您最多选择25个主题
主题必须以中文或者字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
133 行
5.0 KiB
133 行
5.0 KiB
using NUnit.Framework;
|
|
using UnityEngine;
|
|
using System.IO.Abstractions.TestingHelpers;
|
|
using System.Reflection;
|
|
using MLAgents.CommunicatorObjects;
|
|
|
|
namespace MLAgents.Tests
|
|
{
|
|
public class DemonstrationTests : MonoBehaviour
|
|
{
|
|
const string k_DemoDirecory = "Assets/Demonstrations/";
|
|
const string k_ExtensionType = ".demo";
|
|
const string k_DemoName = "Test";
|
|
|
|
[Test]
|
|
public void TestSanitization()
|
|
{
|
|
const string dirtyString = "abc1234567&!@";
|
|
const string knownCleanString = "abc123";
|
|
var cleanString = DemonstrationRecorder.SanitizeName(dirtyString, 6);
|
|
Assert.AreNotEqual(dirtyString, cleanString);
|
|
Assert.AreEqual(cleanString, knownCleanString);
|
|
}
|
|
|
|
[Test]
|
|
public void TestStoreInitalize()
|
|
{
|
|
var fileSystem = new MockFileSystem();
|
|
var demoStore = new DemonstrationStore(fileSystem);
|
|
|
|
Assert.IsFalse(fileSystem.Directory.Exists(k_DemoDirecory));
|
|
|
|
var brainParameters = new BrainParameters
|
|
{
|
|
vectorObservationSize = 3,
|
|
numStackedVectorObservations = 2,
|
|
vectorActionDescriptions = new[] { "TestActionA", "TestActionB" },
|
|
vectorActionSize = new[] { 2, 2 },
|
|
vectorActionSpaceType = SpaceType.Discrete
|
|
};
|
|
|
|
demoStore.Initialize(k_DemoName, brainParameters, "TestBrain");
|
|
|
|
Assert.IsTrue(fileSystem.Directory.Exists(k_DemoDirecory));
|
|
Assert.IsTrue(fileSystem.FileExists(k_DemoDirecory + k_DemoName + k_ExtensionType));
|
|
|
|
var agentInfo = new AgentInfo
|
|
{
|
|
reward = 1f,
|
|
actionMasks = new[] { false, true },
|
|
done = true,
|
|
id = 5,
|
|
maxStepReached = true,
|
|
storedVectorActions = new[] { 0f, 1f },
|
|
};
|
|
|
|
demoStore.Record(agentInfo);
|
|
demoStore.Close();
|
|
}
|
|
|
|
public class ObservationAgent : TestAgent
|
|
{
|
|
public override void CollectObservations()
|
|
{
|
|
collectObservationsCalls += 1;
|
|
AddVectorObs(1f);
|
|
AddVectorObs(2f);
|
|
AddVectorObs(3f);
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void TestAgentWrite()
|
|
{
|
|
var agentGo1 = new GameObject("TestAgent");
|
|
var bpA = agentGo1.AddComponent<BehaviorParameters>();
|
|
bpA.brainParameters.vectorObservationSize = 3;
|
|
bpA.brainParameters.numStackedVectorObservations = 1;
|
|
bpA.brainParameters.vectorActionDescriptions = new[] { "TestActionA", "TestActionB" };
|
|
bpA.brainParameters.vectorActionSize = new[] { 2, 2 };
|
|
bpA.brainParameters.vectorActionSpaceType = SpaceType.Discrete;
|
|
|
|
agentGo1.AddComponent<ObservationAgent>();
|
|
var agent1 = agentGo1.GetComponent<ObservationAgent>();
|
|
|
|
agentGo1.AddComponent<DemonstrationRecorder>();
|
|
var demoRecorder = agentGo1.GetComponent<DemonstrationRecorder>();
|
|
var fileSystem = new MockFileSystem();
|
|
demoRecorder.demonstrationName = "TestBrain";
|
|
demoRecorder.record = true;
|
|
demoRecorder.InitializeDemoStore(fileSystem);
|
|
|
|
var acaGo = new GameObject("TestAcademy");
|
|
acaGo.AddComponent<TestAcademy>();
|
|
var aca = acaGo.GetComponent<TestAcademy>();
|
|
aca.resetParameters = new ResetParameters();
|
|
|
|
var academyInitializeMethod = typeof(Academy).GetMethod("InitializeEnvironment",
|
|
BindingFlags.Instance | BindingFlags.NonPublic);
|
|
var agentEnableMethod = typeof(Agent).GetMethod("OnEnable",
|
|
BindingFlags.Instance | BindingFlags.NonPublic);
|
|
var agentSendInfo = typeof(Agent).GetMethod("SendInfo",
|
|
BindingFlags.Instance | BindingFlags.NonPublic);
|
|
|
|
agentEnableMethod?.Invoke(agent1, new object[] { });
|
|
academyInitializeMethod?.Invoke(aca, new object[] { });
|
|
|
|
// Step the agent
|
|
agent1.RequestDecision();
|
|
agentSendInfo?.Invoke(agent1, new object[] { });
|
|
|
|
demoRecorder.Close();
|
|
|
|
// Read back the demo file and make sure observations were written
|
|
var reader = fileSystem.File.OpenRead("Assets/Demonstrations/TestBrain.demo");
|
|
reader.Seek(DemonstrationStore.MetaDataBytes + 1, 0);
|
|
BrainParametersProto.Parser.ParseDelimitedFrom(reader);
|
|
|
|
var agentInfoProto = AgentInfoActionPairProto.Parser.ParseDelimitedFrom(reader).AgentInfo;
|
|
var obs = agentInfoProto.Observations[2]; // skip dummy sensors
|
|
{
|
|
var vecObs = obs.FloatData.Data;
|
|
Assert.AreEqual(bpA.brainParameters.vectorObservationSize, vecObs.Count);
|
|
for (var i = 0; i < vecObs.Count; i++)
|
|
{
|
|
Assert.AreEqual((float)i + 1, vecObs[i]);
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
}
|
|
}
|