Skip to content
Anya V edited this page Oct 28, 2015 · 16 revisions

Generated Thu Mar 15 08:45:28 2012 by make_actions_html

List of Actions

Action Categories

 

There is a large library of actions available for scheduling as events. Additionally, all of these actions can be used within analyze scripts. Below you will find a listing of the high level groupings of these actions, along with detailed sections for each them.

Print
Print actions are the primary way of saving data from an Avida experiments.
Population
Population actions modify the state of the population, and will actually change the course of the run.
Environment
Actions that allow user to change properties of the environment, including resources.
Save and Load
Actions that allow for saving and loading large data sets, such as full populations.
Landscape Analysis
Actions that use data from the current state of Avida, process it and then output the results.
Driver
Actions that allow user to control program execution, including experiment termination.
For a brief overview of writing a new action, please see Creating an Action below.

 

Alphabetical Listing of Available Actions

AnalyzeLandscape AnalyzePopulation AssignRandomCellData AttackDen AvidianConjugation CalcConsensus ChangeEnvironment CompeteDemes CompeteDemes_AttackKillAndEnergyConserve CompeteDemesByEnergyDistribution CompeteDemesByNetwork CompeteDemesByTaskCount CompeteDemesByTaskCountAndEfficiency CompeteOrganisms ConnectCells CopyDeme CountMultipleOpinions CountOpinions DecayPoints DelayedDemeEvent DelayedDemeEventsPerSlots DeletionLandscape DemeBalanceTwoTasks DemeReactionDiversity DemeResourceThresholdPredicate Desynchronization DiffuseHGTGenomeFragments DisconnectCells DistributeData DistributeDataCheaply DistributeDataEfficiently DivideDemes DumpCellDataGrid DumpClassificationIDGrid DumpDonorGrid DumpEnergyGrid DumpExecutionRatioGrid DumpFitnessGrid DumpGenomeLengthGrid DumpGenotypeColorGrid DumpGenotypeGrid DumpHostTaskGrid DumpIDGrid DumpLandscape DumpLastTaskGrid DumpMaxResGrid DumpMemory DumpParasiteGenotypeGrid DumpParasiteTaskGrid DumpParasiteVirulenceGrid DumpPhenotypeIDGrid DumpReactionGrid DumpReceiverGrid DumpSleepGrid DumpTargetGrid DumpTaskGrid DumpVitalityGrid Echo Exit ExitAveGeneration ExitAveLineageLabelGreater ExitAveLineageLabelLess ExitDemeReplications ExitElapsedTime Flash FlushTopNavTrace FullLandscape HillClimb Inject InjectAll InjectAllRandomRepro InjectCanvas InjectDemes InjectDemesFromNest InjectDemesRandom InjectGroup InjectModuloDemes InjectParasite InjectParasitePair InjectRandom InjectRange InjectResource InjectScaledResource InjectSequence InjectSequenceWDivMutRate InsertionLandscape IteratedConsensus JoinGridCol JoinGridRow KillFractionInSequence KillFractionInSequence_PopLimit KillInstLimit KillInstPair KillMeanBelowThresholdPaintable KillNBelowResourceThreshold KillProb KillRate KillRectangle KillWithinRadiusBelowResourceThreshold KillWithinRadiusBelowResourceThresholdTestAll KillWithinRadiusMeanBelowResourceThreshold LoadPopulation MeasureDemeNetworks MergeResourceAcrossDemes MixPopulation ModMutProb MutationalNeighborhood NewTrial OutflowScaledResource PairTestLandscape Pause PhenotypeMatch PrecalcLandscape Pred_DemeEventMoveBetweenTargets Pred_DemeEventMoveCenter Pred_DemeEventNUniqueIndividualsMovedIntoTarget PredictNuLandscape PredictWLandscape PrintAgePolyethismData
PrintAveNumTasks
PrintAverageData
PrintAvgDemeTasksExeData
PrintAvgTreatableDemeTasksExeData
PrintAvgUntreatableDemeTasksExeData
PrintBirthChamber
PrintBirthChamberMatingTypeHistogram
PrintCCladeCounts
PrintCCladeFitnessHistogram
PrintCCladeRelativeFitnessHistogram
PrintCellData
PrintCellVisitsData
PrintCompetitionData
PrintConsensusData
PrintCountData
PrintCurrentMeanDemeDensity
PrintCurrentOpinions
PrintCurrentReactionData
PrintCurrentReactionRewardData
PrintCurrentTaskCounts
PrintData
PrintDebug
PrintDemeAllStats
PrintDemeAverageData
PrintDemeCompetitionData
PrintDemeCurrentTaskExeData
PrintDemeDonorStats
PrintDemeEnergyDistributionStats
PrintDemeEnergySharingStats
PrintDemeFoundersData
PrintDemeGermlineSequestration
PrintDemeGlobalResources
PrintDemeMigrationSuicidePoints
PrintDemeNetworkData
PrintDemeNetworkTopology
PrintDemeOrgReactionData
PrintDemeOrgTasksData
PrintDemeOrgTasksExeData
PrintDemeReactionData
PrintDemeReactionDiversityReplicationData
PrintDemeReplicationData
PrintDemeResourceStats
PrintDemeResourceThresholdPredicate
PrintDemeSpacialEnergyStats
PrintDemeSpacialSleepStats
PrintDemeStats
PrintDemesTotalAvgEnergy
PrintDemeTasksData
PrintDemeTasksExeData
PrintDemeTestamentStats
PrintDemeTreatableCount
PrintDemeTreatableReplicationData
PrintDemeUntreatableReplicationData
PrintDepthHistogram
PrintDetailedFitnessData
PrintDetailedSynchronizationData
PrintDirectReciprocityData
PrintDivideMutData
PrintDominantData
PrintDominantForagerGenotypes
PrintDominantGenotype
PrintDominantGroupGenotypes
PrintDonationStats
PrintDynamicMaxMinData
PrintEditDistance
PrintErrorData
PrintExtendedTimeData
PrintFemaleMatePreferenceData
PrintFlowRateTuples
PrintGeneticDistanceData
PrintGenomicSiteEntropy
PrintGenotypeAbundanceHistogram
PrintGermlineData
PrintGroupIds
PrintGroupsFormedData
PrintGroupTolerance
PrintHGTData
PrintHostDepthHistogram
PrintHostPhenotypeData
PrintHostTasksData
PrintInstructionAbundanceHistogram
PrintInstructionData
PrintInternalTasksData
PrintInternalTasksQualData
PrintInterruptData
PrintLineageCounts
PrintLineageTotals
PrintLogFitnessHistogram
PrintMarketData
PrintMatingDisplayData
PrintMatingTypeHistogram
PrintMessageData
PrintMessageLog
PrintMigrationData
PrintMiniTraces
PrintMicroTraces
PrintMultiProcessData
PrintMutationRateData
PrintNewReactionData
PrintNewTasksData
PrintNewTasksDataPlus
PrintNumOrgsInDeme
PrintNumOrgsKilledData
PrintOpinionsSetPerDeme
PrintOrganismLocation
PrintParasiteData
PrintParasiteDepthHistogram
PrintParasitePhenotypeData
PrintParasiteTasksData
PrintPerDemeGenPerFounderData
PrintPerDemeReactionData
PrintPerDemeTasksData
PrintPerDemeTasksExeData
PrintPhenotypeData
PrintPhenotypeStatus
PrintPhenotypicPlasticity
PrintPlasticGenotypeSummary
PrintPopulationDistanceData
PrintPredatorAverageData
PrintPredatorErrorData
PrintPredatorInstructionData
PrintPredatorVarianceData
PrintMinPreyFailedAttacks
PrintPredicatedMessages
PrintPreyAverageData
PrintPreyErrorData
PrintPreyInstructionData
PrintPreyVarianceData
PrintProfilingData
PrintReactionData
PrintReactionExeData
PrintReactionRewardData
PrintRelativeFitnessHistogram
PrintReproData
PrintReputationData
PrintResourceData
PrintSenseData
PrintSenseExeData
PrintShadedAltruists
PrintSimpleConsensusData
PrintSleepData
PrintSpeciesAbundanceHistogram
PrintStatsData
PrintStringMatchData
PrintSuccessfulMates
PrintSynchronizationData
PrintTargets
PrintTaskProbHistogram
PrintTasksData
PrintTasksExeData
PrintTaskSnapshot
PrintTasksQualData
PrintThreadsData
PrintTimeData
PrintToleranceData
PrintToleranceInstructionData
PrintTopNavTrace
PrintTotalsData
PrintVarianceData
PrintViableTasksData
PrintWinningDeme
RandomLandscape
RemovePredators
ReplaceFromGermline
ReplicateDemes
ResetDemes
SampleLandscape
SaveDemeFounders
SaveFlameData
SavePopulation
SerialTransfer
SetCellResource
SetConfig
SetDemeResource
SetDemeResourceInflow
SetDemeResourceOutflow
SetEnvironmentInputs
SetEnvironmentRandomMask
SetFracDemeTreatable
SetGradientResource
SetGradientInflow
SetGradientOutflow
SetGradientConeInflow
SetGradientConeOutflow
SetGradientPlatInflow
SetGradientPlatOutflow
SetGradPlatVarInflow
SetMigrationRate
SetMutProb
SetNumInstBefore0Energy
SetOptimizeMinMax
SetPeriodicResource
SetPopCapEnforcement
SetPredatoryResource
SetReactionInst
SetReactionMaxTaskCount
SetReactionMinTaskCount
SetReactionTask
SetReactionValue
SetReactionValueMult
SetResource
SetResourceInflow
SetResourceOutflow
SetSeasonalResource
SetSeasonalResource10Kyears_1To_1
SetSeasonalResource1Kyears_1To_1
SetTaskArgDouble
SetTaskArgInt
SetTaskArgString
SetVerbose
SeverGridCol
SeverGridRow
StopFastForward
SwapCells
SwapRandomCells
Synchronization
TestDominant
TherapyDecayDemeResource
TherapyStructuralNumInst
TherapyStructuralRatioDistBetweenNearest
ToggleFitnessValley
ToggleRewardInstruction
TrackAllMessages
UnitFitness
VERBOSE
ZeroMuts
ZeroResources
 

Driver Actions

These actions control the driver object responsible for executing the current run.
  • Exit No ArgumentsUnconditionally terminate the current run.
  • ExitAveGeneration <double generation>
  • ExitAveLineageLabelGreater <double threshold>Halts the run if the current average lineage label is larger than threshold.
  • ExitAveLineageLabelLess <double threshold>Halts the run if the current average lineage label is smaller than threshold.
  • ExitDemeReplications
  • ExitElapsedTime <int elapsed time [seconds]>
  • Pause No Arguments
  • StopFastForward none
 

Environment Actions

Events that allow user to change environment properties, such as resources and reaction parameters.
  • ChangeEnvironment <string env_string>Action designed to read in and process a line formatted as if it were in the environment file. This will change environmental settings on the fly. You should create all resources and reactions in the environment file and only use this file to change these resources and reactions. Also, note that this action does not replace reactions already in the environment that share the same name as the argument given to ChangeEnvironment; it simply adds another reaction with the same name.
  • DelayedDemeEvent <int x1> <int y1> <int x2> <int y2> <int delay> <int duration> <bool static_position> <int total_events>
  • DelayedDemeEventsPerSlots <int x1> <int y1> <int x2> <int y2> <int delay> <int duration> <bool static_position> <int total_slots_per_deme> <int total_events_per_slot_max> <int total_events_per_slot_min> <int tolal_event_flow_levels>
  • InjectResource <string res_name> <double res_count>Inject (add) a specified amount of a specified resource. res_name must already exist as a resource in environment file.
  • InjectScaledResource <string res_name> <double res_count>
  • MergeResourceAcrossDemes <string deme_res_name> <string global_res_name>
  • OutflowScaledResource <string res_name> <double res_percent>
  • SetCellResource <int cell_id> <string res_name> <double res_count>
  • SetConfig <string config_var> <string value>
  • SetDemeResource <string res_name> <double res_count>
  • SetDemeResourceInflow <int deme id> <string resource_name> <double inflow>
  • SetDemeResourceOutflow <int deme id> <string resource_name> <double outflow>
  • SetEnvironmentInputs <int input_1> <int input_2> <int input_3> Set the inputs that all organisms get from the environment when doing IO to these specific values. There must be exactly three inputs, and they must have the usual values for the top 8 "key" bits, i.e. they must be of the form 0x0F?????? 0x33?????? 0x55?????? where ? can be replaced with any hexadecimal digit.
  • SetEnvironmentRandomMask <int mask>
  • SetFracDemeTreatable
  • SetGradientResource <string env_string>

    Action designed to read in and process a line for ONE gradient resource, formatted as if it were in the environment file. This will change environmental settings for this one gradient resource on the fly. You should create the resource in the environment file and only use this file to change this resource.
    Unlike with ChangeEnvironment, no resources other than the one specified in the event will be affected.

  • SetGradientInflow <string res_name> <double res_inflow>

    Set existing gradient resource plateau inflow rate to a new value, without redrawing the entire resource.

  • SetGradientOutflow <string res_name> <double res_outflow>

    Set existing gradient resource plateau outflow rate to a new value, without redrawing the entire resource.

  • SetGradientConeInflow <string res_name> <double res_inflow>

  • SetGradientConeOutflow <string res_name> <double res_outflow>

  • SetGradientPlatInflow <string res_name> <double res_inflow>

  • SetGradientPlatOutflow <string res_name> <double res_outflow>

  • SetGradPlatVarInflow <string res_name> <double mean> <double variance> <int type>

    Set existing gradient resource plateau inflow rate to a new value, without redrawing the entire resource, based on a random number pull from normal distribution of this mean and variance. As such, this uses a half normal or folded normal approach with expected value = sigma * sqrt(2 /pi). If type == 0, new inflow will be the random number pulled. If type > 0, new inflow will be mean + abs(the random number pulled). If type == 1, new inflow will be max (0, mean - abs(the random number pulled)). If type == 2, new inflow will be max (0, mean + the random number pulled).

<li><strong><a name="SetNumInstBefore0Energy"></a>SetNumInstBefore0Energy</strong>

<int new_value>

  • SetOptimizeMinMax No Arguments
  • SetPeriodicResource <string reaction_name> <string amplitude> <string pi/frequence> <phaseShift*pi> <string initial_Y>
  • SetReactionInst <string reaction_name> <string inst>Set the instruction triggered by this reaction. reaction_name must already exist in the environment file. inst must be in the instruction set.
  • SetPopCapEnforcement [int cap=0] [int rate=1]

    Will set POPULATION_CAP to cap and begin killing orgs off at rate rate by killing rate # orgs + 1 every time a new org is born. Accepts string args (e.g. SetPopCapEnforcement cap=0:rate=1).

  • SetPredatoryResource <string res_name> <double kill_odds> <double guarded_juvs_per_adult>double detection_prob>

    A gradient resource with teeth. If set in motion, will kill with prob kill_odds 1 random org in each cell of plateau. If it passes over a den resource, will kill unguarded offspring with probability kill_odds. If an org steps on the resource, the org is killed with probability kill_odds. detection_prob sets the probability of orgs detecting the predator via look sensors.

  • <li><strong><a name="SetReactionMaxTaskCount"></a>SetReactionMaxTaskCount</strong>
    

    <string reaction_name> <int max_count>Set the max task count required to trigger a reaction to task_count. reaction_name must already exist in the environment file.

  • SetReactionMinTaskCount <string reaction_name> <int min_count>Set the min task count required to trigger a reaction to task_count. reaction_name must already exist in the environment file.
  • SetReactionTask <string reaction_name> <string task_name>Set the task required to trigger a reaction to task_name. reaction_name and task_name must already exist in the environment file.
  • SetReactionValue <string reaction_name> <double value>Set the reaction value to a specific level. reaction_name must already exist in the environment file. value can be negative.
  • SetReactionValueMult <string reaction_name> <double value>Multiply the reaction value by the value. reaction_name must already exist in the environment file. value can be negative.
  • SetResource <string res_name> <double res_count>Set the resource amount to a specific level. res_name must already exist as a resource in environment file.
  • SetResourceInflow <string resource_name> <double inflow>Set the resource inflow to a specific level. res_name must already exist as a resource in environment file.
  • SetResourceOutflow <string resource_name> <double outflow>Set the resource outflow to a specific level. res_name must already exist as a resource in environment file.
  • SetSeasonalResourceSets resource availiblity to seasonal
  • SetSeasonalResource10Kyears_1To_1Sets resource availiblity to seasonal 1 to -1 for 10K years of 365 updates
  • SetSeasonalResource1Kyears_1To_1Sets resource availiblity to seasonal 1 to -1 for 1K years of 365 updates
  • SetTaskArgDouble <int task> <int arg> <double value>
  • SetTaskArgInt <int task> <int arg> <int value>
  • SetTaskArgString <int task> <int arg> <string value>
  • ZeroResources noneSet all resurce levels to zero.
  •  

    Landscape Analysis Actions

    Landscape analysis actions perform various types mutation studies to calculate properties of the fitness landscape for a particular genome. When scheduled as an event during a run, these actions will typically perform analysis on the dominant genotype. In analyze mode, analysis is performed on the entire currently selected batch.

    These actions are often very computationally intensive, thus will take a long time to compute. In order to take advantage of increasingly available multi-processor/multi-core systems, a number of these actions have been enhanced to make use of multiple threads to parallize work. Set the configuration setting MT_CONCURRENCY to the number of logical processors available to make use of all processor resources for these compuations.

    • AnalyzeLandscape [filename="land-analyze.dat"] [int trials=1000] [int min_found=0] [int max_trials=0] [int max_dist=10]
    • AnalyzePopulation [double sample_prob=1] [int landscape=0] [int save_genotype=0] [string filename=""]
    • DeletionLandscape [string filename="land-del.dat"] [int distance=1] [string sitecount_file=""]
    • DumpLandscape [string filename="land-dump.dat"]
    • FullLandscape [string filename="land-full.dat"] [int distance=1] [string entropy_file=""] [string sitecount_file=""]Do a landscape analysis of the dominant genotype or current batch of genotypes, depending on the current mode. The resulting output is a collection of statistics obtained from examining all possible mutations at the distance specified. The default distance is one.
    • HillClimb [string filename="hillclimb.dat"]Does a hill climb with the dominant genotype.
    • InsertionLandscape [string filename="land-ins.dat"] [int distance=1] [string sitecount_file=""]
    • MutationalNeighborhood [string fname="mut-neighborhood.dat"] [int target=-1]
    • PairTestLandscape [string filename=""] [int sample_size=0]If sample_size = 0, pairtest the full landscape.
    • PrecalcLandscape No ArgumentsPrecalculate the distance 1 full landscape for the current batch in parallel using multiple threads. The resulting data is stored into the current batch and can be used by many subsequent output commands within Analyze mode.
    • PredictNuLandscape [string filename="land-predict.dat"]
    • PredictWLandscape [string filename="land-predict.dat"]
    • RandomLandscape [string filename="land-random.dat"] [int distance=1] [int trials=0]
    • SampleLandscape [string filename="land-sample.dat"] [int trials=0]
     

    Population Actions

    Population events modify the state of the population, and will actually change the course of the run. There are a wide variety of these.
    • AssignRandomCellData [num_cells=deme_size]
    • AttackDen [double probability=0.0] [int juvs_per_adult=1]

      Kills each unguarded juv in dens (habitat == 3 or 4) with set probability. juvs_per_adult sets the ratio of guarding adults to juvs. E.g. if ratio is set to 5 and there are 2 guards and 12 juveniles in a den, two random juveniles will be attacked with their probability of death at the set probability.

    • AvidianConjugation (prob. of donation)
    • CompeteDemes [int type=1]
    • CompeteDemes_AttackKillAndEnergyConserve No Arguments
    • CompeteDemesByEnergyDistribution Competes demes according to the distribution of energy among the organisms
    • CompeteDemesByNetwork No arguments.
    • CompeteDemesByTaskCount Competes demes according to the number of times a given task has been completed within that demeCompetes demes based on the total number of times that a task has been completed by an organism in the deme since the was initialized. This action takes one integer parameter representing number of the task that is to be used for competition. If no parameter supplied, the class uses the first task defined in the environment file compete the demes.
    • CompeteDemesByTaskCountAndEfficiency Competes demes according to the number of times a given task has been completed within that deme and the efficiency with which it was done
    • CompeteOrganisms [int type=0] [int parents_survive=0] [double scaled_time=1.0] [int dynamic_scaling=0]Calculates fitness of each organism in the population and creates a new population of descendants where each organism has a chance of replication proportional to its fitness. Can be used to make Avida operate without population dynamics and asynchronous replication, i.e. like a genetic algorithm. If NewTrial events have occurred since the last CompeteOrganisms event, then the average fitness over those trials will be used.competition_type controls how the fitnesses of multiple trials determine the overall fitness used for the competition: 0=geometric mean of fitnesses, 1=scaled geometric mean of fitnesses (the greatest fitness of each trial is scaled to 1.0 before taking the geometric mean), 2=arithmetic mean, 3=geometric mean plus rescales effective fitness values by the geometric mean of the difference from the top score and the median.Setting parents_survive to 1, causes the first copy of an organism that makes it into the new population to be the original (unmutated) parent organism.
    • ConnectCells <int cellA_x> <int cellA_y> <int cellB_x> <int cellB_y>Connects a pair of specified cells.
    • CopyDeme <int src_id> <int dest_id>
    • CountMultipleOpinions [int opinion_count=0]
    • CountOpinions [int desired_opinion=0 [int multiplicity=1 [int side=0]]]
    • DecayPoints No ArgumentsDecays the number of points a deme has accumulated by a percentage that is set in the configuration file.
    • DemeBalanceTwoTasks Two min and max for not
    • DemeReactionDiversity No arguments.
    • DemeResourceThresholdPredicate cString resourceName, cString comparisonOperator, double threasholdValue
    • Desynchronization No Arguments
    • DiffuseHGTGenomeFragments <none>
    • DisconnectCells <int cellA_x> <int cellA_y> <int cellB_x> <int cellB_y>Disconnects a pair of specified cells.
    • DistributeData No arguments.
    • DistributeDataCheaply No arguments.
    • DistributeDataEfficiently No arguments.
    • DivideDemes No arguments (yet!)
    • Flash No arguments
    • FlushTopNavTraceNo arguments

    • Force printing of nav trace (as set up by PrintTopNavTrace) even if all candidate orgs have not been evaluated / reproduced.
    • Inject [string fname="START_ORGANISM"] [int cell_id=0] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]Inject a single organisms into the population. Arguments must be included from left to right; if all arguments are left out, the default creature is the ancestral organism, and it will be injected into cell 0, have an uninitialized merit, and be marked as liniage id 0.
    • InjectAll [string fname="START_ORGANISM"] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]Same as Inject, but no cell_id is specified and the organism is placed into all cells in the population.
    • InjectAllRandomRepro <int length> [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectCanvas [string fname="START_ORGANISM"] [int canvas_id=0] [int canvas_x=0] [int canvas_y=0] [int group_id=-1] [int forager_type=-1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectDemes [string fname="START_ORGANISM"] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectDemesFromNest [int num_orgs=1] [int nest_cellid=0] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectDemesRandom [int num_orgs=1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectGroup [string fname="START_ORGANISM"] [int cell_id=0] [int group_id=-1] [int forager_type=-1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectModuloDemes [string fname="START_ORGANISM"] [int mod_num = 1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • InjectParasite <string filename> <string label> [int cell_start=0] [int cell_end=-1]Attempt to inject a parasite genome into the supplied population cell range with the specified label.
    • InjectParasitePair <string filename_genome> <string filename_parasite> <string label> [int cell_start=0] [int cell_end=-1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]Inject host parasite pairs into the population cell range specified.
    • InjectRandom <int length> [int cell_id=0] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]Injects a randomly generated genome of the supplied length into the population.
    • InjectRange [string fname="START_ORGANISM"] [int cell_start=0] [int cell_end=-1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]Injects identical organisms into a range of cells of the population.Example:InjectRange 000-aaaaa.org 0 10Will inject 10 organisms into cells 0 through 9.
    • InjectSequence <string sequence> [int cell_start=0] [int cell_end=-1] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]Injects identical organisms based on the supplied genome sequence into a range of cells of the population.Example:InjectSequence ckdfhgklsahnfsaggdsgajfg 0 10 100Will inject 10 organisms into cells 0 through 9 with a merit of 100.
    • InjectSequenceWDivMutRate <string sequence> [int cell_start=0] [int cell_end=-1] [double div_mut_rate=0] [double merit=-1] [int lineage_label=0] [double neutral_metric=0]
    • IteratedConsensus [int compete_period=100 [int replace_number=1 [int kill=1 [int restrict_range=1]]]]
    • JoinGridCol [int col_id=-1] [int min_row=0] [int max_row=-1]Add connections between cells along a column in an Avida grid.
    • JoinGridRow [int row_id=-1] [int min_col=0] [int max_col=-1]Add connections between cells along a row in an Avida grid.
    • KillFractionInSequence [double fraction=0.01]
    • KillFractionInSequence_PopLimit [double fraction=0.01]
    • KillInstLimit [double probability=0.9] [cString inst=nand] [int limit=5]
    • KillInstPair [double probability=0.9] [cString inst1=nand] [cString inst2=nor] [int limit=1]
    • KillMeanBelowThresholdPaintable
    • KillNBelowResourceThreshold [int numkills=0, string resource name, double threshold=0]
    • KillProb [double probability=0.9]Using the specified probability, test each organism to see if it is killed off.
    • KillRate [double probability=0.9]Randomly removes a certain proportion of the population. In principle, this action does the same thing as the KillProb event. However, instead of a probability, here one has to specify a rate. The rate has the same unit as fitness. So if the average fitness is 20000, than you remove 50% of the population on every update with a removal rate of 10000.
    • KillRectangle [int x1=0] [int y1=0] [int x2=0] [int y2=0]Kill off all organisms in a rectangle defined by the points (x1, y1) and (x2, y2).
    • KillWithinRadiusBelowResourceThreshold [int numradii=0, int radius=0, string resource name, double threshold=0, double killdensity=1]
    • KillWithinRadiusBelowResourceThresholdTestAll [int numradii=0, int radius=0, string resource name, double threshold=0, double killdensity=1]
    • KillWithinRadiusMeanBelowResourceThreshold [int numradii=0, int radius=0, string resource name, double threshold=0, double killdensity=1]
    • MeasureDemeNetworks No arguments.
    • MixPopulation No arguments.
    • ModMutProb [string mut_type="COPY_MUT"] [double prob=0.0] [int start_cell=-1] [int end_cell=-1]Values for mut_type are POINT, COPY_MUT, COPY_INS, COPY_DEL, COPY_UNIFORM, COPY_SLIP, DIV_MUT, DIV_INS, DIV_DEL, DIV_UNIFORM, DIV_SLIP, DIVIDE_MUT, DIVIDE_INS, DIVIDE_DEL, DIVIDE_UNIFORM, DIVIDE_SLIP, PARENT, INJECT_MUT, INJECT_INS, and INJECT_DEL. These correspond to their counterparts in avida.cfg.To turn off all mutations, use ZeroMuts.
    • NewTrial No ArgumentsImmediately calculates the fitness of each organism in the population, saves this value for use with the CompeteOrganisms event, and resets the state of all organisms.
    • PhenotypeMatch string file-name
    • Pred_DemeEventMoveBetweenTargets [int times=1]
    • Pred_DemeEventMoveCenter [int times=1]
    • Pred_DemeEventNUniqueIndividualsMovedIntoTarget [int numorgs=1]
    • PrintMiniTraces [boolean random=0] [boolean save_dominants=0] [boolean save_groups=0] [boolean save_foragers=0] [int orgs_per=1] [int max_samples=0] [boolean print_genomes=0] [boolean initial]

      Prints a condensed trace of execution during a lifetime. Who is traced is determined by arguements. E.g. with the args save_dominants=1:orgs_per=2, at the specified update(s) a list is created containing the two most abundant genotypes. The next offspring born to parents with those specified genotypes will then be traced for their entire lifetimes. If save_foragers is set to 1, the list would contain the two most abundant genotypes for EACH existing forager type. Multiple types can be saved without duplicating traces. E.g. save_dominants=1:save_foragers=1:orgs_per=2 would trace one org from each of the two most dominant genotypes and one org from each of the two most common genotypes for each of the existing forager types if those genotypes were not also one of the two most abundant overall. If max_samples is > 0, this will cap the total number of orgs traced with priorities on fullfilling orgs_per quota for: dominants > forager types > group ids.

      Setting random will look at current population, select individuals up to max_samples (without replacement) record the sampled genotypes (one per individual, including genotype duplicates) and then trace the next orgs born with those genotypes, removing the genotype instance from the 'to-do' list with each new trace. Random option is not currently compatible with (will override) other save_ arguements or orgs_per.

      Minitraces are currently only fully implemented for the experimental hardware and partially for the SMT hardware because of differences in the way some minitrace variables are tracked by the different hardware types.

      Each call to PrintMiniTraces resets the genotype list, rather than appending to it.

      </p>
      
    • PrintMicroTraces [boolean random=0] [boolean rand_prey=0] [boolean rand_pred=0] [int next_prey=0] [int next_pred=0] [boolean save_dominants=0] [boolean save_groups=0] [boolean save_foragers=0] [int orgs_per=1] [int max_samples=0] [boolean print_genomes=0]

      Same general operation behavior as PrintMiniTraces but only saves executed instruction symbols along with org id, genotype id, forager type, and birth and death updates. Microtraces map executions as 'what the org was trying to do'. So, failed executions are recorded except when CPU costs are being paid. If CPU costs are being paid, we record the execution when the instruction was submitted, not necessarily when it was actually executed. Each microtrace is saved on a single line in microtrace.dat.

      rand_pred and rand_prey are compatible with each other, building a single list of genotypes to trace based on current genotypes in the population for each of the two general forager types (will generate a list of 2 X max_samples if both arguements are used).

      Each call to PrintMicroTraces appends to the genotype list, rather than replacing it (opposite of mini traces).

      If next_prey or next_pred are used, the organisms born to parents with prey or predator foraging targets will be traced, regardless of genotype, until the set arg number have been traced (requested number will be replaced, not appended to, by subsequent event calls).

    • RemovePredators
    • ReplaceFromGermline [double p(kill)=0.0 [int update_cell_data=0]]
    • ReplicateDemes [string trigger=full_deme]

      Tests all demes in a population and replicates those wherein a specific trigger condition has been met. The available triggers are:

      • full_deme: All deme cells are occupied by organisms.
      • corners: The upper-left and lower-right cells in a deme are occupied
      • deme-age: The deme has reached the age specified as DEMES_MAX_AGE in avida.cfg
      • birth-count: The deme has reached the number of births specified as DEMES_MAX_BIRTHS in avida.cfg
      • sat-mov-pred: ???
      • events-killed: ???
      • sat-msg-pred: ???
      • sat-deme-predicate: ???
      • perf-reactions: ???
      • consume-res: The deme has consumed a total number of resources specified as RES_FOR_DEME_REP in avida.cfg
    • ResetDemes No Arguments
    • SerialTransfer [int transfer_size=1] [int ignore_deads=1]Similar to KillProb, but we specify the exact number of organisms to keep alive after the event. The ignore_deads argument determines whether only living organisms are retainted.
    • SetMigrationRate [double rate=0.0]
    • SetMutProb [string mut_type="COPY_MUT"] [double prob=0.0] [int start_cell=-1] [int end_cell=-1]For a list of values for mut_type, see SetMutProb.
    • SeverGridCol [int col_id=-1] [int min_row=0] [int max_row=-1]Remove the connections between cells along a column in an Avida grid.
    • SeverGridRow [int row_id=-1] [int min_col=0] [int max_col=-1]Remove the connections between cells along a row in an Avida grid.
    • SwapCells <int cell_id1> <int cell_id2> Swaps the two organisms and all associated information (such as previous inputs). Doesn't work with identical cell ids.
    • SwapRandomCells <int number swaps> Swaps the specified number of pairs of randomly selected organisms. If randomly selected ids happen to be the same, nothing happens that iteration.
    • Synchronization No Arguments
    • TherapyDecayDemeResource [string resource_name=resname, string decrease_type=(none|lin|exp), double amount=0.2]
    • TherapyStructuralNumInst [cString inst=nand] [double exprWeight=1.0] [double exponent=1.0(linear)]
    • TherapyStructuralRatioDistBetweenNearest [cString inst=nand] [double exprWeight=1.0] [double exponent=1.0(linear)] [int print=100]
    • ToggleFitnessValley No Arguments
    • ToggleRewardInstruction No Arguments
    • TrackAllMessages No Arguments
    • UnitFitness No arguments.
    • ZeroMuts No ArgumentsThis event will set all mutation rates to zero. That is, it will set all cell mutation rates to zero, so that new organisms born will have zero mutation rates. Current organisms will not be affected, and may still mutate.
     

    Print Actions

    Output events are the primary way of saving data from an Avida experiments. The main two types are continuous output, which append to a single file every time the event is trigged, and singular output, which produce a single, complete file for each trigger.
      • CalcConsensus [int lines_saved=0]
      • DumpCellDataGrid [string fname=""]
      • DumpClassificationIDGrid [string fname_prefix=""]
      • DumpDonorGrid [string fname=""]Print out the grid of organisms who donated their merit.
      • DumpEnergyGrid [string fname=""]
      • DumpExecutionRatioGrid [string fname=""]
      • DumpFitnessGrid [string fname=""]Print out the grid of organism fitness values.
      • DumpGenomeLengthGrid [string fname=""]
      • DumpGenotypeColorGrid [int num_colors=12] [string fname=""]
      • DumpGenotypeGrid [string fname=""]
      • DumpHostTaskGrid [string fname=""]Print out the grid of takss that host organisms did in the last gestation cycle. For each host, tasks are first encoded as a binary string (e.g. 100000001 means that organism is doing NOT and EQU and then reported as a base-10 number (257 in the example above).
      • DumpIDGrid [string fname=""]
      • DumpLastTaskGrid [string fname=""]
      • DumpMaxResGrid [string fname=""]
      • DumpMemory [string fname=""]Dump memory summary information.
      • DumpParasiteGenotypeGrid [string fname=""]
      • DumpParasiteTaskGrid [string fname=""]Print out the grid of tasks that parasites did last gestation. For each parasite, tasks are first encoded as a binary string (e.g. 100000001 means that organism is doing NOT and EQU and then reported as a base-10 number (257 in the example above).
      • DumpParasiteVirulenceGrid [string fname=""]
      • DumpPhenotypeIDGrid [string fname=""]
      • DumpReactionGrid [string fname=""]
      • DumpReceiverGrid [string fname=""]
      • DumpSleepGrid [string fname=""]
      • DumpTargetGrid [string fname=""]
      • DumpTaskGrid [string fname=""]Print out the grid of tasks that organisms do. For each organism, tasks are first encoded as a binary string (e.g. 100000001 means that organism is doing NOT and EQU and then reported as a base-10 number (257 in the example above).
      • DumpVitalityGrid [string fname=""]
      • Echo <cString message>Print the supplied message to standard output.
      • PrintAgePolyethismData [string fname="age_polyethism.dat"]
      • PrintAveNumTasks [string fname=""]
      • PrintAverageData [string fname="average.dat"][string filename='average.dat'] Print all of the population averages the specified file.
      • PrintAvgDemeTasksExeData [string fname="avg_deme_tasks_exe.dat"]
      • PrintAvgTreatableDemeTasksExeData [string fname="avg_treatable_deme_tasks_exe.dat"]
      • PrintAvgUntreatableDemeTasksExeData [string fname="avg_untreatable_deme_tasks_exe.dat"]
      • PrintBirthChamber [string fname="birth_chamber/bc-XXXX.dat"] [int hwtype=0]
      • PrintBirthChamberMatingTypeHistogram [string fname="birth_chamber_mating_type_histogram.dat"] [int hwtype=0]
      • PrintCCladeCounts [filename = "cclade_count.dat"]Print a count of the number of oraganisms belonging to a each coalescence clade currently in the population.This action will only work in run mode.This action will require TRACK_CCLADE to be enabled.
      • PrintCCladeFitnessHistogram [filename] [fit_mode] [hist_min] [hist_step] [hist_max]Print a histogram of fitnesses for each coalescence clade in the population.This action will only work in run mode.This action will rerequire TRACK_CCLADE to be enabled.mode may be {CURRENT, ACTUAL, TESTCPU}, whereCURRENT uses the current phenotype value of fitness
    ACTUALuses the current merit and the true gestation time (via test cpu calculation) TESTCPUuses the test cpu measurement. lower_bound, step, upper_bound are log10 values for the individual histogram bins.

     

    • PrintCCladeRelativeFitnessHistogram [filename] [fit_mode] [hist_min] [hist_step] [hist_max]Print a histogram of parent-relative fitness ratios for each coalescence clade in the population.This action will only work in run mode.This action will rerequire TRACK_CCLADE to be enabled.mode may be {CURRENT, ACTUAL, TESTCPU}, whereCURRENT uses the current phenotype value of fitness
    ACTUALuses the current merit and the true gestation time (via test cpu calculation) TESTCPUuses the test cpu measurement. lower_bound, step, upper_bound are values for the individual histogram bins.

     

    • PrintCellData [string fname="cell_data.dat"]
    • PrintCellVisitsData [string fname="visits.dat "]
    • PrintCompetitionData [string fname="competition.dat"]Print out CompeteOrganism statistics. Make the first call after the first set of trials has been completed to get a complete header.
    • PrintConsensusData [string fname="consensus.dat"]
    • PrintCountData [string fname="count.dat"]Print all of the statistics the keep track of counts (such as the number of organisms in the population or the number of instructions executed).
    • PrintCurrentMeanDemeDensity [string fname="deme_currentMeanDensity.dat"]
    • PrintCurrentOpinions [string fname="opinions.dat"]
    • PrintCurrentReactionData [string fname="cur_reactions.dat"]
    • PrintCurrentReactionRewardData [string fname="cur_reaction_reward.dat"]
    • PrintCurrentTaskCounts [string fname="curr_task_counts.dat"]
    • PrintData <cString fname> <cString format>Append to the file specified (continuous output), the data given in the column list. The column list needs to be a comma-seperated list of keywords representing the data types. Many possible data types can be output; see the complete listing for details. Note that this event will even create a detailed column legend at the top of your file so you don't need to seperately keep track of what the columns mean.
    • PrintDebug No Arguments
    • PrintDemeAllStats No Arguments
    • PrintDemeAverageData [string fname="deme_average.dat"]
    • PrintDemeCompetitionData [string fname="deme_compete.dat"]
    • PrintDemeCurrentTaskExeData [string fname=" deme_cur_task_exe.dat "]
    • PrintDemeDonorStats No Arguments
    • PrintDemeEnergyDistributionStats No Arguments
    • PrintDemeEnergySharingStats No Arguments
    • PrintDemeFoundersData [string fname="deme_founders.dat"]
    • PrintDemeGermlineSequestration [string fname="deme_germ.dat"]
    • PrintDemeGlobalResources No ArgumentsPrints each resource in each deme. The format is different than normal Avida output and no information besides the date and time is given in the comments. Format at each update: deme_global_resouces_<update in 6 digits, padded with left 0s> = [ ... <deme_number> <resource0> etc. <deme_number> <resource0> etc. ];
    • PrintDemeMigrationSuicidePoints [string fname=" deme_mig_suicide_points.dat "]
    • PrintDemeNetworkData [string fname="deme_network.dat"]
    • PrintDemeNetworkTopology [string fname="deme_network_topology.dat"]
    • PrintDemeOrgReactionData [string fname="deme_org_reactions.dat"]
    • PrintDemeOrgTasksData [string fname="deme_org_tasks.dat"]
    • PrintDemeOrgTasksExeData [string fname="deme_org_tasks_exe.dat"]
    • PrintDemeReactionData [string fname="deme_reactions.dat"]
    • PrintDemeReactionDiversityReplicationData [string fname="deme_rx_repl.dat"]
    • PrintDemeReplicationData [string fname="deme_repl.dat"]
    • PrintDemeResourceStats No ArgumentsPrints each resource in each deme, with the format noted in the initial comments as normal.
    • PrintDemeResourceThresholdPredicate [string fname="deme_resourceThresholdPredicate.dat"]
    • PrintDemeSpacialEnergyStats No Arguments
    • PrintDemeSpacialSleepStats No Arguments
    • PrintDemeStats No Arguments
    • PrintDemesTotalAvgEnergy No Arguments
    • PrintDemeTasksData [string fname="deme_tasks.dat"]
    • PrintDemeTasksExeData [string fname="deme_tasks_exe.dat"]
    • PrintDemeTestamentStats [string fname="deme_testament.dat"]
    • PrintDemeTreatableCount [string fname="deme_treatable.dat"]
    • PrintDemeTreatableReplicationData [string fname="deme_repl_treatable.dat"]
    • PrintDemeUntreatableReplicationData [string fname="deme_repl_untreatable.dat"]
    • PrintDepthHistogram [string fname="depth_histogram.dat"]
    • PrintDetailedFitnessData [int save_max_f_genotype=0] [int print_fitness_histo=0] [double hist_fmax=1] [double hist_fstep=0.1] [string datafn="fitness.dat"] [string histofn="fitness_histos.dat"] [string histotestfn="fitness_histos_testCPU.dat"]
    • PrintDetailedSynchronizationData [string fname="sync-detail.dat"]
    • PrintDirectReciprocityData [string fname="reciprocity.dat"]
    • PrintDivideMutData [string fname="divide_mut.dat"]Output (regular and log) statistics about individual, per site, rates divide mutation rates (aver, stdev, skew, cur) to divide_mut.dat. Use with multiple divide instuction set.
    • PrintDominantData [string fname="dominant.dat"]Print all of the statistics relating to the dominant genotype.
    • PrintDominantForagerGenotypes [string fname=""]
    • PrintDominantGenotype [string fname=""]Print the dominant organism's genome (and lots of information about it) into the file specified. If no filename is given, the genotype's assigned name is used and the file is placed into the archive subdirectory.
    • PrintDominantGroupGenotypes [string fname=""]
    • PrintDonationStats No Arguments
    • PrintDynamicMaxMinData [string fname=" maxmin.dat "]
    • PrintEditDistance [sample size [filename]]
    • PrintErrorData [string fname="error.dat"]Print all of the standard errors of the average population statistics.
    • PrintExtendedTimeData [string fname="xtime.dat"]
    • PrintFemaleMatePreferenceData [string fname="female_mate_preference_data.dat"]
    • PrintFlowRateTuples [string fname="flow_rate_tuples.dat"]
    • PrintGeneticDistanceData [string ref_creature_file="START_ORGANISM"] [string fname="genetic_distance.dat"]
    • PrintGenomicSiteEntropy [filename = "GenomicSiteEntropyData.dat"]This function will take the initial genotype for each organism in the population/batch, align them, and calculate the per-site entropy of the aligned sequences. Please note that there may be a variable number of columns in each line if the runs are not fixed length. The site entropy will be measured in mers, normalized by the instruction set size. This is a population/batch measure of entropy, not a mutation-selection balance measure.
    • PrintGenotypeAbundanceHistogram [string fname="genotype_abundance_histogram.dat"]Arguments: [string fname="species_abundance_histogram.dat"]Arguments: [string fname="lineage_totals.dat"] [int verbose=1]Arguments: [string fname="lineage_counts.dat"] [int verbose=1]Writes out a genotype abundance histogram.
    • PrintGermlineData [string fname="germline.dat"]
    • PrintGroupIds [string fname="groupids.dat"]
    • PrintGroupsFormedData [string fname="groupformation.dat"]
    • PrintGroupTolerance [string fname="grouptolerance.dat"]
    • PrintHGTData [string fname="hgt.dat"]
    • PrintHostDepthHistogram [string fname="depth_host_histogram.dat"]
    • PrintHostPhenotypeData [string fname="host_phenotype_count.dat"]
    • PrintHostTasksData [string fname="host_tasks.dat"]
    • PrintInstructionAbundanceHistogram [string fname="instruction_histogram-${inst_set}.dat"] [string inst_set]Appends a line containing the bulk count (abundance) of each instruction in the population onto a file.
    • PrintInstructionData [string fname="instruction-${inst_set}.dat"] [string inst_set]Print the by-organisms counts of what instructions they _successfully_ executed beteween birth and divide. Prior to their first divide, organisms values for their parents.
    • PrintInternalTasksData [string fname="in_tasks.dat"]Print the number of organisms that have performed each task using internal resources.Note that tasks performed using internal resources are also counted as tasks perfomed (by PrintTasksData), so that if you wish to know the number of tasks performed not using internal resources you must do some subtraction.
    • PrintInternalTasksQualData [string fname="in_tasks_quality.dat"]Print the total quality of each task when performed using internal resources. (See PrintTasksQualData for more about task quality.
    • PrintInterruptData [string fname="interrupt.dat"]
    • PrintLineageCounts [string fname="lineage_counts.dat"]\n WARNING: This will only have the appropriate header if all lineages are present before this action is run for the first time.
    • PrintLineageTotals
    • PrintLogFitnessHistogram Parameters: <filename> <mode> <min> <step> <max>Print a histogram of organism fitnesses in the current population.This action will only work in run mode.mode may be {CURRENT, ACTUAL, TESTCPU}, whereCURRENT uses the current phenotype value of fitness
    ACTUALuses the current merit and the true gestation time (via test cpu calculation) TESTCPUuses the test cpu measurement. lower_bound, step, upper_bound are log10 values for the individual histogram bins.

     

    • PrintMarketData [string fname="market.dat"]
    • PrintMatingDisplayData [string fname="mating_display_data.dat"]
    • PrintMatingTypeHistogram [string fname="mating_type_histogram.dat"]
    • PrintMessageData [string fname="message.dat"]
    • PrintMessageLog [string fname="message_log.dat"]
    • PrintMigrationData [string fname="migration.dat"]
    • PrintMultiProcessData [string fname="multiprocess.dat"]
    • PrintMutationRateData [string fname="mutation_rates.dat"]Output (regular and log) statistics about individual copy mutation rates (aver, stdev, skew, cur). Useful only when mutation rate is set per organism.
    • PrintNewReactionData [string fname=" newreactions.dat "]Print number of times the particular reaction has newly appeared in the population since the last time this datum was printed. Newly appeared is defined as an organism triggering a reaction that was not triggered by its parent.
    • PrintNewTasksData [string fname="newtasks.dat "]Print number of times the particular task has newly appeared in the population since the last time this datum was printed. Newly appeared is defined as an organism executing a task that was not executed by its parent.
    • PrintNewTasksDataPlus [string fname="newtasksplus.dat "]
    • PrintNumOrgsInDeme No Arguments
    • PrintNumOrgsKilledData [string fname="orgs_killed.dat"]
    • PrintOpinionsSetPerDeme [string fname="opinions_set.dat"]
    • PrintOrganismLocation [string fname="location.dat"]
    • PrintParasiteData [string fname="parasite.dat"]
    • PrintParasiteDepthHistogram [string fname="depth_parasite_histogram.dat"]
    • PrintParasitePhenotypeData [string fname="parasite_phenotype_count.dat"]
    • PrintParasiteTasksData [string fname="parasite_tasks.dat"]
    • PrintPerDemeGenPerFounderData [string fname="deme_gen_between_founders.dat"]
    • PrintPerDemeReactionData [string fname="per_deme_reactions.dat"]
    • PrintPerDemeTasksData [string fname="per_deme_tasks.dat"]
    • PrintPerDemeTasksExeData [string fname="per_deme_tasks_exe.dat"]
    • PrintPhenotypeData [string fname="phenotype_count.dat"][string filename='phenotype_count.dat'] Print the number of phenotypes based on tasks executed this update. Executing a task any number of times is considered the same as executing it once.
    • PrintPhenotypeStatus [string fname="phenotype_status.dat"]
    • PrintPhenotypicPlasticity [string filename="phenplast"] [int num_trials=1000]This function will provided detailed information about the phenotypic varients of the current population/batch by running each genome through a test cpu num_trials times. If this command is executed in run mode, the filename will be appeneded with -Update.dat where Update is the current update. In analyze mode, the default file is merely phenplast.dat. The output file contains the following: id, parent_id, phenotypic_varient_number, frequency, fitness, merit, gestation_time, and task counts for each phenotypic variant of each genotype.
    • PrintPlasticGenotypeSummary [string filename="genotype_plsticity.dat"]
    • PrintPopulationDistanceData [string creature="START_ORGANISM"] [string fname=""] [int save_genotypes=0]
    • PrintPredatorAverageData [string fname="predator_average.dat"]
    • PrintPredatorErrorData [string fname="predator_error.dat"]
    • PrintMinPreyFailedAttacks [string fname="failed_attacks.dat"]
    • PrintPredatorInstructionData [string fname="predator_instruction-${inst_set}.dat"] [string inst_set]
    • PrintPredatorVarianceData [string fname="predator_variance.dat"]
    • PrintPredicatedMessages [string fname="messages.dat"]
    • PrintPreyAverageData [string fname="prey_average.dat"]
    • PrintPreyErrorData [string fname="prey_error.dat"]
    • PrintPreyInstructionData [string fname="prey_instruction-${inst_set}.dat"] [string inst_set]
    • PrintPreyVarianceData [string fname="prey_variance.dat"]
    • PrintProfilingData [string fname="profiling.dat"]
    • PrintReactionData [string fname="reactions.dat"]
    • PrintReactionExeData [string fname="reactions_exe.dat"]
    • PrintReactionRewardData [string fname="reaction_reward.dat"]
    • PrintRelativeFitnessHistogram [filename] [fit_mode] [hist_min] [hist_step] [hist_max]Print a histogram of parent-relative fitness ratios for each coalescence clade in the population.This action will only work in run mode.mode may be {CURRENT, ACTUAL, TESTCPU}, whereCURRENT uses the current phenotype value of fitness
    ACTUALuses the current merit and the true gestation time (via test cpu calculation) TESTCPUuses the test cpu measurement. lower_bound, step, upper_bound are values for the individual histogram bins.

     

    • PrintReproData No arguments
    • Record and print some data up to first reproduction for every org alive now.
    • PrintReputationData [string fname="reputation.dat"]
    • PrintResourceData [string fname="resource.dat"] [string print_maps="1"]Print the current counts of each resource available to the population. This uses the environment configuration to determine what resources are in use. Also optionally creates separate files resource_resource_name.m (in a format that is designed to be read into Matlab) for each spatial resource. Uses 1 as default but you can put 0 to only print resource.dat and save space.
    • PrintSenseData [string fname="sense.dat"]
    • PrintSenseExeData [string fname="sense_exe.dat"]
    • PrintShadedAltruists [string fname="shadedaltruists.dat"]
    • PrintSimpleConsensusData [string fname="simple_consensus.dat"]
    • PrintSleepData [string fname="sleep.dat"]
    • PrintSpeciesAbundanceHistogramWrites out a species abundance histogram.
    • PrintStatsData [string fname="stats.dat"]Print all of the miscellanous population statistics.
    • PrintStringMatchData [string fname="stringmatch.dat"]
    • PrintSuccessfulMates [string fname="mates/mates-XXXX.dat"]
    • PrintSynchronizationData [string fname="sync.dat"]
    • PrintTargets [string fname="targets.dat"]
    • PrintTaskProbHistogram [filename=pp_histogram.dat] [weightbycpus=0]
    • PrintTasksData [string fname="tasks.dat"]Print the number of organisms that are able to perform each task. This uses the environment configuration to determine what tasks are in use.
    • PrintTasksExeData [string fname="tasks_exe.dat"]Print number of times the particular task has been executed this update.
    • PrintTaskSnapshot [string fname=""]Run all organisms in the population through test cpus and print out the number of tasks each can perform.
    • PrintTasksQualData [string fname="tasks_quality.dat"]Print the total quality of each task. By default a successful task is valued as 1.0. Some tasks, however, can grant partial values and/or special bonuses via the quality value.
    • PrintThreadsData [string fname="threads.dat"]
    • PrintTimeData [string fname="time.dat"]Print all of the timing related statistics.
    • PrintToleranceData [string fname="tolerance.dat"]
    • PrintToleranceInstructionData [string fname="toleranceinstruction.dat"]
    • PrintTopNavTrace No arguments
    • Record and print some nav data up to first reproduction for best of orgs alive now, including trace execution, locations, and facings. Will print these data for the org among those with the highest reaction achieved By time of reproduction in shortest amount of time (as measured by cycles). Will print nothing if any of the candidate orgs are still alive when avida exits and no FlushTopNavTrace events were called.

    <li><strong><a name="PrintTotalsData"></a>PrintTotalsData</strong>
    

    [string fname="totals.dat"]Print various totals for the entire length of the run (for example, the total number of organisms ever).

  • PrintVarianceData [string fname="variance.dat"]Print all of the variances of the average population statistics.
  • PrintViableTasksData [string fname="viable_tasks.dat"]
  • PrintWinningDeme [string fname="deme_winners.dat"]
  • SaveDemeFounders [string fname=""]
  • SetVerbose [string verbosity=""]Change the level of output verbosity. Verbose messages will print all of the details of what is happening to the screen. Minimal messages will only briefly state the process being run. Verbose messages are recommended if you're in interactive analysis mode. When no arguments are supplied, action will toggle between NORMAL and ON.Levels: SILENT, NORMAL, ON, DETAILS, DEBUG
  • TestDominant [string fname="dom-test.dat"]
  • VERBOSE [string verbosity=""]
  •  

     

    Save Load Actions

    • LoadPopulation <cString fname> [int update=-1] [int cellid_offset=0] [int lineage_offset=0] [bool load_groups=0] [bool load_birth_cells=0] [bool load_avatars=0] [bool load_rebirth]

      Sets up a population based on a save file such as written out by SavePopulation. It is also possible to append a history file to the save file, in order to preserve the history of a previous run.
      update allows user to set the current update number to a new value
      load_groups allows users to load population files containing individual group ids (opinions) and forager types (aka saved populations with save_groups = 1)
      load_birth_cells allows users to drop each org into it's original birth cell. This can be important for populations in spatial environments where state information would have been collected as the org moved around the world.
      e.g to load a population with birth cells and group ids, but without cell, lineage, or update offsets:
      i LoadPopulation -1 0 0 1 1 0
      load_rebirth will override load_groups, load_birth_cells, load avatars and inject orgs into their saved birth cells, put avatars in their birth cells (if avatars are on), assign parent's merit to org (if inherit merit is on) and assign the parent's forage target if the parent was a 'teacher'
      i LoadPopulation -1 0 0 0 0 0 1

    <li><strong><a name="SaveFlameData"></a>SaveFlameData</strong>
    

    [string filename="flame"]

  • SavePopulation [string filename="detail"] [boolean save_historic=1] [boolean save_groups=0] [boolean save_avatars=0] [boolean save_rebirth=0] Save the genotypes and lots of statistics about the population to the file specified; if no filename is given, use the name detail-update.pop. As with clones, the update number allows a single event to produce many detail files. The details are used to collect crossection data about the population. The filename is a string that is used to prefix the update number and file extension, e.g. detail-100.spop. The save_historic option determines whether the action saves the full history for the current population. save_groups will append data on current group ids, current forage targets and the cell orgs were born into for each occurence of each genotype Using save_rebirth will save additional information about the birth of the organism which would be required to 'repeat' the birth of the organism as if it was still in the population (for behavioral trials, etc): parent_ft, parent is teacher, parent merit (out to 4 dec places) Using save_rebirth will save all possible columns (i.e. will save all save_groups + all save_avatars data even if those flags are off). Save canvas [deprecated] will save information about the canvas location, birth location, and canvas number used by the orgs. If save_canvas is true, save_avatars will be set to false, save_groups will be set to true, and save_rebirth will be set to true.
  •  

    Creating an Action

    The action source code is contained in the source/action directory. Each of the individual action categories has its own source code files (e.g. Landcape Actions are located in the LandscapeActions files).

    Each action is derrived from the cAction class. Briefly, to get an action to work you must create a child class that has a Process and GetDescription function defined as well as a constructor. You must also register this new class with the action library.

    So, with that quick review of what must be done, here is a step by step guide to creating an action:

    1. Identify which of the action categories your action should be assigned to. There are six different action categories described above. Each category has a similar means of creating a new action, but do note that some action commands are generated via macros defined at the top of the files. For instance, in the PrintActions file, you will notice a number of STATS_OUT_FILE macros being used to generate rather repetitively coded standard output files.
    2. Create a new class in the file that follows proper naming conventions. Any class should begin with "cAction" and be followed by the name of the action command you will register with the library. For instance, if we were to create a new command "MyAction", we'd name the class cActionMyAction. Below is a stub for this new action class:
      class cActionMyAction : public cAction
      {
      	private:
      		// Private data members for this action
      	public:
      		cActionMyAction(cWorld* world, const cString& args) : cAction(world, args) { ; }
      
      	static const cString GetDescription() { return "Arguments: My Arguments"; }
      
      	void Process(cAvidaContext&amp; ctx)
      	{
      		//Perform whatever processing is needed when the action is triggered.
      	}
      

      };

    3. Define the private data members, constructor, description string in GetDescription, and the Process function. Any arguments that you specify after the action name in the events configuration will be passed to your new class via the args argument in the constructor. (If you want more documentation for your actions than just the arguments, see the final step in this list.
    4. Register the new action with the action library. At the bottom of each action definitions file, there are the commands that register the individual actions with the action library. In the PrintActions.cc file, for instance, this function is called RegisterPrintActions.To register our example action "MyAction", we'd write:
      action_lib->Register<cActionMyAction>("MyAction");
       
    5. Test your action.
    6. Add a ==== Action action name ==== line in source/utils/make_actions_html/actions_source_info file
    Clone this wiki locally