Staging Area Disruption
Description
Attacking assembly areas where forces prepare for operations.
Lua Implementation
-- Task: Staging Area Disruption
-- Operation: Deep Strike/Interdiction (AIR DOMAIN)
-- Refactored to use TaskRunner
local TaskRunner = require("TaskRunner")
local config = {
subtasks = {"LocateStagingAreas", "MonitorActivity", "TimeStrike", "AssessDisruption"},
timeoutSeconds = 300,
flags = {
activateSensors = true,
captureTargetLocation = false,
enableParallelSensing = true,
requireAmmoForEngagement = true,
requireEngagementAuth = true,
enableAttackFallback = true,
sendStartReport = false,
sendFallbackReport = false,
requestSupport = true,
sendCompletionReport = false,
fallbackWaitSeconds = 30
}
}
return TaskRunner.create(config)
11 actions (clickable in blue)
16 predicates (clickable in green)
Behavior Tree
Open full view-
sequence TaskRoot
-
sequence PreChecks
-
conditional IsOperational cond: IsOperational
-
conditional HasFuel cond: HasFuel
-
conditional HasAmmo cond: HasAmmo
-
-
parallel SenseAndExecute
-
task ActivateSensors action: ActivateSensors
-
sequence Execution
-
selector EngageOrFallback
-
sequence EngagementSequence
-
conditional CanEngage cond: CanEngage
-
task EngageTarget action: EngageTarget
-
-
sequence FallbackSequence
-
send RequestSupport
-
task HoldPosition action: Wait
-
-
-
sequence SubtaskSequence
-
task LocateStagingAreas Subtask #194
-
task MonitorActivity Subtask #195
-
task TimeStrike Subtask #196
-
task AssessDisruption Subtask #197
-
-
-
-
Sub-task Records
-
LocateStagingAreas - Find enemy assembly positions
-- Subtask: LocateStagingAreas -- Parent Task: Staging Area Disruption -- Operation: Deep Strike/Interdiction (AIR DOMAIN) local subtaskState = { status = "PENDING", startTime = 0, data = {} } function execute(params) subtaskState.startTime = vrf.getSimulationTime() subtaskState.status = "EXECUTING" -- Basic operational checks if not IsOperational{} then return false, "Entity not operational" end -- Generic subtask execution AdjustSpeed{} EngageTarget{} ActivateSensors{} subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }} -
MonitorActivity - Track buildup patterns
-- Subtask: MonitorActivity -- Parent Task: Staging Area Disruption -- Operation: Deep Strike/Interdiction (AIR DOMAIN) local subtaskState = { status = "PENDING", startTime = 0, data = {} } function execute(params) subtaskState.startTime = vrf.getSimulationTime() subtaskState.status = "EXECUTING" -- Basic operational checks if not IsOperational{} then return false, "Entity not operational" end -- Sensing and detection ActivateSensors{} ScanSector{} TrackTarget{} -- Check for detections if IsHostile{} then subtaskState.data.target_detected = true return true, "Target detected" end subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }} -
TimeStrike - Attack during peak concentration
-- Subtask: TimeStrike -- Parent Task: Staging Area Disruption -- Operation: Deep Strike/Interdiction (AIR DOMAIN) local subtaskState = { status = "PENDING", startTime = 0, data = {} } function execute(params) subtaskState.startTime = vrf.getSimulationTime() subtaskState.status = "EXECUTING" -- Basic operational checks if not IsOperational{} then return false, "Entity not operational" end -- Combat execution -- Check engagement authority if not HasOrdersToEngage{} then return false, "No engagement authority" end EngageTarget{} FireWeapon{} SelectTarget{} -- Verify engagement success if HasAltitudeAdvantage{} then subtaskState.status = "COMPLETE" return true, "Engagement successful" end subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }} -
AssessDisruption - Evaluate delay achieved
-- Subtask: AssessDisruption -- Parent Task: Staging Area Disruption -- Operation: Deep Strike/Interdiction (AIR DOMAIN) local subtaskState = { status = "PENDING", startTime = 0, data = {} } function execute(params) subtaskState.startTime = vrf.getSimulationTime() subtaskState.status = "EXECUTING" -- Basic operational checks if not IsOperational{} then return false, "Entity not operational" end -- Electronic warfare ActivateJammer{} DeployCountermeasures{} SetJammingParameters{} subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }}
Parameters
No parameters defined yet.
Outputs
No outputs defined yet.
Manage Primitives
Actions (11)
- ActivateJammer
- ActivateSensors
- AdjustSpeed
- DeployCountermeasures
- EngageTarget
- FireWeapon
- ScanSector
- SelectTarget
- SetAltitude
- SetJammingParameters
- TrackTarget
Predicates (16)
- HasAltitudeAdvantage
- HasAmmo
- HasFuel
- HasLOS
- HasOrdersToEngage
- HasSensorContact
- HasWeaponSolution
- IsDetected
- IsHostile
- IsIdentified
- IsInRange
- IsMissionComplete
- IsOperational
- JammerActive
- ROEAllowsEngagement
- TargetJammed
Tip: Click on action/predicate names in the Lua code above to view their implementations.