projection test for gallery space w/ chair using squeezed & gnomic projection.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

106 lines
3.6 KiB

using System;
using Unity.Mathematics;
using UnityEngine;
namespace Unity.MLAgents.Areas
{
/// <summary>
/// The Training Ares Replicator allows for a training area object group to be replicated dynamically during runtime.
/// </summary>
[DefaultExecutionOrder(-5)]
public class TrainingAreaReplicator : MonoBehaviour
{
/// <summary>
/// The base training area to be replicated.
/// </summary>
public GameObject baseArea;
/// <summary>
/// The number of training areas to replicate.
/// </summary>
public int numAreas = 1;
/// <summary>
/// The separation between each training area.
/// </summary>
public float separation = 10f;
int3 m_GridSize = new int3(1, 1, 1);
int m_areaCount = 0;
string m_TrainingAreaName;
/// <summary>
/// The size of the computed grid to pack the training areas into.
/// </summary>
public int3 GridSize => m_GridSize;
/// <summary>
/// The name of the training area.
/// </summary>
public string TrainingAreaName => m_TrainingAreaName;
/// <summary>
/// Called before the simulation begins to computed the grid size for distributing
/// the replicated training areas and set the area name.
/// </summary>
public void Awake()
{
// Computes the Grid Size on Awake
ComputeGridSize();
// Sets the TrainingArea name to the name of the base area.
m_TrainingAreaName = baseArea.name;
}
/// <summary>
/// Called after Awake and before the simulation begins and adds the training areas before
/// the Academy begins.
/// </summary>
public void OnEnable()
{
// Adds the training are replicas during OnEnable to ensure they are added before the Academy begins its work.
AddEnvironments();
}
/// <summary>
/// Computes the Grid Size for replicating the training area.
/// </summary>
void ComputeGridSize()
{
var rootNumAreas = Mathf.Pow(numAreas, 1.0f / 2.0f);
m_GridSize.x = Mathf.CeilToInt(rootNumAreas);
var zSize = Mathf.CeilToInt((float)numAreas / (m_GridSize.x * m_GridSize.y));
m_GridSize.z = zSize == 0 ? 1 : zSize;
}
/// <summary>
/// Adds replicas of the training area to the scene.
/// </summary>
/// <exception cref="UnityAgentsException"></exception>
void AddEnvironments()
{
if (numAreas > m_GridSize.x * m_GridSize.y * m_GridSize.z)
{
throw new UnityAgentsException("The number of training areas that you have specified exceeds the size of the grid.");
}
for (int z = 0; z < m_GridSize.z; z++)
{
for (int x = 0; x < m_GridSize.x; x++)
{
if (m_areaCount == 0)
{
// Skip this first area since it already exists.
m_areaCount = 1;
}
else if (m_areaCount < numAreas)
{
m_areaCount++;
var area = Instantiate(baseArea, new Vector3(x * separation, 0, z * separation), Quaternion.identity);
area.name = m_TrainingAreaName;
}
}
}
}
}
}