Hasty Attack Execution
Description
Quick attack with minimal preparation to maintain momentum.
Lua Implementation
-- Task: Hasty Attack Execution
-- Operation: Offensive Operations (LAND DOMAIN)
-- Refactored to use TaskRunner
local TaskRunner = require("TaskRunner")
local config = {
subtasks = {"QuickAssessment", "IssueFragO", "CoordinateFires", "ExecuteAttack"},
timeoutSeconds = 300,
flags = {
activateSensors = false,
captureTargetLocation = false,
enableParallelSensing = false,
requireAmmoForEngagement = true,
requireEngagementAuth = true,
enableAttackFallback = true,
sendStartReport = false,
sendFallbackReport = false,
requestSupport = true,
sendCompletionReport = false,
fallbackWaitSeconds = 30
}
}
return TaskRunner.create(config)
3 actions (clickable in blue)
10 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
-
-
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 QuickAssessment Subtask #432
-
task IssueFragO Subtask #433
-
task CoordinateFires Subtask #434
-
task ExecuteAttack Subtask #435
-
-
-
Sub-task Records
-
QuickAssessment - Rapid enemy evaluation
-- Subtask: QuickAssessment -- Parent Task: Hasty Attack Execution -- Operation: Offensive Operations (LAND 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 -- Assessment and verification -- Verify results if HasWeaponSolution{} then return true, "Assessment complete" end subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }} -
IssueFragO - Brief orders on the move
-- Subtask: IssueFragO -- Parent Task: Hasty Attack Execution -- Operation: Offensive Operations (LAND 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 EngageTarget{} subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }} -
CoordinateFires - Arrange immediate support
-- Subtask: CoordinateFires -- Parent Task: Hasty Attack Execution -- Operation: Offensive Operations (LAND 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 HasWeaponSolution{} then subtaskState.status = "COMPLETE" return true, "Engagement successful" end subtaskState.status = "COMPLETE" return true, "Subtask completed successfully" end return {{ execute = execute }} -
ExecuteAttack - Launch with available forces
-- Subtask: ExecuteAttack -- Parent Task: Hasty Attack Execution -- Operation: Offensive Operations (LAND 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 HasWeaponSolution{} then subtaskState.status = "COMPLETE" return true, "Engagement successful" end 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 (3)
- EngageTarget
- FireWeapon
- SelectTarget
Predicates (10)
- HasAmmo
- HasFuel
- HasLOS
- HasOrdersToEngage
- HasWeaponSolution
- IsHostile
- IsInRange
- IsMissionComplete
- IsOperational
- ROEAllowsEngagement
Tip: Click on action/predicate names in the Lua code above to view their implementations.