您最多选择25个主题
主题必须以中文或者字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
69 行
1.8 KiB
69 行
1.8 KiB
using UnityEngine;
|
|
using Barracuda;
|
|
using System.Collections.Generic;
|
|
using MLAgents.InferenceBrain;
|
|
using System;
|
|
|
|
namespace MLAgents
|
|
{
|
|
/// <summary>
|
|
/// Where to perform inference.
|
|
/// </summary>
|
|
public enum InferenceDevice
|
|
{
|
|
/// <summary>
|
|
/// CPU inference
|
|
/// </summary>
|
|
CPU = 0,
|
|
|
|
/// <summary>
|
|
/// GPU inference
|
|
/// </summary>
|
|
GPU = 1
|
|
}
|
|
|
|
/// <summary>
|
|
/// The Barracuda Policy uses a Barracuda Model to make decisions at
|
|
/// every step. It uses a ModelRunner that is shared across all
|
|
/// Barracuda Policies that use the same model and inference devices.
|
|
/// </summary>
|
|
internal class BarracudaPolicy : IPolicy
|
|
{
|
|
protected ModelRunner m_ModelRunner;
|
|
|
|
int m_AgentId;
|
|
|
|
/// <summary>
|
|
/// Sensor shapes for the associated Agents. All Agents must have the same shapes for their Sensors.
|
|
/// </summary>
|
|
List<int[]> m_SensorShapes;
|
|
|
|
/// <inheritdoc />
|
|
public BarracudaPolicy(
|
|
BrainParameters brainParameters,
|
|
NNModel model,
|
|
InferenceDevice inferenceDevice)
|
|
{
|
|
var modelRunner = Academy.Instance.GetOrCreateModelRunner(model, brainParameters, inferenceDevice);
|
|
m_ModelRunner = modelRunner;
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public void RequestDecision(AgentInfo info, List<ISensor> sensors)
|
|
{
|
|
m_AgentId = info.episodeId;
|
|
m_ModelRunner?.PutObservations(info, sensors);
|
|
}
|
|
|
|
/// <inheritdoc />
|
|
public float[] DecideAction()
|
|
{
|
|
m_ModelRunner?.DecideBatch();
|
|
return m_ModelRunner?.GetAction(m_AgentId);
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
}
|
|
}
|
|
}
|