Improve the Simulation_Config_Guide

more-targets
Daniel Lovell 2024-09-24 17:45:37 -07:00
parent ded726be64
commit c543479ec1
1 changed files with 134 additions and 117 deletions

View File

@ -4,72 +4,87 @@ This guide provides instructions on how to configure the simulation by editing t
## Configuration Files ## Configuration Files
The main configuration files you will work with are: The main configuration files you will work with are located in the `Assets/StreamingAssets/Configs/` directory. In a deployment context, these files are located in the `micromissiles_Data/StreamingAssets/Configs/` directory.
- **Simulation Configurations**: - **Simulation Configurations**:
- JSON File: [`1_salvo_1_hydra_7_drones.json`](Assets/StreamingAssets/Configs/1_salvo_1_hydra_7_drones.json) - **`1_salvo_1_hydra_7_drones.json`**: A simple, barebones example of a simulation configuration featuring a single salvo in a 7-on-7 scenario.
- C# Script: [`SimulationConfig.cs`](Assets/Scripts/Config/SimulationConfig.cs) - **`3_salvo_10_hydra_200_drones.json`**: A more complex example with three salvos, illustrating a 210-on-200 scenario. This demonstrates how to set up multiple salvos within the simulation.
- **C# Script**: [`SimulationConfig.cs`](Assets/Scripts/Config/SimulationConfig.cs)
- **Model Configurations**: - **Model Configurations** (found in `Assets/StreamingAssets/Configs/Models/`):
- JSON File: [`micromissile.json`](Assets/StreamingAssets/Configs/Models/micromissile.json) - **`micromissile.json`**
- C# Script: [`StaticConfig.cs`](Assets/Scripts/Config/StaticConfig.cs) - **`hydra70.json`**
- **`drone_target.json`**
- **C# Script**: [`StaticConfig.cs`](Assets/Scripts/Config/StaticConfig.cs)
### File Locations ### File Locations
- **Simulation Configurations** are found in `Assets/StreamingAssets/Configs/`. Development context:
- **Model Configurations** are located in `Assets/StreamingAssets/Configs/Models/`. - **Simulation Configurations**: `Assets/StreamingAssets/Configs/`
- **Model Configurations**: `Assets/StreamingAssets/Configs/Models/`
## Simulation Configurations Deployment context:
- **Simulation Configurations**: `micromissiles_Data/StreamingAssets/Configs/`
- **Model Configurations**: `micromissiles_Data/StreamingAssets/Configs/Models/`
### Editing Simulation Configurations ## Overview of Simulation Configurations
### Simulation Configuration Examples
The simulation configurations are defined in JSON files that specify the initial setup for missiles and targets.
#### `1_salvo_1_hydra_7_drones.json` #### `1_salvo_1_hydra_7_drones.json`
This JSON file outlines the initial setup for missiles and targets. This is a basic configuration featuring a single salvo with one missile type (`HYDRA_70`) and seven target drones.
```json:Assets/StreamingAssets/Configs/1_salvo_1_hydra_7_drones.json ```json:Assets/StreamingAssets/Configs/1_salvo_1_hydra_7_drones.json
{ startLine: 1
"timeScale": 1, endLine: 51
"missile_swarm_configs": [
{
"num_agents": 1,
"agent_config": {
"missile_type": "HYDRA_70",
// Additional configurations...
}
}
],
"target_swarm_configs": [
{
"num_agents": 7,
"agent_config": {
"target_type": "DRONE",
// Additional configurations...
}
}
]
}
``` ```
#### `3_salvo_10_hydra_200_drones.json`
This configuration demonstrates a more complex scenario with three salvos, each launching ten `HYDRA_70` missiles at different times against 200 target drones. This results in a total of 210 missiles (including submunitions) engaging 200 targets.
```json:Assets/StreamingAssets/Configs/3_salvo_10_hydra_200_drones.json
startLine: 1
endLine: 100
```
**Key Differences Between the Examples**:
- **Number of Salvos**: The `3_salvo_10_hydra_200_drones.json` file includes multiple salvos by adding multiple entries in the `missile_swarm_configs` array, each with its own `launch_time`.
- **Scale of Engagement**: The second example scales up both the number of missiles and targets, demonstrating how to configure large-scale simulations.
**Achieving Multiple Salvos**:
Multiple salvos are achieved by:
- Adding multiple configurations in the `missile_swarm_configs` array.
- Specifying different `launch_time` values in the `dynamic_config` for each salvo to control when they launch.
### Key Configuration Parameters
- **`timeScale`**: Adjusts the speed of the simulation. - **`timeScale`**: Adjusts the speed of the simulation.
- **`missile_swarm_configs`**: Contains settings for missile swarms. - **`missile_swarm_configs`**: Contains settings for missile swarms. Each entry represents a salvo.
- **`target_swarm_configs`**: Contains settings for target swarms. - **`target_swarm_configs`**: Contains settings for target swarms.
#### Key Configuration Parameters #### Within Each Swarm Configuration
- **`num_agents`**: Number of agents (missiles or targets) in the swarm.
- **`agent_config`**: Settings for each agent, including:
- **`num_agents`**: Specifies how many agents (missiles or targets) are involved.
- **`agent_config`**: Contains settings for each agent, including:
- **`missile_type`** / **`target_type`**: Defines the type of missile or target. - **`missile_type`** / **`target_type`**: Defines the type of missile or target.
- **`initial_state`**: Sets the starting position, rotation, and velocity. - **`initial_state`**: Sets the starting position, rotation, and velocity.
- **`standard_deviation`**: Adds random noise to initial states. - **`standard_deviation`**: Adds random noise to initial states for variability.
- **`dynamic_config`**: Includes time-dependent settings like launch times and sensor configurations. - **`dynamic_config`**: Time-dependent settings like `launch_time` and sensor configurations.
- **`submunitions_config`**: Details for any submunitions used. - **`submunitions_config`**: Details for any submunitions (e.g., micromissiles deployed by a larger missile).
### Adding or Modifying Agents ### Adding or Modifying Agents
1. **Add a New Swarm Configuration**: 1. **Add a New Swarm Configuration**:
To introduce a new missile or target swarm, create a new entry in `missile_swarm_configs` or `target_swarm_configs`. To introduce a new missile or target swarm (or an additional salvo), create a new entry in `missile_swarm_configs` or `target_swarm_configs`.
```json ```json
{ {
@ -77,121 +92,122 @@ This JSON file outlines the initial setup for missiles and targets.
"agent_config": { "agent_config": {
"missile_type": "MICROMISSILE", "missile_type": "MICROMISSILE",
// Additional configurations... // Additional configurations...
"dynamic_config": {
"launch_config": { "launch_time": 15 },
// Other dynamic settings...
}
} }
} }
``` ```
- **`launch_time`** in `dynamic_config` controls when this swarm (or salvo) is deployed.
2. **Modify Existing Configurations**: 2. **Modify Existing Configurations**:
Change parameters like `num_agents`, `initial_state`, or `dynamic_config` to adjust the behavior of existing agents. Adjust parameters like `num_agents`, `initial_state`, or `dynamic_config` to change the behavior of existing agents or salvos.
### `SimulationConfig.cs`
This script defines the data structures used to interpret the JSON configuration files.
```csharp:Assets/Scripts/Config/SimulationConfig.cs
using System;
using System.Collections.Generic;
using UnityEngine;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
[Serializable]
public class SimulationConfig {
[Header("Simulation Settings")]
public float timeScale = 0.05f;
[Header("Missile Swarm Configurations")]
public List<SwarmConfig> missile_swarm_configs = new List<SwarmConfig>();
[Header("Target Swarm Configurations")]
public List<SwarmConfig> target_swarm_configs = new List<SwarmConfig>();
}
// Additional classes and enums...
```
- **Classes**:
- `SimulationConfig`: Contains all simulation settings.
- `SwarmConfig`: Represents a group of agents.
- `AgentConfig`: Configuration for individual agents.
- **Enums**:
- `MissileType`, `TargetType`, and `SensorType` define available types.
#### Editing Enums
To add new missile or target types, update the enums accordingly.
```csharp:Assets/Scripts/Config/SimulationConfig.cs
[JsonConverter(typeof(StringEnumConverter))]
public enum MissileType { HYDRA_70, MICROMISSILE, NEW_MISSILE_TYPE }
```
## Model Configurations ## Model Configurations
The model configurations define the physical and performance characteristics of missile and target models. The default models provided can be customized to suit your research needs.
### Available Models
The `Models` directory contains the following default model configurations:
- **`micromissile.json`**
- **`hydra70.json`**
- **`drone_target.json`**
These JSON files serve as templates and can be tweaked to modify the behavior of the corresponding models.
### Editing Model Configurations ### Editing Model Configurations
#### `micromissile.json` #### Example: `micromissile.json`
This file defines the physical and performance characteristics of the missile models. This file defines parameters for the micromissile model.
```json:Assets/StreamingAssets/Configs/Models/micromissile.json ```json:Assets/StreamingAssets/Configs/Models/micromissile.json
{ startLine: 1
"accelerationConfig": { endLine: 25
"maxReferenceAcceleration": 300,
"referenceSpeed": 1000
},
"boostConfig": {
"boostTime": 0.3,
"boostAcceleration": 350
},
// Additional configurations...
}
``` ```
- **`accelerationConfig`**: Parameters for acceleration. **Configurable Parameters**:
- **`boostConfig`**: Settings for the boost phase.
- **`accelerationConfig`**: Controls acceleration characteristics.
- **`boostConfig`**: Settings for the boost phase of the missile.
- **`liftDragConfig`**: Aerodynamic properties. - **`liftDragConfig`**: Aerodynamic properties.
- **`bodyConfig`**: Physical properties like mass and area. - **`bodyConfig`**: Physical attributes like mass and area.
- **`hitConfig`**: Collision and hit detection properties. - **`hitConfig`**: Collision detection and damage properties.
### Modifying Parameters ### Modifying Parameters
Adjust values to change the missile's behavior, such as increasing acceleration or changing mass. You can tweak the parameters in these model files to adjust performance. For example:
- **Increase Acceleration**: Modify `maxReferenceAcceleration` in `accelerationConfig`.
- **Change Mass**: Adjust the `mass` value in `bodyConfig`.
- **Alter Aerodynamics**: Tweak `liftCoefficient` and `dragCoefficient` in `liftDragConfig`.
### Adding New Models ### Adding New Models
To define a new missile or target model: To define a new missile or target model:
1. **Create a New JSON File** in `Assets/StreamingAssets/Configs/Models/`. 1. **Create a New JSON File** in `Assets/StreamingAssets/Configs/Models/`.
2. **Define Model Parameters** similar to `micromissile.json`.
3. **Update the Code** to recognize and load the new model. 2. **Define Model Parameters** similar to the existing model files.
3. **Update the Code** to recognize and load the new model if necessary.
**Note**: Ensure that any new parameters added to the model configuration are reflected in the corresponding C# classes.
## Relevant C# Scripts
### `SimulationConfig.cs`
This script defines the data structures used to interpret the JSON simulation configuration files.
```csharp:Assets/Scripts/Config/SimulationConfig.cs
startLine: 1
endLine: 112
```
**Classes**:
- `SimulationConfig`: Contains all simulation settings.
- `SwarmConfig`: Represents a group of agents (missiles or targets).
- `AgentConfig`: Configuration for individual agents.
**Enums**:
- `MissileType`, `TargetType`, and `SensorType` define available types.
#### Editing Enums
To add new missile or target types, update the enums accordingly:
```csharp:Assets/Scripts/Config/SimulationConfig.cs
startLine: 127
endLine: 129
```
### `StaticConfig.cs` ### `StaticConfig.cs`
This file defines classes corresponding to the model configuration JSON structure. This script defines the classes corresponding to the model configuration JSON structure.
```csharp:Assets/Scripts/Config/StaticConfig.cs ```csharp:Assets/Scripts/Config/StaticConfig.cs
using System; startLine: 1
endLine: 181
[Serializable]
public class StaticConfig {
// Nested classes for configuration parameters...
}
``` ```
#### Updating Classes **Updating Classes**:
If you add new parameters to the JSON model files, ensure the corresponding classes in `StaticConfig.cs` are updated. If you add new parameters to the JSON model files, ensure the corresponding classes in `StaticConfig.cs` are updated to include these new fields.
## Using the Deployment Build ## Using the Deployment Build
When using the deployment build: When using the deployment build:
- Ensure all required configuration files are included. - **Include Required Configuration Files**: Ensure all necessary JSON configuration files are present in the `StreamingAssets/Configs/` directory.
- Place simulation configuration files in the appropriate directory (`StreamingAssets/Configs/`). - **Adjust Simulations Without Rebuilding**: Modify the JSON files to change simulation parameters without needing to rebuild the application.
- Modify the JSON files to adjust the simulation without needing to rebuild the application.
--- ---
@ -204,4 +220,5 @@ For further assistance, refer to the comments and documentation within the code
--- ---
*This guide aims to help you set up and customize the simulation project effectively. If you encounter any issues or have questions, please reach out to the project maintainers.* *This guide aims to help you set up and customize the simulation project effectively. If you encounter any issues or have questions, please reach out to the project maintainers.*
```