Documentation ¶
Overview ¶
Proto-based function interface for the simulator
Functions for creating common types of auras.
Index ¶
- Constants
- Variables
- func APLRotationFromJsonString(jsonString string) *proto.APLRotation
- func AddPresetEncounter(name string, targetPaths []string)
- func AddPresetTarget(newPreset *PresetTarget)
- func AddWeaponEffect(id int32, weaponEffect ApplyWeaponEffect)
- func ApplyFixedUptimeAura(aura *Aura, uptime float64, tickLength time.Duration, startTime time.Duration)
- func ApplyInspiration(character *Character, uptime float64)
- func ApplyPetConsumeEffects(pet *Character, ownerConsumes *proto.Consumes)
- func ApplyProcTriggerCallback(unit *Unit, aura *Aura, config ProcTrigger)
- func BlessingOfSanctuaryAura(character *Character)
- func BothTimersReady(t1 *Timer, t2 *Timer, sim *Simulation) bool
- func BothTimersReadyAt(t1 *Timer, t2 *Timer) time.Duration
- func BulkSim(ctx context.Context, request *proto.BulkSimRequest, ...) *proto.BulkSimResult
- func CharacterStatsTest(label string, t *testing.T, raid *proto.Raid, expectedStats stats.Stats)
- func ComputeStats(csr *proto.ComputeStatsRequest) *proto.ComputeStatsResult
- func DurationFromSeconds(numSeconds float64) time.Duration
- func Each[T any](src []T, f func(T))
- func EquipmentSpecFromJsonString(jsonString string) *proto.EquipmentSpec
- func FillTalentsProto(data protoreflect.Message, talentsStr string, treeSizes [3]int)
- func FilterMap[K comparable, V any](src map[K]V, f func(K, V) bool) map[K]V
- func FilterSlice[T any](src []T, f func(T) bool) []T
- func Flatten[T any](src [][]T) []T
- func GetPrimaryTalentTreeIndex(talentStr string) uint8
- func GetSchoolResistanceStats(schoolIndex stats.SchoolIndex) []stats.Stat
- func GetTristateValueFloat(effect proto.TristateEffect, regularValue float64, impValue float64) float64
- func GetTristateValueInt32(effect proto.TristateEffect, regularValue int32, impValue int32) int32
- func GetWeaponSkill(unit *Unit, weapon *Item) float64
- func HasEnchantEffect(id int32) bool
- func HasItemEffect(id int32) bool
- func HasItemEffectForTest(id int32) bool
- func HasWeaponEffect(id int32) bool
- func InnervateManaThreshold(character *Character) float64
- func ItemTypeToSlot(it proto.ItemType) proto.ItemSlot
- func MakeSingleTargetEncounter(playerLevel int32, variation float64) *proto.Encounter
- func MakeTristateValue(hasRegular bool, hasImproved bool) proto.TristateEffect
- func MapMap[KI comparable, VI any, KO comparable, VO any](src map[KI]VI, f func(KI, VI) (KO, VO)) map[KO]VO
- func MapSlice[I any, O any](src []I, f func(I) O) []O
- func MaxTimeToReady(t1 *Timer, t2 *Timer, sim *Simulation) time.Duration
- func ModNonMeleeAttackTable(table *AttackTable, attacker *Unit, defender *Unit, weapon *Item)
- func MultiSchoolShouldUseArmor(schoolIndex stats.SchoolIndex, target *Unit) bool
- func NewDefaultTarget(playerLevel int32) *proto.Target
- func NewEnchantEffect(id int32, enchantEffect ApplyEffect)
- func NewItemEffect(id int32, itemEffect ApplyEffect)
- func NewSimpleStatDefensiveTrinketEffect(itemID int32, bonus stats.Stats, duration time.Duration, ...)
- func NewSimpleStatItemActiveEffect(itemID int32, bonus stats.Stats, duration time.Duration, ...)
- func NewSimpleStatItemEffect(itemID int32, bonus stats.Stats, duration time.Duration, ...)
- func NewSimpleStatOffensiveTrinketEffect(itemID int32, bonus stats.Stats, duration time.Duration, ...)
- func NewSimpleStatOffensiveTrinketEffectWithOtherEffects(itemID int32, bonus stats.Stats, duration time.Duration, ...)
- func PlayerProtoToSpec(player *proto.Player) proto.Spec
- func RaidBenchmark(b *testing.B, rsr *proto.RaidSimRequest)
- func RaidPlayersWithClass(raid *proto.Raid, class proto.Class) []*proto.Player
- func RaidSimTest(label string, t *testing.T, rsr *proto.RaidSimRequest, expectedDps float64)
- func RegisterAgentFactory(emptyOptions interface{}, spec proto.Spec, factory AgentFactory, ...)
- func RegisterTemporaryStatsOnUseCD(character *Character, auraLabel string, tempStats stats.Stats, ...)
- func RunBulkSim(request *proto.BulkSimRequest) *proto.BulkSimResult
- func RunBulkSimAsync(ctx context.Context, request *proto.BulkSimRequest, ...)
- func RunRaidSim(request *proto.RaidSimRequest) *proto.RaidSimResult
- func RunRaidSimAsync(request *proto.RaidSimRequest, progress chan *proto.ProgressMetrics)
- func RunSim(rsr *proto.RaidSimRequest, progress chan *proto.ProgressMetrics) *proto.RaidSimResult
- func RunTestSuite(t *testing.T, suiteName string, generators []TestGenerator)
- func ScheduledMajorArmorAura(aura *Aura, options PeriodicActionOptions, raid *proto.Raid)
- func SinglePlayerRaidProto(player *proto.Player, partyBuffs *proto.PartyBuffs, raidBuffs *proto.RaidBuffs, ...) *proto.Raid
- func StatWeights(request *proto.StatWeightsRequest) *proto.StatWeightsResult
- func StatWeightsAsync(request *proto.StatWeightsRequest, progress chan *proto.ProgressMetrics)
- func StatWeightsTest(label string, t *testing.T, _swr *proto.StatWeightsRequest, ...)
- func Ternary[T any](condition bool, val1 T, val2 T) T
- func TernaryDuration(condition bool, val1 time.Duration, val2 time.Duration) time.Duration
- func TernaryFloat64(condition bool, val1 float64, val2 float64) float64
- func TernaryInt(condition bool, val1 int, val2 int) int
- func TernaryInt32(condition bool, val1 int32, val2 int32) int32
- func UnitLevelFloat64(unitLevel int32, maxLevelPlus0Val float64, maxLevelPlus1Val float64, ...) float64
- func WithSpec(player *proto.Player, spec interface{}) *proto.Player
- func WithinToleranceFloat64(expectedValue float64, actualValue float64, tolerance float64) bool
- type AIFactory
- type APLAction
- func (action *APLAction) Execute(sim *Simulation)
- func (action *APLAction) Finalize(rot *APLRotation)
- func (action *APLAction) GetAllAPLValues() []APLValue
- func (action *APLAction) GetAllActions() []*APLAction
- func (action *APLAction) GetAllSpells() []*Spell
- func (action *APLAction) IsReady(sim *Simulation) bool
- func (action *APLAction) String() string
- type APLActionActivateAura
- func (action *APLActionActivateAura) Execute(sim *Simulation)
- func (impl APLActionActivateAura) Finalize(*APLRotation)
- func (impl APLActionActivateAura) GetAPLValues() []APLValue
- func (impl APLActionActivateAura) GetInnerActions() []*APLAction
- func (impl APLActionActivateAura) GetNextAction(*Simulation) *APLAction
- func (action *APLActionActivateAura) IsReady(sim *Simulation) bool
- func (impl APLActionActivateAura) Reset(*Simulation)
- func (action *APLActionActivateAura) String() string
- type APLActionAutocastOtherCooldowns
- func (action *APLActionAutocastOtherCooldowns) Execute(sim *Simulation)
- func (impl APLActionAutocastOtherCooldowns) Finalize(*APLRotation)
- func (impl APLActionAutocastOtherCooldowns) GetAPLValues() []APLValue
- func (impl APLActionAutocastOtherCooldowns) GetInnerActions() []*APLAction
- func (impl APLActionAutocastOtherCooldowns) GetNextAction(*Simulation) *APLAction
- func (action *APLActionAutocastOtherCooldowns) IsReady(sim *Simulation) bool
- func (action *APLActionAutocastOtherCooldowns) Reset(*Simulation)
- func (action *APLActionAutocastOtherCooldowns) String() string
- type APLActionCancelAura
- func (action *APLActionCancelAura) Execute(sim *Simulation)
- func (impl APLActionCancelAura) Finalize(*APLRotation)
- func (impl APLActionCancelAura) GetAPLValues() []APLValue
- func (impl APLActionCancelAura) GetInnerActions() []*APLAction
- func (impl APLActionCancelAura) GetNextAction(*Simulation) *APLAction
- func (action *APLActionCancelAura) IsReady(sim *Simulation) bool
- func (impl APLActionCancelAura) Reset(*Simulation)
- func (action *APLActionCancelAura) String() string
- type APLActionCastSpell
- func (action *APLActionCastSpell) Execute(sim *Simulation)
- func (impl APLActionCastSpell) Finalize(*APLRotation)
- func (impl APLActionCastSpell) GetAPLValues() []APLValue
- func (impl APLActionCastSpell) GetInnerActions() []*APLAction
- func (impl APLActionCastSpell) GetNextAction(*Simulation) *APLAction
- func (action *APLActionCastSpell) IsReady(sim *Simulation) bool
- func (impl APLActionCastSpell) Reset(*Simulation)
- func (action *APLActionCastSpell) String() string
- type APLActionChangeTarget
- func (action *APLActionChangeTarget) Execute(sim *Simulation)
- func (impl APLActionChangeTarget) Finalize(*APLRotation)
- func (impl APLActionChangeTarget) GetAPLValues() []APLValue
- func (impl APLActionChangeTarget) GetInnerActions() []*APLAction
- func (impl APLActionChangeTarget) GetNextAction(*Simulation) *APLAction
- func (action *APLActionChangeTarget) IsReady(sim *Simulation) bool
- func (impl APLActionChangeTarget) Reset(*Simulation)
- func (action *APLActionChangeTarget) String() string
- type APLActionChannelSpell
- func (action *APLActionChannelSpell) Execute(sim *Simulation)
- func (impl APLActionChannelSpell) Finalize(*APLRotation)
- func (action *APLActionChannelSpell) GetAPLValues() []APLValue
- func (impl APLActionChannelSpell) GetInnerActions() []*APLAction
- func (impl APLActionChannelSpell) GetNextAction(*Simulation) *APLAction
- func (action *APLActionChannelSpell) IsReady(sim *Simulation) bool
- func (impl APLActionChannelSpell) Reset(*Simulation)
- func (action *APLActionChannelSpell) String() string
- type APLActionCustomRotation
- func (action *APLActionCustomRotation) Execute(sim *Simulation)
- func (impl APLActionCustomRotation) Finalize(*APLRotation)
- func (impl APLActionCustomRotation) GetAPLValues() []APLValue
- func (impl APLActionCustomRotation) GetInnerActions() []*APLAction
- func (impl APLActionCustomRotation) GetNextAction(*Simulation) *APLAction
- func (action *APLActionCustomRotation) IsReady(sim *Simulation) bool
- func (action *APLActionCustomRotation) Reset(sim *Simulation)
- func (action *APLActionCustomRotation) String() string
- type APLActionImpl
- type APLActionItemSwap
- func (action *APLActionItemSwap) Execute(sim *Simulation)
- func (impl APLActionItemSwap) Finalize(*APLRotation)
- func (impl APLActionItemSwap) GetAPLValues() []APLValue
- func (impl APLActionItemSwap) GetInnerActions() []*APLAction
- func (impl APLActionItemSwap) GetNextAction(*Simulation) *APLAction
- func (action *APLActionItemSwap) IsReady(sim *Simulation) bool
- func (impl APLActionItemSwap) Reset(*Simulation)
- func (action *APLActionItemSwap) String() string
- type APLActionMove
- func (action *APLActionMove) Execute(sim *Simulation)
- func (impl APLActionMove) Finalize(*APLRotation)
- func (impl APLActionMove) GetAPLValues() []APLValue
- func (impl APLActionMove) GetInnerActions() []*APLAction
- func (impl APLActionMove) GetNextAction(*Simulation) *APLAction
- func (action *APLActionMove) IsReady(sim *Simulation) bool
- func (impl APLActionMove) Reset(*Simulation)
- func (action *APLActionMove) String() string
- type APLActionMultidot
- func (action *APLActionMultidot) Execute(sim *Simulation)
- func (impl APLActionMultidot) Finalize(*APLRotation)
- func (action *APLActionMultidot) GetAPLValues() []APLValue
- func (impl APLActionMultidot) GetInnerActions() []*APLAction
- func (impl APLActionMultidot) GetNextAction(*Simulation) *APLAction
- func (action *APLActionMultidot) IsReady(sim *Simulation) bool
- func (action *APLActionMultidot) Reset(*Simulation)
- func (action *APLActionMultidot) String() string
- type APLActionMultishield
- func (action *APLActionMultishield) Execute(sim *Simulation)
- func (impl APLActionMultishield) Finalize(*APLRotation)
- func (action *APLActionMultishield) GetAPLValues() []APLValue
- func (impl APLActionMultishield) GetInnerActions() []*APLAction
- func (impl APLActionMultishield) GetNextAction(*Simulation) *APLAction
- func (action *APLActionMultishield) IsReady(sim *Simulation) bool
- func (action *APLActionMultishield) Reset(*Simulation)
- func (action *APLActionMultishield) String() string
- type APLActionResetSequence
- func (action *APLActionResetSequence) Execute(sim *Simulation)
- func (action *APLActionResetSequence) Finalize(rot *APLRotation)
- func (impl APLActionResetSequence) GetAPLValues() []APLValue
- func (impl APLActionResetSequence) GetInnerActions() []*APLAction
- func (impl APLActionResetSequence) GetNextAction(*Simulation) *APLAction
- func (action *APLActionResetSequence) IsReady(sim *Simulation) bool
- func (impl APLActionResetSequence) Reset(*Simulation)
- func (action *APLActionResetSequence) String() string
- type APLActionSchedule
- func (action *APLActionSchedule) Execute(sim *Simulation)
- func (impl APLActionSchedule) Finalize(*APLRotation)
- func (impl APLActionSchedule) GetAPLValues() []APLValue
- func (action *APLActionSchedule) GetInnerActions() []*APLAction
- func (impl APLActionSchedule) GetNextAction(*Simulation) *APLAction
- func (action *APLActionSchedule) IsReady(sim *Simulation) bool
- func (action *APLActionSchedule) Reset(*Simulation)
- func (action *APLActionSchedule) String() string
- type APLActionSequence
- func (action *APLActionSequence) Execute(sim *Simulation)
- func (action *APLActionSequence) Finalize(rot *APLRotation)
- func (impl APLActionSequence) GetAPLValues() []APLValue
- func (action *APLActionSequence) GetInnerActions() []*APLAction
- func (impl APLActionSequence) GetNextAction(*Simulation) *APLAction
- func (action *APLActionSequence) IsReady(sim *Simulation) bool
- func (action *APLActionSequence) Reset(*Simulation)
- func (action *APLActionSequence) String() string
- type APLActionStrictSequence
- func (action *APLActionStrictSequence) Execute(sim *Simulation)
- func (action *APLActionStrictSequence) Finalize(rot *APLRotation)
- func (impl APLActionStrictSequence) GetAPLValues() []APLValue
- func (action *APLActionStrictSequence) GetInnerActions() []*APLAction
- func (action *APLActionStrictSequence) GetNextAction(sim *Simulation) *APLAction
- func (action *APLActionStrictSequence) IsReady(sim *Simulation) bool
- func (action *APLActionStrictSequence) Reset(*Simulation)
- func (action *APLActionStrictSequence) String() string
- type APLActionTriggerICD
- func (action *APLActionTriggerICD) Execute(sim *Simulation)
- func (impl APLActionTriggerICD) Finalize(*APLRotation)
- func (impl APLActionTriggerICD) GetAPLValues() []APLValue
- func (impl APLActionTriggerICD) GetInnerActions() []*APLAction
- func (impl APLActionTriggerICD) GetNextAction(*Simulation) *APLAction
- func (action *APLActionTriggerICD) IsReady(sim *Simulation) bool
- func (impl APLActionTriggerICD) Reset(*Simulation)
- func (action *APLActionTriggerICD) String() string
- type APLActionWait
- func (action *APLActionWait) Execute(sim *Simulation)
- func (impl APLActionWait) Finalize(*APLRotation)
- func (action *APLActionWait) GetAPLValues() []APLValue
- func (impl APLActionWait) GetInnerActions() []*APLAction
- func (action *APLActionWait) GetNextAction(sim *Simulation) *APLAction
- func (action *APLActionWait) IsReady(sim *Simulation) bool
- func (impl APLActionWait) Reset(*Simulation)
- func (action *APLActionWait) String() string
- type APLActionWaitUntil
- func (action *APLActionWaitUntil) Execute(sim *Simulation)
- func (impl APLActionWaitUntil) Finalize(*APLRotation)
- func (action *APLActionWaitUntil) GetAPLValues() []APLValue
- func (impl APLActionWaitUntil) GetInnerActions() []*APLAction
- func (action *APLActionWaitUntil) GetNextAction(sim *Simulation) *APLAction
- func (action *APLActionWaitUntil) IsReady(sim *Simulation) bool
- func (impl APLActionWaitUntil) Reset(*Simulation)
- func (action *APLActionWaitUntil) String() string
- type APLRotation
- func (apl *APLRotation) DoNextAction(sim *Simulation)
- func (rot *APLRotation) GetAPLAura(sourceUnit UnitReference, auraId *proto.ActionID) AuraReference
- func (rot *APLRotation) GetAPLDot(targetUnit UnitReference, spellId *proto.ActionID) *Dot
- func (rot *APLRotation) GetAPLICDAura(sourceUnit UnitReference, auraId *proto.ActionID) AuraReference
- func (rot *APLRotation) GetAPLMultidotSpell(spellId *proto.ActionID) *Spell
- func (rot *APLRotation) GetAPLMultishieldSpell(spellId *proto.ActionID) *Spell
- func (rot *APLRotation) GetAPLSpell(spellId *proto.ActionID) *Spell
- func (rot *APLRotation) GetSourceUnit(ref *proto.UnitReference) UnitReference
- func (rot *APLRotation) GetTargetUnit(ref *proto.UnitReference) UnitReference
- func (rot *APLRotation) ValidationWarning(message string, vals ...interface{})
- type APLValue
- type APLValueAnd
- type APLValueAuraICDIsReadyWithReactionTime
- type APLValueAuraInternalCooldown
- type APLValueAuraIsActive
- type APLValueAuraIsActiveWithReactionTime
- type APLValueAuraNumStacks
- type APLValueAuraRemainingTime
- type APLValueAuraShouldRefresh
- type APLValueAutoSwingTime
- type APLValueAutoTimeToNext
- type APLValueChannelClipDelay
- type APLValueCoerced
- func (value *APLValueCoerced) GetBool(sim *Simulation) bool
- func (value APLValueCoerced) GetDuration(sim *Simulation) time.Duration
- func (value APLValueCoerced) GetFloat(sim *Simulation) float64
- func (value *APLValueCoerced) GetInnerValues() []APLValue
- func (value APLValueCoerced) GetInt(sim *Simulation) int32
- func (value APLValueCoerced) GetString(sim *Simulation) string
- func (value *APLValueCoerced) String() string
- func (value *APLValueCoerced) Type() proto.APLValueType
- type APLValueCompare
- type APLValueConst
- func (value *APLValueConst) GetBool(_ *Simulation) bool
- func (value *APLValueConst) GetDuration(_ *Simulation) time.Duration
- func (value *APLValueConst) GetFloat(_ *Simulation) float64
- func (value *APLValueConst) GetInt(_ *Simulation) int32
- func (value *APLValueConst) GetString(_ *Simulation) string
- func (value *APLValueConst) String() string
- func (value *APLValueConst) Type() proto.APLValueType
- type APLValueCurrentComboPoints
- type APLValueCurrentEnergy
- type APLValueCurrentHealth
- type APLValueCurrentHealthPercent
- type APLValueCurrentMana
- type APLValueCurrentManaPercent
- type APLValueCurrentRage
- type APLValueCurrentTime
- type APLValueCurrentTimePercent
- type APLValueDotIsActive
- type APLValueDotRemainingTime
- type APLValueFrontOfTarget
- type APLValueGCDIsReady
- type APLValueGCDTimeToReady
- type APLValueIsExecutePhase
- type APLValueMath
- func (value *APLValueMath) GetDuration(sim *Simulation) time.Duration
- func (value *APLValueMath) GetFloat(sim *Simulation) float64
- func (value *APLValueMath) GetInnerValues() []APLValue
- func (value *APLValueMath) GetInt(sim *Simulation) int32
- func (value *APLValueMath) String() string
- func (value *APLValueMath) Type() proto.APLValueType
- type APLValueMax
- func (value *APLValueMax) GetDuration(sim *Simulation) time.Duration
- func (value *APLValueMax) GetFloat(sim *Simulation) float64
- func (value *APLValueMax) GetInnerValues() []APLValue
- func (value *APLValueMax) GetInt(sim *Simulation) int32
- func (value *APLValueMax) String() string
- func (value *APLValueMax) Type() proto.APLValueType
- type APLValueMin
- func (value *APLValueMin) GetDuration(sim *Simulation) time.Duration
- func (value *APLValueMin) GetFloat(sim *Simulation) float64
- func (value *APLValueMin) GetInnerValues() []APLValue
- func (value *APLValueMin) GetInt(sim *Simulation) int32
- func (value *APLValueMin) String() string
- func (value *APLValueMin) Type() proto.APLValueType
- type APLValueNot
- type APLValueNumberTargets
- type APLValueOr
- type APLValueRemainingTime
- type APLValueRemainingTimePercent
- type APLValueSequenceIsComplete
- type APLValueSequenceIsReady
- type APLValueSequenceTimeToReady
- type APLValueSpellCPM
- type APLValueSpellCanCast
- type APLValueSpellCastTime
- type APLValueSpellChanneledTicks
- type APLValueSpellCurrentCost
- type APLValueSpellIsChanneling
- type APLValueSpellIsReady
- type APLValueSpellTimeToReady
- type APLValueSpellTravelTime
- type APLValueTimeToEnergyTick
- type ActionID
- func (actionID ActionID) IsEmptyAction() bool
- func (actionID ActionID) IsItemAction(itemID int32) bool
- func (actionID ActionID) IsOtherAction(otherID proto.OtherAction) bool
- func (actionID ActionID) IsSpellAction(spellID int32) bool
- func (actionID ActionID) SameAction(other ActionID) bool
- func (actionID ActionID) SameActionIgnoreTag(other ActionID) bool
- func (actionID ActionID) String() string
- func (actionID ActionID) ToProto() *proto.ActionID
- func (actionID ActionID) WithTag(tag int32) ActionID
- type ActionMetrics
- type ActionPriority
- type ActiveSetBonus
- type Agent
- type AgentFactory
- type ApplyEffect
- type ApplySpellResults
- type ApplyWeaponEffect
- type AttackTable
- type Aura
- func AncientCorrosivePoisonAura(target *Unit) *Aura
- func ApplyWildStrikes(character *Character) *Aura
- func ApplyWindfury(character *Character) *Aura
- func BattleShoutAura(unit *Unit, impBattleShout int32, boomingVoicePts int32) *Aura
- func BlessingOfMightAura(unit *Unit, impBomPts int32, level int32) *Aura
- func BloodlustAura(character *Character, actionTag int32) *Aura
- func CommandingShoutAura(unit *Unit, commandingPresencePts int32, boomingVoicePts int32) *Aura
- func CrystalYieldAura(target *Unit) *Aura
- func CurseOfElementsAura(target *Unit, playerLevel int32) *Aura
- func CurseOfRecklessnessAura(target *Unit, playerLevel int32) *Aura
- func CurseOfShadowAura(target *Unit, playerLevel int32) *Aura
- func CurseOfVulnerabilityAura(target *Unit) *Aura
- func CurseOfWeaknessAura(target *Unit, points int32, playerLevel int32) *Aura
- func DemonicPactAura(unit *Unit, spellpower float64) *Aura
- func DemoralizingRoarAura(target *Unit, points int32, playerLevel int32) *Aura
- func DemoralizingShoutAura(target *Unit, boomingVoicePts int32, impDemoShoutPts int32, playerLevel int32) *Aura
- func DragonBreathChiliAura(character *Character) *Aura
- func DreamstateAura(unit *Unit) *Aura
- func ExposeArmorAura(target *Unit, improvedEA int32, playerLevel int32) *Aura
- func FaerieFireAura(target *Unit, playerLevel int32) *Aura
- func GiftOfArthasAura(target *Unit) *Aura
- func GraceOfAirTotemAura(unit *Unit, level int32, multiplier float64) *Aura
- func GuardianSpiritAura(character *Character, actionTag int32) *Aura
- func HandOfSacrificeAura(character *Character, actionTag int32) *Aura
- func HemorrhageAura(target *Unit, casterLevel int32) *Aura
- func HomunculiArmorAura(target *Unit, playerLevel int32) *Aura
- func HomunculiAttackPowerAura(target *Unit, playerLevel int32) *Aura
- func HomunculiAttackSpeedAura(target *Unit, playerLevel int32) *Aura
- func HuntersMarkAura(target *Unit, points int32, playerLevel int32) *Aura
- func ImprovedScorchAura(target *Unit) *Aura
- func ImprovedShadowBoltAura(unit *Unit, rank int32) *Aura
- func InnervateAura(character *Character, actionTag int32) *Aura
- func InsectSwarmAura(target *Unit) *Aura
- func InspirationAura(unit *Unit, points int32) *Aura
- func JudgementOfLightAura(target *Unit) *Aura
- func JudgementOfWisdomAura(target *Unit, level int32) *Aura
- func MakePermanent(aura *Aura) *Aura
- func MakeProcTriggerAura(unit *Unit, config ProcTrigger) *Aura
- func MakeStackingAura(character *Character, config StackingStatAura) *Aura
- func ManaTideTotemAura(character *Character, actionTag int32) *Aura
- func MangleAura(target *Unit, playerLevel int32) *Aura
- func MekkatorqueFistDebuffAura(target *Unit, playerLevel int32) *Aura
- func PainSuppressionAura(character *Character, actionTag int32) *Aura
- func PowerInfusionAura(character *Unit, actionTag int32) *Aura
- func RetributionAura(character *Character, sanctifiedRetribution bool) *Aura
- func ScorpidStingAura(target *Unit) *Aura
- func ShadowWeavingAura(unit *Unit, rank int) *Aura
- func StormstrikeAura(unit *Unit) *Aura
- func StrengthOfEarthTotemAura(unit *Unit, level int32, multiplier float64) *Aura
- func SunderArmorAura(target *Unit, playerLevel int32) *Aura
- func ThornsAura(character *Character, points int32) *Aura
- func ThunderClapAura(target *Unit, spellID int32, duration time.Duration, ...) *Aura
- func TricksOfTheTradeAura(character *Unit, actionTag int32) *Aura
- func VindicationAura(target *Unit, points int32, playerLevel int32) *Aura
- func WaylayAura(target *Unit) *Aura
- func WintersChillAura(target *Unit, startingStacks int32) *Aura
- func (aura *Aura) Activate(sim *Simulation)
- func (aura *Aura) AddStack(sim *Simulation)
- func (aura *Aura) AddStacks(sim *Simulation, numStacks int32)
- func (aura *Aura) ApplyOnExpire(newOnExpire OnExpire)
- func (aura *Aura) ApplyOnGain(newOnGain OnGain)
- func (aura *Aura) Deactivate(sim *Simulation)
- func (aura *Aura) ExpiresAt() time.Duration
- func (aura *Aura) GetStacks() int32
- func (aura *Aura) IsActive() bool
- func (aura *Aura) NewExclusiveEffect(categoryName string, singleAura bool, config ExclusiveEffect) *ExclusiveEffect
- func (aura *Aura) Refresh(sim *Simulation)
- func (aura *Aura) RemainingDuration(sim *Simulation) time.Duration
- func (aura *Aura) RemoveStack(sim *Simulation)
- func (aura *Aura) SetStacks(sim *Simulation, newStacks int32)
- func (aura *Aura) ShouldRefreshExclusiveEffects(sim *Simulation, refreshWindow time.Duration) bool
- func (aura *Aura) StartedAt() time.Duration
- func (aura *Aura) TimeActive(sim *Simulation) time.Duration
- func (aura *Aura) UpdateExpires(sim *Simulation, newExpires time.Duration)
- type AuraArray
- type AuraCallback
- type AuraFactory
- type AuraMetrics
- type AuraReference
- type AutoAttackOptions
- type AutoAttacks
- func (aa *AutoAttacks) CancelAutoSwing(sim *Simulation)
- func (aa *AutoAttacks) DelayMeleeBy(sim *Simulation, delay time.Duration)
- func (aa *AutoAttacks) DelayRangedUntil(sim *Simulation, readyAt time.Duration)
- func (aa *AutoAttacks) EnableAutoSwing(sim *Simulation)
- func (aa *AutoAttacks) ExtraMHAttack(sim *Simulation)
- func (aa *AutoAttacks) MH() *Weapon
- func (aa *AutoAttacks) MHAuto() *Spell
- func (aa *AutoAttacks) MHConfig() *SpellConfig
- func (aa *AutoAttacks) MainhandSwingAt() time.Duration
- func (aa *AutoAttacks) MainhandSwingSpeed() time.Duration
- func (aa *AutoAttacks) MaybeReplaceMHSwing(sim *Simulation, mhSwingSpell *Spell) *Spell
- func (aa *AutoAttacks) NewPPMManager(ppm float64, procMask ProcMask) PPMManager
- func (aa *AutoAttacks) NextAnyAttackAt() time.Duration
- func (aa *AutoAttacks) NextAttackAt() time.Duration
- func (aa *AutoAttacks) NextRangedAttackAt() time.Duration
- func (aa *AutoAttacks) OH() *Weapon
- func (aa *AutoAttacks) OHAuto() *Spell
- func (aa *AutoAttacks) OHConfig() *SpellConfig
- func (aa *AutoAttacks) OffhandSwingAt() time.Duration
- func (aa *AutoAttacks) OffhandSwingSpeed() time.Duration
- func (aa *AutoAttacks) PPMProc(sim *Simulation, ppm float64, procMask ProcMask, label string, spell *Spell) bool
- func (aa *AutoAttacks) Ranged() *Weapon
- func (aa *AutoAttacks) RangedAuto() *Spell
- func (aa *AutoAttacks) RangedConfig() *SpellConfig
- func (aa *AutoAttacks) RangedSwingSpeed() time.Duration
- func (aa *AutoAttacks) SetMH(weapon Weapon)
- func (aa *AutoAttacks) SetOH(weapon Weapon)
- func (aa *AutoAttacks) SetOffhandSwingAt(offhandSwingAt time.Duration)
- func (aa *AutoAttacks) SetRanged(weapon Weapon)
- func (aa *AutoAttacks) SetReplaceMHSwing(replaceSwing ReplaceMHSwing)
- func (aa *AutoAttacks) StopMeleeUntil(sim *Simulation, readyAt time.Duration, desyncOH bool)
- func (aa *AutoAttacks) UpdateSwingTimers(sim *Simulation)
- type BaseStatsKey
- type BuffName
- type BuffsCombo
- type CanCastCondition
- type Cast
- type CastConfig
- type CastFunc
- type CastSuccessFunc
- type Character
- func (eb *Character) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
- func (eb *Character) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Character) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mcdm *Character) AddMajorCooldown(mcd MajorCooldown)
- func (character *Character) AddPartyBuffs(partyBuffs *proto.PartyBuffs)
- func (character *Character) AddPet(pet PetAgent)
- func (rb *Character) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (character *Character) AddRaidBuffs(_ *proto.RaidBuffs)
- func (character *Character) ApplyDynamicEquipScaling(sim *Simulation, stat stats.Stat, multiplier float64)
- func (character *Character) ApplyEquipScaling(stat stats.Stat, multiplier float64)
- func (character *Character) BaseEquipStats() stats.Stats
- func (eb *Character) ComboPoints() int32
- func (eb *Character) CurrentEnergy() float64
- func (fb *Character) CurrentFocus() float64
- func (fb *Character) CurrentFocusPerTick() float64
- func (hb *Character) CurrentHealth() float64
- func (hb *Character) CurrentHealthPercent() float64
- func (rb *Character) CurrentRage() float64
- func (character *Character) EnableManaBar()
- func (character *Character) EnableManaBarWithModifier(modifier float64)
- func (mb *Character) EndOOMEvent(sim *Simulation)
- func (character *Character) EquipStats() stats.Stats
- func (character *Character) FillPlayerStats(playerStats *proto.PlayerStats)
- func (character *Character) Finalize()
- func (hb *Character) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (at *Character) GetActiveAuraWithTag(tag string) *Aura
- func (character *Character) GetActiveSetBonusNames() []string
- func (character *Character) GetActiveSetBonuses() []ActiveSetBonus
- func (at *Character) GetAura(label string) *Aura
- func (at *Character) GetAuraByID(actionID ActionID) *Aura
- func (at *Character) GetAuras() []*Aura
- func (at *Character) GetAurasWithTag(tag string) []*Aura
- func (character *Character) GetBaseStats() stats.Stats
- func (character *Character) GetConjuredCD() *Timer
- func (character *Character) GetDefensiveTrinketCD() *Timer
- func (at *Character) GetIcdAuraByID(actionID ActionID) *Aura
- func (mcdm *Character) GetInitialMajorCooldown(actionID ActionID) MajorCooldown
- func (character *Character) GetMHWeapon() *Item
- func (mcdm *Character) GetMajorCooldown(actionID ActionID) *MajorCooldown
- func (mcdm *Character) GetMajorCooldownIDs() []*proto.ActionID
- func (mcdm *Character) GetMajorCooldownIgnoreTag(actionID ActionID) *MajorCooldown
- func (mcdm *Character) GetMajorCooldowns() []*MajorCooldown
- func (character *Character) GetMetricsProto() *proto.UnitMetrics
- func (character *Character) GetOHWeapon() *Item
- func (character *Character) GetOffensiveTrinketCD() *Timer
- func (character *Character) GetPresimOptions(playerConfig *proto.Player) *PresimOptions
- func (character *Character) GetProcMaskForEnchant(effectID int32) ProcMask
- func (character *Character) GetProcMaskForItem(itemID int32) ProcMask
- func (character *Character) GetProcMaskForTypes(weaponTypes ...proto.WeaponType) ProcMask
- func (character *Character) GetPseudoStatsProto() []float64
- func (character *Character) GetRangedWeapon() *Item
- func (at *Character) HasActiveAura(label string) bool
- func (at *Character) HasActiveAuraWithTag(tag string) bool
- func (at *Character) HasActiveAuraWithTagExcludingAura(tag string, excludeAura *Aura) bool
- func (at *Character) HasAura(label string) bool
- func (at *Character) HasAuraWithTag(tag string) bool
- func (character *Character) HasMHWeapon() bool
- func (character *Character) HasOHWeapon() bool
- func (character *Character) HasProfession(prof proto.Profession) bool
- func (character *Character) HasRangedWeapon() bool
- func (character *Character) HasRingEquipped(itemID int32) bool
- func (character *Character) HasRuneById(id int32) bool
- func (character *Character) HasSetBonus(set *ItemSet, numItems int32) bool
- func (character *Character) HasTrinketEquipped(itemID int32) bool
- func (mb *Character) IsOOM() bool
- func (character *Character) IsTanking() bool
- func (hb *Character) MaxHealth() float64
- func (character *Character) NewTemporaryStatsAura(auraLabel string, actionID ActionID, tempStats stats.Stats, ...) *Aura
- func (character *Character) NewTemporaryStatsAuraWrapped(auraLabel string, actionID ActionID, buffs stats.Stats, duration time.Duration, ...) *Aura
- func (eb *Character) NextEnergyTickAt() time.Duration
- func (at *Character) NumActiveAurasWithTag(tag string) int32
- func (at *Character) OnCastComplete(sim *Simulation, spell *Spell)
- func (at *Character) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
- func (at *Character) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Character) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (character *Character) RegisterOnItemSwap(callback OnSwapItem)
- func (at *Character) RegisterResetEffect(resetEffect ResetEffect)
- func (character *Character) RemoveDynamicEquipScaling(sim *Simulation, stat stats.Stat, multiplier float64)
- func (character *Character) RemoveEquipScaling(stat stats.Stat, multiplier float64)
- func (hb *Character) RemoveHealth(sim *Simulation, amount float64)
- func (eb *Character) ResetEnergyTick(sim *Simulation)
- func (eb *Character) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
- func (eb *Character) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Character) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (rb *Character) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mb *Character) StartOOMEvent(sim *Simulation, requiredMana float64)
- func (mcdm *Character) TryUseCooldowns(sim *Simulation)
- func (mcdm *Character) UpdateMajorCooldowns()
- func (character *Character) WeaponFromMainHand() Weapon
- func (character *Character) WeaponFromOffHand() Weapon
- func (character *Character) WeaponFromRanged() Weapon
- type CharacterBuildPhase
- type CharacterIterationMetrics
- type CharacterSuiteConfig
- type CombinedTestGenerator
- type ConsumesCombo
- type Cooldown
- type CooldownActivation
- type CooldownActivationCondition
- type CooldownType
- type DebuffName
- type DefaultAPLValueImpl
- func (impl DefaultAPLValueImpl) Finalize(*APLRotation)
- func (impl DefaultAPLValueImpl) GetBool(sim *Simulation) bool
- func (impl DefaultAPLValueImpl) GetDuration(sim *Simulation) time.Duration
- func (impl DefaultAPLValueImpl) GetFloat(sim *Simulation) float64
- func (impl DefaultAPLValueImpl) GetInnerValues() []APLValue
- func (impl DefaultAPLValueImpl) GetInt(sim *Simulation) int32
- func (impl DefaultAPLValueImpl) GetString(sim *Simulation) string
- type DefenseType
- type DelayedActionOptions
- type DistributionMetrics
- type Dot
- func (dot *Dot) Apply(sim *Simulation)
- func (dot *Dot) ApplyOrRefresh(sim *Simulation)
- func (dot *Dot) ApplyOrReset(sim *Simulation)
- func (dot *Dot) CalcAndDealPeriodicSnapshotDamage(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
- func (dot *Dot) CalcAndDealPeriodicSnapshotHealing(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
- func (dot *Dot) CalcSnapshotDamage(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
- func (dot *Dot) CalcSnapshotHealing(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
- func (dot *Dot) Cancel(sim *Simulation)
- func (dot *Dot) ManualTick(sim *Simulation)
- func (dot *Dot) MaxTicksRemaining() int32
- func (dot *Dot) NextTickAt() time.Duration
- func (dot *Dot) NumTicksRemaining(sim *Simulation) int
- func (dot *Dot) OutcomeExpectedMagicSnapshotCrit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
- func (dot *Dot) OutcomeMagicHitAndSnapshotCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (dot *Dot) OutcomeRangedHitAndCritSnapshot(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (dot *Dot) OutcomeSnapshotCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (dot *Dot) OutcomeTick(_ *Simulation, result *SpellResult, _ *AttackTable)
- func (dot *Dot) OutcomeTickCounted(_ *Simulation, result *SpellResult, _ *AttackTable)
- func (dot *Dot) OutcomeTickPhysicalCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (dot *Dot) OutcomeTickSnapshotCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (dot *Dot) RecomputeAuraDuration()
- func (dot *Dot) RescheduleNextTick(sim *Simulation)
- func (dot *Dot) Rollover(sim *Simulation)
- func (dot *Dot) TakeSnapshot(sim *Simulation, doRollover bool)
- func (dot *Dot) TickOnce(sim *Simulation)
- func (dot *Dot) TickPeriod() time.Duration
- func (dot *Dot) TimeUntilNextTick(sim *Simulation) time.Duration
- type DotArray
- type DotConfig
- type DynamicDamageTakenModifier
- type Enchant
- type Encounter
- type EncounterCombo
- type EnergyCost
- type EnergyCostOptions
- type Environment
- func (env *Environment) GetAgentFromUnit(unit *Unit) Agent
- func (env *Environment) GetMaxDuration() time.Duration
- func (env *Environment) GetNumTargets() int32
- func (env *Environment) GetTarget(index int32) *Target
- func (env *Environment) GetTargetUnit(index int32) *Unit
- func (env *Environment) GetUnit(ref *proto.UnitReference, contextUnit *Unit) *Unit
- func (env *Environment) IsFinalized() bool
- func (env *Environment) NextTarget(target *Unit) *Target
- func (env *Environment) NextTargetUnit(target *Unit) *Unit
- func (env *Environment) PrepullStartTime() time.Duration
- func (env *Environment) RegisterPostFinalizeEffect(postFinalizeEffect PostFinalizeEffect)
- func (env *Environment) RegisterPreFinalizeEffect(preFinalizeEffect PostFinalizeEffect)
- type EnvironmentState
- type Equipment
- func (equipment *Equipment) BaseStats() stats.Stats
- func (equipment *Equipment) EquipItem(item Item)
- func (equipment *Equipment) Finger1() *Item
- func (equipment *Equipment) Finger2() *Item
- func (equipment *Equipment) GetRuneIds() []int32
- func (equipment *Equipment) Hands() *Item
- func (equipment *Equipment) Head() *Item
- func (equipment *Equipment) MainHand() *Item
- func (equipment *Equipment) Neck() *Item
- func (equipment *Equipment) OffHand() *Item
- func (equipment *Equipment) Ranged() *Item
- func (equipment *Equipment) Stats() stats.Stats
- func (equipment *Equipment) ToEquipmentSpecProto() *proto.EquipmentSpec
- func (equipment *Equipment) Trinket1() *Item
- func (equipment *Equipment) Trinket2() *Item
- type EquipmentSpec
- type ExclusiveCategory
- func (ec *ExclusiveCategory) AnyActive() bool
- func (ec *ExclusiveCategory) GetActiveAura() *Aura
- func (ec *ExclusiveCategory) GetActiveEffect() *ExclusiveEffect
- func (ec *ExclusiveCategory) GetHighestPrioActiveEffect() *ExclusiveEffect
- func (ec *ExclusiveCategory) SetActive(sim *Simulation, newActiveEffect *ExclusiveEffect)
- type ExclusiveCategoryArray
- type ExclusiveEffect
- type ExclusiveEffectManager
- type ExpectedDamageCalculator
- type FocusCost
- type FocusCostOptions
- type GearSetCombo
- type GoRand
- type Hand
- type Hardcast
- type HitOutcome
- type IndividualTestSuite
- func (testSuite *IndividualTestSuite) Done(t *testing.T)
- func (testSuite *IndividualTestSuite) TestCasts(testName string, rsr *proto.RaidSimRequest)
- func (testSuite *IndividualTestSuite) TestCharacterStats(testName string, csr *proto.ComputeStatsRequest)
- func (testSuite *IndividualTestSuite) TestDPS(testName string, rsr *proto.RaidSimRequest)
- func (testSuite *IndividualTestSuite) TestStatWeights(testName string, swr *proto.StatWeightsRequest)
- type Item
- type ItemComboChecker
- type ItemFilter
- type ItemSet
- type ItemSpec
- type ItemStringSpec
- type ItemSwap
- func (swap *ItemSwap) CalcStatChanges(slots []proto.ItemSlot) stats.Stats
- func (swap *ItemSwap) GetItem(slot proto.ItemSlot) *Item
- func (swap *ItemSwap) IsEnabled() bool
- func (swap *ItemSwap) IsSwapped() bool
- func (swap *ItemSwap) RegisterOnSwapItemForEffect(effectID int32, aura *Aura)
- func (swap *ItemSwap) RegisterOnSwapItemForEffectWithPPMManager(effectID int32, ppm float64, ppmm *PPMManager, aura *Aura)
- func (swap *ItemSwap) SwapItems(sim *Simulation, slots []proto.ItemSlot)
- type ItemsTestGenerator
- type MajorCooldown
- func (mcd *MajorCooldown) Disable()
- func (mcd *MajorCooldown) Enable()
- func (mcd *MajorCooldown) GetTimings() []time.Duration
- func (mcd *MajorCooldown) IsEnabled() bool
- func (mcd *MajorCooldown) IsReady(sim *Simulation) bool
- func (mcd *MajorCooldown) ReadyAt() time.Duration
- func (mcd *MajorCooldown) TimeToNextCast(sim *Simulation) time.Duration
- func (mcd *MajorCooldown) TimeToReady(sim *Simulation) time.Duration
- func (mcd *MajorCooldown) TryActivate(sim *Simulation, character *Character) bool
- type ManaCost
- type ManaCostOptions
- type MeleeDamageCalculator
- type OnCastComplete
- type OnDamage
- type OnDoneIteration
- type OnExpire
- type OnFocusGain
- type OnGain
- type OnInit
- type OnPeriodicDamage
- type OnPetDisable
- type OnPetEnable
- type OnRageChange
- type OnReset
- type OnSnapshot
- type OnSpellHit
- type OnStacksChange
- type OnStatsChange
- type OnSwapItem
- type OnTick
- type OutcomeApplier
- type PPMManager
- type Party
- func (party *Party) AddStat(stat stats.Stat, amount float64)
- func (party *Party) AddStats(newStats stats.Stats)
- func (party *Party) GetMetrics() *proto.PartyMetrics
- func (party *Party) GetPartyBuffs(basePartyBuffs *proto.PartyBuffs) *proto.PartyBuffs
- func (party *Party) IsFull() bool
- func (party *Party) Size() int
- type PendingAction
- func NewDelayedAction(sim *Simulation, options DelayedActionOptions) *PendingAction
- func NewPeriodicAction(sim *Simulation, options PeriodicActionOptions) *PendingAction
- func StartDelayedAction(sim *Simulation, options DelayedActionOptions) *PendingAction
- func StartPeriodicAction(sim *Simulation, options PeriodicActionOptions) *PendingAction
- type PeriodicActionOptions
- type Pet
- func (eb *Pet) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
- func (eb *Pet) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Pet) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mcdm *Pet) AddMajorCooldown(mcd MajorCooldown)
- func (pet *Pet) AddPartyBuffs(_ *proto.PartyBuffs)
- func (rb *Pet) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (pet *Pet) AddRaidBuffs(_ *proto.RaidBuffs)
- func (pet *Pet) ApplyRunes()
- func (pet *Pet) ApplyTalents()
- func (eb *Pet) ComboPoints() int32
- func (eb *Pet) CurrentEnergy() float64
- func (fb *Pet) CurrentFocus() float64
- func (fb *Pet) CurrentFocusPerTick() float64
- func (hb *Pet) CurrentHealth() float64
- func (hb *Pet) CurrentHealthPercent() float64
- func (rb *Pet) CurrentRage() float64
- func (pet *Pet) Disable(sim *Simulation)
- func (pet *Pet) Enable(sim *Simulation, petAgent PetAgent)
- func (pet *Pet) EnableDynamicMeleeSpeed(inheritance PetMeleeSpeedInheritance)
- func (pet *Pet) EnableDynamicStats(inheritance PetStatInheritance)
- func (pet *Pet) EnableWithTimeout(sim *Simulation, petAgent PetAgent, petDuration time.Duration)
- func (mb *Pet) EndOOMEvent(sim *Simulation)
- func (hb *Pet) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (at *Pet) GetActiveAuraWithTag(tag string) *Aura
- func (at *Pet) GetAura(label string) *Aura
- func (at *Pet) GetAuraByID(actionID ActionID) *Aura
- func (at *Pet) GetAuras() []*Aura
- func (at *Pet) GetAurasWithTag(tag string) []*Aura
- func (pet *Pet) GetCharacter() *Character
- func (at *Pet) GetIcdAuraByID(actionID ActionID) *Aura
- func (mcdm *Pet) GetInitialMajorCooldown(actionID ActionID) MajorCooldown
- func (mcdm *Pet) GetMajorCooldown(actionID ActionID) *MajorCooldown
- func (mcdm *Pet) GetMajorCooldownIDs() []*proto.ActionID
- func (mcdm *Pet) GetMajorCooldownIgnoreTag(actionID ActionID) *MajorCooldown
- func (mcdm *Pet) GetMajorCooldowns() []*MajorCooldown
- func (at *Pet) HasActiveAura(label string) bool
- func (at *Pet) HasActiveAuraWithTag(tag string) bool
- func (at *Pet) HasActiveAuraWithTagExcludingAura(tag string, excludeAura *Aura) bool
- func (at *Pet) HasAura(label string) bool
- func (at *Pet) HasAuraWithTag(tag string) bool
- func (pet *Pet) IsGuardian() bool
- func (mb *Pet) IsOOM() bool
- func (hb *Pet) MaxHealth() float64
- func (eb *Pet) NextEnergyTickAt() time.Duration
- func (at *Pet) NumActiveAurasWithTag(tag string) int32
- func (at *Pet) OnCastComplete(sim *Simulation, spell *Spell)
- func (pet *Pet) OnGCDReady(_ *Simulation)
- func (at *Pet) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
- func (at *Pet) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Pet) RegisterResetEffect(resetEffect ResetEffect)
- func (hb *Pet) RemoveHealth(sim *Simulation, amount float64)
- func (eb *Pet) ResetEnergyTick(sim *Simulation)
- func (eb *Pet) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
- func (eb *Pet) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Pet) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (rb *Pet) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mb *Pet) StartOOMEvent(sim *Simulation, requiredMana float64)
- func (mcdm *Pet) TryUseCooldowns(sim *Simulation)
- func (mcdm *Pet) UpdateMajorCooldowns()
- type PetAgent
- type PetMeleeSpeedInheritance
- type PetStatInheritance
- type PostFinalizeEffect
- type PowerBarType
- type PrepullAction
- type PresetTarget
- type PresimOptions
- type Presimmer
- type ProcHandler
- type ProcMask
- type ProcTrigger
- type RageBarOptions
- type RageCost
- type RageCostOptions
- type Raid
- func (raid *Raid) AddStats(s stats.Stats)
- func (raid *Raid) GetActiveUnits() []*Unit
- func (raid *Raid) GetFirstEmptyRaidIndex() (*Party, int)
- func (raid *Raid) GetFirstNPlayersOrPets(n int32) []*Unit
- func (raid *Raid) GetFirstTargetDummy() *TargetDummy
- func (raid *Raid) GetMetrics() *proto.RaidMetrics
- func (raid *Raid) GetPlayerFromUnit(unit *Unit) Agent
- func (raid *Raid) GetPlayerFromUnitIndex(unitIndex int32) Agent
- func (raid *Raid) GetPlayerParty(unit *Unit) *Party
- func (raid *Raid) GetPlayersOfClass(class proto.Class) []Agent
- func (raid *Raid) GetRaidBuffs(baseRaidBuffs *proto.RaidBuffs) *proto.RaidBuffs
- func (raid *Raid) Size() int
- type Rand
- type RandomSuffix
- type ReplaceMHSwing
- type ResetEffect
- type ResourceKey
- type ResourceMetrics
- func (resourceMetrics *ResourceMetrics) ActualGainForCurrentIteration() float64
- func (resourceMetrics *ResourceMetrics) AddEvent(gain float64, actualGain float64)
- func (resourceMetrics *ResourceMetrics) EventsForCurrentIteration() int32
- func (resourceMetrics *ResourceMetrics) ToProto() *proto.ResourceMetrics
- type RotationCastsTestGenerator
- type RotationCombo
- type Rune
- type SettingsCombos
- type Shield
- type ShieldArray
- type ShieldConfig
- type Simulation
- func (sim *Simulation) AddPendingAction(pa *PendingAction)
- func (sim *Simulation) AddTask(task Task)
- func (sim *Simulation) Cleanup()
- func (sim *Simulation) GetRemainingDuration() time.Duration
- func (sim *Simulation) GetRemainingDurationPercent() float64
- func (sim *Simulation) IsExecutePhase20() bool
- func (sim *Simulation) IsExecutePhase25() bool
- func (sim *Simulation) IsExecutePhase35() bool
- func (sim *Simulation) PrePull()
- func (sim *Simulation) Proc(p float64, label string) bool
- func (sim *Simulation) RandomExpFloat(label string) float64
- func (sim *Simulation) RandomFloat(label string) float64
- func (sim *Simulation) RegisterExecutePhaseCallback(callback func(sim *Simulation, isExecute int32))
- func (sim *Simulation) RemoveTask(task Task)
- func (sim *Simulation) RescheduleTask(taskTime time.Duration)
- func (sim *Simulation) Reseed(seed int64)
- func (sim *Simulation) Reset()
- func (sim *Simulation) Roll(min float64, max float64) float64
- func (sim *Simulation) RollWithLabel(min float64, max float64, label string) float64
- func (sim *Simulation) Step() bool
- type SingleCharacterStatsTestGenerator
- type SingleDpsTestGenerator
- type SingleStatWeightsTestGenerator
- type SpecOptionsCombo
- type SpecSetter
- type Spell
- func (spell *Spell) AOEDot() *Dot
- func (spell *Spell) AOEHot() *Dot
- func (spell *Spell) ApplyAOEThreat(threatAmount float64)
- func (spell *Spell) ApplyAOEThreatIgnoreMultipliers(threatAmount float64)
- func (spell *Spell) ApplyCostModifiers(cost float64) float64
- func (spell *Spell) ApplyPostOutcomeDamageModifiers(sim *Simulation, result *SpellResult)
- func (spell *Spell) AttackerDamageMultiplier(attackTable *AttackTable) float64
- func (spell *Spell) BonusWeaponDamage() float64
- func (spell *Spell) CalcAndDealDamage(sim *Simulation, target *Unit, baseDamage float64, ...) *SpellResult
- func (spell *Spell) CalcAndDealHealing(sim *Simulation, target *Unit, baseHealing float64, ...) *SpellResult
- func (spell *Spell) CalcAndDealOutcome(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
- func (spell *Spell) CalcAndDealPeriodicDamage(sim *Simulation, target *Unit, baseDamage float64, ...) *SpellResult
- func (spell *Spell) CalcAndDealPeriodicHealing(sim *Simulation, target *Unit, baseHealing float64, ...) *SpellResult
- func (spell *Spell) CalcDamage(sim *Simulation, target *Unit, baseDamage float64, ...) *SpellResult
- func (spell *Spell) CalcHealing(sim *Simulation, target *Unit, baseHealing float64, ...) *SpellResult
- func (spell *Spell) CalcOutcome(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
- func (spell *Spell) CalcPeriodicDamage(sim *Simulation, target *Unit, baseDamage float64, ...) *SpellResult
- func (spell *Spell) CanCast(sim *Simulation, target *Unit) bool
- func (spell *Spell) Cast(sim *Simulation, target *Unit) bool
- func (spell *Spell) CastTime() time.Duration
- func (spell *Spell) CasterHealingMultiplier() float64
- func (spell *Spell) ComboPointMetrics() *ResourceMetrics
- func (spell *Spell) CritMultiplier(at *AttackTable) float64
- func (spell *Spell) CurCPM(sim *Simulation) float64
- func (spell *Spell) CurDamagePerCast() float64
- func (spell *Spell) CurDot() *Dot
- func (spell *Spell) CurHot() *Dot
- func (spell *Spell) DealDamage(sim *Simulation, result *SpellResult)
- func (spell *Spell) DealHealing(sim *Simulation, result *SpellResult)
- func (spell *Spell) DealOutcome(sim *Simulation, result *SpellResult)
- func (spell *Spell) DealPeriodicDamage(sim *Simulation, result *SpellResult)
- func (spell *Spell) DealPeriodicHealing(sim *Simulation, result *SpellResult)
- func (spell *Spell) DisposeResult(result *SpellResult)
- func (spell *Spell) Dot(target *Unit) *Dot
- func (spell *Spell) EffectiveCastTime() time.Duration
- func (spell *Spell) EnergyMetrics() *ResourceMetrics
- func (spell *Spell) ExpectedInitialDamage(sim *Simulation, target *Unit) float64
- func (spell *Spell) ExpectedTickDamage(sim *Simulation, target *Unit) float64
- func (spell *Spell) ExpectedTickDamageFromCurrentSnapshot(sim *Simulation, target *Unit) float64
- func (spell *Spell) ExpertisePercentage() float64
- func (spell *Spell) HealingCritChance() float64
- func (spell *Spell) HealingCritCheck(sim *Simulation) bool
- func (spell *Spell) HealingPower(target *Unit) float64
- func (spell *Spell) HealthMetrics(target *Unit) *ResourceMetrics
- func (spell *Spell) Hot(target *Unit) *Dot
- func (spell *Spell) IsMH() bool
- func (spell *Spell) IsMelee() bool
- func (spell *Spell) IsOH() bool
- func (spell *Spell) IsReady(sim *Simulation) bool
- func (spell *Spell) IssueRefund(sim *Simulation)
- func (spell *Spell) MagicCritCheck(sim *Simulation, target *Unit) bool
- func (spell *Spell) MagicHitCheck(sim *Simulation, attackTable *AttackTable) bool
- func (spell *Spell) MeleeAttackPower() float64
- func (spell *Spell) NewResult(target *Unit) *SpellResult
- func (spell *Spell) OutcomeAlwaysHit(_ *Simulation, result *SpellResult, _ *AttackTable)
- func (spell *Spell) OutcomeAlwaysMiss(_ *Simulation, result *SpellResult, _ *AttackTable)
- func (spell *Spell) OutcomeEnemyMeleeWhite(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeExpectedMagicAlwaysHit(_ *Simulation, _ *SpellResult, _ *AttackTable)
- func (spell *Spell) OutcomeExpectedMagicCrit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeExpectedMagicHit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeExpectedMagicHitAndCrit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeExpectedTick(_ *Simulation, _ *SpellResult, _ *AttackTable)
- func (spell *Spell) OutcomeHealing(_ *Simulation, result *SpellResult, _ *AttackTable)
- func (spell *Spell) OutcomeHealingCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMagicCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMagicHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMagicHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeSpecialCritOnly(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeSpecialHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeSpecialHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeSpecialNoBlockDodgeParry(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeSpecialNoBlockDodgeParryNoCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeWeaponSpecialHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeWeaponSpecialNoCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeMeleeWhite(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeRangedCritOnly(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeRangedHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeRangedHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeRangedHitAndCritNoBlock(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) OutcomeTickMagicHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
- func (spell *Spell) PhysicalCritChance(attackTable *AttackTable) float64
- func (spell *Spell) PhysicalCritCheck(sim *Simulation, attackTable *AttackTable) bool
- func (spell *Spell) PhysicalHitChance(attackTable *AttackTable) float64
- func (spell *Spell) RangedAttackPower(target *Unit) float64
- func (spell *Spell) ReadyAt() time.Duration
- func (spell *Spell) ResistanceMultiplier(sim *Simulation, isPeriodic bool, attackTable *AttackTable) (float64, HitOutcome)
- func (spell *Spell) SelfHot() *Dot
- func (spell *Spell) SelfShield() *Shield
- func (spell *Spell) SetMetricsSplit(splitIdx int32)
- func (spell *Spell) SetSchool(schoolIndex stats.SchoolIndex)
- func (spell *Spell) Shield(target *Unit) *Shield
- func (spell *Spell) ShouldRefreshExclusiveEffects(sim *Simulation, target *Unit, refreshWindow time.Duration) bool
- func (spell *Spell) SkipCastAndApplyEffects(sim *Simulation, target *Unit)
- func (spell *Spell) SpellChanceToMiss(attackTable *AttackTable) float64
- func (spell *Spell) SpellCritChance(target *Unit) float64
- func (spell *Spell) SpellDamage() float64
- func (spell *Spell) SpellHitChance(target *Unit) float64
- func (spell *Spell) SpellPower() float64
- func (spell *Spell) SpellSchoolPower() float64
- func (spell *Spell) TargetDamageMultiplier(attackTable *AttackTable, isPeriodic bool) float64
- func (spell *Spell) ThreatFromDamage(outcome HitOutcome, damage float64) float64
- func (spell *Spell) TimeToReady(sim *Simulation) time.Duration
- func (spell *Spell) TravelTime() time.Duration
- func (spell *Spell) WaitTravelTime(sim *Simulation, callback func(*Simulation))
- type SpellConfig
- type SpellCost
- type SpellFlag
- type SpellMetrics
- type SpellRegisteredHandler
- type SpellResult
- type SpellSchool
- type SpiritManaRegenPerSecond
- type SplitMix64
- type StackingStatAura
- type StatWeightValues
- type StatWeightsResult
- type SubGenerator
- type SubstitutionComboChecker
- type TalentsCombo
- type Target
- func (eb *Target) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
- func (eb *Target) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Target) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (target *Target) AddPartyBuffs(_ *proto.PartyBuffs)
- func (rb *Target) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (target *Target) AddRaidBuffs(_ *proto.RaidBuffs)
- func (target *Target) ApplyRunes()
- func (target *Target) ApplyTalents()
- func (eb *Target) ComboPoints() int32
- func (eb *Target) CurrentEnergy() float64
- func (fb *Target) CurrentFocus() float64
- func (fb *Target) CurrentFocusPerTick() float64
- func (hb *Target) CurrentHealth() float64
- func (hb *Target) CurrentHealthPercent() float64
- func (rb *Target) CurrentRage() float64
- func (mb *Target) EndOOMEvent(sim *Simulation)
- func (target *Target) ExecuteCustomRotation(sim *Simulation)
- func (hb *Target) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (at *Target) GetActiveAuraWithTag(tag string) *Aura
- func (at *Target) GetAura(label string) *Aura
- func (at *Target) GetAuraByID(actionID ActionID) *Aura
- func (at *Target) GetAuras() []*Aura
- func (at *Target) GetAurasWithTag(tag string) []*Aura
- func (target *Target) GetCharacter() *Character
- func (at *Target) GetIcdAuraByID(actionID ActionID) *Aura
- func (target *Target) GetMetricsProto() *proto.UnitMetrics
- func (at *Target) HasActiveAura(label string) bool
- func (at *Target) HasActiveAuraWithTag(tag string) bool
- func (at *Target) HasActiveAuraWithTagExcludingAura(tag string, excludeAura *Aura) bool
- func (at *Target) HasAura(label string) bool
- func (at *Target) HasAuraWithTag(tag string) bool
- func (target *Target) Initialize()
- func (mb *Target) IsOOM() bool
- func (hb *Target) MaxHealth() float64
- func (eb *Target) NextEnergyTickAt() time.Duration
- func (target *Target) NextTarget() *Target
- func (at *Target) NumActiveAurasWithTag(tag string) int32
- func (at *Target) OnCastComplete(sim *Simulation, spell *Spell)
- func (at *Target) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
- func (at *Target) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Target) RegisterResetEffect(resetEffect ResetEffect)
- func (hb *Target) RemoveHealth(sim *Simulation, amount float64)
- func (target *Target) Reset(sim *Simulation)
- func (eb *Target) ResetEnergyTick(sim *Simulation)
- func (eb *Target) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
- func (eb *Target) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Target) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (rb *Target) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mb *Target) StartOOMEvent(sim *Simulation, requiredMana float64)
- type TargetAI
- type TargetDummy
- func (eb *TargetDummy) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
- func (eb *TargetDummy) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *TargetDummy) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mcdm *TargetDummy) AddMajorCooldown(mcd MajorCooldown)
- func (td *TargetDummy) AddPartyBuffs(partyBuffs *proto.PartyBuffs)
- func (rb *TargetDummy) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (td *TargetDummy) AddRaidBuffs(raidBuffs *proto.RaidBuffs)
- func (td *TargetDummy) ApplyRunes()
- func (td *TargetDummy) ApplyTalents()
- func (eb *TargetDummy) ComboPoints() int32
- func (eb *TargetDummy) CurrentEnergy() float64
- func (fb *TargetDummy) CurrentFocus() float64
- func (fb *TargetDummy) CurrentFocusPerTick() float64
- func (hb *TargetDummy) CurrentHealth() float64
- func (hb *TargetDummy) CurrentHealthPercent() float64
- func (rb *TargetDummy) CurrentRage() float64
- func (mb *TargetDummy) EndOOMEvent(sim *Simulation)
- func (td *TargetDummy) ExecuteCustomRotation(sim *Simulation)
- func (hb *TargetDummy) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (at *TargetDummy) GetActiveAuraWithTag(tag string) *Aura
- func (at *TargetDummy) GetAura(label string) *Aura
- func (at *TargetDummy) GetAuraByID(actionID ActionID) *Aura
- func (at *TargetDummy) GetAuras() []*Aura
- func (at *TargetDummy) GetAurasWithTag(tag string) []*Aura
- func (td *TargetDummy) GetCharacter() *Character
- func (at *TargetDummy) GetIcdAuraByID(actionID ActionID) *Aura
- func (mcdm *TargetDummy) GetInitialMajorCooldown(actionID ActionID) MajorCooldown
- func (mcdm *TargetDummy) GetMajorCooldown(actionID ActionID) *MajorCooldown
- func (mcdm *TargetDummy) GetMajorCooldownIDs() []*proto.ActionID
- func (mcdm *TargetDummy) GetMajorCooldownIgnoreTag(actionID ActionID) *MajorCooldown
- func (mcdm *TargetDummy) GetMajorCooldowns() []*MajorCooldown
- func (at *TargetDummy) HasActiveAura(label string) bool
- func (at *TargetDummy) HasActiveAuraWithTag(tag string) bool
- func (at *TargetDummy) HasActiveAuraWithTagExcludingAura(tag string, excludeAura *Aura) bool
- func (at *TargetDummy) HasAura(label string) bool
- func (at *TargetDummy) HasAuraWithTag(tag string) bool
- func (td *TargetDummy) Initialize()
- func (mb *TargetDummy) IsOOM() bool
- func (hb *TargetDummy) MaxHealth() float64
- func (eb *TargetDummy) NextEnergyTickAt() time.Duration
- func (at *TargetDummy) NumActiveAurasWithTag(tag string) int32
- func (at *TargetDummy) OnCastComplete(sim *Simulation, spell *Spell)
- func (at *TargetDummy) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
- func (at *TargetDummy) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *TargetDummy) RegisterResetEffect(resetEffect ResetEffect)
- func (hb *TargetDummy) RemoveHealth(sim *Simulation, amount float64)
- func (td *TargetDummy) Reset(sim *Simulation)
- func (eb *TargetDummy) ResetEnergyTick(sim *Simulation)
- func (eb *TargetDummy) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
- func (eb *TargetDummy) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *TargetDummy) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (rb *TargetDummy) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (mb *TargetDummy) StartOOMEvent(sim *Simulation, requiredMana float64)
- func (mcdm *TargetDummy) TryUseCooldowns(sim *Simulation)
- func (mcdm *TargetDummy) UpdateMajorCooldowns()
- type TargetedActionMetrics
- type Task
- type TestGenerator
- type Timer
- type Unit
- func (unit *Unit) AddBonusRangedCritRating(amount float64)
- func (unit *Unit) AddBonusRangedHitRating(amount float64)
- func (eb *Unit) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
- func (unit *Unit) AddDynamicDamageTakenModifier(ddtm DynamicDamageTakenModifier)
- func (eb *Unit) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Unit) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (unit *Unit) AddMana(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (rb *Unit) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (unit *Unit) AddStat(stat stats.Stat, amount float64)
- func (unit *Unit) AddStatDynamic(sim *Simulation, stat stats.Stat, amount float64)
- func (unit *Unit) AddStats(stat stats.Stats)
- func (unit *Unit) AddStatsDynamic(sim *Simulation, bonus stats.Stats)
- func (unit *Unit) ApplyCastSpeed(dur time.Duration) time.Duration
- func (unit *Unit) ApplyCastSpeedForSpell(dur time.Duration, spell *Spell) time.Duration
- func (unit *Unit) Armor() float64
- func (unit *Unit) ArmorPenetrationPercentage(armorPenRating float64) float64
- func (unit *Unit) BlockValue() float64
- func (unit *Unit) CancelGCDTimer(sim *Simulation)
- func (eb *Unit) ComboPoints() int32
- func (eb *Unit) CurrentEnergy() float64
- func (fb *Unit) CurrentFocus() float64
- func (fb *Unit) CurrentFocusPerTick() float64
- func (hb *Unit) CurrentHealth() float64
- func (hb *Unit) CurrentHealthPercent() float64
- func (unit *Unit) CurrentMana() float64
- func (unit *Unit) CurrentManaPercent() float64
- func (rb *Unit) CurrentRage() float64
- func (unit *Unit) DisableDynamicStatDep(sim *Simulation, dep *stats.StatDependency)
- func (unit *Unit) EnableAutoAttacks(agent Agent, options AutoAttackOptions)
- func (unit *Unit) EnableDynamicStatDep(sim *Simulation, dep *stats.StatDependency)
- func (unit *Unit) EnableEnergyBar(maxEnergy float64)
- func (unit *Unit) EnableFocusBar(regenMultiplier float64, onFocusGain OnFocusGain)
- func (unit *Unit) EnableHealthBar()
- func (unit *Unit) EnableRageBar(options RageBarOptions)
- func (mb *Unit) EndOOMEvent(sim *Simulation)
- func (unit *Unit) ExecuteCustomRotation(sim *Simulation)
- func (hb *Unit) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (at *Unit) GetActiveAuraWithTag(tag string) *Aura
- func (at *Unit) GetAura(label string) *Aura
- func (at *Unit) GetAuraByID(actionID ActionID) *Aura
- func (at *Unit) GetAuras() []*Aura
- func (at *Unit) GetAurasWithTag(tag string) []*Aura
- func (unit *Unit) GetCritTakenMultiplier(spell *Spell) float64
- func (unit *Unit) GetCurrentPowerBar() PowerBarType
- func (unit *Unit) GetDiminishedDodgeChance() float64
- func (unit *Unit) GetDiminishedMissChance() float64
- func (unit *Unit) GetDiminishedParryChance() float64
- func (caster *Unit) GetEnemyExclusiveCategories(category string) ExclusiveCategoryArray
- func (at *Unit) GetIcdAuraByID(actionID ActionID) *Aura
- func (unit *Unit) GetInitialStat(stat stats.Stat) float64
- func (unit *Unit) GetManaNotCastingMetrics() *ResourceMetrics
- func (unit *Unit) GetMetadata() *proto.UnitMetadata
- func (at *Unit) GetMetricsProto() []*proto.AuraMetrics
- func (unit *Unit) GetOpponents() []*Unit
- func (unit *Unit) GetOrInitTimer(timer **Timer) *Timer
- func (unit *Unit) GetOrRegisterAura(aura Aura) *Aura
- func (unit *Unit) GetOrRegisterSpell(config SpellConfig) *Spell
- func (unit *Unit) GetSchoolDamageDoneMultiplier(spell *Spell) float64
- func (unit *Unit) GetSchoolDamageTakenMultiplier(spell *Spell) float64
- func (unit *Unit) GetSpell(actionID ActionID) *Spell
- func (unit *Unit) GetSpellsMatchingSchool(school SpellSchool) []*Spell
- func (unit *Unit) GetStat(stat stats.Stat) float64
- func (unit *Unit) GetStats() stats.Stats
- func (unit *Unit) GetUnit(ref *proto.UnitReference) *Unit
- func (at *Unit) HasActiveAura(label string) bool
- func (at *Unit) HasActiveAuraWithTag(tag string) bool
- func (at *Unit) HasActiveAuraWithTagExcludingAura(tag string, excludeAura *Aura) bool
- func (at *Unit) HasAura(label string) bool
- func (at *Unit) HasAuraWithTag(tag string) bool
- func (unit *Unit) HasEnergyBar() bool
- func (unit *Unit) HasFocusBar() bool
- func (unit *Unit) HasHealthBar() bool
- func (unit *Unit) HasManaBar() bool
- func (unit *Unit) HasRageBar() bool
- func (unit *Unit) HasTemporaryBonusForStat(stat stats.Stat) bool
- func (unit *Unit) HasTemporaryMeleeSwingSpeedIncrease() bool
- func (unit *Unit) HasTemporaryRangedSwingSpeedIncrease() bool
- func (unit *Unit) HasTemporarySpellCastSpeedIncrease() bool
- func (unit *Unit) InitialCastSpeed() float64
- func (unit *Unit) IsActive() bool
- func (unit *Unit) IsEnabled() bool
- func (mb *Unit) IsOOM() bool
- func (unit *Unit) IsOpponent(other *Unit) bool
- func (unit *Unit) Log(sim *Simulation, message string, vals ...interface{})
- func (unit *Unit) LogLabel() string
- func (unit *Unit) MHNormalizedWeaponDamage(sim *Simulation, attackPower float64) float64
- func (unit *Unit) MHWeaponDamage(sim *Simulation, attackPower float64) float64
- func (unit *Unit) MP5ManaRegenPerSecond() float64
- func (unit *Unit) ManaRegenPerSecondWhileCasting() float64
- func (unit *Unit) ManaRegenPerSecondWhileNotCasting() float64
- func (unit *Unit) ManaTick(sim *Simulation)
- func (hb *Unit) MaxHealth() float64
- func (unit *Unit) MaxMana() float64
- func (unit *Unit) MoveTo(moveRange float64, sim *Simulation)
- func (unit *Unit) MultiplyAttackSpeed(sim *Simulation, amount float64)
- func (unit *Unit) MultiplyCastSpeed(amount float64)
- func (unit *Unit) MultiplyMeleeSpeed(sim *Simulation, amount float64)
- func (unit *Unit) MultiplyRangedSpeed(sim *Simulation, amount float64)
- func (unit *Unit) NewAPLAction(rot *APLRotation, config *proto.APLAction) APLActionImpl
- func (unit *Unit) NewAPLValue(rot *APLRotation, config *proto.APLValue) APLValue
- func (unit *Unit) NewComboPointMetrics(actionID ActionID) *ResourceMetrics
- func (caster *Unit) NewEnemyAuraArray(makeAura func(*Unit, int32) *Aura) AuraArray
- func (caster *Unit) NewEnemyExclusiveCategoryArray(makeExclusiveCategory func(*Unit) *ExclusiveCategory) ExclusiveCategoryArray
- func (unit *Unit) NewEnergyMetrics(actionID ActionID) *ResourceMetrics
- func (unit *Unit) NewFocusMetrics(actionID ActionID) *ResourceMetrics
- func (unit *Unit) NewHealthMetrics(actionID ActionID) *ResourceMetrics
- func (unit *Unit) NewManaMetrics(actionID ActionID) *ResourceMetrics
- func (caster *Unit) NewPartyAuraArray(makeAura func(*Unit) *Aura) AuraArray
- func (unit *Unit) NewRageMetrics(actionID ActionID) *ResourceMetrics
- func (caster *Unit) NewRaidAuraArray(makeAura func(*Unit) *Aura) AuraArray
- func (unit *Unit) NewTimer() *Timer
- func (eb *Unit) NextEnergyTickAt() time.Duration
- func (unit *Unit) NextGCDAt() time.Duration
- func (at *Unit) NumActiveAurasWithTag(tag string) int32
- func (unit *Unit) OHNormalizedWeaponDamage(sim *Simulation, attackPower float64) float64
- func (unit *Unit) OHWeaponDamage(sim *Simulation, attackPower float64) float64
- func (at *Unit) OnCastComplete(sim *Simulation, spell *Spell)
- func (at *Unit) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
- func (at *Unit) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
- func (at *Unit) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
- func (unit *Unit) OnSpellRegistered(handler SpellRegisteredHandler)
- func (unit *Unit) RangedSwingSpeed() float64
- func (unit *Unit) RangedWeaponDamage(sim *Simulation, attackPower float64) float64
- func (unit *Unit) RegisterAura(aura Aura) *Aura
- func (unit *Unit) RegisterPrepullAction(doAt time.Duration, action func(*Simulation))
- func (at *Unit) RegisterResetEffect(resetEffect ResetEffect)
- func (unit *Unit) RegisterSpell(config SpellConfig) *Spell
- func (hb *Unit) RemoveHealth(sim *Simulation, amount float64)
- func (eb *Unit) ResetEnergyTick(sim *Simulation)
- func (unit *Unit) SetCurrentPowerBar(bar PowerBarType)
- func (unit *Unit) SetGCDTimer(sim *Simulation, gcdReadyAt time.Duration)
- func (unit *Unit) SpellGCD() time.Duration
- func (eb *Unit) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
- func (eb *Unit) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (fb *Unit) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (unit *Unit) SpendMana(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (rb *Unit) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
- func (unit *Unit) SpiritManaRegenPerSecondDefault() float64
- func (mb *Unit) StartOOMEvent(sim *Simulation, requiredMana float64)
- func (unit *Unit) SwingSpeed() float64
- func (unit *Unit) TimeUntilManaRegen(desiredMana float64) time.Duration
- func (unit *Unit) UpdateManaRegenRates()
- func (unit *Unit) WaitUntil(sim *Simulation, readyTime time.Duration)
- type UnitMetrics
- func (unitMetrics *UnitMetrics) AddFinalPetMetrics(petMetrics *UnitMetrics)
- func (unitMetrics *UnitMetrics) AddOOMTime(sim *Simulation, dur time.Duration)
- func (unitMetrics *UnitMetrics) MarkOOM(sim *Simulation)
- func (unitMetrics *UnitMetrics) NewResourceMetrics(actionID ActionID, resourceType proto.ResourceType) *ResourceMetrics
- func (unitMetrics *UnitMetrics) ToProto() *proto.UnitMetrics
- func (unitMetrics *UnitMetrics) UpdateDpasp(dpspSeconds float64)
- type UnitReference
- type UnitStats
- type UnitType
- type Weapon
- func (weapon *Weapon) AverageDamage() float64
- func (weapon *Weapon) BaseDamage(sim *Simulation) float64
- func (weapon *Weapon) CalculateAverageWeaponDamage(attackPower float64) float64
- func (weapon *Weapon) CalculateNormalizedWeaponDamage(sim *Simulation, attackPower float64) float64
- func (weapon *Weapon) CalculateWeaponDamage(sim *Simulation, attackPower float64) float64
- func (weapon *Weapon) DPS() float64
- func (weapon *Weapon) EnemyWeaponDamage(sim *Simulation, attackPower float64, damageSpread float64) float64
- func (weapon *Weapon) GetSpellSchool() SpellSchool
- type WeaponAttack
Constants ¶
const ( ItemIDAtieshMage = 22589 ItemIDAtieshWarlock = 22630 ItemIDBraidedEterniumChain = 24114 ItemIDChainOfTheTwilightOwl = 24121 ItemIDEyeOfTheNight = 24116 ItemIDJadePendantOfBlasting = 20966 ItemIDTheLightningCapacitor = 28785 )
IDs for items used in core
const ( ProcMaskMeleeMH = ProcMaskMeleeMHAuto | ProcMaskMeleeMHSpecial ProcMaskMeleeOH = ProcMaskMeleeOHAuto | ProcMaskMeleeOHSpecial // Equivalent to in-game mask of 4. ProcMaskMeleeWhiteHit = ProcMaskMeleeMHAuto | ProcMaskMeleeOHAuto // Equivalent to in-game mask of 68. ProcMaskWhiteHit = ProcMaskMeleeMHAuto | ProcMaskMeleeOHAuto | ProcMaskRangedAuto // Equivalent to in-game mask of 16. ProcMaskMeleeSpecial = ProcMaskMeleeMHSpecial | ProcMaskMeleeOHSpecial // Equivalent to in-game mask of 272. ProcMaskMeleeOrRangedSpecial = ProcMaskMeleeSpecial | ProcMaskRangedSpecial // Equivalent to in-game mask of 20. ProcMaskMelee = ProcMaskMeleeWhiteHit | ProcMaskMeleeSpecial // Equivalent to in-game mask of 320. ProcMaskRanged = ProcMaskRangedAuto | ProcMaskRangedSpecial // Equivalent to in-game mask of 340. ProcMaskMeleeOrRanged = ProcMaskMelee | ProcMaskRanged ProcMaskDirect = ProcMaskMelee | ProcMaskRanged | ProcMaskSpellDamage ProcMaskSpecial = ProcMaskMeleeOrRangedSpecial | ProcMaskSpellDamage ProcMaskMeleeOrProc = ProcMaskMelee | ProcMaskProc ProcMaskSpellOrProc = ProcMaskSpellDamage | ProcMaskProc )
const ( OutcomePartial = OutcomePartial1_4 | OutcomePartial2_4 | OutcomePartial3_4 OutcomeLanded = OutcomeHit | OutcomeCrit | OutcomeCrush | OutcomeGlance | OutcomeBlock )
const ( CooldownPriorityLow = -1000 CooldownPriorityDefault = 0 CooldownPriorityDrums = 2000 CooldownPriorityBloodlust = 1000 )
const ( SpellSchoolNone SpellSchool = 0 SpellSchoolPhysical SpellSchool = 1 << iota SpellSchoolArcane SpellSchoolFire SpellSchoolFrost SpellSchoolHoly SpellSchoolNature SpellSchoolShadow // Physical x Other SpellSchoolSpellstrike = SpellSchoolPhysical | SpellSchoolArcane SpellSchoolFlamestrike = SpellSchoolPhysical | SpellSchoolFire SpellSchoolFroststrike = SpellSchoolPhysical | SpellSchoolFrost SpellSchoolHolystrike = SpellSchoolPhysical | SpellSchoolHoly SpellSchoolStormstrike = SpellSchoolPhysical | SpellSchoolNature SpellSchoolShadowstrike = SpellSchoolPhysical | SpellSchoolShadow // Arcane x Other SpellSchoolSpellfire = SpellSchoolArcane | SpellSchoolFire SpellSchoolSpellFrost = SpellSchoolArcane | SpellSchoolFrost SpellSchoolDivine = SpellSchoolArcane | SpellSchoolHoly SpellSchoolAstral = SpellSchoolArcane | SpellSchoolNature SpellSchoolSpellShadow = SpellSchoolArcane | SpellSchoolShadow // Fire x Other SpellSchoolFrostfire = SpellSchoolFire | SpellSchoolFrost SpellSchoolRadiant = SpellSchoolFire | SpellSchoolHoly SpellSchoolVolcanic = SpellSchoolFire | SpellSchoolNature SpellSchoolShadowflame = SpellSchoolFire | SpellSchoolShadow // Frost x Other SpellSchoolHolyfrost = SpellSchoolFrost | SpellSchoolHoly SpellSchoolFroststorm = SpellSchoolFrost | SpellSchoolNature SpellSchoolShadowfrost = SpellSchoolFrost | SpellSchoolShadow // Holy x Other SpellSchoolHolystorm = SpellSchoolHoly | SpellSchoolNature SpellSchoolTwilight = SpellSchoolHoly | SpellSchoolShadow // Nature x Other SpellSchoolPlague = SpellSchoolNature | SpellSchoolShadow SpellSchoolElemental = SpellSchoolFire | SpellSchoolFrost | SpellSchoolNature SpellSchoolAttack = SpellSchoolPhysical | SpellSchoolSpellstrike | SpellSchoolFlamestrike | SpellSchoolFroststrike | SpellSchoolHolystrike | SpellSchoolStormstrike | SpellSchoolShadowstrike SpellSchoolMagic = SpellSchoolArcane | SpellSchoolFire | SpellSchoolFrost | SpellSchoolHoly | SpellSchoolNature | SpellSchoolShadow )
const ArmorPenPerPercentArmor = 13.99
const AverageMagicPartialResistPerLevelMultiplier = 0.02
const BaseFocusPerTick = 5.0
const BattleShoutRanks = 7
const BleedEffectCategory = "BleedDamage"
Bleed Damage Multiplier category
const BlockRatingPerBlockChance = 5.000000
const BloodlustAuraTag = "Bloodlust"
const BloodlustCD = time.Minute * 10
const BloodlustDuration = time.Second * 40
const CharacterBuildPhaseAll = CharacterBuildPhaseBase | CharacterBuildPhaseGear | CharacterBuildPhaseTalents | CharacterBuildPhaseBuffs | CharacterBuildPhaseConsumes
const CharacterMaxLevel = 60
const CritRatingPerCritChance = 1
const DTPSReferenceStat = stats.Armor
const DefaultAttackPowerPerDPS = 14.0
const DefenseRatingPerDefense = 1.500000
const DefenseRatingToChanceReduction = (1.0 / DefenseRatingPerDefense) * MissDodgeParryBlockCritChancePerDefense / 100
const DemoralizingShoutRanks = 5
const Diminish_Cd_Druid = 116.890707 / 100
const Diminish_Cd_Nondruid = 88.129021 / 100
const Diminish_Cm = 16.000 / 100
const Diminish_Cp = 47.003525 / 100
const Diminish_kCd_Druid = (Diminish_k_Druid * Diminish_Cd_Druid)
const Diminish_kCd_Nondruid = (Diminish_k_Nondruid * Diminish_Cd_Nondruid)
const Diminish_kCm_Druid = (Diminish_k_Druid * Diminish_Cm)
const Diminish_kCm_Nondruid = (Diminish_k_Nondruid * Diminish_Cm)
const Diminish_kCp = (Diminish_k_Nondruid * Diminish_Cp)
const Diminish_k_Druid = 0.972
Could be in constants.go, but they won't be used anywhere else C values are divided by 100 so that we are working with 1% = 0.01
const Diminish_k_Nondruid = 0.956
const DivineGuardianCD = time.Minute * 2
const DivineGuardianDuration = time.Second * 6
const DodgeRatingPerDodgeChance = 13.800001
const EnemyAutoAttackAPCoefficient = 1.0 / (14.0 * 177.0)
Updated based on formulas supplied by InDebt on WoWSims Discord
const EnergyPerTick = 20.2
const EnergyTickDuration = time.Millisecond * 2020
Time between energy ticks.
const ExpertisePerQuarterPercentReduction = 2.500000
const GCDDefault = time.Millisecond * 1500
const GCDMin = time.Second * 1
const GuardianSpiritCD = time.Minute * 3
const GuardianSpiritDuration = time.Second * 10
const HandOfSacrificeCD = time.Minute * 5 // use Divine Shield CD here
const HandOfSacrificeDuration = time.Millisecond * 10500 // subtract Divine Shield GCD
const HasteRatingPerHastePercent = 1
Crit/Hit/Haste ratings are straight percentage values in classic
const HuntersMarkAuraTag = "HuntersMark"
const Inactive = -1
const InnervateCD = time.Minute * 6
const InnervateDuration = time.Second * 20
const LongDuration = 300
const ManaTideTotemCD = time.Minute * 5
const ManaTideTotemDuration = time.Second * 12
const MaxFocus = 100.0
Time between focus ticks.
const MaxRage = 100.0
const MeleeHitRatingPerHitChance = 1
const MissDodgeParryBlockCritChancePerDefense = 0.04
const NeverExpires = time.Duration(math.MaxInt64)
const PainSuppressionCD = time.Minute * 3
const PainSuppressionDuration = time.Second * 8
const ParryRatingPerParryChance = 13.800001
const PowerInfusionCD = time.Minute * 3
const PowerInfusionDuration = time.Second * 15
const ReplenishmentAuraDuration = time.Second * 15
const ResilienceRatingPerCritDamageReductionPercent = ResilienceRatingPerCritReductionChance / 2.2
const ResilienceRatingPerCritReductionChance = 28.750002
const SatedAuraLabel = "Sated"
const ShatteringThrowCD = time.Minute * 5
const ShortDuration = 60
const SpellBatchWindow = time.Millisecond * 10
const SpellCritEffectCategory = "spellcritdebuff"
const SpellCritRatingPerCritChance = 1
const SpellFirePowerEffectCategory = "spellFirePowerdebuff"
const SpellHitRatingPerHitChance = 1
const ThreatPerManaGained = 0.5
const ThreatPerRageGained = 5
const TricksOfTheTradeCD = time.Second * 3600 // CD is 30s from the time buff ends (so 40s with glyph) but that's in order to be able to set the number of TotT you'll have during the fight
const UnholyFrenzyCD = time.Minute * 3
const UnholyFrenzyDuration = time.Second * 30
const WindfuryRanks = 3
Variables ¶
var ( WindfuryBuffLevelToRank = []int32{ 25: 0, 40: 1, 50: 2, 60: 3, } WindfuryBuffSpellId = [WindfuryRanks + 1]int32{0, 8516, 10608, 10610} WindfuryBuffBonusAP = [WindfuryRanks + 1]float64{0, 122, 229, 315} )
var AddEffectsToTest = true
This value can be set before adding item effects, to control whether they are included in tests.
var AverageDefaultSimTestOptions = &proto.SimOptions{ Iterations: 2000, IsTest: true, Debug: false, RandomSeed: 101, }
var BaseStats = map[BaseStatsKey]stats.Stats{}
var BattleShoutBaseAP = [BattleShoutRanks + 1]float64{0, 20, 40, 57, 93, 138, 193, 232}
var BattleShoutLevel = [BattleShoutRanks + 1]int{0, 1, 12, 22, 32, 42, 52, 60}
var BattleShoutSpellId = [BattleShoutRanks + 1]int32{0, 6673, 5242, 6192, 11549, 11550, 11551, 25289}
var BloodlustActionID = ActionID{SpellID: 2825}
var BuffSpellByLevel = map[BuffName]map[int32]stats.Stats{ ArcaneIntellect: { 25: stats.Stats{ stats.Intellect: 7, }, 40: stats.Stats{ stats.Intellect: 15, }, 50: stats.Stats{ stats.Intellect: 22, }, 60: stats.Stats{ stats.Intellect: 31, }, }, DivineSpirit: { 25: stats.Stats{ stats.Spirit: 0, }, 40: stats.Stats{ stats.Spirit: 23, }, 50: stats.Stats{ stats.Spirit: 33, }, 60: stats.Stats{ stats.Spirit: 40, }, }, AspectOfTheWild: { 25: stats.Stats{ stats.NatureResistance: 0, }, 40: stats.Stats{ stats.Stamina: 0, }, 50: stats.Stats{ stats.Stamina: 45, }, 60: stats.Stats{ stats.Stamina: 60, }, }, BattleShout: { 25: stats.Stats{ stats.AttackPower: 60, }, 40: stats.Stats{ stats.AttackPower: 94, }, 50: stats.Stats{ stats.AttackPower: 139, }, 60: stats.Stats{ stats.AttackPower: 193, }, }, BlessingOfMight: { 25: stats.Stats{ stats.AttackPower: 55, }, 40: stats.Stats{ stats.AttackPower: 85, }, 50: stats.Stats{ stats.AttackPower: 115, }, 60: stats.Stats{ stats.AttackPower: 185, }, }, BlessingOfWisdom: { 25: stats.Stats{ stats.MP5: 15, }, 40: stats.Stats{ stats.MP5: 20, }, 50: stats.Stats{ stats.MP5: 25, }, 60: stats.Stats{ stats.MP5: 33, }, }, BloodPact: { 25: stats.Stats{ stats.Stamina: 9, }, 40: stats.Stats{ stats.Stamina: 30, }, 50: stats.Stats{ stats.Stamina: 42, }, 60: stats.Stats{ stats.Stamina: 42, }, }, GraceOfAir: { 25: stats.Stats{ stats.Agility: 0, }, 40: stats.Stats{ stats.Agility: 0, }, 50: stats.Stats{ stats.Agility: 43, }, 60: stats.Stats{ stats.Agility: 77, }, }, FrostResistanceAura: { 25: stats.Stats{ stats.NatureResistance: 0, }, 40: stats.Stats{ stats.Stamina: 30, }, 50: stats.Stats{ stats.Stamina: 45, }, 60: stats.Stats{ stats.Stamina: 60, }, }, FrostResistanceTotem: { 25: stats.Stats{ stats.NatureResistance: 30, }, 40: stats.Stats{ stats.Stamina: 45, }, 50: stats.Stats{ stats.Stamina: 60, }, 60: stats.Stats{ stats.Stamina: 60, }, }, HornOfLordaeron: { 25: stats.Stats{ stats.Strength: 17, stats.Agility: 17, }, 40: stats.Stats{ stats.Strength: 26, stats.Agility: 26, }, 50: stats.Stats{ stats.Strength: 45, stats.Agility: 45, }, 60: stats.Stats{ stats.Strength: 89, stats.Agility: 89, }, }, ManaSpring: { 25: stats.Stats{ stats.MP5: 0, }, 40: stats.Stats{ stats.MP5: 15, }, 50: stats.Stats{ stats.MP5: 20, }, 60: stats.Stats{ stats.MP5: 25, }, }, MarkOfTheWild: { 25: stats.Stats{ stats.Armor: 105, stats.Stamina: 4, stats.Agility: 4, stats.Strength: 4, stats.Intellect: 4, stats.Spirit: 4, stats.ArcaneResistance: 0, stats.ShadowResistance: 0, stats.NatureResistance: 0, stats.FireResistance: 0, stats.FrostResistance: 0, }, 40: stats.Stats{ stats.Armor: 195, stats.Stamina: 8, stats.Agility: 8, stats.Strength: 8, stats.Intellect: 8, stats.Spirit: 8, stats.ArcaneResistance: 10, stats.ShadowResistance: 10, stats.NatureResistance: 10, stats.FireResistance: 10, stats.FrostResistance: 10, }, 50: stats.Stats{ stats.Armor: 240, stats.Stamina: 10, stats.Agility: 10, stats.Strength: 10, stats.Intellect: 10, stats.Spirit: 10, stats.ArcaneResistance: 15, stats.ShadowResistance: 15, stats.NatureResistance: 15, stats.FireResistance: 15, stats.FrostResistance: 15, }, 60: stats.Stats{ stats.Armor: 285, stats.Stamina: 12, stats.Agility: 12, stats.Strength: 12, stats.Intellect: 12, stats.Spirit: 12, stats.ArcaneResistance: 20, stats.ShadowResistance: 20, stats.NatureResistance: 20, stats.FireResistance: 20, stats.FrostResistance: 20, }, }, NatureResistanceTotem: { 25: stats.Stats{ stats.NatureResistance: 0, }, 40: stats.Stats{ stats.Stamina: 30, }, 50: stats.Stats{ stats.Stamina: 45, }, 60: stats.Stats{ stats.Stamina: 60, }, }, PowerWordFortitude: { 25: stats.Stats{ stats.Stamina: 20, }, 40: stats.Stats{ stats.Stamina: 32, }, 50: stats.Stats{ stats.Stamina: 43, }, 60: stats.Stats{ stats.Stamina: 54, }, }, ShadowProtection: { 25: stats.Stats{ stats.ShadowResistance: 0, }, 40: stats.Stats{ stats.Stamina: 30, }, 50: stats.Stats{ stats.Stamina: 45, }, 60: stats.Stats{ stats.Stamina: 60, }, }, TrueshotAura: { 25: stats.Stats{ stats.AttackPower: 0, stats.RangedAttackPower: 0, }, 40: stats.Stats{ stats.AttackPower: 50, stats.RangedAttackPower: 50, }, 50: stats.Stats{ stats.AttackPower: 75, stats.RangedAttackPower: 75, }, 60: stats.Stats{ stats.AttackPower: 100, stats.RangedAttackPower: 100, }, }, StrengthOfEarth: { 25: stats.Stats{ stats.Strength: 20, }, 40: stats.Stats{ stats.Strength: 36, }, 50: stats.Stats{ stats.Strength: 61, }, 60: stats.Stats{ stats.Strength: 77, }, }, ScrollOfAgility: { 25: stats.Stats{ stats.Agility: 9, }, 40: stats.Stats{ stats.Agility: 13, }, 50: stats.Stats{ stats.Agility: 17, }, 60: stats.Stats{ stats.Agility: 17, }, }, ScrollOfIntellect: { 25: stats.Stats{ stats.Intellect: 8, }, 40: stats.Stats{ stats.Intellect: 12, }, 50: stats.Stats{ stats.Intellect: 16, }, 60: stats.Stats{ stats.Intellect: 16, }, }, ScrollOfSpirit: { 25: stats.Stats{ stats.Spirit: 7, }, 40: stats.Stats{ stats.Spirit: 11, }, 50: stats.Stats{ stats.Spirit: 15, }, 60: stats.Stats{ stats.Spirit: 15, }, }, ScrollOfStamina: { 25: stats.Stats{ stats.Stamina: 8, }, 40: stats.Stats{ stats.Stamina: 12, }, 50: stats.Stats{ stats.Stamina: 16, }, 60: stats.Stats{ stats.Stamina: 16, }, }, ScrollOfStrength: { 25: stats.Stats{ stats.Strength: 9, }, 40: stats.Stats{ stats.Strength: 13, }, 50: stats.Stats{ stats.Strength: 13, }, 60: stats.Stats{ stats.Strength: 17, }, }, }
Stats from buffs pre-tristate buffs
var ChanceOfDeathAuraLabel = "Chance of Death"
var ClassBaseCrit = map[proto.Class]stats.Stats{ proto.Class_ClassUnknown: {}, proto.Class_ClassWarrior: { stats.SpellCrit: 0.0000 * CritRatingPerCritChance, stats.MeleeCrit: 0.0000 * CritRatingPerCritChance, }, proto.Class_ClassPaladin: { stats.SpellCrit: 3.5000 * CritRatingPerCritChance, stats.MeleeCrit: 0.7000 * CritRatingPerCritChance, }, proto.Class_ClassHunter: { stats.SpellCrit: 3.6000 * CritRatingPerCritChance, stats.MeleeCrit: 0.0000 * CritRatingPerCritChance, }, proto.Class_ClassRogue: { stats.SpellCrit: 0.0000 * CritRatingPerCritChance, stats.MeleeCrit: 0.0000 * CritRatingPerCritChance, }, proto.Class_ClassPriest: { stats.SpellCrit: 0.8000 * CritRatingPerCritChance, stats.MeleeCrit: 3.0000 * CritRatingPerCritChance, }, proto.Class_ClassShaman: { stats.SpellCrit: 2.3000 * CritRatingPerCritChance, stats.MeleeCrit: 1.7000 * CritRatingPerCritChance, }, proto.Class_ClassMage: { stats.SpellCrit: 0.2000 * CritRatingPerCritChance, stats.MeleeCrit: 3.2000 * CritRatingPerCritChance, }, proto.Class_ClassWarlock: { stats.SpellCrit: 1.7000 * CritRatingPerCritChance, stats.MeleeCrit: 2.0000 * CritRatingPerCritChance, }, proto.Class_ClassDruid: { stats.SpellCrit: 1.8000 * CritRatingPerCritChance, stats.MeleeCrit: 0.9000 * CritRatingPerCritChance, }, }
var ClassBaseStats = map[proto.Class]map[int]stats.Stats{ proto.Class_ClassUnknown: {}, proto.Class_ClassWarrior: { 25: { stats.Health: 274, stats.Mana: 0, stats.Agility: 39, stats.Strength: 54, stats.Intellect: 23, stats.Spirit: 28, stats.Stamina: 50, stats.AttackPower: 25*3 - 20, }, 40: { stats.Health: 649, stats.Mana: 0, stats.Agility: 54, stats.Strength: 79, stats.Intellect: 26, stats.Spirit: 34, stats.Stamina: 72, stats.AttackPower: 40*3 - 20, }, 50: { stats.Health: 1079, stats.Mana: 0, stats.Agility: 66, stats.Strength: 98, stats.Intellect: 28, stats.Spirit: 39, stats.Stamina: 90, stats.AttackPower: 50*3 - 20, }, 60: { stats.Health: 1689, stats.Mana: 0, stats.Agility: 80, stats.Strength: 120, stats.Intellect: 30, stats.Spirit: 45, stats.Stamina: 110, stats.AttackPower: 60*3 - 20, }, }, proto.Class_ClassPaladin: { 25: { stats.Health: 266, stats.Mana: 552, stats.Agility: 34, stats.Strength: 48, stats.Intellect: 36, stats.Spirit: 38, stats.Stamina: 47, stats.AttackPower: 25*3 - 20, }, 40: { stats.Health: 621, stats.Mana: 987, stats.Agility: 46, stats.Strength: 70, stats.Intellect: 49, stats.Spirit: 52, stats.Stamina: 67, stats.AttackPower: 40*3 - 20, }, 50: { stats.Health: 966, stats.Mana: 1257, stats.Agility: 55, stats.Strength: 86, stats.Intellect: 59, stats.Spirit: 63, stats.Stamina: 82, stats.AttackPower: 50*3 - 20, }, 60: { stats.Health: 1381, stats.Mana: 1512, stats.Agility: 65, stats.Strength: 105, stats.Intellect: 70, stats.Spirit: 75, stats.Stamina: 100, stats.AttackPower: 60*3 - 20, }, }, proto.Class_ClassHunter: { 25: { stats.Health: 292, stats.Mana: 611, stats.Agility: 55, stats.Strength: 31, stats.Intellect: 34, stats.Spirit: 37, stats.Stamina: 43, stats.AttackPower: 25*2 - 20, stats.RangedAttackPower: 25*2 - 20, }, 40: { stats.Health: 667, stats.Mana: 1105, stats.Agility: 81, stats.Strength: 40, stats.Intellect: 46, stats.Spirit: 49, stats.Stamina: 61, stats.AttackPower: 40*2 - 20, stats.RangedAttackPower: 40*2 - 20, }, 50: { stats.Health: 1047, stats.Mana: 1420, stats.Agility: 102, stats.Strength: 47, stats.Intellect: 55, stats.Spirit: 59, stats.Stamina: 74, stats.AttackPower: 50*2 - 20, stats.RangedAttackPower: 50*2 - 20, }, 60: { stats.Health: 1467, stats.Mana: 1720, stats.Agility: 125, stats.Strength: 55, stats.Intellect: 65, stats.Spirit: 70, stats.Stamina: 90, stats.AttackPower: 60*2 - 20, stats.RangedAttackPower: 60*2 - 20, }, }, proto.Class_ClassRogue: { 25: { stats.Health: 318, stats.Mana: 0, stats.Agility: 57, stats.Strength: 40, stats.Intellect: 25, stats.Spirit: 30, stats.Stamina: 38, stats.AttackPower: 25*2 - 20, }, 40: { stats.Health: 703, stats.Mana: 0, stats.Agility: 84, stats.Strength: 55, stats.Intellect: 29, stats.Spirit: 37, stats.Stamina: 52, stats.AttackPower: 40*2 - 20, }, 50: { stats.Health: 1068, stats.Mana: 0, stats.Agility: 106, stats.Strength: 67, stats.Intellect: 32, stats.Spirit: 43, stats.Stamina: 63, stats.AttackPower: 50*2 - 20, }, 60: { stats.Health: 1523, stats.Mana: 0, stats.Agility: 130, stats.Strength: 80, stats.Intellect: 35, stats.Spirit: 50, stats.Stamina: 75, stats.AttackPower: 60*2 - 20, }, }, proto.Class_ClassPriest: { 25: { stats.Health: 302, stats.Mana: 497, stats.Agility: 26, stats.Strength: 25, stats.Intellect: 53, stats.Spirit: 55, stats.Stamina: 30, stats.AttackPower: -10, }, 40: { stats.Health: 637, stats.Mana: 911, stats.Agility: 31, stats.Strength: 29, stats.Intellect: 78, stats.Spirit: 81, stats.Stamina: 37, stats.AttackPower: -10, }, 50: { stats.Health: 972, stats.Mana: 1166, stats.Agility: 35, stats.Strength: 32, stats.Intellect: 98, stats.Spirit: 102, stats.Stamina: 43, stats.AttackPower: -10, }, 60: { stats.Health: 1397, stats.Mana: 1376, stats.Agility: 40, stats.Strength: 35, stats.Intellect: 120, stats.Spirit: 125, stats.Stamina: 50, stats.AttackPower: -10, }, }, proto.Class_ClassShaman: { 25: { stats.Health: 257, stats.Mana: 505, stats.Agility: 31, stats.Strength: 41, stats.Intellect: 43, stats.Spirit: 47, stats.Stamina: 45, stats.AttackPower: 25*2 - 20, }, 40: { stats.Health: 610, stats.Mana: 975, stats.Agility: 40, stats.Strength: 58, stats.Intellect: 61, stats.Spirit: 67, stats.Stamina: 63, stats.AttackPower: 40*2 - 20, }, 50: { stats.Health: 947, stats.Mana: 1255, stats.Agility: 47, stats.Strength: 70, stats.Intellect: 74, stats.Spirit: 82, stats.Stamina: 78, stats.AttackPower: 50*2 - 20, }, 60: { stats.Health: 1423, stats.Mana: 1520, stats.Agility: 55, stats.Strength: 85, stats.Intellect: 90, stats.Spirit: 100, stats.Stamina: 95, stats.AttackPower: 60*2 - 20, }, }, proto.Class_ClassMage: { 25: { stats.Health: 315, stats.Mana: 481, stats.Agility: 25, stats.Strength: 23, stats.Intellect: 55, stats.Spirit: 53, stats.Stamina: 28, stats.AttackPower: -10, }, 40: { stats.Health: 630, stats.Mana: 853, stats.Agility: 29, stats.Strength: 26, stats.Intellect: 81, stats.Spirit: 78, stats.Stamina: 34, stats.AttackPower: -10, }, 50: { stats.Health: 955, stats.Mana: 1048, stats.Agility: 32, stats.Strength: 28, stats.Intellect: 102, stats.Spirit: 98, stats.Stamina: 39, stats.AttackPower: -10, }, 60: { stats.Health: 1370, stats.Mana: 1213, stats.Agility: 35, stats.Strength: 30, stats.Intellect: 125, stats.Spirit: 120, stats.Stamina: 45, stats.AttackPower: -10, }, }, proto.Class_ClassWarlock: { 25: { stats.Health: 279, stats.Mana: 498, stats.Agility: 30, stats.Strength: 28, stats.Intellect: 50, stats.Spirit: 52, stats.Stamina: 35, stats.AttackPower: -10, }, 40: { stats.Health: 634, stats.Mana: 923, stats.Agility: 37, stats.Strength: 34, stats.Intellect: 72, stats.Spirit: 75, stats.Stamina: 46, stats.AttackPower: -10, }, 50: { stats.Health: 979, stats.Mana: 1163, stats.Agility: 43, stats.Strength: 39, stats.Intellect: 90, stats.Spirit: 94, stats.Stamina: 55, stats.AttackPower: -10, }, 60: { stats.Health: 1414, stats.Mana: 1373, stats.Agility: 50, stats.Strength: 45, stats.Intellect: 110, stats.Spirit: 115, stats.Stamina: 65, stats.AttackPower: -10, }, }, proto.Class_ClassDruid: { 25: { stats.Health: 318, stats.Mana: 479, stats.Agility: 33, stats.Strength: 35, stats.Intellect: 47, stats.Spirit: 50, stats.Stamina: 36, stats.AttackPower: -20, }, 40: { stats.Health: 683, stats.Mana: 854, stats.Agility: 43, stats.Strength: 46, stats.Intellect: 67, stats.Spirit: 72, stats.Stamina: 49, stats.AttackPower: -20, }, 50: { stats.Health: 1038, stats.Mana: 1064, stats.Agility: 51, stats.Strength: 55, stats.Intellect: 82, stats.Spirit: 90, stats.Stamina: 59, stats.AttackPower: -20, }, 60: { stats.Health: 1483, stats.Mana: 1244, stats.Agility: 60, stats.Strength: 65, stats.Intellect: 100, stats.Spirit: 110, stats.Stamina: 70, stats.AttackPower: -20, }, }, }
var CritPerAgiAtLevel = map[proto.Class]map[int]float64{ proto.Class_ClassUnknown: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassWarrior: {25: 0.1111, 40: 0.0758, 50: 0.0604, 60: 0.0500}, proto.Class_ClassPaladin: {25: 0.1075, 40: 0.0741, 50: 0.0618, 60: 0.0506}, proto.Class_ClassHunter: {25: 0.0515, 40: 0.0303, 50: 0.0239, 60: 0.0189}, proto.Class_ClassRogue: {25: 0.0952, 40: 0.0556, 50: 0.0440, 60: 0.0345}, proto.Class_ClassPriest: {25: 0.0769, 40: 0.0645, 50: 0.0565, 60: 0.0500}, proto.Class_ClassShaman: {25: 0.0971, 40: 0.0717, 50: 0.0602, 60: 0.0508}, proto.Class_ClassMage: {25: 0.0720, 40: 0.0621, 50: 0.0566, 60: 0.0514}, proto.Class_ClassWarlock: {25: 0.0909, 40: 0.0698, 50: 0.0551, 60: 0.0500}, proto.Class_ClassDruid: {25: 0.1025, 40: 0.0719, 50: 0.0599, 60: 0.0500}, }
Melee/Ranged crit agi scaling TODO P3: Level 50 values are still wotlk values
var CritPerIntAtLevel = map[proto.Class]map[int]float64{ proto.Class_ClassUnknown: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassWarrior: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassPaladin: {25: 0.0357, 40: 0.0246, 50: 0.0203, 60: 0.0167}, proto.Class_ClassHunter: {25: 0.0350, 40: 0.0241, 50: 0.0200, 60: 0.0165}, proto.Class_ClassRogue: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassPriest: {25: 0.0457, 40: 0.0269, 50: 0.0212, 60: 0.0168}, proto.Class_ClassShaman: {25: 0.0422, 40: 0.0262, 50: 0.0210, 60: 0.0169}, proto.Class_ClassMage: {25: 0.0475, 40: 0.0276, 50: 0.0214, 60: 0.0168}, proto.Class_ClassWarlock: {25: 0.0429, 40: 0.0262, 50: 0.0207, 60: 0.0165}, proto.Class_ClassDruid: {25: 0.0427, 40: 0.0260, 50: 0.0208, 60: 0.0167}, }
Spell crit int scaling TODO P3: Level 50 values are still wotlk values
var DefaultSimTestOptions = &proto.SimOptions{ Iterations: 20, IsTest: true, Debug: false, RandomSeed: 101, }
var DefaultTargetProtoLvl25 = &proto.Target{ Level: 27, Stats: stats.Stats{ stats.Armor: 1104, stats.AttackPower: 320, }.ToFloatArray(), MobType: proto.MobType_MobTypeDemon, SwingSpeed: 2, MinBaseDamage: 4192.05, ParryHaste: true, DamageSpread: 0.3333, }
var DefaultTargetProtoLvl40 = &proto.Target{ Level: 42, Stats: stats.Stats{ stats.Armor: 1104, stats.AttackPower: 320, }.ToFloatArray(), MobType: proto.MobType_MobTypeDemon, SwingSpeed: 2, MinBaseDamage: 4192.05, ParryHaste: true, DamageSpread: 0.3333, }
var DemoralizingShoutBaseAP = [DemoralizingShoutRanks + 1]float64{0, 45, 56, 76, 111, 146}
var DemoralizingShoutLevel = [DemoralizingShoutRanks + 1]int{0, 14, 24, 34, 44, 54}
var DemoralizingShoutSpellId = [DemoralizingShoutRanks + 1]int32{0, 1160, 6190, 11554, 11555, 11556}
var DenseDynamiteActionID = ActionID{ItemID: 18641}
var DivineGuardianAuraTag = "DivineGuardian"
var DodgePerAgiAtLevel = map[proto.Class]map[int32]float64{ proto.Class_ClassUnknown: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassWarrior: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassPaladin: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassHunter: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassRogue: {25: float64(1 / 5.429), 40: 0.111, 50: 0.0, 60: 0}, proto.Class_ClassPriest: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassShaman: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassMage: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassWarlock: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, proto.Class_ClassDruid: {25: 0.0, 40: 0.0, 50: 0.0, 60: 0.0}, }
Dodge agility scaling TODO: Scaling for all classes and for past level 50
var EnchantsByEffectID = map[int32]Enchant{}
var EzThroRadiationBombActionID = ActionID{ItemID: 215168}
var FullBuffsPhase1 = BuffsCombo{ Label: "Phase 1 Buffs", Debuffs: FullDebuffsPhase1, Party: FullPartyBuffs, Player: FullIndividualBuffsPhase1, Raid: FullRaidBuffsPhase1, }
var FullBuffsPhase2 = BuffsCombo{ Label: "Phase 2 Buffs", Debuffs: FullDebuffsPhase2, Party: FullPartyBuffs, Player: FullIndividualBuffsPhase2, Raid: FullRaidBuffsPhase2, }
var FullDebuffsPhase1 = &proto.Debuffs{ CurseOfElements: true, CurseOfRecklessness: true, CurseOfVulnerability: true, CurseOfWeakness: proto.TristateEffect_TristateEffectImproved, DemoralizingRoar: proto.TristateEffect_TristateEffectImproved, DemoralizingShout: proto.TristateEffect_TristateEffectImproved, Dreamstate: true, ExposeArmor: proto.TristateEffect_TristateEffectImproved, FaerieFire: true, InsectSwarm: true, ImprovedShadowBolt: true, ScorpidSting: true, SunderArmor: true, ThunderClap: proto.TristateEffect_TristateEffectImproved, }
var FullDebuffsPhase2 = &proto.Debuffs{ CurseOfElements: true, CurseOfRecklessness: true, CurseOfVulnerability: true, CurseOfWeakness: proto.TristateEffect_TristateEffectImproved, DemoralizingRoar: proto.TristateEffect_TristateEffectImproved, DemoralizingShout: proto.TristateEffect_TristateEffectImproved, Dreamstate: true, ExposeArmor: proto.TristateEffect_TristateEffectImproved, FaerieFire: true, InsectSwarm: true, ImprovedScorch: true, ImprovedShadowBolt: true, JudgementOfLight: true, JudgementOfWisdom: true, ScorpidSting: true, ShadowWeaving: true, Stormstrike: true, SunderArmor: true, ThunderClap: proto.TristateEffect_TristateEffectImproved, WintersChill: true, }
var FullIndividualBuffsPhase1 = &proto.IndividualBuffs{ AshenvalePvpBuff: true, BlessingOfKings: true, BlessingOfMight: proto.TristateEffect_TristateEffectImproved, BlessingOfWisdom: proto.TristateEffect_TristateEffectImproved, BoonOfBlackfathom: true, SaygesFortune: proto.SaygesFortune_SaygesDamage, }
var FullIndividualBuffsPhase2 = &proto.IndividualBuffs{ BlessingOfKings: true, BlessingOfMight: proto.TristateEffect_TristateEffectImproved, BlessingOfSanctuary: true, BlessingOfWisdom: proto.TristateEffect_TristateEffectImproved, SaygesFortune: proto.SaygesFortune_SaygesDamage, SparkOfInspiration: true, }
var FullPartyBuffs = &proto.PartyBuffs{}
var FullRaidBuffsPhase1 = &proto.RaidBuffs{ ArcaneBrilliance: true, AspectOfTheLion: true, BattleShout: proto.TristateEffect_TristateEffectImproved, BloodPact: proto.TristateEffect_TristateEffectImproved, DevotionAura: proto.TristateEffect_TristateEffectImproved, GiftOfTheWild: proto.TristateEffect_TristateEffectImproved, PowerWordFortitude: proto.TristateEffect_TristateEffectImproved, RetributionAura: proto.TristateEffect_TristateEffectImproved, StrengthOfEarthTotem: proto.TristateEffect_TristateEffectImproved, Thorns: proto.TristateEffect_TristateEffectImproved, }
var FullRaidBuffsPhase2 = &proto.RaidBuffs{ ArcaneBrilliance: true, AspectOfTheLion: true, BattleShout: proto.TristateEffect_TristateEffectImproved, BloodPact: proto.TristateEffect_TristateEffectImproved, DevotionAura: proto.TristateEffect_TristateEffectImproved, DivineSpirit: true, FireResistanceAura: true, FireResistanceTotem: true, FrostResistanceAura: true, FrostResistanceTotem: true, GiftOfTheWild: proto.TristateEffect_TristateEffectImproved, LeaderOfThePack: true, ManaSpringTotem: proto.TristateEffect_TristateEffectImproved, MoonkinAura: true, NatureResistanceTotem: true, PowerWordFortitude: proto.TristateEffect_TristateEffectImproved, RetributionAura: proto.TristateEffect_TristateEffectImproved, ShadowProtection: true, StrengthOfEarthTotem: proto.TristateEffect_TristateEffectImproved, Thorns: proto.TristateEffect_TristateEffectImproved, TrueshotAura: true, SanctityAura: true, }
var GoblinLandMineActionID = ActionID{ItemID: 4395}
var GuardianSpiritAuraTag = "GuardianSpirit"
var HandOfSacrificeAuraTag = "HandOfSacrifice"
var HighYieldRadiationBombActionID = ActionID{ItemID: 215127}
var InnervateAuraTag = "Innervate"
var ItemsByID = map[int32]Item{}
var JudgementOfLightAuraLabel = "Judgement of Light"
var JudgementOfWisdomAuraLabel = "Judgement of Wisdom"
var LevelToBuffRank = map[BuffName]map[int32]int32{ BattleShout: { 25: 3, 40: 4, 50: 5, 60: 7, }, GraceOfAir: { 50: 1, 60: 3, }, StrengthOfEarth: { 25: 2, 40: 3, 50: 3, 60: 5, }, Windfury: { 40: 1, 50: 2, 60: 3, }, }
var LevelToDebuffRank = map[DebuffName]map[int32]int32{ DemoralizingShout: { 25: 2, 40: 3, 50: 4, 60: 5, }, }
var ManaTideTotemActionID = ActionID{SpellID: 16190}
var ManaTideTotemAuraTag = "ManaTideTotem"
var PainSuppressionAuraTag = "PainSuppression"
var PowerInfusionActionID = ActionID{SpellID: 10060}
var PowerInfusionAuraTag = "PowerInfusion"
var PresetEncounters []*proto.PresetEncounter
var RaceOffsets = map[proto.Race]stats.Stats{ proto.Race_RaceUnknown: {}, proto.Race_RaceHuman: {}, proto.Race_RaceOrc: { stats.Agility: -3, stats.Strength: 3, stats.Intellect: -3, stats.Spirit: 3, stats.Stamina: 2, }, proto.Race_RaceDwarf: { stats.Agility: -4, stats.Strength: 2, stats.Intellect: -1, stats.Spirit: -1, stats.Stamina: 3, }, proto.Race_RaceNightElf: { stats.Agility: 5, stats.Strength: -3, stats.Intellect: 0, stats.Spirit: 0, stats.Stamina: -1, }, proto.Race_RaceUndead: { stats.Agility: -2, stats.Strength: -1, stats.Intellect: -2, stats.Spirit: 5, stats.Stamina: 1, }, proto.Race_RaceTauren: { stats.Agility: -5, stats.Strength: 5, stats.Intellect: -5, stats.Spirit: 2, stats.Stamina: 2, }, proto.Race_RaceGnome: { stats.Agility: 3, stats.Strength: -5, stats.Intellect: 3, stats.Spirit: 0, stats.Stamina: -1, }, proto.Race_RaceTroll: { stats.Agility: 2, stats.Strength: 1, stats.Intellect: -4, stats.Spirit: 1, stats.Stamina: 1, }, }
var RandomSuffixesByID = map[int32]RandomSuffix{}
var SapperActionID = ActionID{ItemID: 10646}
var SolidDynamiteActionID = ActionID{ItemID: 10507}
var StatWeightsDefaultSimTestOptions = &proto.SimOptions{ Iterations: 300, IsTest: true, Debug: false, RandomSeed: 101, }
var ThoriumGrenadeActionID = ActionID{ItemID: 15993}
var TricksOfTheTradeAuraTag = "TricksOfTheTrade"
var UnholyFrenzyAuraTag = "UnholyFrenzy"
var WITH_DB = false
Functions ¶
func APLRotationFromJsonString ¶
func APLRotationFromJsonString(jsonString string) *proto.APLRotation
func AddPresetEncounter ¶
func AddPresetTarget ¶
func AddPresetTarget(newPreset *PresetTarget)
func AddWeaponEffect ¶
func AddWeaponEffect(id int32, weaponEffect ApplyWeaponEffect)
func ApplyFixedUptimeAura ¶
func ApplyInspiration ¶
func ApplyPetConsumeEffects ¶
func ApplyProcTriggerCallback ¶
func ApplyProcTriggerCallback(unit *Unit, aura *Aura, config ProcTrigger)
func BlessingOfSanctuaryAura ¶
func BlessingOfSanctuaryAura(character *Character)
func BothTimersReady ¶
func BothTimersReady(t1 *Timer, t2 *Timer, sim *Simulation) bool
func BulkSim ¶
func BulkSim(ctx context.Context, request *proto.BulkSimRequest, progress chan *proto.ProgressMetrics) *proto.BulkSimResult
func CharacterStatsTest ¶
func ComputeStats ¶
func ComputeStats(csr *proto.ComputeStatsRequest) *proto.ComputeStatsResult
*
- Returns character stats taking into account gear / buffs / consumes / etc
func DurationFromSeconds ¶
func EquipmentSpecFromJsonString ¶
func EquipmentSpecFromJsonString(jsonString string) *proto.EquipmentSpec
func FillTalentsProto ¶
func FillTalentsProto(data protoreflect.Message, talentsStr string, treeSizes [3]int)
Uses proto reflection to set fields in a talents proto (e.g. MageTalents, WarriorTalents) based on a talentsStr. treeSizes should contain the number of talents in each tree, usually around 30. This is needed because talent strings truncate 0's at the end of each tree, so we can't infer the start index of the tree from the string.
func FilterMap ¶
func FilterMap[K comparable, V any](src map[K]V, f func(K, V) bool) map[K]V
Returns a new map containing only the key/value pairs for which f returns true.
func FilterSlice ¶
Returns a new slice containing only the elements for which f returns true.
func GetPrimaryTalentTreeIndex ¶
Returns the talent tree (0, 1, or 2) of the tree with the most points.
talentStr is expected to be a wowhead-formatted talent string, e.g. "12123131-123123123-123123213"
func GetSchoolResistanceStats ¶
func GetSchoolResistanceStats(schoolIndex stats.SchoolIndex) []stats.Stat
Get array of resistance stat indices for a (multi)school. Physical school uses Armor as stat index!
func GetTristateValueFloat ¶
func GetTristateValueFloat(effect proto.TristateEffect, regularValue float64, impValue float64) float64
func GetTristateValueInt32 ¶
func GetTristateValueInt32(effect proto.TristateEffect, regularValue int32, impValue int32) int32
func GetWeaponSkill ¶
func HasEnchantEffect ¶
func HasItemEffect ¶
func HasItemEffectForTest ¶
func HasWeaponEffect ¶
func InnervateManaThreshold ¶
func MakeTristateValue ¶
func MakeTristateValue(hasRegular bool, hasImproved bool) proto.TristateEffect
func MapMap ¶
func MapMap[KI comparable, VI any, KO comparable, VO any](src map[KI]VI, f func(KI, VI) (KO, VO)) map[KO]VO
Returns a new map by applying f to each key/value pair in src.
func MaxTimeToReady ¶
func MaxTimeToReady(t1 *Timer, t2 *Timer, sim *Simulation) time.Duration
func ModNonMeleeAttackTable ¶
func ModNonMeleeAttackTable(table *AttackTable, attacker *Unit, defender *Unit, weapon *Item)
func MultiSchoolShouldUseArmor ¶
func MultiSchoolShouldUseArmor(schoolIndex stats.SchoolIndex, target *Unit) bool
Decide whether to use armor for physical multi school spells
TODO: This is most likely not accurate. A short test showed that it seems to not simply use armor if it's lower, but the breakpoint appeared to be pretty close to the resistance value.
func NewDefaultTarget ¶
func NewEnchantEffect ¶
func NewEnchantEffect(id int32, enchantEffect ApplyEffect)
func NewItemEffect ¶
func NewItemEffect(id int32, itemEffect ApplyEffect)
Registers an ApplyEffect function which will be called before the Sim starts, for any Agent that is wearing the item.
func NewSimpleStatItemEffect ¶
func NewSimpleStatItemEffect(itemID int32, bonus stats.Stats, duration time.Duration, cooldown time.Duration)
No shared CD
func RaidBenchmark ¶
func RaidBenchmark(b *testing.B, rsr *proto.RaidSimRequest)
func RaidPlayersWithClass ¶
func RaidSimTest ¶
func RegisterAgentFactory ¶
func RegisterAgentFactory(emptyOptions interface{}, spec proto.Spec, factory AgentFactory, specSetter SpecSetter)
func RegisterTemporaryStatsOnUseCD ¶
func RegisterTemporaryStatsOnUseCD(character *Character, auraLabel string, tempStats stats.Stats, duration time.Duration, config SpellConfig)
Add a major cooldown to the given agent, which provides a temporary boost to a single stat. This is use for effects like Icon of the Silver Crescent and Bloodlust Brooch.
func RunBulkSim ¶
func RunBulkSim(request *proto.BulkSimRequest) *proto.BulkSimResult
func RunBulkSimAsync ¶
func RunBulkSimAsync(ctx context.Context, request *proto.BulkSimRequest, progress chan *proto.ProgressMetrics)
func RunRaidSim ¶
func RunRaidSim(request *proto.RaidSimRequest) *proto.RaidSimResult
*
- Runs multiple iterations of the sim with a full raid.
func RunRaidSimAsync ¶
func RunRaidSimAsync(request *proto.RaidSimRequest, progress chan *proto.ProgressMetrics)
func RunSim ¶
func RunSim(rsr *proto.RaidSimRequest, progress chan *proto.ProgressMetrics) *proto.RaidSimResult
func RunTestSuite ¶
func RunTestSuite(t *testing.T, suiteName string, generators []TestGenerator)
func ScheduledMajorArmorAura ¶
func ScheduledMajorArmorAura(aura *Aura, options PeriodicActionOptions, raid *proto.Raid)
func SinglePlayerRaidProto ¶
func StatWeights ¶
func StatWeights(request *proto.StatWeightsRequest) *proto.StatWeightsResult
*
- Returns stat weights and EP values, with standard deviations, for all stats.
func StatWeightsAsync ¶
func StatWeightsAsync(request *proto.StatWeightsRequest, progress chan *proto.ProgressMetrics)
func StatWeightsTest ¶
func TernaryDuration ¶
func UnitLevelFloat64 ¶
func UnitLevelFloat64(unitLevel int32, maxLevelPlus0Val float64, maxLevelPlus1Val float64, maxLevelPlus2Val float64, maxLevelPlus3Val float64) float64
TODO: Classic lower levels comparison
Types ¶
type APLAction ¶
type APLAction struct {
// contains filtered or unexported fields
}
func (*APLAction) Execute ¶
func (action *APLAction) Execute(sim *Simulation)
func (*APLAction) Finalize ¶
func (action *APLAction) Finalize(rot *APLRotation)
func (*APLAction) GetAllAPLValues ¶
Returns all APLValues used by this action and all of its inner Actions.
func (*APLAction) GetAllActions ¶
Returns this Action, along with all inner Actions.
func (*APLAction) GetAllSpells ¶
func (*APLAction) IsReady ¶
func (action *APLAction) IsReady(sim *Simulation) bool
type APLActionActivateAura ¶
type APLActionActivateAura struct {
// contains filtered or unexported fields
}
func (*APLActionActivateAura) Execute ¶
func (action *APLActionActivateAura) Execute(sim *Simulation)
func (APLActionActivateAura) Finalize ¶
func (impl APLActionActivateAura) Finalize(*APLRotation)
func (APLActionActivateAura) GetAPLValues ¶
func (impl APLActionActivateAura) GetAPLValues() []APLValue
func (APLActionActivateAura) GetInnerActions ¶
func (impl APLActionActivateAura) GetInnerActions() []*APLAction
func (APLActionActivateAura) GetNextAction ¶
func (impl APLActionActivateAura) GetNextAction(*Simulation) *APLAction
func (*APLActionActivateAura) IsReady ¶
func (action *APLActionActivateAura) IsReady(sim *Simulation) bool
func (APLActionActivateAura) Reset ¶
func (impl APLActionActivateAura) Reset(*Simulation)
func (*APLActionActivateAura) String ¶
func (action *APLActionActivateAura) String() string
type APLActionAutocastOtherCooldowns ¶
type APLActionAutocastOtherCooldowns struct {
// contains filtered or unexported fields
}
func (*APLActionAutocastOtherCooldowns) Execute ¶
func (action *APLActionAutocastOtherCooldowns) Execute(sim *Simulation)
func (APLActionAutocastOtherCooldowns) Finalize ¶
func (impl APLActionAutocastOtherCooldowns) Finalize(*APLRotation)
func (APLActionAutocastOtherCooldowns) GetAPLValues ¶
func (impl APLActionAutocastOtherCooldowns) GetAPLValues() []APLValue
func (APLActionAutocastOtherCooldowns) GetInnerActions ¶
func (impl APLActionAutocastOtherCooldowns) GetInnerActions() []*APLAction
func (APLActionAutocastOtherCooldowns) GetNextAction ¶
func (impl APLActionAutocastOtherCooldowns) GetNextAction(*Simulation) *APLAction
func (*APLActionAutocastOtherCooldowns) IsReady ¶
func (action *APLActionAutocastOtherCooldowns) IsReady(sim *Simulation) bool
func (*APLActionAutocastOtherCooldowns) Reset ¶
func (action *APLActionAutocastOtherCooldowns) Reset(*Simulation)
func (*APLActionAutocastOtherCooldowns) String ¶
func (action *APLActionAutocastOtherCooldowns) String() string
type APLActionCancelAura ¶
type APLActionCancelAura struct {
// contains filtered or unexported fields
}
func (*APLActionCancelAura) Execute ¶
func (action *APLActionCancelAura) Execute(sim *Simulation)
func (APLActionCancelAura) Finalize ¶
func (impl APLActionCancelAura) Finalize(*APLRotation)
func (APLActionCancelAura) GetAPLValues ¶
func (impl APLActionCancelAura) GetAPLValues() []APLValue
func (APLActionCancelAura) GetInnerActions ¶
func (impl APLActionCancelAura) GetInnerActions() []*APLAction
func (APLActionCancelAura) GetNextAction ¶
func (impl APLActionCancelAura) GetNextAction(*Simulation) *APLAction
func (*APLActionCancelAura) IsReady ¶
func (action *APLActionCancelAura) IsReady(sim *Simulation) bool
func (APLActionCancelAura) Reset ¶
func (impl APLActionCancelAura) Reset(*Simulation)
func (*APLActionCancelAura) String ¶
func (action *APLActionCancelAura) String() string
type APLActionCastSpell ¶
type APLActionCastSpell struct {
// contains filtered or unexported fields
}
func (*APLActionCastSpell) Execute ¶
func (action *APLActionCastSpell) Execute(sim *Simulation)
func (APLActionCastSpell) Finalize ¶
func (impl APLActionCastSpell) Finalize(*APLRotation)
func (APLActionCastSpell) GetAPLValues ¶
func (impl APLActionCastSpell) GetAPLValues() []APLValue
func (APLActionCastSpell) GetInnerActions ¶
func (impl APLActionCastSpell) GetInnerActions() []*APLAction
func (APLActionCastSpell) GetNextAction ¶
func (impl APLActionCastSpell) GetNextAction(*Simulation) *APLAction
func (*APLActionCastSpell) IsReady ¶
func (action *APLActionCastSpell) IsReady(sim *Simulation) bool
func (APLActionCastSpell) Reset ¶
func (impl APLActionCastSpell) Reset(*Simulation)
func (*APLActionCastSpell) String ¶
func (action *APLActionCastSpell) String() string
type APLActionChangeTarget ¶
type APLActionChangeTarget struct {
// contains filtered or unexported fields
}
func (*APLActionChangeTarget) Execute ¶
func (action *APLActionChangeTarget) Execute(sim *Simulation)
func (APLActionChangeTarget) Finalize ¶
func (impl APLActionChangeTarget) Finalize(*APLRotation)
func (APLActionChangeTarget) GetAPLValues ¶
func (impl APLActionChangeTarget) GetAPLValues() []APLValue
func (APLActionChangeTarget) GetInnerActions ¶
func (impl APLActionChangeTarget) GetInnerActions() []*APLAction
func (APLActionChangeTarget) GetNextAction ¶
func (impl APLActionChangeTarget) GetNextAction(*Simulation) *APLAction
func (*APLActionChangeTarget) IsReady ¶
func (action *APLActionChangeTarget) IsReady(sim *Simulation) bool
func (APLActionChangeTarget) Reset ¶
func (impl APLActionChangeTarget) Reset(*Simulation)
func (*APLActionChangeTarget) String ¶
func (action *APLActionChangeTarget) String() string
type APLActionChannelSpell ¶
type APLActionChannelSpell struct {
// contains filtered or unexported fields
}
func (*APLActionChannelSpell) Execute ¶
func (action *APLActionChannelSpell) Execute(sim *Simulation)
func (APLActionChannelSpell) Finalize ¶
func (impl APLActionChannelSpell) Finalize(*APLRotation)
func (*APLActionChannelSpell) GetAPLValues ¶
func (action *APLActionChannelSpell) GetAPLValues() []APLValue
func (APLActionChannelSpell) GetInnerActions ¶
func (impl APLActionChannelSpell) GetInnerActions() []*APLAction
func (APLActionChannelSpell) GetNextAction ¶
func (impl APLActionChannelSpell) GetNextAction(*Simulation) *APLAction
func (*APLActionChannelSpell) IsReady ¶
func (action *APLActionChannelSpell) IsReady(sim *Simulation) bool
func (APLActionChannelSpell) Reset ¶
func (impl APLActionChannelSpell) Reset(*Simulation)
func (*APLActionChannelSpell) String ¶
func (action *APLActionChannelSpell) String() string
type APLActionCustomRotation ¶
type APLActionCustomRotation struct {
// contains filtered or unexported fields
}
func (*APLActionCustomRotation) Execute ¶
func (action *APLActionCustomRotation) Execute(sim *Simulation)
func (APLActionCustomRotation) Finalize ¶
func (impl APLActionCustomRotation) Finalize(*APLRotation)
func (APLActionCustomRotation) GetAPLValues ¶
func (impl APLActionCustomRotation) GetAPLValues() []APLValue
func (APLActionCustomRotation) GetInnerActions ¶
func (impl APLActionCustomRotation) GetInnerActions() []*APLAction
func (APLActionCustomRotation) GetNextAction ¶
func (impl APLActionCustomRotation) GetNextAction(*Simulation) *APLAction
func (*APLActionCustomRotation) IsReady ¶
func (action *APLActionCustomRotation) IsReady(sim *Simulation) bool
func (*APLActionCustomRotation) Reset ¶
func (action *APLActionCustomRotation) Reset(sim *Simulation)
func (*APLActionCustomRotation) String ¶
func (action *APLActionCustomRotation) String() string
type APLActionImpl ¶
type APLActionImpl interface { // Returns all inner APL Actions. GetInnerActions() []*APLAction // Returns all APLValues used by this Action (but not by inner Actions). GetAPLValues() []APLValue // Performs optional post-processing. Finalize(*APLRotation) // Invoked before each sim iteration. Reset(*Simulation) // Whether this action is available to be used right now. IsReady(*Simulation) bool // Performs the action. Execute(*Simulation) // Called only while this action is controlling the rotation. GetNextAction(sim *Simulation) *APLAction // Pretty-print string for debugging. String() string }
type APLActionItemSwap ¶
type APLActionItemSwap struct {
// contains filtered or unexported fields
}
func (*APLActionItemSwap) Execute ¶
func (action *APLActionItemSwap) Execute(sim *Simulation)
func (APLActionItemSwap) Finalize ¶
func (impl APLActionItemSwap) Finalize(*APLRotation)
func (APLActionItemSwap) GetAPLValues ¶
func (impl APLActionItemSwap) GetAPLValues() []APLValue
func (APLActionItemSwap) GetInnerActions ¶
func (impl APLActionItemSwap) GetInnerActions() []*APLAction
func (APLActionItemSwap) GetNextAction ¶
func (impl APLActionItemSwap) GetNextAction(*Simulation) *APLAction
func (*APLActionItemSwap) IsReady ¶
func (action *APLActionItemSwap) IsReady(sim *Simulation) bool
func (APLActionItemSwap) Reset ¶
func (impl APLActionItemSwap) Reset(*Simulation)
func (*APLActionItemSwap) String ¶
func (action *APLActionItemSwap) String() string
type APLActionMove ¶
type APLActionMove struct {
// contains filtered or unexported fields
}
func (*APLActionMove) Execute ¶
func (action *APLActionMove) Execute(sim *Simulation)
func (APLActionMove) Finalize ¶
func (impl APLActionMove) Finalize(*APLRotation)
func (APLActionMove) GetAPLValues ¶
func (impl APLActionMove) GetAPLValues() []APLValue
func (APLActionMove) GetInnerActions ¶
func (impl APLActionMove) GetInnerActions() []*APLAction
func (APLActionMove) GetNextAction ¶
func (impl APLActionMove) GetNextAction(*Simulation) *APLAction
func (*APLActionMove) IsReady ¶
func (action *APLActionMove) IsReady(sim *Simulation) bool
func (APLActionMove) Reset ¶
func (impl APLActionMove) Reset(*Simulation)
func (*APLActionMove) String ¶
func (action *APLActionMove) String() string
type APLActionMultidot ¶
type APLActionMultidot struct {
// contains filtered or unexported fields
}
func (*APLActionMultidot) Execute ¶
func (action *APLActionMultidot) Execute(sim *Simulation)
func (APLActionMultidot) Finalize ¶
func (impl APLActionMultidot) Finalize(*APLRotation)
func (*APLActionMultidot) GetAPLValues ¶
func (action *APLActionMultidot) GetAPLValues() []APLValue
func (APLActionMultidot) GetInnerActions ¶
func (impl APLActionMultidot) GetInnerActions() []*APLAction
func (APLActionMultidot) GetNextAction ¶
func (impl APLActionMultidot) GetNextAction(*Simulation) *APLAction
func (*APLActionMultidot) IsReady ¶
func (action *APLActionMultidot) IsReady(sim *Simulation) bool
func (*APLActionMultidot) Reset ¶
func (action *APLActionMultidot) Reset(*Simulation)
func (*APLActionMultidot) String ¶
func (action *APLActionMultidot) String() string
type APLActionMultishield ¶
type APLActionMultishield struct {
// contains filtered or unexported fields
}
func (*APLActionMultishield) Execute ¶
func (action *APLActionMultishield) Execute(sim *Simulation)
func (APLActionMultishield) Finalize ¶
func (impl APLActionMultishield) Finalize(*APLRotation)
func (*APLActionMultishield) GetAPLValues ¶
func (action *APLActionMultishield) GetAPLValues() []APLValue
func (APLActionMultishield) GetInnerActions ¶
func (impl APLActionMultishield) GetInnerActions() []*APLAction
func (APLActionMultishield) GetNextAction ¶
func (impl APLActionMultishield) GetNextAction(*Simulation) *APLAction
func (*APLActionMultishield) IsReady ¶
func (action *APLActionMultishield) IsReady(sim *Simulation) bool
func (*APLActionMultishield) Reset ¶
func (action *APLActionMultishield) Reset(*Simulation)
func (*APLActionMultishield) String ¶
func (action *APLActionMultishield) String() string
type APLActionResetSequence ¶
type APLActionResetSequence struct {
// contains filtered or unexported fields
}
func (*APLActionResetSequence) Execute ¶
func (action *APLActionResetSequence) Execute(sim *Simulation)
func (*APLActionResetSequence) Finalize ¶
func (action *APLActionResetSequence) Finalize(rot *APLRotation)
func (APLActionResetSequence) GetAPLValues ¶
func (impl APLActionResetSequence) GetAPLValues() []APLValue
func (APLActionResetSequence) GetInnerActions ¶
func (impl APLActionResetSequence) GetInnerActions() []*APLAction
func (APLActionResetSequence) GetNextAction ¶
func (impl APLActionResetSequence) GetNextAction(*Simulation) *APLAction
func (*APLActionResetSequence) IsReady ¶
func (action *APLActionResetSequence) IsReady(sim *Simulation) bool
func (APLActionResetSequence) Reset ¶
func (impl APLActionResetSequence) Reset(*Simulation)
func (*APLActionResetSequence) String ¶
func (action *APLActionResetSequence) String() string
type APLActionSchedule ¶
type APLActionSchedule struct {
// contains filtered or unexported fields
}
func (*APLActionSchedule) Execute ¶
func (action *APLActionSchedule) Execute(sim *Simulation)
func (APLActionSchedule) Finalize ¶
func (impl APLActionSchedule) Finalize(*APLRotation)
func (APLActionSchedule) GetAPLValues ¶
func (impl APLActionSchedule) GetAPLValues() []APLValue
func (*APLActionSchedule) GetInnerActions ¶
func (action *APLActionSchedule) GetInnerActions() []*APLAction
func (APLActionSchedule) GetNextAction ¶
func (impl APLActionSchedule) GetNextAction(*Simulation) *APLAction
func (*APLActionSchedule) IsReady ¶
func (action *APLActionSchedule) IsReady(sim *Simulation) bool
func (*APLActionSchedule) Reset ¶
func (action *APLActionSchedule) Reset(*Simulation)
func (*APLActionSchedule) String ¶
func (action *APLActionSchedule) String() string
type APLActionSequence ¶
type APLActionSequence struct {
// contains filtered or unexported fields
}
func (*APLActionSequence) Execute ¶
func (action *APLActionSequence) Execute(sim *Simulation)
func (*APLActionSequence) Finalize ¶
func (action *APLActionSequence) Finalize(rot *APLRotation)
func (APLActionSequence) GetAPLValues ¶
func (impl APLActionSequence) GetAPLValues() []APLValue
func (*APLActionSequence) GetInnerActions ¶
func (action *APLActionSequence) GetInnerActions() []*APLAction
func (APLActionSequence) GetNextAction ¶
func (impl APLActionSequence) GetNextAction(*Simulation) *APLAction
func (*APLActionSequence) IsReady ¶
func (action *APLActionSequence) IsReady(sim *Simulation) bool
func (*APLActionSequence) Reset ¶
func (action *APLActionSequence) Reset(*Simulation)
func (*APLActionSequence) String ¶
func (action *APLActionSequence) String() string
type APLActionStrictSequence ¶
type APLActionStrictSequence struct {
// contains filtered or unexported fields
}
func (*APLActionStrictSequence) Execute ¶
func (action *APLActionStrictSequence) Execute(sim *Simulation)
func (*APLActionStrictSequence) Finalize ¶
func (action *APLActionStrictSequence) Finalize(rot *APLRotation)
func (APLActionStrictSequence) GetAPLValues ¶
func (impl APLActionStrictSequence) GetAPLValues() []APLValue
func (*APLActionStrictSequence) GetInnerActions ¶
func (action *APLActionStrictSequence) GetInnerActions() []*APLAction
func (*APLActionStrictSequence) GetNextAction ¶
func (action *APLActionStrictSequence) GetNextAction(sim *Simulation) *APLAction
func (*APLActionStrictSequence) IsReady ¶
func (action *APLActionStrictSequence) IsReady(sim *Simulation) bool
func (*APLActionStrictSequence) Reset ¶
func (action *APLActionStrictSequence) Reset(*Simulation)
func (*APLActionStrictSequence) String ¶
func (action *APLActionStrictSequence) String() string
type APLActionTriggerICD ¶
type APLActionTriggerICD struct {
// contains filtered or unexported fields
}
func (*APLActionTriggerICD) Execute ¶
func (action *APLActionTriggerICD) Execute(sim *Simulation)
func (APLActionTriggerICD) Finalize ¶
func (impl APLActionTriggerICD) Finalize(*APLRotation)
func (APLActionTriggerICD) GetAPLValues ¶
func (impl APLActionTriggerICD) GetAPLValues() []APLValue
func (APLActionTriggerICD) GetInnerActions ¶
func (impl APLActionTriggerICD) GetInnerActions() []*APLAction
func (APLActionTriggerICD) GetNextAction ¶
func (impl APLActionTriggerICD) GetNextAction(*Simulation) *APLAction
func (*APLActionTriggerICD) IsReady ¶
func (action *APLActionTriggerICD) IsReady(sim *Simulation) bool
func (APLActionTriggerICD) Reset ¶
func (impl APLActionTriggerICD) Reset(*Simulation)
func (*APLActionTriggerICD) String ¶
func (action *APLActionTriggerICD) String() string
type APLActionWait ¶
type APLActionWait struct {
// contains filtered or unexported fields
}
func (*APLActionWait) Execute ¶
func (action *APLActionWait) Execute(sim *Simulation)
func (APLActionWait) Finalize ¶
func (impl APLActionWait) Finalize(*APLRotation)
func (*APLActionWait) GetAPLValues ¶
func (action *APLActionWait) GetAPLValues() []APLValue
func (APLActionWait) GetInnerActions ¶
func (impl APLActionWait) GetInnerActions() []*APLAction
func (*APLActionWait) GetNextAction ¶
func (action *APLActionWait) GetNextAction(sim *Simulation) *APLAction
func (*APLActionWait) IsReady ¶
func (action *APLActionWait) IsReady(sim *Simulation) bool
func (APLActionWait) Reset ¶
func (impl APLActionWait) Reset(*Simulation)
func (*APLActionWait) String ¶
func (action *APLActionWait) String() string
type APLActionWaitUntil ¶
type APLActionWaitUntil struct {
// contains filtered or unexported fields
}
func (*APLActionWaitUntil) Execute ¶
func (action *APLActionWaitUntil) Execute(sim *Simulation)
func (APLActionWaitUntil) Finalize ¶
func (impl APLActionWaitUntil) Finalize(*APLRotation)
func (*APLActionWaitUntil) GetAPLValues ¶
func (action *APLActionWaitUntil) GetAPLValues() []APLValue
func (APLActionWaitUntil) GetInnerActions ¶
func (impl APLActionWaitUntil) GetInnerActions() []*APLAction
func (*APLActionWaitUntil) GetNextAction ¶
func (action *APLActionWaitUntil) GetNextAction(sim *Simulation) *APLAction
func (*APLActionWaitUntil) IsReady ¶
func (action *APLActionWaitUntil) IsReady(sim *Simulation) bool
func (APLActionWaitUntil) Reset ¶
func (impl APLActionWaitUntil) Reset(*Simulation)
func (*APLActionWaitUntil) String ¶
func (action *APLActionWaitUntil) String() string
type APLRotation ¶
type APLRotation struct {
// contains filtered or unexported fields
}
func (*APLRotation) DoNextAction ¶
func (apl *APLRotation) DoNextAction(sim *Simulation)
We intentionally try to mimic the behavior of simc APL to avoid confusion and leverage the community's existing familiarity. https://github.com/simulationcraft/simc/wiki/ActionLists
func (*APLRotation) GetAPLAura ¶
func (rot *APLRotation) GetAPLAura(sourceUnit UnitReference, auraId *proto.ActionID) AuraReference
func (*APLRotation) GetAPLDot ¶
func (rot *APLRotation) GetAPLDot(targetUnit UnitReference, spellId *proto.ActionID) *Dot
func (*APLRotation) GetAPLICDAura ¶
func (rot *APLRotation) GetAPLICDAura(sourceUnit UnitReference, auraId *proto.ActionID) AuraReference
func (*APLRotation) GetAPLMultidotSpell ¶
func (rot *APLRotation) GetAPLMultidotSpell(spellId *proto.ActionID) *Spell
func (*APLRotation) GetAPLMultishieldSpell ¶
func (rot *APLRotation) GetAPLMultishieldSpell(spellId *proto.ActionID) *Spell
func (*APLRotation) GetAPLSpell ¶
func (rot *APLRotation) GetAPLSpell(spellId *proto.ActionID) *Spell
func (*APLRotation) GetSourceUnit ¶
func (rot *APLRotation) GetSourceUnit(ref *proto.UnitReference) UnitReference
func (*APLRotation) GetTargetUnit ¶
func (rot *APLRotation) GetTargetUnit(ref *proto.UnitReference) UnitReference
func (*APLRotation) ValidationWarning ¶
func (rot *APLRotation) ValidationWarning(message string, vals ...interface{})
type APLValue ¶
type APLValue interface { // Returns all inner APLValues. GetInnerValues() []APLValue // The type of value that will be returned. Type() proto.APLValueType // Gets the value, assuming it is a particular type. Usually only one of // these should be implemented in each class. GetBool(*Simulation) bool GetInt(*Simulation) int32 GetFloat(*Simulation) float64 GetDuration(*Simulation) time.Duration GetString(*Simulation) string // Performs optional post-processing. Finalize(*APLRotation) // Pretty-print string for debugging. String() string }
type APLValueAnd ¶
type APLValueAnd struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAnd) GetBool ¶
func (value *APLValueAnd) GetBool(sim *Simulation) bool
func (*APLValueAnd) GetInnerValues ¶
func (value *APLValueAnd) GetInnerValues() []APLValue
func (*APLValueAnd) String ¶
func (value *APLValueAnd) String() string
func (*APLValueAnd) Type ¶
func (value *APLValueAnd) Type() proto.APLValueType
type APLValueAuraICDIsReadyWithReactionTime ¶
type APLValueAuraICDIsReadyWithReactionTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraICDIsReadyWithReactionTime) GetBool ¶
func (value *APLValueAuraICDIsReadyWithReactionTime) GetBool(sim *Simulation) bool
func (*APLValueAuraICDIsReadyWithReactionTime) String ¶
func (value *APLValueAuraICDIsReadyWithReactionTime) String() string
func (*APLValueAuraICDIsReadyWithReactionTime) Type ¶
func (value *APLValueAuraICDIsReadyWithReactionTime) Type() proto.APLValueType
type APLValueAuraInternalCooldown ¶
type APLValueAuraInternalCooldown struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraInternalCooldown) GetDuration ¶
func (value *APLValueAuraInternalCooldown) GetDuration(sim *Simulation) time.Duration
func (*APLValueAuraInternalCooldown) String ¶
func (value *APLValueAuraInternalCooldown) String() string
func (*APLValueAuraInternalCooldown) Type ¶
func (value *APLValueAuraInternalCooldown) Type() proto.APLValueType
type APLValueAuraIsActive ¶
type APLValueAuraIsActive struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraIsActive) GetBool ¶
func (value *APLValueAuraIsActive) GetBool(sim *Simulation) bool
func (*APLValueAuraIsActive) String ¶
func (value *APLValueAuraIsActive) String() string
func (*APLValueAuraIsActive) Type ¶
func (value *APLValueAuraIsActive) Type() proto.APLValueType
type APLValueAuraIsActiveWithReactionTime ¶
type APLValueAuraIsActiveWithReactionTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraIsActiveWithReactionTime) GetBool ¶
func (value *APLValueAuraIsActiveWithReactionTime) GetBool(sim *Simulation) bool
func (*APLValueAuraIsActiveWithReactionTime) String ¶
func (value *APLValueAuraIsActiveWithReactionTime) String() string
func (*APLValueAuraIsActiveWithReactionTime) Type ¶
func (value *APLValueAuraIsActiveWithReactionTime) Type() proto.APLValueType
type APLValueAuraNumStacks ¶
type APLValueAuraNumStacks struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraNumStacks) GetInt ¶
func (value *APLValueAuraNumStacks) GetInt(sim *Simulation) int32
func (*APLValueAuraNumStacks) String ¶
func (value *APLValueAuraNumStacks) String() string
func (*APLValueAuraNumStacks) Type ¶
func (value *APLValueAuraNumStacks) Type() proto.APLValueType
type APLValueAuraRemainingTime ¶
type APLValueAuraRemainingTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraRemainingTime) GetDuration ¶
func (value *APLValueAuraRemainingTime) GetDuration(sim *Simulation) time.Duration
func (*APLValueAuraRemainingTime) String ¶
func (value *APLValueAuraRemainingTime) String() string
func (*APLValueAuraRemainingTime) Type ¶
func (value *APLValueAuraRemainingTime) Type() proto.APLValueType
type APLValueAuraShouldRefresh ¶
type APLValueAuraShouldRefresh struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAuraShouldRefresh) GetBool ¶
func (value *APLValueAuraShouldRefresh) GetBool(sim *Simulation) bool
func (*APLValueAuraShouldRefresh) GetInnerValues ¶
func (value *APLValueAuraShouldRefresh) GetInnerValues() []APLValue
func (*APLValueAuraShouldRefresh) String ¶
func (value *APLValueAuraShouldRefresh) String() string
func (*APLValueAuraShouldRefresh) Type ¶
func (value *APLValueAuraShouldRefresh) Type() proto.APLValueType
type APLValueAutoSwingTime ¶
type APLValueAutoSwingTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAutoSwingTime) GetDuration ¶
func (value *APLValueAutoSwingTime) GetDuration(sim *Simulation) time.Duration
func (*APLValueAutoSwingTime) String ¶
func (value *APLValueAutoSwingTime) String() string
func (*APLValueAutoSwingTime) Type ¶
func (value *APLValueAutoSwingTime) Type() proto.APLValueType
type APLValueAutoTimeToNext ¶
type APLValueAutoTimeToNext struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueAutoTimeToNext) GetDuration ¶
func (value *APLValueAutoTimeToNext) GetDuration(sim *Simulation) time.Duration
func (*APLValueAutoTimeToNext) String ¶
func (value *APLValueAutoTimeToNext) String() string
func (*APLValueAutoTimeToNext) Type ¶
func (value *APLValueAutoTimeToNext) Type() proto.APLValueType
type APLValueChannelClipDelay ¶
type APLValueChannelClipDelay struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueChannelClipDelay) GetDuration ¶
func (value *APLValueChannelClipDelay) GetDuration(sim *Simulation) time.Duration
func (*APLValueChannelClipDelay) String ¶
func (value *APLValueChannelClipDelay) String() string
func (*APLValueChannelClipDelay) Type ¶
func (value *APLValueChannelClipDelay) Type() proto.APLValueType
type APLValueCoerced ¶
type APLValueCoerced struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCoerced) GetBool ¶
func (value *APLValueCoerced) GetBool(sim *Simulation) bool
func (APLValueCoerced) GetDuration ¶
func (value APLValueCoerced) GetDuration(sim *Simulation) time.Duration
func (APLValueCoerced) GetFloat ¶
func (value APLValueCoerced) GetFloat(sim *Simulation) float64
func (*APLValueCoerced) GetInnerValues ¶
func (value *APLValueCoerced) GetInnerValues() []APLValue
func (APLValueCoerced) GetInt ¶
func (value APLValueCoerced) GetInt(sim *Simulation) int32
func (APLValueCoerced) GetString ¶
func (value APLValueCoerced) GetString(sim *Simulation) string
func (*APLValueCoerced) String ¶
func (value *APLValueCoerced) String() string
func (*APLValueCoerced) Type ¶
func (value *APLValueCoerced) Type() proto.APLValueType
type APLValueCompare ¶
type APLValueCompare struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCompare) GetBool ¶
func (value *APLValueCompare) GetBool(sim *Simulation) bool
func (*APLValueCompare) GetInnerValues ¶
func (value *APLValueCompare) GetInnerValues() []APLValue
func (*APLValueCompare) String ¶
func (value *APLValueCompare) String() string
func (*APLValueCompare) Type ¶
func (value *APLValueCompare) Type() proto.APLValueType
type APLValueConst ¶
type APLValueConst struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueConst) GetBool ¶
func (value *APLValueConst) GetBool(_ *Simulation) bool
func (*APLValueConst) GetDuration ¶
func (value *APLValueConst) GetDuration(_ *Simulation) time.Duration
func (*APLValueConst) GetFloat ¶
func (value *APLValueConst) GetFloat(_ *Simulation) float64
func (*APLValueConst) GetInt ¶
func (value *APLValueConst) GetInt(_ *Simulation) int32
func (*APLValueConst) GetString ¶
func (value *APLValueConst) GetString(_ *Simulation) string
func (*APLValueConst) String ¶
func (value *APLValueConst) String() string
func (*APLValueConst) Type ¶
func (value *APLValueConst) Type() proto.APLValueType
type APLValueCurrentComboPoints ¶
type APLValueCurrentComboPoints struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentComboPoints) GetInt ¶
func (value *APLValueCurrentComboPoints) GetInt(sim *Simulation) int32
func (*APLValueCurrentComboPoints) String ¶
func (value *APLValueCurrentComboPoints) String() string
func (*APLValueCurrentComboPoints) Type ¶
func (value *APLValueCurrentComboPoints) Type() proto.APLValueType
type APLValueCurrentEnergy ¶
type APLValueCurrentEnergy struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentEnergy) GetFloat ¶
func (value *APLValueCurrentEnergy) GetFloat(sim *Simulation) float64
func (*APLValueCurrentEnergy) String ¶
func (value *APLValueCurrentEnergy) String() string
func (*APLValueCurrentEnergy) Type ¶
func (value *APLValueCurrentEnergy) Type() proto.APLValueType
type APLValueCurrentHealth ¶
type APLValueCurrentHealth struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentHealth) GetFloat ¶
func (value *APLValueCurrentHealth) GetFloat(sim *Simulation) float64
func (*APLValueCurrentHealth) String ¶
func (value *APLValueCurrentHealth) String() string
func (*APLValueCurrentHealth) Type ¶
func (value *APLValueCurrentHealth) Type() proto.APLValueType
type APLValueCurrentHealthPercent ¶
type APLValueCurrentHealthPercent struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentHealthPercent) GetFloat ¶
func (value *APLValueCurrentHealthPercent) GetFloat(sim *Simulation) float64
func (*APLValueCurrentHealthPercent) String ¶
func (value *APLValueCurrentHealthPercent) String() string
func (*APLValueCurrentHealthPercent) Type ¶
func (value *APLValueCurrentHealthPercent) Type() proto.APLValueType
type APLValueCurrentMana ¶
type APLValueCurrentMana struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentMana) GetFloat ¶
func (value *APLValueCurrentMana) GetFloat(sim *Simulation) float64
func (*APLValueCurrentMana) String ¶
func (value *APLValueCurrentMana) String() string
func (*APLValueCurrentMana) Type ¶
func (value *APLValueCurrentMana) Type() proto.APLValueType
type APLValueCurrentManaPercent ¶
type APLValueCurrentManaPercent struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentManaPercent) GetFloat ¶
func (value *APLValueCurrentManaPercent) GetFloat(sim *Simulation) float64
func (*APLValueCurrentManaPercent) String ¶
func (value *APLValueCurrentManaPercent) String() string
func (*APLValueCurrentManaPercent) Type ¶
func (value *APLValueCurrentManaPercent) Type() proto.APLValueType
type APLValueCurrentRage ¶
type APLValueCurrentRage struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueCurrentRage) GetFloat ¶
func (value *APLValueCurrentRage) GetFloat(sim *Simulation) float64
func (*APLValueCurrentRage) String ¶
func (value *APLValueCurrentRage) String() string
func (*APLValueCurrentRage) Type ¶
func (value *APLValueCurrentRage) Type() proto.APLValueType
type APLValueCurrentTime ¶
type APLValueCurrentTime struct {
DefaultAPLValueImpl
}
func (*APLValueCurrentTime) GetDuration ¶
func (value *APLValueCurrentTime) GetDuration(sim *Simulation) time.Duration
func (*APLValueCurrentTime) String ¶
func (value *APLValueCurrentTime) String() string
func (*APLValueCurrentTime) Type ¶
func (value *APLValueCurrentTime) Type() proto.APLValueType
type APLValueCurrentTimePercent ¶
type APLValueCurrentTimePercent struct {
DefaultAPLValueImpl
}
func (*APLValueCurrentTimePercent) GetFloat ¶
func (value *APLValueCurrentTimePercent) GetFloat(sim *Simulation) float64
func (*APLValueCurrentTimePercent) String ¶
func (value *APLValueCurrentTimePercent) String() string
func (*APLValueCurrentTimePercent) Type ¶
func (value *APLValueCurrentTimePercent) Type() proto.APLValueType
type APLValueDotIsActive ¶
type APLValueDotIsActive struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueDotIsActive) GetBool ¶
func (value *APLValueDotIsActive) GetBool(sim *Simulation) bool
func (*APLValueDotIsActive) String ¶
func (value *APLValueDotIsActive) String() string
func (*APLValueDotIsActive) Type ¶
func (value *APLValueDotIsActive) Type() proto.APLValueType
type APLValueDotRemainingTime ¶
type APLValueDotRemainingTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueDotRemainingTime) GetDuration ¶
func (value *APLValueDotRemainingTime) GetDuration(sim *Simulation) time.Duration
func (*APLValueDotRemainingTime) String ¶
func (value *APLValueDotRemainingTime) String() string
func (*APLValueDotRemainingTime) Type ¶
func (value *APLValueDotRemainingTime) Type() proto.APLValueType
type APLValueFrontOfTarget ¶
type APLValueFrontOfTarget struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueFrontOfTarget) GetBool ¶
func (value *APLValueFrontOfTarget) GetBool(sim *Simulation) bool
func (*APLValueFrontOfTarget) String ¶
func (value *APLValueFrontOfTarget) String() string
func (*APLValueFrontOfTarget) Type ¶
func (value *APLValueFrontOfTarget) Type() proto.APLValueType
type APLValueGCDIsReady ¶
type APLValueGCDIsReady struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueGCDIsReady) GetBool ¶
func (value *APLValueGCDIsReady) GetBool(sim *Simulation) bool
func (*APLValueGCDIsReady) String ¶
func (value *APLValueGCDIsReady) String() string
func (*APLValueGCDIsReady) Type ¶
func (value *APLValueGCDIsReady) Type() proto.APLValueType
type APLValueGCDTimeToReady ¶
type APLValueGCDTimeToReady struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueGCDTimeToReady) GetDuration ¶
func (value *APLValueGCDTimeToReady) GetDuration(sim *Simulation) time.Duration
func (*APLValueGCDTimeToReady) String ¶
func (value *APLValueGCDTimeToReady) String() string
func (*APLValueGCDTimeToReady) Type ¶
func (value *APLValueGCDTimeToReady) Type() proto.APLValueType
type APLValueIsExecutePhase ¶
type APLValueIsExecutePhase struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueIsExecutePhase) GetBool ¶
func (value *APLValueIsExecutePhase) GetBool(sim *Simulation) bool
func (*APLValueIsExecutePhase) String ¶
func (value *APLValueIsExecutePhase) String() string
func (*APLValueIsExecutePhase) Type ¶
func (value *APLValueIsExecutePhase) Type() proto.APLValueType
type APLValueMath ¶
type APLValueMath struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueMath) GetDuration ¶
func (value *APLValueMath) GetDuration(sim *Simulation) time.Duration
func (*APLValueMath) GetFloat ¶
func (value *APLValueMath) GetFloat(sim *Simulation) float64
func (*APLValueMath) GetInnerValues ¶
func (value *APLValueMath) GetInnerValues() []APLValue
func (*APLValueMath) GetInt ¶
func (value *APLValueMath) GetInt(sim *Simulation) int32
func (*APLValueMath) String ¶
func (value *APLValueMath) String() string
func (*APLValueMath) Type ¶
func (value *APLValueMath) Type() proto.APLValueType
type APLValueMax ¶
type APLValueMax struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueMax) GetDuration ¶
func (value *APLValueMax) GetDuration(sim *Simulation) time.Duration
func (*APLValueMax) GetFloat ¶
func (value *APLValueMax) GetFloat(sim *Simulation) float64
func (*APLValueMax) GetInnerValues ¶
func (value *APLValueMax) GetInnerValues() []APLValue
func (*APLValueMax) GetInt ¶
func (value *APLValueMax) GetInt(sim *Simulation) int32
func (*APLValueMax) String ¶
func (value *APLValueMax) String() string
func (*APLValueMax) Type ¶
func (value *APLValueMax) Type() proto.APLValueType
type APLValueMin ¶
type APLValueMin struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueMin) GetDuration ¶
func (value *APLValueMin) GetDuration(sim *Simulation) time.Duration
func (*APLValueMin) GetFloat ¶
func (value *APLValueMin) GetFloat(sim *Simulation) float64
func (*APLValueMin) GetInnerValues ¶
func (value *APLValueMin) GetInnerValues() []APLValue
func (*APLValueMin) GetInt ¶
func (value *APLValueMin) GetInt(sim *Simulation) int32
func (*APLValueMin) String ¶
func (value *APLValueMin) String() string
func (*APLValueMin) Type ¶
func (value *APLValueMin) Type() proto.APLValueType
type APLValueNot ¶
type APLValueNot struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueNot) GetBool ¶
func (value *APLValueNot) GetBool(sim *Simulation) bool
func (*APLValueNot) GetInnerValues ¶
func (value *APLValueNot) GetInnerValues() []APLValue
func (*APLValueNot) String ¶
func (value *APLValueNot) String() string
func (*APLValueNot) Type ¶
func (value *APLValueNot) Type() proto.APLValueType
type APLValueNumberTargets ¶
type APLValueNumberTargets struct {
DefaultAPLValueImpl
}
func (*APLValueNumberTargets) GetInt ¶
func (value *APLValueNumberTargets) GetInt(sim *Simulation) int32
func (*APLValueNumberTargets) String ¶
func (value *APLValueNumberTargets) String() string
func (*APLValueNumberTargets) Type ¶
func (value *APLValueNumberTargets) Type() proto.APLValueType
type APLValueOr ¶
type APLValueOr struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueOr) GetBool ¶
func (value *APLValueOr) GetBool(sim *Simulation) bool
func (*APLValueOr) GetInnerValues ¶
func (value *APLValueOr) GetInnerValues() []APLValue
func (*APLValueOr) String ¶
func (value *APLValueOr) String() string
func (*APLValueOr) Type ¶
func (value *APLValueOr) Type() proto.APLValueType
type APLValueRemainingTime ¶
type APLValueRemainingTime struct {
DefaultAPLValueImpl
}
func (*APLValueRemainingTime) GetDuration ¶
func (value *APLValueRemainingTime) GetDuration(sim *Simulation) time.Duration
func (*APLValueRemainingTime) String ¶
func (value *APLValueRemainingTime) String() string
func (*APLValueRemainingTime) Type ¶
func (value *APLValueRemainingTime) Type() proto.APLValueType
type APLValueRemainingTimePercent ¶
type APLValueRemainingTimePercent struct {
DefaultAPLValueImpl
}
func (*APLValueRemainingTimePercent) GetFloat ¶
func (value *APLValueRemainingTimePercent) GetFloat(sim *Simulation) float64
func (*APLValueRemainingTimePercent) String ¶
func (value *APLValueRemainingTimePercent) String() string
func (*APLValueRemainingTimePercent) Type ¶
func (value *APLValueRemainingTimePercent) Type() proto.APLValueType
type APLValueSequenceIsComplete ¶
type APLValueSequenceIsComplete struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSequenceIsComplete) Finalize ¶
func (value *APLValueSequenceIsComplete) Finalize(rot *APLRotation)
func (*APLValueSequenceIsComplete) GetBool ¶
func (value *APLValueSequenceIsComplete) GetBool(sim *Simulation) bool
func (*APLValueSequenceIsComplete) String ¶
func (value *APLValueSequenceIsComplete) String() string
func (*APLValueSequenceIsComplete) Type ¶
func (value *APLValueSequenceIsComplete) Type() proto.APLValueType
type APLValueSequenceIsReady ¶
type APLValueSequenceIsReady struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSequenceIsReady) Finalize ¶
func (value *APLValueSequenceIsReady) Finalize(rot *APLRotation)
func (*APLValueSequenceIsReady) GetBool ¶
func (value *APLValueSequenceIsReady) GetBool(sim *Simulation) bool
func (*APLValueSequenceIsReady) String ¶
func (value *APLValueSequenceIsReady) String() string
func (*APLValueSequenceIsReady) Type ¶
func (value *APLValueSequenceIsReady) Type() proto.APLValueType
type APLValueSequenceTimeToReady ¶
type APLValueSequenceTimeToReady struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSequenceTimeToReady) Finalize ¶
func (value *APLValueSequenceTimeToReady) Finalize(rot *APLRotation)
func (*APLValueSequenceTimeToReady) GetDuration ¶
func (value *APLValueSequenceTimeToReady) GetDuration(sim *Simulation) time.Duration
func (*APLValueSequenceTimeToReady) String ¶
func (value *APLValueSequenceTimeToReady) String() string
func (*APLValueSequenceTimeToReady) Type ¶
func (value *APLValueSequenceTimeToReady) Type() proto.APLValueType
type APLValueSpellCPM ¶
type APLValueSpellCPM struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellCPM) GetFloat ¶
func (value *APLValueSpellCPM) GetFloat(sim *Simulation) float64
func (*APLValueSpellCPM) String ¶
func (value *APLValueSpellCPM) String() string
func (*APLValueSpellCPM) Type ¶
func (value *APLValueSpellCPM) Type() proto.APLValueType
type APLValueSpellCanCast ¶
type APLValueSpellCanCast struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellCanCast) GetBool ¶
func (value *APLValueSpellCanCast) GetBool(sim *Simulation) bool
func (*APLValueSpellCanCast) String ¶
func (value *APLValueSpellCanCast) String() string
func (*APLValueSpellCanCast) Type ¶
func (value *APLValueSpellCanCast) Type() proto.APLValueType
type APLValueSpellCastTime ¶
type APLValueSpellCastTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellCastTime) GetDuration ¶
func (value *APLValueSpellCastTime) GetDuration(_ *Simulation) time.Duration
func (*APLValueSpellCastTime) String ¶
func (value *APLValueSpellCastTime) String() string
func (*APLValueSpellCastTime) Type ¶
func (value *APLValueSpellCastTime) Type() proto.APLValueType
type APLValueSpellChanneledTicks ¶
type APLValueSpellChanneledTicks struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellChanneledTicks) GetInt ¶
func (value *APLValueSpellChanneledTicks) GetInt(_ *Simulation) int32
func (*APLValueSpellChanneledTicks) String ¶
func (value *APLValueSpellChanneledTicks) String() string
func (*APLValueSpellChanneledTicks) Type ¶
func (value *APLValueSpellChanneledTicks) Type() proto.APLValueType
type APLValueSpellCurrentCost ¶
type APLValueSpellCurrentCost struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellCurrentCost) GetFloat ¶
func (value *APLValueSpellCurrentCost) GetFloat(_ *Simulation) float64
func (*APLValueSpellCurrentCost) String ¶
func (value *APLValueSpellCurrentCost) String() string
func (*APLValueSpellCurrentCost) Type ¶
func (value *APLValueSpellCurrentCost) Type() proto.APLValueType
type APLValueSpellIsChanneling ¶
type APLValueSpellIsChanneling struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellIsChanneling) GetBool ¶
func (value *APLValueSpellIsChanneling) GetBool(_ *Simulation) bool
func (*APLValueSpellIsChanneling) String ¶
func (value *APLValueSpellIsChanneling) String() string
func (*APLValueSpellIsChanneling) Type ¶
func (value *APLValueSpellIsChanneling) Type() proto.APLValueType
type APLValueSpellIsReady ¶
type APLValueSpellIsReady struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellIsReady) GetBool ¶
func (value *APLValueSpellIsReady) GetBool(sim *Simulation) bool
func (*APLValueSpellIsReady) String ¶
func (value *APLValueSpellIsReady) String() string
func (*APLValueSpellIsReady) Type ¶
func (value *APLValueSpellIsReady) Type() proto.APLValueType
type APLValueSpellTimeToReady ¶
type APLValueSpellTimeToReady struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellTimeToReady) GetDuration ¶
func (value *APLValueSpellTimeToReady) GetDuration(sim *Simulation) time.Duration
func (*APLValueSpellTimeToReady) String ¶
func (value *APLValueSpellTimeToReady) String() string
func (*APLValueSpellTimeToReady) Type ¶
func (value *APLValueSpellTimeToReady) Type() proto.APLValueType
type APLValueSpellTravelTime ¶
type APLValueSpellTravelTime struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueSpellTravelTime) GetDuration ¶
func (value *APLValueSpellTravelTime) GetDuration(_ *Simulation) time.Duration
func (*APLValueSpellTravelTime) String ¶
func (value *APLValueSpellTravelTime) String() string
func (*APLValueSpellTravelTime) Type ¶
func (value *APLValueSpellTravelTime) Type() proto.APLValueType
type APLValueTimeToEnergyTick ¶
type APLValueTimeToEnergyTick struct { DefaultAPLValueImpl // contains filtered or unexported fields }
func (*APLValueTimeToEnergyTick) GetDuration ¶
func (value *APLValueTimeToEnergyTick) GetDuration(sim *Simulation) time.Duration
func (*APLValueTimeToEnergyTick) String ¶
func (value *APLValueTimeToEnergyTick) String() string
func (*APLValueTimeToEnergyTick) Type ¶
func (value *APLValueTimeToEnergyTick) Type() proto.APLValueType
type ActionID ¶
type ActionID struct { // Only one of these should be set. SpellID int32 ItemID int32 OtherID proto.OtherAction Tag int32 }
func ProtoToActionID ¶
func (ActionID) IsEmptyAction ¶
func (ActionID) IsItemAction ¶
func (ActionID) IsOtherAction ¶
func (actionID ActionID) IsOtherAction(otherID proto.OtherAction) bool
func (ActionID) IsSpellAction ¶
func (ActionID) SameAction ¶
func (ActionID) SameActionIgnoreTag ¶
type ActionMetrics ¶
type ActionMetrics struct { IsMelee bool // True if melee action, false if spell action. // Metrics for this action, for each possible target. Targets []TargetedActionMetrics }
func (*ActionMetrics) ToProto ¶
func (actionMetrics *ActionMetrics) ToProto(actionID ActionID) *proto.ActionMetrics
type ActionPriority ¶
type ActionPriority int32
const ( ActionPriorityLow ActionPriority = -1 ActionPriorityGCD ActionPriority = 0 // Higher than GCD because regen can cause GCD actions (if we were waiting // for mana). ActionPriorityRegen ActionPriority = 1 // Autos can cause regen (JoW, rage, energy procs, etc) so they should be // higher prio so that we never go backwards in the priority order. ActionPriorityAuto ActionPriority = 2 // DOTs need to be higher than anything else so that dots can properly expire before we take other actions. ActionPriorityDOT ActionPriority = 3 ActionPriorityPrePull ActionPriority = 10 )
type ActiveSetBonus ¶
type ActiveSetBonus struct { // Name of the set. Name string // Number of pieces required for this bonus. NumPieces int32 // Function for applying the effects of this set bonus. BonusEffect ApplyEffect }
type Agent ¶
type Agent interface { // The Character controlled by this Agent. GetCharacter() *Character // Called once after all Players/Pets/Targets have finished the construction phase. // Use this to register spells and any initialization steps that require // other raid members or auras. Initialize() // Updates the input Buffs to include raid-wide buffs provided by this Agent. AddRaidBuffs(raidBuffs *proto.RaidBuffs) // Updates the input Buffs to include party-wide buffs provided by this Agent. AddPartyBuffs(partyBuffs *proto.PartyBuffs) // All talent and runes stats / auras should be added within this callback. This makes sure // talents are applied at the right time so we can calculate groups of stats. ApplyTalents() ApplyRunes() // Returns this Agent to its initial state. Called before each Sim iteration // and once after the final iteration. Reset(sim *Simulation) // Custom factories for APL values and actions, for cases where the value/action // involves class or spec-specific behavior. // // Should return nil when the config doesn't match any custom behaviors. NewAPLValue(rot *APLRotation, config *proto.APLValue) APLValue NewAPLAction(rot *APLRotation, config *proto.APLAction) APLActionImpl // Implements custom rotation behavior. Usually for pets and targets but can be used // for players too. ExecuteCustomRotation(sim *Simulation) }
Agent can be thought of as the 'Player', i.e. the thing controlling the Character. This is the interface implemented by each class/spec.
type ApplyEffect ¶
type ApplyEffect func(Agent)
Function for applying permanent effects to an Agent.
Passing Character instead of Agent would work for almost all cases, but there are occasionally class-specific item effects.
func MakeTemporaryStatsOnUseCDRegistration ¶
func MakeTemporaryStatsOnUseCDRegistration(auraLabel string, tempStats stats.Stats, duration time.Duration, config SpellConfig, cdFunc func(*Character) Cooldown, sharedCDFunc func(*Character) Cooldown) ApplyEffect
Helper function to make an ApplyEffect for a temporary stats on-use cooldown.
type ApplySpellResults ¶
type ApplySpellResults func(sim *Simulation, target *Unit, spell *Spell)
type ApplyWeaponEffect ¶
Function for applying permanent effects to an agent's weapon
type AttackTable ¶
type AttackTable struct { Attacker *Unit Defender *Unit Weapon *Item BaseMissChance float64 HitSuppression float64 BaseSpellMissChance float64 BaseBlockChance float64 BaseDodgeChance float64 BaseParryChance float64 BaseGlanceChance float64 GlanceMultiplierMin float64 GlanceMultiplierMax float64 MeleeCritSuppression float64 SpellCritSuppression float64 // All "Apply Aura: Mod All Damage Done Against Creature" effects in Vanilla and TBC also increase the CritMultiplier. // Explicitly for hunters' "Monster Slaying" and "Humanoid Slaying", but likewise for rogues' "Murder", or trolls' "Beastslaying". CritMultiplier float64 DamageDealtMultiplier float64 // attacker buff, applied in applyAttackerModifiers() DamageTakenMultiplier float64 // defender debuff, applied in applyTargetModifiers() NatureDamageTakenMultiplier float64 HauntSEDamageTakenMultiplier float64 HealingDealtMultiplier float64 }
Holds cached values for outcome/damage calculations, for a specific attacker+defender pair. These are updated dynamically when attacker or defender stats change.
func NewAttackTable ¶
func NewAttackTable(attacker *Unit, defender *Unit, weapon *Item) *AttackTable
func (*AttackTable) GetArmorDamageModifier ¶
func (at *AttackTable) GetArmorDamageModifier(spell *Spell) float64
func (*AttackTable) GetBinaryHitChance ¶
func (at *AttackTable) GetBinaryHitChance(si stats.SchoolIndex) float64
func (*AttackTable) GetPartialResistThresholds ¶
func (at *AttackTable) GetPartialResistThresholds(si stats.SchoolIndex, pureDot bool) (float64, float64, float64)
type Aura ¶
type Aura struct { // String label for this Aura. Guaranteed to be unique among the Auras for a single Unit. Label string // For easily grouping auras. Tag string ActionID ActionID // If set, metrics will be tracked for this aura. ActionIDForProc ActionID // If set, indicates that this aura is a trigger aura for the specified proc. Icd *Cooldown // The internal cooldown if any Duration time.Duration // Duration of aura, upon being applied. // The unit this aura is attached to. Unit *Unit MaxStacks int32 ExclusiveEffects []*ExclusiveEffect // Lifecycle callbacks. OnInit OnInit OnReset OnReset OnDoneIteration OnDoneIteration OnGain OnGain OnExpire OnExpire OnStacksChange OnStacksChange // Invoked when the number of stacks of this aura changes. OnStatsChange OnStatsChange // Invoked when the stats of this aura owner changes. OnCastComplete OnCastComplete // Invoked when a spell cast completes casting, before results are calculated. OnSpellHitDealt OnSpellHit // Invoked when a spell hits and this unit is the caster. OnSpellHitTaken OnSpellHit // Invoked when a spell hits and this unit is the target. OnPeriodicDamageDealt OnPeriodicDamage // Invoked when a dot tick occurs and this unit is the caster. OnPeriodicDamageTaken OnPeriodicDamage // Invoked when a dot tick occurs and this unit is the target. OnHealDealt OnSpellHit // Invoked when a heal hits and this unit is the caster. OnHealTaken OnSpellHit // Invoked when a heal hits and this unit is the target. OnPeriodicHealDealt OnPeriodicDamage // Invoked when a hot tick occurs and this unit is the caster. OnPeriodicHealTaken OnPeriodicDamage // Invoked when a hot tick occurs and this unit is the target. OnRageChange OnRageChange // Invoked when unit's rage value changes. // If non-default, stat bonuses fron the OnGain callback of this aura will be // included in Character Stats in the UI. BuildPhase CharacterBuildPhase // contains filtered or unexported fields }
Aura lifecycle:
myAura := unit.RegisterAura(myAuraConfig) myAura.Activate(sim) myAura.SetStacks(sim, 3) myAura.Refresh(sim) myAura.Deactivate(sim)
func ApplyWildStrikes ¶
func ApplyWindfury ¶
func BattleShoutAura ¶
func BloodlustAura ¶
func CommandingShoutAura ¶
func CrystalYieldAura ¶
func CurseOfElementsAura ¶
func CurseOfRecklessnessAura ¶
func CurseOfShadowAura ¶
func CurseOfWeaknessAura ¶
TODO: Classic
func DemonicPactAura ¶
TODO: Classic Runes
func DemoralizingRoarAura ¶
TODO: Classic
func DemoralizingShoutAura ¶
func DragonBreathChiliAura ¶
func DreamstateAura ¶
func ExposeArmorAura ¶
func FaerieFireAura ¶
func GiftOfArthasAura ¶
func GraceOfAirTotemAura ¶
func GuardianSpiritAura ¶
func HandOfSacrificeAura ¶
func HemorrhageAura ¶
func HomunculiArmorAura ¶
func ImprovedScorchAura ¶
func ImprovedShadowBoltAura ¶
func InnervateAura ¶
func InsectSwarmAura ¶
func JudgementOfLightAura ¶
func JudgementOfWisdomAura ¶
TODO: Classic verify logic
func MakeProcTriggerAura ¶
func MakeProcTriggerAura(unit *Unit, config ProcTrigger) *Aura
func MakeStackingAura ¶
func MakeStackingAura(character *Character, config StackingStatAura) *Aura
func ManaTideTotemAura ¶
func MangleAura ¶
func PainSuppressionAura ¶
func PowerInfusionAura ¶
func RetributionAura ¶
func ScorpidStingAura ¶
func ShadowWeavingAura ¶
func StormstrikeAura ¶
func SunderArmorAura ¶
func ThornsAura ¶
func ThunderClapAura ¶
func TricksOfTheTradeAura ¶
func VindicationAura ¶
TODO: Classic
func WaylayAura ¶
func WintersChillAura ¶
func (*Aura) Activate ¶
func (aura *Aura) Activate(sim *Simulation)
Adds a new aura to the simulation. If an aura with the same ID already exists it will be replaced with the new one.
func (*Aura) AddStack ¶
func (aura *Aura) AddStack(sim *Simulation)
func (*Aura) AddStacks ¶
func (aura *Aura) AddStacks(sim *Simulation, numStacks int32)
func (*Aura) ApplyOnExpire ¶
Adds a handler to be called OnExpire, in addition to any current handlers.
func (*Aura) ApplyOnGain ¶
Adds a handler to be called OnGain, in addition to any current handlers.
func (*Aura) NewExclusiveEffect ¶
func (aura *Aura) NewExclusiveEffect(categoryName string, singleAura bool, config ExclusiveEffect) *ExclusiveEffect
func (*Aura) Refresh ¶
func (aura *Aura) Refresh(sim *Simulation)
func (*Aura) RemainingDuration ¶
func (aura *Aura) RemainingDuration(sim *Simulation) time.Duration
func (*Aura) RemoveStack ¶
func (aura *Aura) RemoveStack(sim *Simulation)
func (*Aura) SetStacks ¶
func (aura *Aura) SetStacks(sim *Simulation, newStacks int32)
func (*Aura) ShouldRefreshExclusiveEffects ¶
func (aura *Aura) ShouldRefreshExclusiveEffects(sim *Simulation, refreshWindow time.Duration) bool
Returns if an aura should be refreshed, i.e. the aura is inactive/about to expire AND there are no other active effects of equal or greater strength.
func (*Aura) TimeActive ¶
func (aura *Aura) TimeActive(sim *Simulation) time.Duration
The amount of time this aura has been active.
func (*Aura) UpdateExpires ¶
func (aura *Aura) UpdateExpires(sim *Simulation, newExpires time.Duration)
type AuraCallback ¶
type AuraCallback uint16
const ( CallbackEmpty AuraCallback = 0 CallbackOnSpellHitDealt AuraCallback = 1 << iota CallbackOnSpellHitTaken CallbackOnPeriodicDamageDealt CallbackOnHealDealt CallbackOnPeriodicHealDealt CallbackOnCastComplete )
func (AuraCallback) Matches ¶
func (c AuraCallback) Matches(other AuraCallback) bool
type AuraFactory ¶
type AuraFactory func(*Simulation) *Aura
type AuraMetrics ¶
type AuraMetrics struct { ID ActionID // Metrics for the current iteration. Uptime time.Duration Procs int32 // contains filtered or unexported fields }
func (*AuraMetrics) ToProto ¶
func (auraMetrics *AuraMetrics) ToProto() *proto.AuraMetrics
type AuraReference ¶
type AuraReference struct {
// contains filtered or unexported fields
}
func NewAuraReference ¶
func NewAuraReference(sourceUnit UnitReference, auraId *proto.ActionID) AuraReference
func NewIcdAuraReference ¶
func NewIcdAuraReference(sourceUnit UnitReference, auraId *proto.ActionID) AuraReference
func (*AuraReference) Get ¶
func (ar *AuraReference) Get() *Aura
func (*AuraReference) String ¶
func (ar *AuraReference) String() string
type AutoAttackOptions ¶
type AutoAttackOptions struct { MainHand Weapon OffHand Weapon Ranged Weapon AutoSwingMelee bool // If true, core engine will handle calling SwingMelee() for you. AutoSwingRanged bool // If true, core engine will handle calling SwingRanged() for you. ReplaceMHSwing ReplaceMHSwing }
Options for initializing auto attacks.
type AutoAttacks ¶
type AutoAttacks struct { AutoSwingMelee bool AutoSwingRanged bool IsDualWielding bool // contains filtered or unexported fields }
func (*AutoAttacks) CancelAutoSwing ¶
func (aa *AutoAttacks) CancelAutoSwing(sim *Simulation)
Stops the auto swing action for the rest of the iteration. Used for pets after being disabled.
func (*AutoAttacks) DelayMeleeBy ¶
func (aa *AutoAttacks) DelayMeleeBy(sim *Simulation, delay time.Duration)
Delays all swing timers for the specified amount. Only used by Slam.
func (*AutoAttacks) DelayRangedUntil ¶
func (aa *AutoAttacks) DelayRangedUntil(sim *Simulation, readyAt time.Duration)
func (*AutoAttacks) EnableAutoSwing ¶
func (aa *AutoAttacks) EnableAutoSwing(sim *Simulation)
Re-enables the auto swing action for the iteration
func (*AutoAttacks) ExtraMHAttack ¶
func (aa *AutoAttacks) ExtraMHAttack(sim *Simulation)
ExtraMHAttack should be used for all "extra attack" procs in Classic Era versions, including Wild Strikes and Hand of Justice. In vanilla, these procs don't actually grant a full extra attack, but instead just advance the MH swing timer.
func (*AutoAttacks) MH ¶
func (aa *AutoAttacks) MH() *Weapon
func (*AutoAttacks) MHAuto ¶
func (aa *AutoAttacks) MHAuto() *Spell
func (*AutoAttacks) MHConfig ¶
func (aa *AutoAttacks) MHConfig() *SpellConfig
func (*AutoAttacks) MainhandSwingAt ¶
func (aa *AutoAttacks) MainhandSwingAt() time.Duration
func (*AutoAttacks) MainhandSwingSpeed ¶
func (aa *AutoAttacks) MainhandSwingSpeed() time.Duration
The amount of time between two MH swings.
func (*AutoAttacks) MaybeReplaceMHSwing ¶
func (aa *AutoAttacks) MaybeReplaceMHSwing(sim *Simulation, mhSwingSpell *Spell) *Spell
Optionally replaces the given swing spell with an Agent-specified MH Swing replacer. This is for effects like Heroic Strike or Raptor Strike.
func (*AutoAttacks) NewPPMManager ¶
func (aa *AutoAttacks) NewPPMManager(ppm float64, procMask ProcMask) PPMManager
func (*AutoAttacks) NextAnyAttackAt ¶
func (aa *AutoAttacks) NextAnyAttackAt() time.Duration
Returns the time at which the next attack will occur.
func (*AutoAttacks) NextAttackAt ¶
func (aa *AutoAttacks) NextAttackAt() time.Duration
Returns the time at which the next melee attack will occur.
func (*AutoAttacks) NextRangedAttackAt ¶
func (aa *AutoAttacks) NextRangedAttackAt() time.Duration
Returns the time at which the next ranged attack will occur.
func (*AutoAttacks) OH ¶
func (aa *AutoAttacks) OH() *Weapon
func (*AutoAttacks) OHAuto ¶
func (aa *AutoAttacks) OHAuto() *Spell
func (*AutoAttacks) OHConfig ¶
func (aa *AutoAttacks) OHConfig() *SpellConfig
func (*AutoAttacks) OffhandSwingAt ¶
func (aa *AutoAttacks) OffhandSwingAt() time.Duration
func (*AutoAttacks) OffhandSwingSpeed ¶
func (aa *AutoAttacks) OffhandSwingSpeed() time.Duration
The amount of time between two OH swings.
func (*AutoAttacks) PPMProc ¶
func (aa *AutoAttacks) PPMProc(sim *Simulation, ppm float64, procMask ProcMask, label string, spell *Spell) bool
Returns whether a PPM-based effect procced. Using NewPPMManager() is preferred; this function should only be used when the attacker is not known at initialization time.
func (*AutoAttacks) Ranged ¶
func (aa *AutoAttacks) Ranged() *Weapon
func (*AutoAttacks) RangedAuto ¶
func (aa *AutoAttacks) RangedAuto() *Spell
func (*AutoAttacks) RangedConfig ¶
func (aa *AutoAttacks) RangedConfig() *SpellConfig
func (*AutoAttacks) RangedSwingSpeed ¶
func (aa *AutoAttacks) RangedSwingSpeed() time.Duration
The amount of time between two Ranged swings.
func (*AutoAttacks) SetMH ¶
func (aa *AutoAttacks) SetMH(weapon Weapon)
func (*AutoAttacks) SetOH ¶
func (aa *AutoAttacks) SetOH(weapon Weapon)
func (*AutoAttacks) SetOffhandSwingAt ¶
func (aa *AutoAttacks) SetOffhandSwingAt(offhandSwingAt time.Duration)
func (*AutoAttacks) SetRanged ¶
func (aa *AutoAttacks) SetRanged(weapon Weapon)
func (*AutoAttacks) SetReplaceMHSwing ¶
func (aa *AutoAttacks) SetReplaceMHSwing(replaceSwing ReplaceMHSwing)
func (*AutoAttacks) StopMeleeUntil ¶
func (aa *AutoAttacks) StopMeleeUntil(sim *Simulation, readyAt time.Duration, desyncOH bool)
StopMeleeUntil should be used whenever a non-melee spell is cast. It stops melee, then restarts it at end of cast, but with a reset swing timer (as if swings had just landed).
func (*AutoAttacks) UpdateSwingTimers ¶
func (aa *AutoAttacks) UpdateSwingTimers(sim *Simulation)
type BuffName ¶
type BuffName int32
const ( // General Buffs ArcaneIntellect BuffName = iota BattleShout BlessingOfMight BlessingOfWisdom BloodPact DivineSpirit GraceOfAir ManaSpring MarkOfTheWild PowerWordFortitude StrengthOfEarth TrueshotAura HornOfLordaeron Windfury SanctityAura // Resistance AspectOfTheWild FrostResistanceTotem FrostResistanceAura NatureResistanceTotem ShadowProtection // Scrolls ScrollOfAgility ScrollOfIntellect ScrollOfSpirit ScrollOfStrength ScrollOfStamina )
type BuffsCombo ¶
type BuffsCombo struct { Label string Raid *proto.RaidBuffs Party *proto.PartyBuffs Debuffs *proto.Debuffs Player *proto.IndividualBuffs Consumes []ConsumesCombo }
type CanCastCondition ¶
type CanCastCondition func(sim *Simulation, target *Unit) bool
type Cast ¶
type Cast struct { // Amount of resource that will be consumed by this cast. Cost float64 // The length of time the GCD will be on CD as a result of this cast. GCD time.Duration // The amount of time between the call to spell.Cast() and when the spell // effects are invoked. CastTime time.Duration }
func (*Cast) EffectiveTime ¶
type CastConfig ¶
type CastConfig struct { // Default cast values with all static effects applied. DefaultCast Cast // Dynamic modifications for each cast. ModifyCast func(*Simulation, *Spell, *Cast) // Ignores haste when calculating the GCD and cast time for this cast. // Automatically set if GCD and cast times are all 0, e.g. for empty casts. IgnoreHaste bool CD Cooldown CastTime func(spell *Spell) time.Duration }
Input for constructing the CastSpell function for a spell.
type CastFunc ¶
type CastFunc func(*Simulation, *Unit)
type CastSuccessFunc ¶
type CastSuccessFunc func(*Simulation, *Unit) bool
type Character ¶
type Character struct { Unit Name string // Different from Label, needed for returned results. Race proto.Race Class proto.Class Spec proto.Spec // Current gear. Equipment //Item Swap Handler ItemSwap ItemSwap // Consumables this Character will be using. Consumes *proto.Consumes PrimaryTalentTree uint8 // Up reference to this Character's Party. Party *Party // This character's index within its party [0-4]. PartyIndex int Pets []*Pet // cached in AddPet, for advance() // contains filtered or unexported fields }
Character is a data structure to hold all the shared values that all class logic shares. All players have stats, equipment, auras, etc
func (*Character) AddComboPoints ¶
func (eb *Character) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
func (*Character) AddEnergy ¶
func (eb *Character) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) AddFocus ¶
func (fb *Character) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) AddMajorCooldown ¶
func (mcdm *Character) AddMajorCooldown(mcd MajorCooldown)
Registers a major cooldown to the Character, which will be automatically used when available.
func (*Character) AddPartyBuffs ¶
func (character *Character) AddPartyBuffs(partyBuffs *proto.PartyBuffs)
func (*Character) AddRage ¶
func (rb *Character) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) AddRaidBuffs ¶
func (*Character) ApplyDynamicEquipScaling ¶
func (character *Character) ApplyDynamicEquipScaling(sim *Simulation, stat stats.Stat, multiplier float64)
func (*Character) ApplyEquipScaling ¶
func (*Character) BaseEquipStats ¶
func (*Character) ComboPoints ¶
func (eb *Character) ComboPoints() int32
func (*Character) CurrentEnergy ¶
func (eb *Character) CurrentEnergy() float64
func (*Character) CurrentFocus ¶
func (fb *Character) CurrentFocus() float64
func (*Character) CurrentFocusPerTick ¶
func (fb *Character) CurrentFocusPerTick() float64
func (*Character) CurrentHealth ¶
func (hb *Character) CurrentHealth() float64
func (*Character) CurrentHealthPercent ¶
func (hb *Character) CurrentHealthPercent() float64
func (*Character) CurrentRage ¶
func (rb *Character) CurrentRage() float64
func (*Character) EnableManaBar ¶
func (character *Character) EnableManaBar()
EnableManaBar will setup caster stat dependencies (int->mana and int->spellcrit) as well as enable the mana gain action to regenerate mana. It will then enable mana gain metrics for reporting.
func (*Character) EnableManaBarWithModifier ¶
func (*Character) EndOOMEvent ¶
func (mb *Character) EndOOMEvent(sim *Simulation)
func (*Character) EquipStats ¶
func (*Character) FillPlayerStats ¶
func (character *Character) FillPlayerStats(playerStats *proto.PlayerStats)
func (*Character) GainHealth ¶
func (hb *Character) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) GetActiveAuraWithTag ¶
func (*Character) GetActiveSetBonusNames ¶
Returns the names of all active set bonuses.
func (*Character) GetActiveSetBonuses ¶
func (character *Character) GetActiveSetBonuses() []ActiveSetBonus
Returns a list describing all active set bonuses.
func (*Character) GetAuraByID ¶
func (*Character) GetAurasWithTag ¶
func (*Character) GetBaseStats ¶
func (*Character) GetConjuredCD ¶
func (*Character) GetDefensiveTrinketCD ¶
func (*Character) GetIcdAuraByID ¶
func (*Character) GetInitialMajorCooldown ¶
func (mcdm *Character) GetInitialMajorCooldown(actionID ActionID) MajorCooldown
func (*Character) GetMHWeapon ¶
Returns the MH weapon if one is equipped, and null otherwise.
func (*Character) GetMajorCooldown ¶
func (mcdm *Character) GetMajorCooldown(actionID ActionID) *MajorCooldown
func (*Character) GetMajorCooldownIDs ¶
func (*Character) GetMajorCooldownIgnoreTag ¶
func (mcdm *Character) GetMajorCooldownIgnoreTag(actionID ActionID) *MajorCooldown
func (*Character) GetMajorCooldowns ¶
func (mcdm *Character) GetMajorCooldowns() []*MajorCooldown
Returns all MCDs.
func (*Character) GetMetricsProto ¶
func (character *Character) GetMetricsProto() *proto.UnitMetrics
func (*Character) GetOHWeapon ¶
Returns the OH weapon if one is equipped, and null otherwise. Note that shields / Held-in-off-hand items are NOT counted as weapons in this function.
func (*Character) GetOffensiveTrinketCD ¶
func (*Character) GetPresimOptions ¶
func (character *Character) GetPresimOptions(playerConfig *proto.Player) *PresimOptions
func (*Character) GetProcMaskForEnchant ¶
func (*Character) GetProcMaskForItem ¶
func (*Character) GetProcMaskForTypes ¶
func (character *Character) GetProcMaskForTypes(weaponTypes ...proto.WeaponType) ProcMask
func (*Character) GetPseudoStatsProto ¶
func (*Character) GetRangedWeapon ¶
Returns the ranged weapon if one is equipped, and null otherwise.
func (*Character) HasActiveAura ¶
func (*Character) HasActiveAuraWithTag ¶
func (*Character) HasActiveAuraWithTagExcludingAura ¶
func (*Character) HasAuraWithTag ¶
func (*Character) HasMHWeapon ¶
func (*Character) HasOHWeapon ¶
func (*Character) HasProfession ¶
func (character *Character) HasProfession(prof proto.Profession) bool
func (*Character) HasRangedWeapon ¶
func (*Character) HasRingEquipped ¶
func (*Character) HasRuneById ¶
func (*Character) HasSetBonus ¶
func (*Character) HasTrinketEquipped ¶
func (*Character) NewTemporaryStatsAura ¶
func (character *Character) NewTemporaryStatsAura(auraLabel string, actionID ActionID, tempStats stats.Stats, duration time.Duration) *Aura
Helper for the common case of making an aura that adds stats.
func (*Character) NewTemporaryStatsAuraWrapped ¶
func (character *Character) NewTemporaryStatsAuraWrapped(auraLabel string, actionID ActionID, buffs stats.Stats, duration time.Duration, modConfig func(*Aura)) *Aura
Alternative that allows modifying the Aura config.
func (*Character) NextEnergyTickAt ¶
func (*Character) NumActiveAurasWithTag ¶
func (*Character) OnCastComplete ¶
func (at *Character) OnCastComplete(sim *Simulation, spell *Spell)
Invokes the OnCastComplete event for all tracked Auras.
func (*Character) OnHealDealt ¶
func (at *Character) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnHeal event for all tracked Auras.
func (*Character) OnHealTaken ¶
func (at *Character) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Character) OnPeriodicDamageDealt ¶
func (at *Character) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicDamage
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Character) OnPeriodicDamageTaken ¶
func (at *Character) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Character) OnPeriodicHealDealt ¶
func (at *Character) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicHeal
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Character) OnPeriodicHealTaken ¶
func (at *Character) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Character) OnRageChange ¶
func (at *Character) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
Invokes the OnRageChange for all tracked auras
func (*Character) OnSpellHitDealt ¶
func (at *Character) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnSpellHit event for all tracked Auras.
func (*Character) OnSpellHitTaken ¶
func (at *Character) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Character) RegisterOnItemSwap ¶
func (character *Character) RegisterOnItemSwap(callback OnSwapItem)
func (*Character) RegisterResetEffect ¶
func (at *Character) RegisterResetEffect(resetEffect ResetEffect)
Registers a callback to this Character which will be invoked on every Sim reset.
func (*Character) RemoveDynamicEquipScaling ¶
func (character *Character) RemoveDynamicEquipScaling(sim *Simulation, stat stats.Stat, multiplier float64)
func (*Character) RemoveEquipScaling ¶
func (*Character) RemoveHealth ¶
func (hb *Character) RemoveHealth(sim *Simulation, amount float64)
func (*Character) ResetEnergyTick ¶
func (eb *Character) ResetEnergyTick(sim *Simulation)
Gives an immediate partial energy tick and restarts the tick timer.
func (*Character) SpendComboPoints ¶
func (eb *Character) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
func (*Character) SpendEnergy ¶
func (eb *Character) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) SpendFocus ¶
func (fb *Character) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) SpendRage ¶
func (rb *Character) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Character) StartOOMEvent ¶
func (mb *Character) StartOOMEvent(sim *Simulation, requiredMana float64)
func (*Character) TryUseCooldowns ¶
func (mcdm *Character) TryUseCooldowns(sim *Simulation)
func (*Character) UpdateMajorCooldowns ¶
func (mcdm *Character) UpdateMajorCooldowns()
This function should be called if the CD for a major cooldown changes outside of the TryActivate() call.
func (*Character) WeaponFromMainHand ¶
Returns weapon stats using the main hand equipped weapon.
func (*Character) WeaponFromOffHand ¶
Returns weapon stats using the off-hand equipped weapon.
func (*Character) WeaponFromRanged ¶
Returns weapon stats using the ranged equipped weapon.
type CharacterBuildPhase ¶
type CharacterBuildPhase uint8
const ( CharacterBuildPhaseNone CharacterBuildPhase = 0 CharacterBuildPhaseBase CharacterBuildPhase = 1 << iota CharacterBuildPhaseGear CharacterBuildPhaseTalents CharacterBuildPhaseBuffs CharacterBuildPhaseConsumes )
func (CharacterBuildPhase) Matches ¶
func (cbp CharacterBuildPhase) Matches(other CharacterBuildPhase) bool
type CharacterIterationMetrics ¶
type CharacterIterationMetrics struct { Died bool // Whether this unit died in the current iteration. WentOOM bool // Whether the agent has hit OOM at least once in this iteration. ManaSpent float64 ManaGained float64 OOMTime time.Duration // time spent not casting and waiting for regen. FirstOOMTimestamp time.Duration // Timestamp at which unit first went OOM. }
Metrics for the current iteration, for 1 agent. Keep this as a separate struct, so it's easy to clear.
type CharacterSuiteConfig ¶
type CharacterSuiteConfig struct { Class proto.Class Race proto.Race Level int32 GearSet GearSetCombo SpecOptions SpecOptionsCombo Talents string Rotation RotationCombo Buffs BuffsCombo Consumes ConsumesCombo IsHealer bool IsTank bool InFrontOfTarget bool OtherRaces []proto.Race OtherGearSets []GearSetCombo OtherSpecOptions []SpecOptionsCombo OtherRotations []RotationCombo OtherConsumes []ConsumesCombo ItemFilter ItemFilter StatsToWeigh []proto.Stat EPReferenceStat proto.Stat Cooldowns *proto.Cooldowns }
type CombinedTestGenerator ¶
type CombinedTestGenerator struct {
// contains filtered or unexported fields
}
func (*CombinedTestGenerator) GetTest ¶
func (generator *CombinedTestGenerator) GetTest(testIdx int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*CombinedTestGenerator) NumTests ¶
func (generator *CombinedTestGenerator) NumTests() int
type ConsumesCombo ¶
type Cooldown ¶
type Cooldown struct { *Timer // Default amount of time after activation before this CD can be used again. // Note that some CDs won't use this, e.g. the GCD. Duration time.Duration }
func (*Cooldown) Use ¶
func (cd *Cooldown) Use(sim *Simulation)
Puts this CD on cooldown, using the default duration.
type CooldownActivation ¶
type CooldownActivation func(*Simulation, *Character)
Function for activating a cooldown. Returns whether the activation was successful.
type CooldownActivationCondition ¶
type CooldownActivationCondition func(*Simulation, *Character) bool
Condition for whether a cooldown can/should be activated. Returning false prevents the cooldown from being activated.
type CooldownType ¶
type CooldownType byte
const ( CooldownTypeUnknown CooldownType = 0 CooldownTypeMana CooldownType = 1 << iota CooldownTypeDPS CooldownTypeExplosive CooldownTypeSurvival )
func (CooldownType) Matches ¶
func (ct CooldownType) Matches(other CooldownType) bool
type DebuffName ¶
type DebuffName int32
const ( // General Buffs DemoralizingShout DebuffName = iota )
type DefaultAPLValueImpl ¶
type DefaultAPLValueImpl struct { }
Provides empty implementations for the GetX() value interface functions.
func (DefaultAPLValueImpl) Finalize ¶
func (impl DefaultAPLValueImpl) Finalize(*APLRotation)
func (DefaultAPLValueImpl) GetBool ¶
func (impl DefaultAPLValueImpl) GetBool(sim *Simulation) bool
func (DefaultAPLValueImpl) GetDuration ¶
func (impl DefaultAPLValueImpl) GetDuration(sim *Simulation) time.Duration
func (DefaultAPLValueImpl) GetFloat ¶
func (impl DefaultAPLValueImpl) GetFloat(sim *Simulation) float64
func (DefaultAPLValueImpl) GetInnerValues ¶
func (impl DefaultAPLValueImpl) GetInnerValues() []APLValue
func (DefaultAPLValueImpl) GetInt ¶
func (impl DefaultAPLValueImpl) GetInt(sim *Simulation) int32
func (DefaultAPLValueImpl) GetString ¶
func (impl DefaultAPLValueImpl) GetString(sim *Simulation) string
type DefenseType ¶
type DefenseType byte
const ( DefenseTypeNone DefenseType = iota DefenseTypeMagic DefenseTypeMelee DefenseTypeRanged )
type DelayedActionOptions ¶
type DelayedActionOptions struct { // When the action should be performed. DoAt time.Duration Priority ActionPriority OnAction func(*Simulation) CleanUp func(*Simulation) }
type DistributionMetrics ¶
type DistributionMetrics struct { // Values for the current iteration. These are cleared after each iteration. Total float64 // contains filtered or unexported fields }
func NewDistributionMetrics ¶
func NewDistributionMetrics() DistributionMetrics
func (*DistributionMetrics) ToProto ¶
func (distMetrics *DistributionMetrics) ToProto() *proto.DistributionMetrics
type Dot ¶
type Dot struct { Spell *Spell // Embed Aura, so we can use IsActive/Refresh/etc directly. *Aura NumberOfTicks int32 // number of ticks over the whole duration TickLength time.Duration // time between each tick // If true, tick length will be shortened based on casting speed. AffectedByCastSpeed bool OnSnapshot OnSnapshot OnTick OnTick SnapshotBaseDamage float64 SnapshotCritChance float64 SnapshotAttackerMultiplier float64 // Number of ticks since last call to Apply(). TickCount int32 // contains filtered or unexported fields }
func (*Dot) Apply ¶
func (dot *Dot) Apply(sim *Simulation)
func (*Dot) ApplyOrRefresh ¶
func (dot *Dot) ApplyOrRefresh(sim *Simulation)
Like Apply(), but does not reset the tick timer.
func (*Dot) ApplyOrReset ¶
func (dot *Dot) ApplyOrReset(sim *Simulation)
ApplyOrReset is used for rolling dots that reset the tick timer on reapplication. This is more efficient than Apply(), and works around tickAction.CleanUp() wrongly generating an extra ticks if (re-)application and tick happen at the same time.
func (*Dot) CalcAndDealPeriodicSnapshotDamage ¶
func (dot *Dot) CalcAndDealPeriodicSnapshotDamage(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
func (*Dot) CalcAndDealPeriodicSnapshotHealing ¶
func (dot *Dot) CalcAndDealPeriodicSnapshotHealing(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
func (*Dot) CalcSnapshotDamage ¶
func (dot *Dot) CalcSnapshotDamage(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
func (*Dot) CalcSnapshotHealing ¶
func (dot *Dot) CalcSnapshotHealing(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
func (*Dot) Cancel ¶
func (dot *Dot) Cancel(sim *Simulation)
func (*Dot) ManualTick ¶
func (dot *Dot) ManualTick(sim *Simulation)
ManualTick forces the dot forward one tick Will cancel the dot if it is out of ticks.
func (*Dot) MaxTicksRemaining ¶
func (*Dot) NextTickAt ¶
func (*Dot) NumTicksRemaining ¶
func (dot *Dot) NumTicksRemaining(sim *Simulation) int
func (*Dot) OutcomeExpectedMagicSnapshotCrit ¶
func (dot *Dot) OutcomeExpectedMagicSnapshotCrit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Dot) OutcomeMagicHitAndSnapshotCrit ¶
func (dot *Dot) OutcomeMagicHitAndSnapshotCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Dot) OutcomeRangedHitAndCritSnapshot ¶
func (dot *Dot) OutcomeRangedHitAndCritSnapshot(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Dot) OutcomeSnapshotCrit ¶
func (dot *Dot) OutcomeSnapshotCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Dot) OutcomeTick ¶
func (dot *Dot) OutcomeTick(_ *Simulation, result *SpellResult, _ *AttackTable)
A tick always hits, but we don't count them as hits in the metrics.
func (*Dot) OutcomeTickCounted ¶
func (dot *Dot) OutcomeTickCounted(_ *Simulation, result *SpellResult, _ *AttackTable)
func (*Dot) OutcomeTickPhysicalCrit ¶
func (dot *Dot) OutcomeTickPhysicalCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Dot) OutcomeTickSnapshotCrit ¶
func (dot *Dot) OutcomeTickSnapshotCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Dot) RecomputeAuraDuration ¶
func (dot *Dot) RecomputeAuraDuration()
Call this after manually changing NumberOfTicks or TickLength.
func (*Dot) RescheduleNextTick ¶
func (dot *Dot) RescheduleNextTick(sim *Simulation)
func (*Dot) Rollover ¶
func (dot *Dot) Rollover(sim *Simulation)
Rollover is used to reset the duration of a dot from an external spell (not casting the dot itself) This keeps the snapshot crit and %dmg modifiers. However, sp and haste are recalculated.
func (*Dot) TakeSnapshot ¶
func (dot *Dot) TakeSnapshot(sim *Simulation, doRollover bool)
Takes a new snapshot of this Dot's effects.
In most cases this will be called automatically, and should only be called to force a new snapshot to be taken.
doRollover will apply previously snapshotted crit/%dmg instead of recalculating.
func (*Dot) TickOnce ¶
func (dot *Dot) TickOnce(sim *Simulation)
Forces an instant tick. Does not reset the tick timer or aura duration, the tick is simply an extra tick.
func (*Dot) TickPeriod ¶
TickPeriod is how fast the snapshot dot ticks.
func (*Dot) TimeUntilNextTick ¶
func (dot *Dot) TimeUntilNextTick(sim *Simulation) time.Duration
type DotConfig ¶
type DotConfig struct { IsAOE bool // Set to true for AOE dots (Blizzard, Hurricane, Consecrate, etc) SelfOnly bool // Set to true to only create the self-hot. // Optional, will default to the corresponding spell. Spell *Spell Aura Aura NumberOfTicks int32 // number of ticks over the whole duration TickLength time.Duration // time between each tick // If true, tick length will be shortened based on casting speed. AffectedByCastSpeed bool OnSnapshot OnSnapshot OnTick OnTick }
type DynamicDamageTakenModifier ¶
type DynamicDamageTakenModifier func(sim *Simulation, spell *Spell, result *SpellResult)
type Enchant ¶
func EnchantFromProto ¶
func EnchantFromProto(pData *proto.SimEnchant) Enchant
type Encounter ¶
type Encounter struct { Duration time.Duration DurationVariation time.Duration Targets []*Target TargetUnits []*Unit ExecuteProportion_20 float64 ExecuteProportion_25 float64 ExecuteProportion_35 float64 EndFightAtHealth float64 // DamageTaken is used to track health fights instead of duration fights. // Once primary target has taken its health worth of damage, fight ends. DamageTaken float64 // In health fight: set to true until we get something to base on DurationIsEstimate bool // contains filtered or unexported fields }
func NewEncounter ¶
func (*Encounter) AOECapMultiplier ¶
func (*Encounter) GetMetricsProto ¶
func (encounter *Encounter) GetMetricsProto() *proto.EncounterMetrics
type EncounterCombo ¶
func MakeDefaultEncounterCombos ¶
func MakeDefaultEncounterCombos(playerLevel int32) []EncounterCombo
type EnergyCost ¶
type EnergyCost struct { Refund float64 RefundMetrics *ResourceMetrics ResourceMetrics *ResourceMetrics ComboPointMetrics *ResourceMetrics }
func (*EnergyCost) CostFailureReason ¶
func (ec *EnergyCost) CostFailureReason(_ *Simulation, spell *Spell) string
func (*EnergyCost) IssueRefund ¶
func (ec *EnergyCost) IssueRefund(sim *Simulation, spell *Spell)
func (*EnergyCost) MeetsRequirement ¶
func (ec *EnergyCost) MeetsRequirement(_ *Simulation, spell *Spell) bool
func (*EnergyCost) SpendCost ¶
func (ec *EnergyCost) SpendCost(sim *Simulation, spell *Spell)
type EnergyCostOptions ¶
type EnergyCostOptions struct { Cost float64 Refund float64 RefundMetrics *ResourceMetrics // Optional, will default to unit.EnergyRefundMetrics if not supplied. }
type Environment ¶
type Environment struct { State EnvironmentState // Whether stats are currently being measured. Used to disable some validation // checks which are otherwise helpful. MeasuringStats bool Raid *Raid Encounter Encounter AllUnits []*Unit BaseDuration time.Duration // base duration DurationVariation time.Duration // variation per duration // contains filtered or unexported fields }
func NewEnvironment ¶
func NewEnvironment(raidProto *proto.Raid, encounterProto *proto.Encounter, runFakePrepull bool) (*Environment, *proto.RaidStats, *proto.EncounterStats)
func (*Environment) GetAgentFromUnit ¶
func (env *Environment) GetAgentFromUnit(unit *Unit) Agent
func (*Environment) GetMaxDuration ¶
func (env *Environment) GetMaxDuration() time.Duration
The maximum possible duration for any iteration.
func (*Environment) GetNumTargets ¶
func (env *Environment) GetNumTargets() int32
func (*Environment) GetTarget ¶
func (env *Environment) GetTarget(index int32) *Target
func (*Environment) GetTargetUnit ¶
func (env *Environment) GetTargetUnit(index int32) *Unit
func (*Environment) GetUnit ¶
func (env *Environment) GetUnit(ref *proto.UnitReference, contextUnit *Unit) *Unit
func (*Environment) IsFinalized ¶
func (env *Environment) IsFinalized() bool
func (*Environment) NextTarget ¶
func (env *Environment) NextTarget(target *Unit) *Target
func (*Environment) NextTargetUnit ¶
func (env *Environment) NextTargetUnit(target *Unit) *Unit
func (*Environment) PrepullStartTime ¶
func (env *Environment) PrepullStartTime() time.Duration
func (*Environment) RegisterPostFinalizeEffect ¶
func (env *Environment) RegisterPostFinalizeEffect(postFinalizeEffect PostFinalizeEffect)
Registers a callback to this Character which will be invoked AFTER all Units are finalized.
func (*Environment) RegisterPreFinalizeEffect ¶
func (env *Environment) RegisterPreFinalizeEffect(preFinalizeEffect PostFinalizeEffect)
Registers a callback to this Character which will be invoked BEFORE all Units are finalized, but after they are all initialized and have other effects applied.
type EnvironmentState ¶
type EnvironmentState int
const ( Created EnvironmentState = iota Constructed Initialized Finalized )
type Equipment ¶
type Equipment [proto.ItemSlot_ItemSlotRanged + 1]Item
func NewEquipmentSet ¶
func NewEquipmentSet(equipSpec EquipmentSpec) Equipment
func ProtoToEquipment ¶
func ProtoToEquipment(es *proto.EquipmentSpec) Equipment
func (*Equipment) GetRuneIds ¶
func (*Equipment) ToEquipmentSpecProto ¶
func (equipment *Equipment) ToEquipmentSpecProto() *proto.EquipmentSpec
type EquipmentSpec ¶
type EquipmentSpec [proto.ItemSlot_ItemSlotRanged + 1]ItemSpec
Structs used for looking up items/enchants
func ProtoToEquipmentSpec ¶
func ProtoToEquipmentSpec(es *proto.EquipmentSpec) EquipmentSpec
type ExclusiveCategory ¶
type ExclusiveCategory struct { Name string SingleAura bool // If true, only 1 aura in this category may be active at a time. // contains filtered or unexported fields }
func (*ExclusiveCategory) AnyActive ¶
func (ec *ExclusiveCategory) AnyActive() bool
func (*ExclusiveCategory) GetActiveAura ¶
func (ec *ExclusiveCategory) GetActiveAura() *Aura
func (*ExclusiveCategory) GetActiveEffect ¶
func (ec *ExclusiveCategory) GetActiveEffect() *ExclusiveEffect
func (*ExclusiveCategory) GetHighestPrioActiveEffect ¶
func (ec *ExclusiveCategory) GetHighestPrioActiveEffect() *ExclusiveEffect
func (*ExclusiveCategory) SetActive ¶
func (ec *ExclusiveCategory) SetActive(sim *Simulation, newActiveEffect *ExclusiveEffect)
type ExclusiveCategoryArray ¶
type ExclusiveCategoryArray []*ExclusiveCategory
func (ExclusiveCategoryArray) Get ¶
func (categories ExclusiveCategoryArray) Get(target *Unit) *ExclusiveCategory
type ExclusiveEffect ¶
type ExclusiveEffect struct { Aura *Aura Priority float64 OnGain func(*ExclusiveEffect, *Simulation) OnExpire func(*ExclusiveEffect, *Simulation) Category *ExclusiveCategory // contains filtered or unexported fields }
An Exclusive effect is one which may not be active at the same time as other effects in the same category. For example, the armor reduction effects from Sunder Armor and Expose Armor are exclusive with each other.
Within each ExclusiveCategory, the ExclusiveEffect with the highest Priority AND isEnabled == true is the one whose effect is applied.
func AtkSpeedReductionEffect ¶
func AtkSpeedReductionEffect(aura *Aura, speedMultiplier float64) *ExclusiveEffect
func RegisterPercentDamageModifierEffect ¶
func RegisterPercentDamageModifierEffect(aura *Aura, percentDamageModifier float64) *ExclusiveEffect
func (*ExclusiveEffect) Activate ¶
func (ee *ExclusiveEffect) Activate(sim *Simulation) bool
Returns whether the effect is active.
func (*ExclusiveEffect) Deactivate ¶
func (ee *ExclusiveEffect) Deactivate(sim *Simulation)
func (*ExclusiveEffect) IsActive ¶
func (ee *ExclusiveEffect) IsActive() bool
func (*ExclusiveEffect) SetPriority ¶
func (ee *ExclusiveEffect) SetPriority(sim *Simulation, newPrio float64)
type ExclusiveEffectManager ¶
type ExclusiveEffectManager struct {
// contains filtered or unexported fields
}
func (*ExclusiveEffectManager) GetExclusiveEffectCategory ¶
func (eem *ExclusiveEffectManager) GetExclusiveEffectCategory(categoryName string) *ExclusiveCategory
Returns a category with the given name. Creates a new category if one doesn't already exist.
type ExpectedDamageCalculator ¶
type ExpectedDamageCalculator func(sim *Simulation, target *Unit, spell *Spell, useSnapshot bool) *SpellResult
type FocusCost ¶
type FocusCost struct { Refund float64 RefundMetrics *ResourceMetrics ResourceMetrics *ResourceMetrics }
func (*FocusCost) CostFailureReason ¶
func (fc *FocusCost) CostFailureReason(_ *Simulation, spell *Spell) string
func (*FocusCost) IssueRefund ¶
func (fc *FocusCost) IssueRefund(sim *Simulation, spell *Spell)
func (*FocusCost) MeetsRequirement ¶
func (fc *FocusCost) MeetsRequirement(_ *Simulation, spell *Spell) bool
func (*FocusCost) SpendCost ¶
func (fc *FocusCost) SpendCost(sim *Simulation, spell *Spell)
type FocusCostOptions ¶
type FocusCostOptions struct { Cost float64 Refund float64 RefundMetrics *ResourceMetrics // Optional, will default to unit.FocusRefundMetrics if not supplied }
type GearSetCombo ¶
type GearSetCombo struct { Label string GearSet *proto.EquipmentSpec }
func GetGearSet ¶
func GetGearSet(dir string, file string) GearSetCombo
type GoRand ¶
func (GoRand) NextFloat64 ¶
type HitOutcome ¶
type HitOutcome uint16
Possible outcomes of any hit/damage roll.
const ( OutcomeEmpty HitOutcome = 0 // These bits are set by the hit roll OutcomeMiss HitOutcome = 1 << iota OutcomeHit OutcomeDodge OutcomeGlance OutcomeParry OutcomeBlock // These bits are set by the crit and damage rolls. OutcomeCrit OutcomeCrush OutcomePartial1_4 // 1/4 of the spell was resisted. OutcomePartial2_4 // 2/4 of the spell was resisted. OutcomePartial3_4 // 3/4 of the spell was resisted. )
Single-bit outcomes.
func (HitOutcome) Matches ¶
func (ho HitOutcome) Matches(other HitOutcome) bool
Returns whether there is any overlap between the given masks.
func (HitOutcome) PartialResistString ¶
func (ho HitOutcome) PartialResistString() string
func (HitOutcome) String ¶
func (ho HitOutcome) String() string
type IndividualTestSuite ¶
type IndividualTestSuite struct { Name string // contains filtered or unexported fields }
func NewIndividualTestSuite ¶
func NewIndividualTestSuite(suiteName string) *IndividualTestSuite
func (*IndividualTestSuite) Done ¶
func (testSuite *IndividualTestSuite) Done(t *testing.T)
func (*IndividualTestSuite) TestCasts ¶
func (testSuite *IndividualTestSuite) TestCasts(testName string, rsr *proto.RaidSimRequest)
func (*IndividualTestSuite) TestCharacterStats ¶
func (testSuite *IndividualTestSuite) TestCharacterStats(testName string, csr *proto.ComputeStatsRequest)
func (*IndividualTestSuite) TestDPS ¶
func (testSuite *IndividualTestSuite) TestDPS(testName string, rsr *proto.RaidSimRequest)
func (*IndividualTestSuite) TestStatWeights ¶
func (testSuite *IndividualTestSuite) TestStatWeights(testName string, swr *proto.StatWeightsRequest)
type Item ¶
type Item struct { ID int32 Type proto.ItemType ArmorType proto.ArmorType // Weapon Stats WeaponType proto.WeaponType HandType proto.HandType RangedWeaponType proto.RangedWeaponType WeaponDamageMin float64 WeaponDamageMax float64 SwingSpeed float64 Name string Stats stats.Stats // Stats applied to wearer Quality proto.ItemQuality SetName string // Empty string if not part of a set. WeaponSkills stats.WeaponSkills // Modified for each instance of the item. RandomSuffix RandomSuffix Enchant Enchant Rune int32 //Internal use TempEnchant int32 }
func ItemFromProto ¶
func (*Item) ToItemSpecProto ¶
type ItemComboChecker ¶
type ItemComboChecker map[int64]struct{}
type ItemFilter ¶
type ItemFilter struct { // If set to ClassUnknown, any class is fine. Class proto.Class ArmorType proto.ArmorType // Empty lists allows any value. Otherwise, item must match a value from the list. WeaponTypes []proto.WeaponType HandTypes []proto.HandType RangedWeaponTypes []proto.RangedWeaponType // Item IDs to ignore. IDBlacklist []int32 }
Returns all items that meet the given conditions.
func (*ItemFilter) FindAllItems ¶
func (filter *ItemFilter) FindAllItems() []Item
func (*ItemFilter) FindAllSets ¶
func (filter *ItemFilter) FindAllSets() []*ItemSet
type ItemSet ¶
type ItemSet struct { Name string AlternativeName string // Maps set piece requirement to an ApplyEffect function that will be called // before the Sim starts. // // The function should apply any benefits provided by the set bonus. Bonuses map[int32]ApplyEffect }
func NewItemSet ¶
Registers a new ItemSet with item IDs populated.
type ItemStringSpec ¶
Like ItemSpec, but uses names for reference instead of ID.
type ItemSwap ¶
type ItemSwap struct {
// contains filtered or unexported fields
}
func (*ItemSwap) CalcStatChanges ¶
func (*ItemSwap) RegisterOnSwapItemForEffect ¶
Helper for handling Effects that use the effectID to toggle the aura on and off
func (*ItemSwap) RegisterOnSwapItemForEffectWithPPMManager ¶
func (swap *ItemSwap) RegisterOnSwapItemForEffectWithPPMManager(effectID int32, ppm float64, ppmm *PPMManager, aura *Aura)
Helper for handling Effects that use PPMManager to toggle the aura on/off
type ItemsTestGenerator ¶
type ItemsTestGenerator struct { // Fields describing the base API request. Player *proto.Player PartyBuffs *proto.PartyBuffs RaidBuffs *proto.RaidBuffs Debuffs *proto.Debuffs Encounter *proto.Encounter SimOptions *proto.SimOptions IsHealer bool // Some fields are populated automatically. ItemFilter ItemFilter // contains filtered or unexported fields }
func (*ItemsTestGenerator) GetTest ¶
func (generator *ItemsTestGenerator) GetTest(testIdx int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*ItemsTestGenerator) NumTests ¶
func (generator *ItemsTestGenerator) NumTests() int
type MajorCooldown ¶
type MajorCooldown struct { // Spell that is cast when this MCD is activated. Spell *Spell // Cooldowns with higher priority get used first. This is important when some // cooldowns have a non-zero cast time. For example, Drums should be used // before Bloodlust. Priority int32 // Internal category, used for filtering. For example, mages want to disable // all DPS cooldowns during their regen rotation. Type CooldownType // Whether the cooldown meets all optional conditions for activation. These // conditions will be ignored when the user specifies their own activation time. // This is for things like mana thresholds, which are optimizations for better // automatic timing. ShouldActivate CooldownActivationCondition // contains filtered or unexported fields }
func (*MajorCooldown) Disable ¶
func (mcd *MajorCooldown) Disable()
func (*MajorCooldown) Enable ¶
func (mcd *MajorCooldown) Enable()
func (*MajorCooldown) GetTimings ¶
func (mcd *MajorCooldown) GetTimings() []time.Duration
func (*MajorCooldown) IsEnabled ¶
func (mcd *MajorCooldown) IsEnabled() bool
func (*MajorCooldown) IsReady ¶
func (mcd *MajorCooldown) IsReady(sim *Simulation) bool
func (*MajorCooldown) ReadyAt ¶
func (mcd *MajorCooldown) ReadyAt() time.Duration
func (*MajorCooldown) TimeToNextCast ¶
func (mcd *MajorCooldown) TimeToNextCast(sim *Simulation) time.Duration
Roughly how long until the next cast will happen, accounting for both spell CD and user-specified timings.
func (*MajorCooldown) TimeToReady ¶
func (mcd *MajorCooldown) TimeToReady(sim *Simulation) time.Duration
func (*MajorCooldown) TryActivate ¶
func (mcd *MajorCooldown) TryActivate(sim *Simulation, character *Character) bool
Public version of TryActivate for manual activation by Agent code. Note that this version will work even if the MCD is disabled.
type ManaCost ¶
type ManaCost struct {
ResourceMetrics *ResourceMetrics
}
func (*ManaCost) CostFailureReason ¶
func (mc *ManaCost) CostFailureReason(sim *Simulation, spell *Spell) string
func (*ManaCost) IssueRefund ¶
func (mc *ManaCost) IssueRefund(_ *Simulation, _ *Spell)
func (*ManaCost) MeetsRequirement ¶
func (mc *ManaCost) MeetsRequirement(sim *Simulation, spell *Spell) bool
func (*ManaCost) SpendCost ¶
func (mc *ManaCost) SpendCost(sim *Simulation, spell *Spell)
type ManaCostOptions ¶
type MeleeDamageCalculator ¶
type OnCastComplete ¶
type OnCastComplete func(aura *Aura, sim *Simulation, spell *Spell)
Callback for when a cast is finished, i.e. when the in-game castbar reaches full.
type OnDamage ¶
type OnDamage func(aura *Aura, sim *Simulation, spell *Spell, result *SpellResult)
OnDamage is called after damage is calculated. Use it for proc effects or anything that comes from the final result of dealing damage.
type OnDoneIteration ¶
type OnDoneIteration func(aura *Aura, sim *Simulation)
type OnExpire ¶
type OnExpire func(aura *Aura, sim *Simulation)
type OnFocusGain ¶
type OnFocusGain func(sim *Simulation)
OnFocusGain is called any time focus is increased.
type OnGain ¶
type OnGain func(aura *Aura, sim *Simulation)
type OnInit ¶
type OnInit func(aura *Aura, sim *Simulation)
type OnPeriodicDamage ¶
type OnPeriodicDamage func(aura *Aura, sim *Simulation, spell *Spell, result *SpellResult)
OnPeriodicDamage is called when dots tick, after damage is calculated. Use it for proc effects or anything that comes from the final result of a tick.
type OnPetDisable ¶
type OnPetDisable func(sim *Simulation)
type OnPetEnable ¶
type OnPetEnable func(sim *Simulation)
type OnRageChange ¶
type OnRageChange func(aura *Aura, sim *Simulation, metrics *ResourceMetrics)
OnRageChange is called any time rage is increased.
type OnReset ¶
type OnReset func(aura *Aura, sim *Simulation)
type OnSnapshot ¶
type OnSnapshot func(sim *Simulation, target *Unit, dot *Dot, isRollover bool)
type OnSpellHit ¶
type OnSpellHit func(aura *Aura, sim *Simulation, spell *Spell, result *SpellResult)
Callback for after a spell hits the target and after damage is calculated. Use it for proc effects or anything that comes from the final result of the spell.
type OnStacksChange ¶
type OnStacksChange func(aura *Aura, sim *Simulation, oldStacks int32, newStacks int32)
type OnStatsChange ¶
type OnSwapItem ¶
type OnSwapItem func(*Simulation)
type OnTick ¶
type OnTick func(sim *Simulation, target *Unit, dot *Dot)
type OutcomeApplier ¶
type OutcomeApplier func(sim *Simulation, result *SpellResult, attackTable *AttackTable)
This function should do 3 things:
- Set the Outcome of the hit effect.
- Update spell outcome metrics.
- Modify the damage if necessary.
type PPMManager ¶
type PPMManager struct {
// contains filtered or unexported fields
}
func (*PPMManager) Chance ¶
func (ppmm *PPMManager) Chance(procMask ProcMask) float64
func (*PPMManager) Proc ¶
func (ppmm *PPMManager) Proc(sim *Simulation, procMask ProcMask, label string) bool
Returns whether the effect procced.
func (*PPMManager) ProcWithWeaponSpecials ¶
func (ppmm *PPMManager) ProcWithWeaponSpecials(sim *Simulation, procMask ProcMask, label string) bool
Returns whether the effect procced. This is different from Proc() in that yellow melee hits use a proc chance based on the equipped weapon speed rather than the base attack speed. This distinction matters for feral druids.
type Party ¶
type Party struct { Raid *Raid Index int Players []Agent Pets []PetAgent // Cached list of all the pets in the party. PlayersAndPets []Agent // Cached list of players + pets, concatenated. // contains filtered or unexported fields }
func (*Party) GetMetrics ¶
func (party *Party) GetMetrics() *proto.PartyMetrics
func (*Party) GetPartyBuffs ¶
func (party *Party) GetPartyBuffs(basePartyBuffs *proto.PartyBuffs) *proto.PartyBuffs
type PendingAction ¶
type PendingAction struct { NextActionAt time.Duration Priority ActionPriority // Action to perform (required). OnAction func(sim *Simulation) // Cleanup when the action is cancelled (optional). CleanUp func(sim *Simulation) // contains filtered or unexported fields }
func NewDelayedAction ¶
func NewDelayedAction(sim *Simulation, options DelayedActionOptions) *PendingAction
func NewPeriodicAction ¶
func NewPeriodicAction(sim *Simulation, options PeriodicActionOptions) *PendingAction
func StartDelayedAction ¶
func StartDelayedAction(sim *Simulation, options DelayedActionOptions) *PendingAction
Convenience for immediately creating and starting a delayed action.
func StartPeriodicAction ¶
func StartPeriodicAction(sim *Simulation, options PeriodicActionOptions) *PendingAction
Convenience for immediately creating and starting a periodic action.
func (*PendingAction) Cancel ¶
func (pa *PendingAction) Cancel(sim *Simulation)
type PeriodicActionOptions ¶
type PeriodicActionOptions struct { // How often the action should be performed. Period time.Duration // Number of times to perform the action before stopping. // 0 indicates a permanent periodic action. NumTicks int // Whether the first tick should happen immediately. If false, first tick will // wait for Period. TickImmediately bool Priority ActionPriority OnAction func(*Simulation) CleanUp func(*Simulation) }
type Pet ¶
type Pet struct { Character Owner *Character OnPetEnable OnPetEnable OnPetDisable OnPetDisable // contains filtered or unexported fields }
Pet is an extension of Character, for any entity created by a player that can take actions on its own.
func (*Pet) AddComboPoints ¶
func (eb *Pet) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
func (*Pet) AddEnergy ¶
func (eb *Pet) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) AddFocus ¶
func (fb *Pet) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) AddMajorCooldown ¶
func (mcdm *Pet) AddMajorCooldown(mcd MajorCooldown)
Registers a major cooldown to the Character, which will be automatically used when available.
func (*Pet) AddPartyBuffs ¶
func (pet *Pet) AddPartyBuffs(_ *proto.PartyBuffs)
func (*Pet) AddRage ¶
func (rb *Pet) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) AddRaidBuffs ¶
func (*Pet) ApplyRunes ¶
func (pet *Pet) ApplyRunes()
func (*Pet) ApplyTalents ¶
func (pet *Pet) ApplyTalents()
func (*Pet) ComboPoints ¶
func (eb *Pet) ComboPoints() int32
func (*Pet) CurrentEnergy ¶
func (eb *Pet) CurrentEnergy() float64
func (*Pet) CurrentFocus ¶
func (fb *Pet) CurrentFocus() float64
func (*Pet) CurrentFocusPerTick ¶
func (fb *Pet) CurrentFocusPerTick() float64
func (*Pet) CurrentHealth ¶
func (hb *Pet) CurrentHealth() float64
func (*Pet) CurrentHealthPercent ¶
func (hb *Pet) CurrentHealthPercent() float64
func (*Pet) CurrentRage ¶
func (rb *Pet) CurrentRage() float64
func (*Pet) Disable ¶
func (pet *Pet) Disable(sim *Simulation)
func (*Pet) Enable ¶
func (pet *Pet) Enable(sim *Simulation, petAgent PetAgent)
petAgent should be the PetAgent which embeds this Pet.
func (*Pet) EnableDynamicMeleeSpeed ¶
func (pet *Pet) EnableDynamicMeleeSpeed(inheritance PetMeleeSpeedInheritance)
Enables and possibly updates how the pet inherits its owner's melee speed. DK use only.
func (*Pet) EnableDynamicStats ¶
func (pet *Pet) EnableDynamicStats(inheritance PetStatInheritance)
Enables and possibly updates how the pet inherits its owner's stats. DK use only.
func (*Pet) EnableWithTimeout ¶
func (pet *Pet) EnableWithTimeout(sim *Simulation, petAgent PetAgent, petDuration time.Duration)
Helper for enabling a pet that will expire after a certain duration.
func (*Pet) EndOOMEvent ¶
func (mb *Pet) EndOOMEvent(sim *Simulation)
func (*Pet) GainHealth ¶
func (hb *Pet) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) GetActiveAuraWithTag ¶
func (*Pet) GetAuraByID ¶
func (*Pet) GetAurasWithTag ¶
func (*Pet) GetCharacter ¶
Default implementations for some Agent functions which most Pets don't need.
func (*Pet) GetIcdAuraByID ¶
func (*Pet) GetInitialMajorCooldown ¶
func (mcdm *Pet) GetInitialMajorCooldown(actionID ActionID) MajorCooldown
func (*Pet) GetMajorCooldown ¶
func (mcdm *Pet) GetMajorCooldown(actionID ActionID) *MajorCooldown
func (*Pet) GetMajorCooldownIDs ¶
func (*Pet) GetMajorCooldownIgnoreTag ¶
func (mcdm *Pet) GetMajorCooldownIgnoreTag(actionID ActionID) *MajorCooldown
func (*Pet) GetMajorCooldowns ¶
func (mcdm *Pet) GetMajorCooldowns() []*MajorCooldown
Returns all MCDs.
func (*Pet) HasActiveAura ¶
func (*Pet) HasActiveAuraWithTag ¶
func (*Pet) HasActiveAuraWithTagExcludingAura ¶
func (*Pet) HasAuraWithTag ¶
func (*Pet) IsGuardian ¶
func (*Pet) NextEnergyTickAt ¶
func (*Pet) NumActiveAurasWithTag ¶
func (*Pet) OnCastComplete ¶
func (at *Pet) OnCastComplete(sim *Simulation, spell *Spell)
Invokes the OnCastComplete event for all tracked Auras.
func (*Pet) OnGCDReady ¶
func (pet *Pet) OnGCDReady(_ *Simulation)
func (*Pet) OnHealDealt ¶
func (at *Pet) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnHeal event for all tracked Auras.
func (*Pet) OnHealTaken ¶
func (at *Pet) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Pet) OnPeriodicDamageDealt ¶
func (at *Pet) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicDamage
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Pet) OnPeriodicDamageTaken ¶
func (at *Pet) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Pet) OnPeriodicHealDealt ¶
func (at *Pet) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicHeal
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Pet) OnPeriodicHealTaken ¶
func (at *Pet) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Pet) OnRageChange ¶
func (at *Pet) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
Invokes the OnRageChange for all tracked auras
func (*Pet) OnSpellHitDealt ¶
func (at *Pet) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnSpellHit event for all tracked Auras.
func (*Pet) OnSpellHitTaken ¶
func (at *Pet) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Pet) RegisterResetEffect ¶
func (at *Pet) RegisterResetEffect(resetEffect ResetEffect)
Registers a callback to this Character which will be invoked on every Sim reset.
func (*Pet) RemoveHealth ¶
func (hb *Pet) RemoveHealth(sim *Simulation, amount float64)
func (*Pet) ResetEnergyTick ¶
func (eb *Pet) ResetEnergyTick(sim *Simulation)
Gives an immediate partial energy tick and restarts the tick timer.
func (*Pet) SpendComboPoints ¶
func (eb *Pet) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
func (*Pet) SpendEnergy ¶
func (eb *Pet) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) SpendFocus ¶
func (fb *Pet) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) SpendRage ¶
func (rb *Pet) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Pet) StartOOMEvent ¶
func (mb *Pet) StartOOMEvent(sim *Simulation, requiredMana float64)
func (*Pet) TryUseCooldowns ¶
func (mcdm *Pet) TryUseCooldowns(sim *Simulation)
func (*Pet) UpdateMajorCooldowns ¶
func (mcdm *Pet) UpdateMajorCooldowns()
This function should be called if the CD for a major cooldown changes outside of the TryActivate() call.
type PetMeleeSpeedInheritance ¶
type PetMeleeSpeedInheritance func(amount float64)
type PostFinalizeEffect ¶
type PostFinalizeEffect func()
Callback for doing something after finalization.
type PrepullAction ¶
type PrepullAction struct { DoAt time.Duration Action func(*Simulation) }
Callback for doing something on prepull.
type PresetTarget ¶
type PresetTarget struct { // String in folder-structure format identifying a category for this unit, e.g. "Black Temple/Bosses". PathPrefix string Config *proto.Target AI AIFactory }
func GetPresetTargetWithID ¶
func GetPresetTargetWithID(id int32) *PresetTarget
func GetPresetTargetWithPath ¶
func GetPresetTargetWithPath(path string) *PresetTarget
func (PresetTarget) Path ¶
func (pt PresetTarget) Path() string
func (PresetTarget) ToProto ¶
func (pt PresetTarget) ToProto() *proto.PresetTarget
type PresimOptions ¶
type PresimOptions struct { // Called once before each presim round. // // Modify the player parameter to use whatever player options are desired // for the presim. SetPresimPlayerOptions func(player *proto.Player) // Called once after each presim round to provide the results. // // Should return true if this Agent is done running presims, and false otherwise. OnPresimResult func(presimResult *proto.UnitMetrics, iterations int32, duration time.Duration) bool }
Controls the presim behavior for 1 Agent.
type Presimmer ¶
type Presimmer interface {
GetPresimOptions(*proto.Player) *PresimOptions
}
A presim is a full simulation run with multiple iterations, as a preparation step for testing out settings before starting the recorded iterations.
To use this, just implement this interface on your Agent.
If you don't know what this is, you probably don't need it.
type ProcHandler ¶
type ProcHandler func(sim *Simulation, spell *Spell, result *SpellResult)
type ProcMask ¶
type ProcMask uint32
const ( // Default value is invalid, to force authors to think about proc masks. ProcMaskUnknown ProcMask = 0 ProcMaskEmpty ProcMask = 1 << iota ProcMaskMeleeMHAuto ProcMaskMeleeOHAuto ProcMaskMeleeMHSpecial ProcMaskMeleeOHSpecial ProcMaskRangedAuto ProcMaskRangedSpecial ProcMaskSpellDamage ProcMaskSpellHealing // Special mask for procs that can trigger things ProcMaskProc // Mask for FT weapon and rogue poisons, seems to be spell procs from a weapon imbue ProcMaskWeaponProc // Mind Flay ProcMaskNotInSpellbook // Can proc Talisman of Volatile power, but nothing else? ProcMaskSuppressedProc // Can't proc Windfury / Wild Strikes ProcMaskSuppressedExtraAttackAura )
Single-bit masks. These don't need to match Blizzard's values.
type ProcTrigger ¶
type ProcTrigger struct { Name string ActionID ActionID Duration time.Duration Callback AuraCallback ProcMask ProcMask ProcMaskExclude ProcMask SpellFlags SpellFlag Outcome HitOutcome Harmful bool ProcChance float64 PPM float64 ICD time.Duration Handler ProcHandler }
type RageBarOptions ¶
type RageCost ¶
type RageCost struct { Refund float64 RefundMetrics *ResourceMetrics ResourceMetrics *ResourceMetrics }
func (*RageCost) CostFailureReason ¶
func (rc *RageCost) CostFailureReason(sim *Simulation, spell *Spell) string
func (*RageCost) IssueRefund ¶
func (rc *RageCost) IssueRefund(sim *Simulation, spell *Spell)
func (*RageCost) MeetsRequirement ¶
func (rc *RageCost) MeetsRequirement(_ *Simulation, spell *Spell) bool
func (*RageCost) SpendCost ¶
func (rc *RageCost) SpendCost(sim *Simulation, spell *Spell)
type RageCostOptions ¶
type RageCostOptions struct { Cost float64 Refund float64 RefundMetrics *ResourceMetrics // Optional, will default to unit.RageRefundMetrics if not supplied. }
type Raid ¶
type Raid struct { Parties []*Party AllPlayerUnits []*Unit // Cached list of all Players in the raid. AllUnits []*Unit // Cached list of all Units (players and pets) in the raid. // contains filtered or unexported fields }
func (*Raid) GetActiveUnits ¶
func (*Raid) GetFirstEmptyRaidIndex ¶
Returns (party, index within party)
func (*Raid) GetFirstNPlayersOrPets ¶
func (*Raid) GetFirstTargetDummy ¶
func (raid *Raid) GetFirstTargetDummy() *TargetDummy
func (*Raid) GetMetrics ¶
func (raid *Raid) GetMetrics() *proto.RaidMetrics
func (*Raid) GetPlayerFromUnit ¶
func (*Raid) GetPlayerFromUnitIndex ¶
func (*Raid) GetPlayerParty ¶
func (*Raid) GetRaidBuffs ¶
type Rand ¶
type Rand interface { Next() uint64 NextFloat64() float64 Seed(int64) GetSeed() int64 rand.Source64 }
implementing Source or Source64 is possible, but adds too much overhead
type RandomSuffix ¶
func RandomSuffixFromProto ¶
func RandomSuffixFromProto(pData *proto.ItemRandomSuffix) RandomSuffix
type ReplaceMHSwing ¶
type ReplaceMHSwing func(sim *Simulation, mhSwingSpell *Spell) *Spell
ReplaceMHSwing is called right before a main hand auto attack fires. It must never return nil, but either a replacement spell or the passed in regular mhSwingSpell. This allows for abilities that convert a white attack into a yellow attack.
type ResourceKey ¶
type ResourceKey struct { ActionID ActionID Type proto.ResourceType }
type ResourceMetrics ¶
type ResourceMetrics struct { ActionID ActionID Type proto.ResourceType Events int32 Gain float64 ActualGain float64 EventsFromPreviousIterations int32 ActualGainFromPreviousIterations float64 }
func (*ResourceMetrics) ActualGainForCurrentIteration ¶
func (resourceMetrics *ResourceMetrics) ActualGainForCurrentIteration() float64
func (*ResourceMetrics) AddEvent ¶
func (resourceMetrics *ResourceMetrics) AddEvent(gain float64, actualGain float64)
func (*ResourceMetrics) EventsForCurrentIteration ¶
func (resourceMetrics *ResourceMetrics) EventsForCurrentIteration() int32
func (*ResourceMetrics) ToProto ¶
func (resourceMetrics *ResourceMetrics) ToProto() *proto.ResourceMetrics
type RotationCastsTestGenerator ¶
type RotationCastsTestGenerator struct { SpecOptions []SpecOptionsCombo PartyBuffs *proto.PartyBuffs RaidBuffs *proto.RaidBuffs Debuffs *proto.Debuffs Player *proto.Player Encounter *proto.Encounter SimOptions *proto.SimOptions }
func (*RotationCastsTestGenerator) GetTest ¶
func (generator *RotationCastsTestGenerator) GetTest(testIdx int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*RotationCastsTestGenerator) NumTests ¶
func (generator *RotationCastsTestGenerator) NumTests() int
type RotationCombo ¶
type RotationCombo struct { Label string Rotation *proto.APLRotation }
func GetAplRotation ¶
func GetAplRotation(dir string, file string) RotationCombo
type SettingsCombos ¶
type SettingsCombos struct { Class proto.Class Races []proto.Race Level int32 GearSets []GearSetCombo TalentSets []TalentsCombo SpecOptions []SpecOptionsCombo Rotations []RotationCombo Buffs []BuffsCombo Encounters []EncounterCombo SimOptions *proto.SimOptions IsHealer bool Cooldowns *proto.Cooldowns }
func (*SettingsCombos) GetTest ¶
func (combos *SettingsCombos) GetTest(testIdx int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*SettingsCombos) NumTests ¶
func (combos *SettingsCombos) NumTests() int
type Shield ¶
type Shield struct { Spell *Spell // Embed Aura so we can use IsActive/Refresh/etc directly. *Aura }
Rerpresents an absorption effect, e.g. Power Word: Shield.
func (*Shield) Apply ¶
func (shield *Shield) Apply(sim *Simulation, shieldAmount float64)
type ShieldArray ¶
type ShieldArray []*Shield
func (ShieldArray) Get ¶
func (shields ShieldArray) Get(target *Unit) *Shield
type ShieldConfig ¶
type Simulation ¶
type Simulation struct { *Environment Options *proto.SimOptions CurrentTime time.Duration // duration that has elapsed in the sim since starting Duration time.Duration // Duration of current iteration NeedsInput bool // Sim is in interactive mode and needs input ProgressReport func(*proto.ProgressMetrics) Log func(string, ...interface{}) // contains filtered or unexported fields }
func NewSim ¶
func NewSim(rsr *proto.RaidSimRequest) *Simulation
func (*Simulation) AddPendingAction ¶
func (sim *Simulation) AddPendingAction(pa *PendingAction)
func (*Simulation) AddTask ¶
func (sim *Simulation) AddTask(task Task)
func (*Simulation) Cleanup ¶
func (sim *Simulation) Cleanup()
func (*Simulation) GetRemainingDuration ¶
func (sim *Simulation) GetRemainingDuration() time.Duration
func (*Simulation) GetRemainingDurationPercent ¶
func (sim *Simulation) GetRemainingDurationPercent() float64
Returns the percentage of time remaining in the current iteration, as a value from 0-1.
func (*Simulation) IsExecutePhase20 ¶
func (sim *Simulation) IsExecutePhase20() bool
func (*Simulation) IsExecutePhase25 ¶
func (sim *Simulation) IsExecutePhase25() bool
func (*Simulation) IsExecutePhase35 ¶
func (sim *Simulation) IsExecutePhase35() bool
func (*Simulation) PrePull ¶
func (sim *Simulation) PrePull()
func (*Simulation) RandomExpFloat ¶
func (sim *Simulation) RandomExpFloat(label string) float64
func (*Simulation) RandomFloat ¶
func (sim *Simulation) RandomFloat(label string) float64
Returns a random float64 between 0.0 (inclusive) and 1.0 (exclusive).
In tests, although we can set the initial seed, test results are still very sensitive to the exact order of RandomFloat() calls. To mitigate this, when testing we use a separate rand object for each RandomFloat callsite, distinguished by the label string.
func (*Simulation) RegisterExecutePhaseCallback ¶
func (sim *Simulation) RegisterExecutePhaseCallback(callback func(sim *Simulation, isExecute int32))
func (*Simulation) RemoveTask ¶
func (sim *Simulation) RemoveTask(task Task)
func (*Simulation) RescheduleTask ¶
func (sim *Simulation) RescheduleTask(taskTime time.Duration)
func (*Simulation) Reseed ¶
func (sim *Simulation) Reseed(seed int64)
func (*Simulation) Reset ¶
func (sim *Simulation) Reset()
func (*Simulation) Roll ¶
func (sim *Simulation) Roll(min float64, max float64) float64
Shorthand for commonly-used RNG behavior. Returns a random number between min and max.
func (*Simulation) RollWithLabel ¶
func (sim *Simulation) RollWithLabel(min float64, max float64, label string) float64
func (*Simulation) Step ¶
func (sim *Simulation) Step() bool
type SingleCharacterStatsTestGenerator ¶
type SingleCharacterStatsTestGenerator struct { Name string Request *proto.ComputeStatsRequest }
func (*SingleCharacterStatsTestGenerator) GetTest ¶
func (generator *SingleCharacterStatsTestGenerator) GetTest(_ int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*SingleCharacterStatsTestGenerator) NumTests ¶
func (generator *SingleCharacterStatsTestGenerator) NumTests() int
type SingleDpsTestGenerator ¶
type SingleDpsTestGenerator struct { Name string Request *proto.RaidSimRequest }
func (*SingleDpsTestGenerator) GetTest ¶
func (generator *SingleDpsTestGenerator) GetTest(_ int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*SingleDpsTestGenerator) NumTests ¶
func (generator *SingleDpsTestGenerator) NumTests() int
type SingleStatWeightsTestGenerator ¶
type SingleStatWeightsTestGenerator struct { Name string Request *proto.StatWeightsRequest }
func (*SingleStatWeightsTestGenerator) GetTest ¶
func (generator *SingleStatWeightsTestGenerator) GetTest(_ int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest)
func (*SingleStatWeightsTestGenerator) NumTests ¶
func (generator *SingleStatWeightsTestGenerator) NumTests() int
type SpecOptionsCombo ¶
type SpecOptionsCombo struct { Label string SpecOptions interface{} }
type SpecSetter ¶
type Spell ¶
type Spell struct { // ID for this spell. ActionID // Used to identify spells with multiple ranks that need to be referenced SpellCode int32 // The unit who will perform this spell. Unit *Unit SpellSchool SpellSchool // Schoolmask of all schools this spell uses. Use Spell.SetSchool() to change this! DefenseType DefenseType SchoolIndex stats.SchoolIndex // Use Spell.SetSchool() to change this! SchoolBaseIndices []stats.SchoolIndex // Base school indices for multi schools. Use Spell.SetSchool() to change this! IsMultischool bool // True if school is composed of multiple base schools. Use Spell.SetSchool() to change this! // Controls which effects can proc from this spell. ProcMask ProcMask // Flags Flags SpellFlag // From which slot this spell cast. Usually from Mainhand CastType proto.CastType // Speed in yards/second. Spell missile speeds can be found in the game data. // Example: https://wow.tools/dbc/?dbc=spellmisc&build=3.4.0.44996 MissileSpeed float64 ResourceMetrics *ResourceMetrics Cost SpellCost // Cost for the spell. DefaultCast Cast // Default cast parameters with all static effects applied. CD Cooldown ExtraCastCondition CanCastCondition SpellMetrics []SpellMetrics // Performs the actions of this spell. ApplyEffects ApplySpellResults // The current or most recent cast data. CurCast Cast BonusHitRating float64 BonusCritRating float64 BonusSpellPower float64 BonusExpertiseRating float64 BonusArmorPenRating float64 CastTimeMultiplier float64 CostMultiplier float64 DamageMultiplier float64 DamageMultiplierAdditive float64 CritDamageBonus float64 // Multiplier for all threat generated by this effect. ThreatMultiplier float64 // Adds a fixed amount of threat to this spell, before multipliers. FlatThreatBonus float64 // Per-target auras that are related to this spell, usually buffs or debuffs applied by the spell. RelatedAuras []AuraArray // Reference to a spell to be considered as the CD // Defaults to this spell (Used for Next Melee spells) CdSpell *Spell // contains filtered or unexported fields }
func (*Spell) ApplyAOEThreat ¶
func (*Spell) ApplyAOEThreatIgnoreMultipliers ¶
func (*Spell) ApplyCostModifiers ¶
func (*Spell) ApplyPostOutcomeDamageModifiers ¶
func (spell *Spell) ApplyPostOutcomeDamageModifiers(sim *Simulation, result *SpellResult)
func (*Spell) AttackerDamageMultiplier ¶
func (spell *Spell) AttackerDamageMultiplier(attackTable *AttackTable) float64
Returns the combined attacker modifiers.
func (*Spell) BonusWeaponDamage ¶
func (*Spell) CalcAndDealDamage ¶
func (spell *Spell) CalcAndDealDamage(sim *Simulation, target *Unit, baseDamage float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcAndDealHealing ¶
func (spell *Spell) CalcAndDealHealing(sim *Simulation, target *Unit, baseHealing float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcAndDealOutcome ¶
func (spell *Spell) CalcAndDealOutcome(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcAndDealPeriodicDamage ¶
func (spell *Spell) CalcAndDealPeriodicDamage(sim *Simulation, target *Unit, baseDamage float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcAndDealPeriodicHealing ¶
func (spell *Spell) CalcAndDealPeriodicHealing(sim *Simulation, target *Unit, baseHealing float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcDamage ¶
func (spell *Spell) CalcDamage(sim *Simulation, target *Unit, baseDamage float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcHealing ¶
func (spell *Spell) CalcHealing(sim *Simulation, target *Unit, baseHealing float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CalcOutcome ¶
func (spell *Spell) CalcOutcome(sim *Simulation, target *Unit, outcomeApplier OutcomeApplier) *SpellResult
For spells that do no damage but still have a hit/miss check.
func (*Spell) CalcPeriodicDamage ¶
func (spell *Spell) CalcPeriodicDamage(sim *Simulation, target *Unit, baseDamage float64, outcomeApplier OutcomeApplier) *SpellResult
func (*Spell) CanCast ¶
func (spell *Spell) CanCast(sim *Simulation, target *Unit) bool
Returns whether a call to Cast() would be successful, without actually doing a cast.
func (*Spell) CasterHealingMultiplier ¶
func (*Spell) ComboPointMetrics ¶
func (spell *Spell) ComboPointMetrics() *ResourceMetrics
func (*Spell) CritMultiplier ¶
func (spell *Spell) CritMultiplier(at *AttackTable) float64
CritMultiplier() returns the damage multiplier for critical strikes, based on CritDamageBonus and DefenseType. https://web.archive.org/web/20081014064638/http://elitistjerks.com/f31/t12595-relentless_earthstorm_diamond_-_melee_only/p4/ https://github.com/TheGroxEmpire/TBC_DPS_Warrior_Sim/issues/30
func (*Spell) CurDamagePerCast ¶
Metrics for the current iteration
func (*Spell) DealDamage ¶
func (spell *Spell) DealDamage(sim *Simulation, result *SpellResult)
func (*Spell) DealHealing ¶
func (spell *Spell) DealHealing(sim *Simulation, result *SpellResult)
func (*Spell) DealOutcome ¶
func (spell *Spell) DealOutcome(sim *Simulation, result *SpellResult)
func (*Spell) DealPeriodicDamage ¶
func (spell *Spell) DealPeriodicDamage(sim *Simulation, result *SpellResult)
func (*Spell) DealPeriodicHealing ¶
func (spell *Spell) DealPeriodicHealing(sim *Simulation, result *SpellResult)
func (*Spell) DisposeResult ¶
func (spell *Spell) DisposeResult(result *SpellResult)
func (*Spell) EffectiveCastTime ¶
Time until either the cast is finished or GCD is ready again, whichever is longer
func (*Spell) EnergyMetrics ¶
func (spell *Spell) EnergyMetrics() *ResourceMetrics
func (*Spell) ExpectedInitialDamage ¶
func (spell *Spell) ExpectedInitialDamage(sim *Simulation, target *Unit) float64
func (*Spell) ExpectedTickDamage ¶
func (spell *Spell) ExpectedTickDamage(sim *Simulation, target *Unit) float64
func (*Spell) ExpectedTickDamageFromCurrentSnapshot ¶
func (spell *Spell) ExpectedTickDamageFromCurrentSnapshot(sim *Simulation, target *Unit) float64
func (*Spell) ExpertisePercentage ¶
func (*Spell) HealingCritChance ¶
func (*Spell) HealingCritCheck ¶
func (spell *Spell) HealingCritCheck(sim *Simulation) bool
func (*Spell) HealingPower ¶
func (*Spell) HealthMetrics ¶
func (spell *Spell) HealthMetrics(target *Unit) *ResourceMetrics
func (*Spell) IsReady ¶
func (spell *Spell) IsReady(sim *Simulation) bool
func (*Spell) IssueRefund ¶
func (spell *Spell) IssueRefund(sim *Simulation)
func (*Spell) MagicCritCheck ¶
func (spell *Spell) MagicCritCheck(sim *Simulation, target *Unit) bool
func (*Spell) MagicHitCheck ¶
func (spell *Spell) MagicHitCheck(sim *Simulation, attackTable *AttackTable) bool
func (*Spell) MeleeAttackPower ¶
func (*Spell) NewResult ¶
func (spell *Spell) NewResult(target *Unit) *SpellResult
func (*Spell) OutcomeAlwaysHit ¶
func (spell *Spell) OutcomeAlwaysHit(_ *Simulation, result *SpellResult, _ *AttackTable)
func (*Spell) OutcomeAlwaysMiss ¶
func (spell *Spell) OutcomeAlwaysMiss(_ *Simulation, result *SpellResult, _ *AttackTable)
func (*Spell) OutcomeEnemyMeleeWhite ¶
func (spell *Spell) OutcomeEnemyMeleeWhite(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeExpectedMagicAlwaysHit ¶
func (spell *Spell) OutcomeExpectedMagicAlwaysHit(_ *Simulation, _ *SpellResult, _ *AttackTable)
func (*Spell) OutcomeExpectedMagicCrit ¶
func (spell *Spell) OutcomeExpectedMagicCrit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeExpectedMagicHit ¶
func (spell *Spell) OutcomeExpectedMagicHit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeExpectedMagicHitAndCrit ¶
func (spell *Spell) OutcomeExpectedMagicHitAndCrit(_ *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeExpectedTick ¶
func (spell *Spell) OutcomeExpectedTick(_ *Simulation, _ *SpellResult, _ *AttackTable)
func (*Spell) OutcomeHealing ¶
func (spell *Spell) OutcomeHealing(_ *Simulation, result *SpellResult, _ *AttackTable)
func (*Spell) OutcomeHealingCrit ¶
func (spell *Spell) OutcomeHealingCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMagicCrit ¶
func (spell *Spell) OutcomeMagicCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMagicHit ¶
func (spell *Spell) OutcomeMagicHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMagicHitAndCrit ¶
func (spell *Spell) OutcomeMagicHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeSpecialCritOnly ¶
func (spell *Spell) OutcomeMeleeSpecialCritOnly(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeSpecialHit ¶
func (spell *Spell) OutcomeMeleeSpecialHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeSpecialHitAndCrit ¶
func (spell *Spell) OutcomeMeleeSpecialHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeSpecialNoBlockDodgeParry ¶
func (spell *Spell) OutcomeMeleeSpecialNoBlockDodgeParry(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeSpecialNoBlockDodgeParryNoCrit ¶
func (spell *Spell) OutcomeMeleeSpecialNoBlockDodgeParryNoCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeWeaponSpecialHitAndCrit ¶
func (spell *Spell) OutcomeMeleeWeaponSpecialHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
Like OutcomeMeleeSpecialHitAndCrit, but blocks prevent crits (all weapon damage based attacks).
func (*Spell) OutcomeMeleeWeaponSpecialNoCrit ¶
func (spell *Spell) OutcomeMeleeWeaponSpecialNoCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeMeleeWhite ¶
func (spell *Spell) OutcomeMeleeWhite(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeRangedCritOnly ¶
func (spell *Spell) OutcomeRangedCritOnly(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeRangedHit ¶
func (spell *Spell) OutcomeRangedHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeRangedHitAndCrit ¶
func (spell *Spell) OutcomeRangedHitAndCrit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeRangedHitAndCritNoBlock ¶
func (spell *Spell) OutcomeRangedHitAndCritNoBlock(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) OutcomeTickMagicHit ¶
func (spell *Spell) OutcomeTickMagicHit(sim *Simulation, result *SpellResult, attackTable *AttackTable)
func (*Spell) PhysicalCritChance ¶
func (spell *Spell) PhysicalCritChance(attackTable *AttackTable) float64
func (*Spell) PhysicalCritCheck ¶
func (spell *Spell) PhysicalCritCheck(sim *Simulation, attackTable *AttackTable) bool
func (*Spell) PhysicalHitChance ¶
func (spell *Spell) PhysicalHitChance(attackTable *AttackTable) float64
func (*Spell) RangedAttackPower ¶
func (*Spell) ResistanceMultiplier ¶
func (spell *Spell) ResistanceMultiplier(sim *Simulation, isPeriodic bool, attackTable *AttackTable) (float64, HitOutcome)
Modifies damage based on Armor or Magic resistances, depending on the damage type.
func (*Spell) SelfShield ¶
func (*Spell) SetMetricsSplit ¶
func (*Spell) SetSchool ¶
func (spell *Spell) SetSchool(schoolIndex stats.SchoolIndex)
Sets school index, mask and base indices.
func (*Spell) ShouldRefreshExclusiveEffects ¶
func (*Spell) SkipCastAndApplyEffects ¶
func (spell *Spell) SkipCastAndApplyEffects(sim *Simulation, target *Unit)
Skips the actual cast and applies spell effects immediately.
func (*Spell) SpellChanceToMiss ¶
func (spell *Spell) SpellChanceToMiss(attackTable *AttackTable) float64
func (*Spell) SpellCritChance ¶
func (*Spell) SpellDamage ¶
func (*Spell) SpellHitChance ¶
func (*Spell) SpellPower ¶
TODO: This should probably be merged with SpellDamage()? Doesn't make sense the way it is.
func (*Spell) SpellSchoolPower ¶
func (*Spell) TargetDamageMultiplier ¶
func (spell *Spell) TargetDamageMultiplier(attackTable *AttackTable, isPeriodic bool) float64
func (*Spell) ThreatFromDamage ¶
func (spell *Spell) ThreatFromDamage(outcome HitOutcome, damage float64) float64
func (*Spell) TimeToReady ¶
func (spell *Spell) TimeToReady(sim *Simulation) time.Duration
func (*Spell) TravelTime ¶
func (*Spell) WaitTravelTime ¶
func (spell *Spell) WaitTravelTime(sim *Simulation, callback func(*Simulation))
type SpellConfig ¶
type SpellConfig struct { // See definition of Spell (below) for comments on these. ActionID // Used to identify spells with multiple ranks that need to be referenced SpellCode int32 SpellSchool SpellSchool DefenseType DefenseType ProcMask ProcMask Flags SpellFlag CastType proto.CastType MissileSpeed float64 BaseCost float64 MetricSplits int Rank int RequiredLevel int ManaCost ManaCostOptions EnergyCost EnergyCostOptions RageCost RageCostOptions FocusCost FocusCostOptions Cast CastConfig ExtraCastCondition CanCastCondition BonusHitRating float64 BonusCritRating float64 BonusSpellPower float64 BonusExpertiseRating float64 BonusArmorPenRating float64 CritDamageBonus float64 DamageMultiplier float64 DamageMultiplierAdditive float64 ThreatMultiplier float64 FlatThreatBonus float64 // Performs the actions of this spell. ApplyEffects ApplySpellResults // Optional field. Calculates expected average damage. ExpectedInitialDamage ExpectedDamageCalculator ExpectedTickDamage ExpectedDamageCalculator Dot DotConfig Hot DotConfig Shield ShieldConfig RelatedAuras []AuraArray }
type SpellCost ¶
type SpellCost interface { // Whether the Unit associated with the spell meets the resource cost // requirements to cast the spell. MeetsRequirement(*Simulation, *Spell) bool // Returns a message for when the cast fails due to lack of resources. CostFailureReason(*Simulation, *Spell) string // Subtracts the resources used from a cast from the Unit. SpendCost(*Simulation, *Spell) // Space for handling refund mechanics. Not all spells provide refunds. IssueRefund(*Simulation, *Spell) }
Handles computing the cost of spells and checking whether the Unit meets them.
type SpellFlag ¶
type SpellFlag uint32
Other flags
const ( SpellFlagNone SpellFlag = 0 SpellFlagIgnoreResists SpellFlag = 1 << iota // skip spell resist/armor SpellFlagIgnoreTargetModifiers // skip target damage modifiers SpellFlagIgnoreAttackerModifiers // skip attacker damage modifiers SpellFlagApplyArmorReduction // Forces damage reduction from armor to apply, even if it otherwise wouldn't. SpellFlagCannotBeDodged // Ignores dodge in physical hit rolls SpellFlagIncludeTargetBonusDamage // Spell benefits from Gift of Arthas and Hemorrhage. SpellFlagBinary // Does not do partial resists and could need a different hit roll. SpellFlagChanneled // Spell is channeled SpellFlagDisease // Spell is categorized as disease SpellFlagPoison // Spell is categorized as poison SpellFlagHauntSE // Spell benefits from haunt/SE effects SpellFlagHelpful // For healing spells / buffs. SpellFlagMeleeMetrics // Marks a spell as a melee ability for metrics. SpellFlagNoOnCastComplete // Disables the OnCastComplete callback. SpellFlagNoMetrics // Disables metrics for a spell. SpellFlagNoLogs // Disables logs for a spell. SpellFlagAPL // Indicates this spell can be used from an APL rotation. SpellFlagMCD // Indicates this spell is a MajorCooldown. SpellFlagNoOnDamageDealt // Disables OnSpellHitDealt and OnPeriodicDamageDealt aura callbacks for this spell. SpellFlagPrepullOnly // Indicates this spell should only be used during prepull. Not enforced, just a signal for the APL UI. SpellFlagEncounterOnly // Indicates this spell should only be used during the encounter (not prepull). Not enforced, just a signal for the APL UI. SpellFlagPotion // Indicates this spell is a potion spell. SpellFlagPrepullPotion // Indicates this spell is the prepull potion. SpellFlagCombatPotion // Indicates this spell is the combat potion. SpellFlagResetAttackSwing // Indicates this spell resets the melee swing timer. SpellFlagCastTimeNoGCD // Indicates this spell is hunters Auto shot spell SpellFlagPureDot // Indicates this spell is a dot with no initial damage component // Used to let agents categorize their spells. SpellFlagAgentReserved1 SpellFlagAgentReserved2 SpellFlagAgentReserved3 SpellFlagAgentReserved4 SpellFlagIgnoreModifiers = SpellFlagIgnoreAttackerModifiers | SpellFlagIgnoreTargetModifiers )
type SpellMetrics ¶
type SpellMetrics struct { Casts int32 Misses int32 Hits int32 Crits int32 Crushes int32 Dodges int32 Glances int32 Parries int32 Blocks int32 TotalDamage float64 // Damage done by all casts of this spell. TotalThreat float64 // Threat generated by all casts of this spell. TotalHealing float64 // Healing done by all casts of this spell. TotalShielding float64 // Shielding done by all casts of this spell. TotalCastTime time.Duration }
Metric totals for a spell against a specific target, for the current iteration.
type SpellRegisteredHandler ¶
type SpellRegisteredHandler func(spell *Spell)
type SpellResult ¶
type SpellResult struct { // Target of the spell. Target *Unit // Results Outcome HitOutcome Damage float64 // Damage done by this cast. Threat float64 // The amount of threat generated by this cast. ResistanceMultiplier float64 // Partial Resists / Armor multiplier PreOutcomeDamage float64 // Damage done by this cast before Outcome is applied // contains filtered or unexported fields }
func (*SpellResult) DamageString ¶
func (result *SpellResult) DamageString() string
func (*SpellResult) DidCrit ¶
func (result *SpellResult) DidCrit() bool
func (*SpellResult) HealingString ¶
func (result *SpellResult) HealingString() string
func (*SpellResult) Landed ¶
func (result *SpellResult) Landed() bool
type SpellSchool ¶
type SpellSchool byte
func SpellSchoolFromIndex ¶
func SpellSchoolFromIndex(schoolIndex stats.SchoolIndex) SpellSchool
Get spell school mask from school index.
func SpellSchoolFromProto ¶
func SpellSchoolFromProto(p proto.SpellSchool) SpellSchool
func (SpellSchool) GetSchoolIndex ¶
func (ss SpellSchool) GetSchoolIndex() stats.SchoolIndex
Get school index from school mask. Will error if mask is for an undefined multi-school. This involves a map lookup. Do not use in hot path code.
func (SpellSchool) Matches ¶
func (ss SpellSchool) Matches(other SpellSchool) bool
Returns whether there is any overlap between the given masks.
type SpiritManaRegenPerSecond ¶
type SpiritManaRegenPerSecond func() float64
type SplitMix64 ¶
type SplitMix64 struct {
// contains filtered or unexported fields
}
adapted from https://prng.di.unimi.it/splitmix64.c
func NewSplitMix ¶
func NewSplitMix(seed uint64) *SplitMix64
func (*SplitMix64) GetSeed ¶
func (sm *SplitMix64) GetSeed() int64
func (*SplitMix64) Int63 ¶
func (sm *SplitMix64) Int63() int64
func (*SplitMix64) Next ¶
func (sm *SplitMix64) Next() uint64
func (*SplitMix64) NextFloat64 ¶
func (sm *SplitMix64) NextFloat64() float64
func (*SplitMix64) Seed ¶
func (sm *SplitMix64) Seed(s int64)
func (*SplitMix64) Uint64 ¶
func (sm *SplitMix64) Uint64() uint64
type StackingStatAura ¶
type StatWeightValues ¶
type StatWeightValues struct { Weights UnitStats WeightsStdev UnitStats EpValues UnitStats EpValuesStdev UnitStats }
func NewStatWeightValues ¶
func NewStatWeightValues() StatWeightValues
func (*StatWeightValues) ToProto ¶
func (swv *StatWeightValues) ToProto() *proto.StatWeightValues
type StatWeightsResult ¶
type StatWeightsResult struct { Dps StatWeightValues Hps StatWeightValues Tps StatWeightValues Dtps StatWeightValues Tmi StatWeightValues PDeath StatWeightValues }
func CalcStatWeight ¶
func CalcStatWeight(swr *proto.StatWeightsRequest, referenceStat stats.Stat, progress chan *proto.ProgressMetrics) *StatWeightsResult
func NewStatWeightsResult ¶
func NewStatWeightsResult() *StatWeightsResult
func (*StatWeightsResult) ToProto ¶
func (swr *StatWeightsResult) ToProto() *proto.StatWeightsResult
type SubGenerator ¶
type SubGenerator struct {
// contains filtered or unexported fields
}
type SubstitutionComboChecker ¶
type SubstitutionComboChecker map[string]struct{}
func (*SubstitutionComboChecker) HasCombo ¶
func (ic *SubstitutionComboChecker) HasCombo(replacements equipmentSubstitution) bool
type TalentsCombo ¶
type Target ¶
Target is an enemy/boss that can be the target of player attacks/spells.
func (*Target) AddComboPoints ¶
func (eb *Target) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
func (*Target) AddEnergy ¶
func (eb *Target) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) AddFocus ¶
func (fb *Target) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) AddPartyBuffs ¶
func (target *Target) AddPartyBuffs(_ *proto.PartyBuffs)
func (*Target) AddRage ¶
func (rb *Target) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) AddRaidBuffs ¶
Empty Agent interface functions.
func (*Target) ApplyRunes ¶
func (target *Target) ApplyRunes()
func (*Target) ApplyTalents ¶
func (target *Target) ApplyTalents()
func (*Target) ComboPoints ¶
func (eb *Target) ComboPoints() int32
func (*Target) CurrentEnergy ¶
func (eb *Target) CurrentEnergy() float64
func (*Target) CurrentFocus ¶
func (fb *Target) CurrentFocus() float64
func (*Target) CurrentFocusPerTick ¶
func (fb *Target) CurrentFocusPerTick() float64
func (*Target) CurrentHealth ¶
func (hb *Target) CurrentHealth() float64
func (*Target) CurrentHealthPercent ¶
func (hb *Target) CurrentHealthPercent() float64
func (*Target) CurrentRage ¶
func (rb *Target) CurrentRage() float64
func (*Target) EndOOMEvent ¶
func (mb *Target) EndOOMEvent(sim *Simulation)
func (*Target) ExecuteCustomRotation ¶
func (target *Target) ExecuteCustomRotation(sim *Simulation)
func (*Target) GainHealth ¶
func (hb *Target) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) GetActiveAuraWithTag ¶
func (*Target) GetAuraByID ¶
func (*Target) GetAurasWithTag ¶
func (*Target) GetCharacter ¶
func (*Target) GetIcdAuraByID ¶
func (*Target) GetMetricsProto ¶
func (target *Target) GetMetricsProto() *proto.UnitMetrics
func (*Target) HasActiveAura ¶
func (*Target) HasActiveAuraWithTag ¶
func (*Target) HasActiveAuraWithTagExcludingAura ¶
func (*Target) HasAuraWithTag ¶
func (*Target) Initialize ¶
func (target *Target) Initialize()
func (*Target) NextEnergyTickAt ¶
func (*Target) NextTarget ¶
func (*Target) NumActiveAurasWithTag ¶
func (*Target) OnCastComplete ¶
func (at *Target) OnCastComplete(sim *Simulation, spell *Spell)
Invokes the OnCastComplete event for all tracked Auras.
func (*Target) OnHealDealt ¶
func (at *Target) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnHeal event for all tracked Auras.
func (*Target) OnHealTaken ¶
func (at *Target) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Target) OnPeriodicDamageDealt ¶
func (at *Target) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicDamage
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Target) OnPeriodicDamageTaken ¶
func (at *Target) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Target) OnPeriodicHealDealt ¶
func (at *Target) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicHeal
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Target) OnPeriodicHealTaken ¶
func (at *Target) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Target) OnRageChange ¶
func (at *Target) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
Invokes the OnRageChange for all tracked auras
func (*Target) OnSpellHitDealt ¶
func (at *Target) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnSpellHit event for all tracked Auras.
func (*Target) OnSpellHitTaken ¶
func (at *Target) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Target) RegisterResetEffect ¶
func (at *Target) RegisterResetEffect(resetEffect ResetEffect)
Registers a callback to this Character which will be invoked on every Sim reset.
func (*Target) RemoveHealth ¶
func (hb *Target) RemoveHealth(sim *Simulation, amount float64)
func (*Target) Reset ¶
func (target *Target) Reset(sim *Simulation)
func (*Target) ResetEnergyTick ¶
func (eb *Target) ResetEnergyTick(sim *Simulation)
Gives an immediate partial energy tick and restarts the tick timer.
func (*Target) SpendComboPoints ¶
func (eb *Target) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
func (*Target) SpendEnergy ¶
func (eb *Target) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) SpendFocus ¶
func (fb *Target) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) SpendRage ¶
func (rb *Target) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Target) StartOOMEvent ¶
func (mb *Target) StartOOMEvent(sim *Simulation, requiredMana float64)
type TargetAI ¶
type TargetAI interface { Initialize(*Target, *proto.Target) Reset(*Simulation) ExecuteCustomRotation(*Simulation) }
type TargetDummy ¶
type TargetDummy struct {
Character
}
func NewTargetDummy ¶
func NewTargetDummy(dummyIndex int, party *Party, partyIndex int) *TargetDummy
func (*TargetDummy) AddComboPoints ¶
func (eb *TargetDummy) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
func (*TargetDummy) AddEnergy ¶
func (eb *TargetDummy) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) AddFocus ¶
func (fb *TargetDummy) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) AddMajorCooldown ¶
func (mcdm *TargetDummy) AddMajorCooldown(mcd MajorCooldown)
Registers a major cooldown to the Character, which will be automatically used when available.
func (*TargetDummy) AddPartyBuffs ¶
func (td *TargetDummy) AddPartyBuffs(partyBuffs *proto.PartyBuffs)
func (*TargetDummy) AddRage ¶
func (rb *TargetDummy) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) AddRaidBuffs ¶
func (td *TargetDummy) AddRaidBuffs(raidBuffs *proto.RaidBuffs)
func (*TargetDummy) ApplyRunes ¶
func (td *TargetDummy) ApplyRunes()
func (*TargetDummy) ApplyTalents ¶
func (td *TargetDummy) ApplyTalents()
func (*TargetDummy) ComboPoints ¶
func (eb *TargetDummy) ComboPoints() int32
func (*TargetDummy) CurrentEnergy ¶
func (eb *TargetDummy) CurrentEnergy() float64
func (*TargetDummy) CurrentFocus ¶
func (fb *TargetDummy) CurrentFocus() float64
func (*TargetDummy) CurrentFocusPerTick ¶
func (fb *TargetDummy) CurrentFocusPerTick() float64
func (*TargetDummy) CurrentHealth ¶
func (hb *TargetDummy) CurrentHealth() float64
func (*TargetDummy) CurrentHealthPercent ¶
func (hb *TargetDummy) CurrentHealthPercent() float64
func (*TargetDummy) CurrentRage ¶
func (rb *TargetDummy) CurrentRage() float64
func (*TargetDummy) EndOOMEvent ¶
func (mb *TargetDummy) EndOOMEvent(sim *Simulation)
func (*TargetDummy) ExecuteCustomRotation ¶
func (td *TargetDummy) ExecuteCustomRotation(sim *Simulation)
func (*TargetDummy) GainHealth ¶
func (hb *TargetDummy) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) GetActiveAuraWithTag ¶
func (*TargetDummy) GetAuraByID ¶
func (*TargetDummy) GetAurasWithTag ¶
func (*TargetDummy) GetCharacter ¶
func (td *TargetDummy) GetCharacter() *Character
func (*TargetDummy) GetIcdAuraByID ¶
func (*TargetDummy) GetInitialMajorCooldown ¶
func (mcdm *TargetDummy) GetInitialMajorCooldown(actionID ActionID) MajorCooldown
func (*TargetDummy) GetMajorCooldown ¶
func (mcdm *TargetDummy) GetMajorCooldown(actionID ActionID) *MajorCooldown
func (*TargetDummy) GetMajorCooldownIDs ¶
func (*TargetDummy) GetMajorCooldownIgnoreTag ¶
func (mcdm *TargetDummy) GetMajorCooldownIgnoreTag(actionID ActionID) *MajorCooldown
func (*TargetDummy) GetMajorCooldowns ¶
func (mcdm *TargetDummy) GetMajorCooldowns() []*MajorCooldown
Returns all MCDs.
func (*TargetDummy) HasActiveAura ¶
func (*TargetDummy) HasActiveAuraWithTag ¶
func (*TargetDummy) HasActiveAuraWithTagExcludingAura ¶
func (*TargetDummy) HasAuraWithTag ¶
func (*TargetDummy) Initialize ¶
func (td *TargetDummy) Initialize()
func (*TargetDummy) NextEnergyTickAt ¶
func (*TargetDummy) NumActiveAurasWithTag ¶
func (*TargetDummy) OnCastComplete ¶
func (at *TargetDummy) OnCastComplete(sim *Simulation, spell *Spell)
Invokes the OnCastComplete event for all tracked Auras.
func (*TargetDummy) OnHealDealt ¶
func (at *TargetDummy) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnHeal event for all tracked Auras.
func (*TargetDummy) OnHealTaken ¶
func (at *TargetDummy) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*TargetDummy) OnPeriodicDamageDealt ¶
func (at *TargetDummy) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicDamage
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*TargetDummy) OnPeriodicDamageTaken ¶
func (at *TargetDummy) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*TargetDummy) OnPeriodicHealDealt ¶
func (at *TargetDummy) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicHeal
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*TargetDummy) OnPeriodicHealTaken ¶
func (at *TargetDummy) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*TargetDummy) OnRageChange ¶
func (at *TargetDummy) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
Invokes the OnRageChange for all tracked auras
func (*TargetDummy) OnSpellHitDealt ¶
func (at *TargetDummy) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnSpellHit event for all tracked Auras.
func (*TargetDummy) OnSpellHitTaken ¶
func (at *TargetDummy) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*TargetDummy) RegisterResetEffect ¶
func (at *TargetDummy) RegisterResetEffect(resetEffect ResetEffect)
Registers a callback to this Character which will be invoked on every Sim reset.
func (*TargetDummy) RemoveHealth ¶
func (hb *TargetDummy) RemoveHealth(sim *Simulation, amount float64)
func (*TargetDummy) Reset ¶
func (td *TargetDummy) Reset(sim *Simulation)
func (*TargetDummy) ResetEnergyTick ¶
func (eb *TargetDummy) ResetEnergyTick(sim *Simulation)
Gives an immediate partial energy tick and restarts the tick timer.
func (*TargetDummy) SpendComboPoints ¶
func (eb *TargetDummy) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
func (*TargetDummy) SpendEnergy ¶
func (eb *TargetDummy) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) SpendFocus ¶
func (fb *TargetDummy) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) SpendRage ¶
func (rb *TargetDummy) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*TargetDummy) StartOOMEvent ¶
func (mb *TargetDummy) StartOOMEvent(sim *Simulation, requiredMana float64)
func (*TargetDummy) TryUseCooldowns ¶
func (mcdm *TargetDummy) TryUseCooldowns(sim *Simulation)
func (*TargetDummy) UpdateMajorCooldowns ¶
func (mcdm *TargetDummy) UpdateMajorCooldowns()
This function should be called if the CD for a major cooldown changes outside of the TryActivate() call.
type TargetedActionMetrics ¶
type TargetedActionMetrics struct { UnitIndex int32 Casts int32 Hits int32 Crits int32 Misses int32 Dodges int32 Parries int32 Blocks int32 Glances int32 Damage float64 Threat float64 Healing float64 Shielding float64 CastTime time.Duration }
func (*TargetedActionMetrics) ToProto ¶
func (tam *TargetedActionMetrics) ToProto() *proto.TargetedActionMetrics
type Task ¶
type Task interface {
RunTask(sim *Simulation) time.Duration
}
type TestGenerator ¶
type TestGenerator interface { // The total number of tests that this generator can generate. NumTests() int // The name and API request for the test with the given index. GetTest(testIdx int) (string, *proto.ComputeStatsRequest, *proto.StatWeightsRequest, *proto.RaidSimRequest) }
func FullCharacterTestSuiteGenerator ¶
func FullCharacterTestSuiteGenerator(configs []CharacterSuiteConfig) []TestGenerator
type Timer ¶
Stored value is the time at which the cooldown will be available again.
func (*Timer) IsReady ¶
func (timer *Timer) IsReady(sim *Simulation) bool
func (*Timer) TimeToReady ¶
func (timer *Timer) TimeToReady(sim *Simulation) time.Duration
type Unit ¶
type Unit struct { Type UnitType // Index of this unit with its group. // For Players, this is the 0-indexed raid index (0-24). // For Enemies, this is its enemy index. // For Pets, this is the same as the owner's index. Index int32 // Unique index of this unit among all units in the environment. // This is used as the index for attack tables. UnitIndex int32 // Unique label for logging. Label string Level int32 // Level of Unit, e.g. Bosses are 63. MobType proto.MobType // Amount of time it takes for the human agent to react to in-game events. // Used by certain APL values and actions. ReactionTime time.Duration // Amount of time following a post-GCD channel tick, to when the next action can be performed. ChannelClipDelay time.Duration // How far this unit is from its target(s). Measured in yards, this is used // for calculating spell travel time for certain spells. StartDistanceFromTarget float64 DistanceFromTarget float64 Moving bool // Environment in which this Unit exists. This will be nil until after the // construction phase. Env *Environment // Provides stat dependency management behavior. stats.StatDependencyManager PseudoStats stats.PseudoStats // All spells that can be cast by this unit. Spellbook []*Spell // Pets owned by this Unit. PetAgents []PetAgent DynamicStatsPets []*Pet DynamicMeleeSpeedPets []*Pet // AutoAttacks is the manager for auto attack swings. // Must be enabled to use, with "EnableAutoAttacks()". AutoAttacks AutoAttacks Rotation *APLRotation // Statistics describing the results of the sim. Metrics UnitMetrics AttackTables []map[proto.CastType]*AttackTable DynamicDamageTakenModifiers []DynamicDamageTakenModifier GCD *Timer // Used for applying the effect of a hardcast spell when casting finishes. // For channeled spells, only Expires is set. // No more than one cast may be active at any given time. Hardcast Hardcast CastSpeed float64 CurrentTarget *Unit // The currently-channeled DOT spell, otherwise nil. ChanneledDot *Dot // contains filtered or unexported fields }
Unit is an abstraction of a Character/Boss/Pet/etc, containing functionality shared by all of them.
func (*Unit) AddBonusRangedCritRating ¶
func (*Unit) AddBonusRangedHitRating ¶
func (*Unit) AddComboPoints ¶
func (eb *Unit) AddComboPoints(sim *Simulation, pointsToAdd int32, metrics *ResourceMetrics)
func (*Unit) AddDynamicDamageTakenModifier ¶
func (unit *Unit) AddDynamicDamageTakenModifier(ddtm DynamicDamageTakenModifier)
func (*Unit) AddEnergy ¶
func (eb *Unit) AddEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) AddFocus ¶
func (fb *Unit) AddFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) AddMana ¶
func (unit *Unit) AddMana(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) AddRage ¶
func (rb *Unit) AddRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) AddStatDynamic ¶
func (unit *Unit) AddStatDynamic(sim *Simulation, stat stats.Stat, amount float64)
func (*Unit) AddStatsDynamic ¶
func (unit *Unit) AddStatsDynamic(sim *Simulation, bonus stats.Stats)
func (*Unit) ApplyCastSpeedForSpell ¶
func (*Unit) ArmorPenetrationPercentage ¶
func (*Unit) BlockValue ¶
func (*Unit) CancelGCDTimer ¶
func (unit *Unit) CancelGCDTimer(sim *Simulation)
Call this to stop the GCD loop for a unit. This is mostly used for pets that get summoned / expire.
func (*Unit) ComboPoints ¶
func (eb *Unit) ComboPoints() int32
func (*Unit) CurrentEnergy ¶
func (eb *Unit) CurrentEnergy() float64
func (*Unit) CurrentFocus ¶
func (fb *Unit) CurrentFocus() float64
func (*Unit) CurrentFocusPerTick ¶
func (fb *Unit) CurrentFocusPerTick() float64
func (*Unit) CurrentHealth ¶
func (hb *Unit) CurrentHealth() float64
func (*Unit) CurrentHealthPercent ¶
func (hb *Unit) CurrentHealthPercent() float64
func (*Unit) CurrentMana ¶
func (*Unit) CurrentManaPercent ¶
func (*Unit) CurrentRage ¶
func (rb *Unit) CurrentRage() float64
func (*Unit) DisableDynamicStatDep ¶
func (unit *Unit) DisableDynamicStatDep(sim *Simulation, dep *stats.StatDependency)
func (*Unit) EnableAutoAttacks ¶
func (unit *Unit) EnableAutoAttacks(agent Agent, options AutoAttackOptions)
func (*Unit) EnableDynamicStatDep ¶
func (unit *Unit) EnableDynamicStatDep(sim *Simulation, dep *stats.StatDependency)
func (*Unit) EnableEnergyBar ¶
func (*Unit) EnableFocusBar ¶
func (unit *Unit) EnableFocusBar(regenMultiplier float64, onFocusGain OnFocusGain)
func (*Unit) EnableHealthBar ¶
func (unit *Unit) EnableHealthBar()
func (*Unit) EnableRageBar ¶
func (unit *Unit) EnableRageBar(options RageBarOptions)
func (*Unit) EndOOMEvent ¶
func (mb *Unit) EndOOMEvent(sim *Simulation)
func (*Unit) ExecuteCustomRotation ¶
func (unit *Unit) ExecuteCustomRotation(sim *Simulation)
func (*Unit) GainHealth ¶
func (hb *Unit) GainHealth(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) GetActiveAuraWithTag ¶
func (*Unit) GetAuraByID ¶
func (*Unit) GetAurasWithTag ¶
func (*Unit) GetCritTakenMultiplier ¶
Get school crit taken multiplier. Returns highest multiplier if spell is multi school.
func (*Unit) GetCurrentPowerBar ¶
func (unit *Unit) GetCurrentPowerBar() PowerBarType
func (*Unit) GetDiminishedDodgeChance ¶
func (*Unit) GetDiminishedMissChance ¶
func (*Unit) GetDiminishedParryChance ¶
func (*Unit) GetEnemyExclusiveCategories ¶
func (caster *Unit) GetEnemyExclusiveCategories(category string) ExclusiveCategoryArray
func (*Unit) GetIcdAuraByID ¶
func (*Unit) GetManaNotCastingMetrics ¶
func (unit *Unit) GetManaNotCastingMetrics() *ResourceMetrics
func (*Unit) GetMetadata ¶
func (unit *Unit) GetMetadata() *proto.UnitMetadata
func (*Unit) GetMetricsProto ¶
func (at *Unit) GetMetricsProto() []*proto.AuraMetrics
func (*Unit) GetOpponents ¶
func (*Unit) GetOrInitTimer ¶
Helper for shared timers that are not always needed, so it is only allocated if necessary.
func (*Unit) GetOrRegisterAura ¶
func (*Unit) GetOrRegisterSpell ¶
func (unit *Unit) GetOrRegisterSpell(config SpellConfig) *Spell
Retrieves an existing spell with the same ID as the config uses, or registers it if there is none.
func (*Unit) GetSchoolDamageDoneMultiplier ¶
Get school damage done multiplier. Returns highest multiplier if spell is multi school.
func (*Unit) GetSchoolDamageTakenMultiplier ¶
Get school damage taken multiplier. Returns highest multiplier if spell is multi school.
func (*Unit) GetSpell ¶
Returns the first registered spell with the given ID, or nil if there are none.
func (*Unit) GetSpellsMatchingSchool ¶
func (unit *Unit) GetSpellsMatchingSchool(school SpellSchool) []*Spell
func (*Unit) HasActiveAura ¶
func (*Unit) HasActiveAuraWithTag ¶
func (*Unit) HasActiveAuraWithTagExcludingAura ¶
func (*Unit) HasAuraWithTag ¶
func (*Unit) HasEnergyBar ¶
func (*Unit) HasFocusBar ¶
func (*Unit) HasHealthBar ¶
func (*Unit) HasManaBar ¶
func (*Unit) HasRageBar ¶
func (*Unit) HasTemporaryBonusForStat ¶
Returns whether the indicates stat is currently modified by a temporary bonus.
func (*Unit) HasTemporaryMeleeSwingSpeedIncrease ¶
Returns if melee swings have any temporary increases active.
func (*Unit) HasTemporaryRangedSwingSpeedIncrease ¶
Returns if ranged swings have any temporary increases active.
func (*Unit) HasTemporarySpellCastSpeedIncrease ¶
Returns if spell casting has any temporary increases active.
func (*Unit) InitialCastSpeed ¶
func (*Unit) IsEnabled ¶
Units can be disabled for several reasons:
- Downtime for temporary pets (e.g. Water Elemental)
- Enemy units in various phases (not yet implemented)
- Dead units (not yet implemented)
func (*Unit) IsOpponent ¶
func (*Unit) Log ¶
func (unit *Unit) Log(sim *Simulation, message string, vals ...interface{})
func (*Unit) MHNormalizedWeaponDamage ¶
func (unit *Unit) MHNormalizedWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Unit) MHWeaponDamage ¶
func (unit *Unit) MHWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Unit) MP5ManaRegenPerSecond ¶
Returns the rate of mana regen per second from mp5.
func (*Unit) ManaRegenPerSecondWhileCasting ¶
Returns the rate of mana regen per second, assuming this unit is considered to be casting.
func (*Unit) ManaRegenPerSecondWhileNotCasting ¶
Returns the rate of mana regen per second, assuming this unit is considered to be not casting.
func (*Unit) ManaTick ¶
func (unit *Unit) ManaTick(sim *Simulation)
Applies 1 'tick' of mana regen, which worth 2s of regeneration based on mp5/int/spirit/etc.
func (*Unit) MaxMana ¶
Gets the Maxiumum mana including bonus and temporary affects that would increase your mana pool.
func (*Unit) MoveTo ¶
func (unit *Unit) MoveTo(moveRange float64, sim *Simulation)
func (*Unit) MultiplyAttackSpeed ¶
func (unit *Unit) MultiplyAttackSpeed(sim *Simulation, amount float64)
Helper for when both MultiplyMeleeSpeed and MultiplyRangedSpeed are needed.
func (*Unit) MultiplyCastSpeed ¶
func (*Unit) MultiplyMeleeSpeed ¶
func (unit *Unit) MultiplyMeleeSpeed(sim *Simulation, amount float64)
MultiplyMeleeSpeed will alter the attack speed multiplier and change swing speed of all autoattack swings in progress.
func (*Unit) MultiplyRangedSpeed ¶
func (unit *Unit) MultiplyRangedSpeed(sim *Simulation, amount float64)
func (*Unit) NewAPLAction ¶
func (unit *Unit) NewAPLAction(rot *APLRotation, config *proto.APLAction) APLActionImpl
Default implementation of Agent.NewAPLAction so each spec doesn't need this boilerplate.
func (*Unit) NewAPLValue ¶
func (unit *Unit) NewAPLValue(rot *APLRotation, config *proto.APLValue) APLValue
Default implementation of Agent.NewAPLValue so each spec doesn't need this boilerplate.
func (*Unit) NewComboPointMetrics ¶
func (unit *Unit) NewComboPointMetrics(actionID ActionID) *ResourceMetrics
func (*Unit) NewEnemyAuraArray ¶
func (*Unit) NewEnemyExclusiveCategoryArray ¶
func (caster *Unit) NewEnemyExclusiveCategoryArray(makeExclusiveCategory func(*Unit) *ExclusiveCategory) ExclusiveCategoryArray
func (*Unit) NewEnergyMetrics ¶
func (unit *Unit) NewEnergyMetrics(actionID ActionID) *ResourceMetrics
func (*Unit) NewFocusMetrics ¶
func (unit *Unit) NewFocusMetrics(actionID ActionID) *ResourceMetrics
func (*Unit) NewHealthMetrics ¶
func (unit *Unit) NewHealthMetrics(actionID ActionID) *ResourceMetrics
Convenience helpers for NewResourceMetrics.
func (*Unit) NewManaMetrics ¶
func (unit *Unit) NewManaMetrics(actionID ActionID) *ResourceMetrics
func (*Unit) NewPartyAuraArray ¶
func (*Unit) NewRageMetrics ¶
func (unit *Unit) NewRageMetrics(actionID ActionID) *ResourceMetrics
func (*Unit) NewRaidAuraArray ¶
func (*Unit) NextEnergyTickAt ¶
func (*Unit) NumActiveAurasWithTag ¶
func (*Unit) OHNormalizedWeaponDamage ¶
func (unit *Unit) OHNormalizedWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Unit) OHWeaponDamage ¶
func (unit *Unit) OHWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Unit) OnCastComplete ¶
func (at *Unit) OnCastComplete(sim *Simulation, spell *Spell)
Invokes the OnCastComplete event for all tracked Auras.
func (*Unit) OnHealDealt ¶
func (at *Unit) OnHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnHeal event for all tracked Auras.
func (*Unit) OnHealTaken ¶
func (at *Unit) OnHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Unit) OnPeriodicDamageDealt ¶
func (at *Unit) OnPeriodicDamageDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicDamage
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Unit) OnPeriodicDamageTaken ¶
func (at *Unit) OnPeriodicDamageTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Unit) OnPeriodicHealDealt ¶
func (at *Unit) OnPeriodicHealDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnPeriodicHeal
As a debuff when target is being hit by dot. As a buff when caster's dots are ticking.
func (*Unit) OnPeriodicHealTaken ¶
func (at *Unit) OnPeriodicHealTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Unit) OnRageChange ¶
func (at *Unit) OnRageChange(sim *Simulation, metrics *ResourceMetrics)
Invokes the OnRageChange for all tracked auras
func (*Unit) OnSpellHitDealt ¶
func (at *Unit) OnSpellHitDealt(sim *Simulation, spell *Spell, result *SpellResult)
Invokes the OnSpellHit event for all tracked Auras.
func (*Unit) OnSpellHitTaken ¶
func (at *Unit) OnSpellHitTaken(sim *Simulation, spell *Spell, result *SpellResult)
func (*Unit) OnSpellRegistered ¶
func (unit *Unit) OnSpellRegistered(handler SpellRegisteredHandler)
func (*Unit) RangedSwingSpeed ¶
func (*Unit) RangedWeaponDamage ¶
func (unit *Unit) RangedWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Unit) RegisterAura ¶
func (*Unit) RegisterPrepullAction ¶
func (unit *Unit) RegisterPrepullAction(doAt time.Duration, action func(*Simulation))
Registers a callback to this Unit which will be invoked on the prepull at the specified negative time.
func (*Unit) RegisterResetEffect ¶
func (at *Unit) RegisterResetEffect(resetEffect ResetEffect)
Registers a callback to this Character which will be invoked on every Sim reset.
func (*Unit) RegisterSpell ¶
func (unit *Unit) RegisterSpell(config SpellConfig) *Spell
Registers a new spell to the unit. Returns the newly created spell.
func (*Unit) RemoveHealth ¶
func (hb *Unit) RemoveHealth(sim *Simulation, amount float64)
func (*Unit) ResetEnergyTick ¶
func (eb *Unit) ResetEnergyTick(sim *Simulation)
Gives an immediate partial energy tick and restarts the tick timer.
func (*Unit) SetCurrentPowerBar ¶
func (unit *Unit) SetCurrentPowerBar(bar PowerBarType)
func (*Unit) SetGCDTimer ¶
func (unit *Unit) SetGCDTimer(sim *Simulation, gcdReadyAt time.Duration)
func (*Unit) SpendComboPoints ¶
func (eb *Unit) SpendComboPoints(sim *Simulation, metrics *ResourceMetrics)
func (*Unit) SpendEnergy ¶
func (eb *Unit) SpendEnergy(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) SpendFocus ¶
func (fb *Unit) SpendFocus(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) SpendMana ¶
func (unit *Unit) SpendMana(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) SpendRage ¶
func (rb *Unit) SpendRage(sim *Simulation, amount float64, metrics *ResourceMetrics)
func (*Unit) SpiritManaRegenPerSecondDefault ¶
Returns the rate of mana regen per second from spirit. All classes except Priest and Mage use this.
func (*Unit) StartOOMEvent ¶
func (mb *Unit) StartOOMEvent(sim *Simulation, requiredMana float64)
func (*Unit) SwingSpeed ¶
func (*Unit) TimeUntilManaRegen ¶
Returns the amount of time this Unit would need to wait in order to reach the desired amount of mana, via mana regen.
Assumes that desiredMana > currentMana. Calculation assumes the Unit will not take any actions during this period that would reset the 5-second rule.
func (*Unit) UpdateManaRegenRates ¶
func (unit *Unit) UpdateManaRegenRates()
type UnitMetrics ¶
type UnitMetrics struct { CharacterIterationMetrics // contains filtered or unexported fields }
func NewUnitMetrics ¶
func NewUnitMetrics() UnitMetrics
func (*UnitMetrics) AddFinalPetMetrics ¶
func (unitMetrics *UnitMetrics) AddFinalPetMetrics(petMetrics *UnitMetrics)
This should be called at the end of each iteration, to include metrics from Pets in those of their owner. Assumes that doneIteration() has already been called on the pet metrics.
func (*UnitMetrics) AddOOMTime ¶
func (unitMetrics *UnitMetrics) AddOOMTime(sim *Simulation, dur time.Duration)
func (*UnitMetrics) MarkOOM ¶
func (unitMetrics *UnitMetrics) MarkOOM(sim *Simulation)
func (*UnitMetrics) NewResourceMetrics ¶
func (unitMetrics *UnitMetrics) NewResourceMetrics(actionID ActionID, resourceType proto.ResourceType) *ResourceMetrics
func (*UnitMetrics) ToProto ¶
func (unitMetrics *UnitMetrics) ToProto() *proto.UnitMetrics
func (*UnitMetrics) UpdateDpasp ¶
func (unitMetrics *UnitMetrics) UpdateDpasp(dpspSeconds float64)
type UnitReference ¶
type UnitReference struct {
// contains filtered or unexported fields
}
Struct for handling unit references, to account for values that can change dynamically (e.g. CurrentTarget).
func NewUnitReference ¶
func NewUnitReference(ref *proto.UnitReference, contextUnit *Unit) UnitReference
func (UnitReference) Get ¶
func (ur UnitReference) Get() *Unit
func (*UnitReference) String ¶
func (ur *UnitReference) String() string
type UnitStats ¶
func NewUnitStats ¶
func NewUnitStats() UnitStats
type Weapon ¶
type Weapon struct { BaseDamageMin float64 BaseDamageMax float64 AttackPowerPerDPS float64 SwingSpeed float64 NormalizedSwingSpeed float64 SpellSchool SpellSchool }
Represents a generic weapon. Pets / unarmed / various other cases don't use actual weapon items so this is an abstraction of a Weapon.
func (*Weapon) AverageDamage ¶
func (*Weapon) BaseDamage ¶
func (weapon *Weapon) BaseDamage(sim *Simulation) float64
func (*Weapon) CalculateAverageWeaponDamage ¶
func (*Weapon) CalculateNormalizedWeaponDamage ¶
func (weapon *Weapon) CalculateNormalizedWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Weapon) CalculateWeaponDamage ¶
func (weapon *Weapon) CalculateWeaponDamage(sim *Simulation, attackPower float64) float64
func (*Weapon) EnemyWeaponDamage ¶
func (weapon *Weapon) EnemyWeaponDamage(sim *Simulation, attackPower float64, damageSpread float64) float64
func (*Weapon) GetSpellSchool ¶
func (weapon *Weapon) GetSpellSchool() SpellSchool
type WeaponAttack ¶
type WeaponAttack struct { Weapon // contains filtered or unexported fields }
Source Files ¶
- agent.go
- api.go
- apl.go
- apl_action.go
- apl_actions_casting.go
- apl_actions_misc.go
- apl_actions_sequences.go
- apl_actions_timing.go
- apl_helpers.go
- apl_value.go
- apl_values_aura.go
- apl_values_auto_attacks.go
- apl_values_core.go
- apl_values_encounter.go
- apl_values_gcd.go
- apl_values_operators.go
- apl_values_properties.go
- apl_values_resources.go
- apl_values_sequences.go
- apl_values_spell.go
- attack.go
- aura.go
- aura_helpers.go
- avoid_dr.go
- base_stats.go
- base_stats_auto_gen.go
- buffs.go
- bulksim.go
- cast.go
- character.go
- constants.go
- consumes.go
- cooldown.go
- database.go
- debuffs.go
- dot.go
- energy.go
- environment.go
- exclusive_effect.go
- flags.go
- focus.go
- gcd.go
- health.go
- item_effects.go
- item_sets.go
- item_swaps.go
- major_cooldown.go
- mana.go
- metrics_aggregator.go
- pending_action.go
- periodic_action.go
- pet.go
- presim.go
- racials.go
- rage.go
- raid.go
- rand.go
- shield.go
- sim.go
- spell.go
- spell_outcome.go
- spell_resistances.go
- spell_result.go
- spell_school.go
- statweight.go
- target.go
- target_ai.go
- target_dummy.go
- test_generators.go
- test_suite.go
- test_utils.go
- unit.go
- utils.go