DemGenTrout 1.3

No preview image

2 collaborators

Default-person Béatrice Frank (Author)
Philippe Baret (Advisor)

Tags

brown trout 

Tagged by Béatrice Frank over 11 years ago

fish 

Tagged by Béatrice Frank over 11 years ago

hatchery 

Tagged by Béatrice Frank over 11 years ago

population dynamics 

Tagged by Béatrice Frank over 11 years ago

population genetics 

Tagged by Béatrice Frank over 11 years ago

salmo trutta 

Tagged by Béatrice Frank over 11 years ago

stocking 

Tagged by Béatrice Frank over 11 years ago

Child of model DemGenTrout 1.1
Visible to everyone | Changeable by the author
Model was written in NetLogo 5.0.2 • Viewed 506 times • Downloaded 27 times • Run 0 times
Download the 'DemGenTrout 1.3' modelDownload this modelEmbed this model

Do you have questions or comments about this model? Ask them here! (You'll first need to log in.)


WHAT IS IT?

This is the version 1.3 of a brown trout demogenetic model developed by Beatrice Frank during her PhD thesis (Supervisor: Prof. Philippe Baret, Earth and Life Institute, Universite catholique de Louvain). This version includes features of DemGenTrout 1.1 (faster initialisation) and simulates stocking with hatchery trout.

HOW IT WORKS

The model, named DemGenTrout, was designed to understand how anthropogenic disturbances can affect a brown trout (Salmo trutta L.) population living in a river / nursery brook system of the Lesse River network (Belgium). Changes in the demogenetic (i.e., demography and genetics) structure of the population were monitored, and at a latter stage, the model was used to predict how trout populations might respond to migration barriers and stocking with hatchery trout (Frank & Baret, 2013).

The model has been described following the ODD (Overview, Design concepts, Details) protocol (Grimm et al., 2006; 2010) in DemGenTrout 1.1. To study stocking impacts on wild brown trout, several modifications of the model structure were needed. More specifically, one submodel, two breeds, and eight parameters (stocking-start, stocking-end, stocking-coefficient, num-stocked, survival-factor, trout-spawning-prob, stocked-spawning-prob, hybrid-spawning-prob) were added. Both spawning and survival submodels were adapted to include phenotypic and genetic differences between hatchery-reared and wild trout.

The new submodel, 'intro-stocked-trout', simulates the introduction of hatchery individuals in the Lesse River (stream L). Each year at week 27 (i.e., the end of March, corresponding to the beginning of the fishing season) and during 10 years, a fixed number of stocked trout (num-stocked parameter) is introduced in stream L. This number is calculated once, at week 27 of year 1, as the product of the stocking-coefficient by the number of wild trout in stream L. The state variables of each stocked trout are defined as follows. Their length is drawn from a random normal distribution with a mean of 248.47 mm and a standard deviation of 26.71 mm. Their condition factor is set to 1.1, as hatchery fish are often larger and heavier than wild fish. The weight of each individual is calculated as its condition factor times its length cubed according to Fulton's formula. Genotypes are assigned in accordance with alleles and corresponding allelic frequencies observed for hatchery-reared individuals (see text files ''input-genotypes-stocking-12markers'' and ''input-genofreq-stocking-12markers''). All stocked individuals are of age 2.

The spawning submodel was modified to incorporate the new breeds, which correspond to stocked trout and hybrids. Both breeds have the same state variables as those defined for wild trout. Breed attribution to each offspring depends of the mating. A thirteenth locus was added in trout genotypes for breed tracking, with homozygous alleles arbitrarily fixed to '000' and '999' for wild and hatchery trout, respectively. Hybrids are identified as individuals having heterozygous alleles (i.e., either '000/999' or '999/000'). Phenotypes are thus inherited the same way as genotypes. We hypothesised that stocked trout had reduced reproductive success in comparison with wild trout, and their probability of spawning was set to 0.10 (stocked-spawning-prob parameter). For wild trout, the spawning probability was set to 1.00 (trout-spawning-prob). The spawning probability for hybrids (hybrid-spawning-prob) is given by: trout-spawning-prob * (1 - ((1 - stocked-spawning-prob) / 2)) and is thus equal to 0.55.

The survival process of trout was also adapted. We hypothesised a high mortality of hatchery-reared fish soon after their release, in comparison with wild fish. The survival rate of age-2 hatchery trout released in stream L was thus divided by the survival-factor, set to 10 (the survival of stocked trout is 10 times lower than the rate normally used for wild trout). As phenotypic differences between hatchery and wild fish often disappear after 1 year in nature, stocked trout of age strictly higher than 2 and hatchery trout born in the system have the same age-specific survival rates than wild trout. Survival of hybrids is computed from survival of wild (SW) and hatchery trout (SS): SH = SW * (1 - ((1 - SS) / 2)).

HOW TO USE IT

Click the 'Setup' button to initialise the model. In this version, the values of all variables are imported from the file ''DemGenTrout-world.csv''.

You can change the values of parameters with the sliders, then click the 'Change parameters' button, or you can keep the default values (to restore them, click the 'Restore parameters' button). Only parameters linked to stocking can be modified:

  • stocking-start and stocking-end, the time period of stoking in years.
  • stocking-coefficient, the intensity of stocking in relation to the number of wild trout present in stream L (typically, values from 0.50 to 0.70 reflect a moderate stoking).
  • survival-factor, the division factor for survival rate of stocked individuals of age 2 living in stream L in relation to the survival rate of wild trout of the same age class.
  • trout-spawning-prob, the probability of spawning for wild trout.
  • stocked-spawning-prob, the probability of spawning for hatchery trout.

Click the 'go' button to start the simulation (click 'go' again to stop it). The model can also be run weekly ('step-W' button), monthly ('step-M') or yearly ('step-Y'). The two plots on the left show abundance of wild trout, stocked trout and hybrids in both streams, and is updated each year at week 1. The six plots on the right vary with time, and represent the age distribution of wild trout, stocked trout and hybrids in both streams.

THINGS TO NOTICE AND TO TRY

You can test the following parameterizations described in Frank & Baret (2013):

  • a spawning probability equal to 1 for all breeds, by setting the stocked-spawning-prob equal to 1.
  • a survival rate for freshly stocked trout similar to wild trout, by setting the survival-factor equal to 1.
  • the two previous modifications, by setting both stocked-spawning-prob and survival-factor equal to 1.

Stocking with hatchery fish thus shows a relatively weak impact on the demographic structure of the brook population (i.e., abundance around 3300 individuals after 35 years of simulation) provided that stocked trout had lower survival and spawning probabilities than wild trout. However, a drastic reduction in abundance of wild trout in stream C is observed (i.e., abundance around 1800 individuals after 35 years) in the latter case implementing a situation where hatchery and wild trout have similar survival and spawning probabilities.

RELATED MODELS

DemGenTrout 1.0: This is the first version of the DemGenTrout model, as described in Frank & Baret (2013).

DemGenTrout 1.1: In comparison with DemGenTrout 1.0, the initialisation of this version is faster.

DemGenTrout 1.2: This version includes features of DemGenTrout 1.1 (faster initialisation) and simulates a barrier to upstream spawning migration.

CREDITS AND CITATION

The development of the model was funded by the "Fonds pour la formation a la Recherche dans l'Industrie et dans l'Agriculture" (F.R.I.A.). During the formulation phase, the report describing the inSTREAM model of Railsback et al. (2009) has been an inspirational source. For the programming phase, many of the sample NetLogo models were of great use.

To refer to this model in academic publications, please use: Frank, B.M., Baret, P.V. (2013). Simulating brown trout demogenetics in a river/nursery brook system: The individual-based model DemGenTrout. Ecological Modelling 248: 184-202.

COPYRIGHT AND LICENSE

DemGenTrout 1.3 (2012)

Beatrice M. Frank

Earth and Life Institute

Universite catholique de Louvain

beatrice.frank@gmail.com

CC BY-NC-SA 3.0

This work is licensed under the Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License. To view a copy of this license, visit http://creativecommons.org/licenses/by-nc-sa/3.0/.

Comments and Questions

About DemGenTrout 1.3

This version includes features of DemGenTrout 1.1 (faster initialisation) and simulates stocking with hatchery trout. An applet of the model is available at: http://sites-final.uclouvain.be/gena-truites/DemGenTrout/DemGenTrout-V1-3.html

Posted about 12 years ago

Click to Run Model

;; DemGenTrout 1.3 (2012)
;;
;; Developed by
;; Beatrice M. Frank
;; Earth and Life Institute
;; Universite catholique de Louvain
;; Beatrice.Frank@gmail.com
;; 
;; Last updated: September 2012

breed[ trout ]
breed[ dead ]
breed[ gone ]
breed[ stocked ]
breed[ hybrid ]

;; trout state variables
trout-own[ sex genotype natal-stream week-of-birth week-of-birth2 ;; fixed
  current-stream age stage status body-length body-weight condition-factor num-offspring
  spawned? moved-to-spawn? returned? ]

;; gone trout state variables
gone-own[ sex genotype natal-stream week-of-birth week-of-birth2 ;; fixed
  current-stream age stage status body-length body-weight condition-factor num-offspring
  spawned? moved-to-spawn? returned? ]

;; dead trout state variables
dead-own[ sex genotype natal-stream week-of-birth week-of-birth2 ;; fixed
  current-stream age stage status body-length body-weight condition-factor num-offspring
  spawned? moved-to-spawn? returned? ]

;; stocked state variables
stocked-own[ sex genotype natal-stream week-of-birth week-of-birth2 ;; fixed
  current-stream age stage status body-length body-weight condition-factor num-offspring
  spawned? moved-to-spawn? returned? newly-stocked? ]

;; hybrid state variables
hybrid-own[ sex genotype natal-stream week-of-birth week-of-birth2 ;; fixed
  current-stream age stage status body-length body-weight condition-factor num-offspring
  spawned? moved-to-spawn? returned? ]
  
;; stream state variables
patches-own [ stream flow temperature ] 

globals[ week week-of-year month-of-year year
 ;; trout initialisation
 prop-C prop-L init-N
 prop-age0-C prop-age1-C prop-age2-C prop-age3-C
 prop-age0-L prop-age1-L prop-age2-L
 meanl-age0-C meanl-age0-L meanl-age1-C meanl-age1-L meanl-age2-C meanl-age2-L meanl-age3-C meanl-age3-L
 sdl-age0-C sdl-age0-L sdl-age1-C sdl-age1-L sdl-age2-C sdl-age2-L sdl-age3-C sdl-age3-L 
 trdown-age0-C trdown-age0-L trdown-age1-C trdown-age1-L trdown-age2-C trdown-age2-L trdown-age3-C trdown-age3-L
 trup-age0-C trup-age0-L trup-age1-C trup-age1-L trup-age2-C trup-age2-L trup-age3-C trup-age3-L
 meanl-birth-C sdl-birth-C meanl-birth-L sdl-birth-L trdown-C trup-C trdown-L trup-L 
 mean-bcf-C sd-bcf-C mean-bcf-L sd-bcf-L
 propC-inL 
 ;; stream input data
 streamC-discharge streamL-discharge streamC-temperature streamL-temperature 
 mean-dischargeC sd-dischargeC mean-dischargeL sd-dischargeL
 mean-temperatureC sd-temperatureC mean-temperatureL sd-temperatureL
 max-dischargeC max-dischargeL

 ;; survival parameters 
 streamC-age0-survival streamC-age1-survival streamC-age2-survival streamC-age3-survival
 streamL-age0-survival streamL-age1-survival streamL-age2-survival streamL-age3-survival 
 streamC-age0-survival-list streamC-age1-survival-list streamC-age2-survival-list streamC-age3-survival-list
 streamL-age0-survival-list streamL-age1-survival-list streamL-age2-survival-list streamL-age3-survival-list  
 C-age0-survival C-age1-survival C-age2-survival C-age3-survival
 L-age0-survival L-age1-survival L-age2-survival L-age3-survival 
 predation-factor
 ;; growth parameters
 streamC-parK streamL-parK
 streamC-max-length streamC-parA streamC-parB streamL-max-length streamL-parA streamL-parB   
 ;; spawning parameters
 spawn-start spawn-end moved-prop spawn-mean-length spawn-mean-cond
 spawn-sd-length spawn-sd-cond spawn-min-age
 spawn-mean-temperature spawn-sd-temperature spawn-mean-flow spawn-sd-flow
 streamC-capacity offprod offprod-min-length offprod-max-length offprod-min
 offspringC-varA offspringC-varB offspringL-varA offspringL-varB
 offprodC-max offprodL-max 
 length-heritability 
 ;; hatching parameters
 hatch-start hatch-end
 ;; downstream movement parameters
 move-start move-end move-min-age move-max-age
 move-mean-length move-sd-length 
 move-age1-prob move-age1-varB move-age1-varA
 move-age2-prob move-age2-varB move-age2-varA 
 move-mean-temperature move-sd-temperature move-mean-flow move-sd-flow
 ;; leaving stream L forever parameters
 leaving-propC leaving-propL
 ;; stocking
; stocking-start stocking-end stocking-coefficient survival-factor
 num-stocked hybrid-spawning-prob ; trout-spawning-prob stocked-spawning-prob 

 out-year out-month out-week
]  

to setup
  clear-all      
  no-display     
  ;; controlling the random numbers
  random-seed 1223251200  
  
  ;; first week of the year = 1st to 7th October included
  set week 1
  set week-of-year 1
  set month-of-year 1
  set year 1
  
  import-world "DemGenTrout-world.csv"
  ask trout [set genotype lput "000/000" genotype]
  
  reset-ticks
  restore-defaults
end 

to restore-defaults
  ;; restore the default parameters linked to stocking
  set stocking-start 1
  set stocking-end 10
  set stocking-coefficient 0.50     
  set survival-factor 10  
  set trout-spawning-prob 1.00
  set stocked-spawning-prob 0.10  
  ;; compute spawning probability for hybrids
  set hybrid-spawning-prob (trout-spawning-prob * (1 - ((1 - stocked-spawning-prob) / 2)))    
end 

to set-parameters  
  ;; compute spawning probability for hybrids
  set hybrid-spawning-prob (trout-spawning-prob * (1 - ((1 - stocked-spawning-prob) / 2)))   
end 

;;;;;;;;;;;;;;;;;;;;;;;;;;;;; SCHEDULING ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

to go
  no-display 

  tick 
  ;; end at year 35
  if ticks = 1820 [ user-message "Input data are only available for 35 years."  stop ]
  ;; a year = 52 weeks  
  set week-of-year (week mod 52) + 1
  set month-of-year (int(week-of-year / 4.5) mod 52) + 1 
  set year (int(week / 52)) + 1 ; mod 52
  
  ;; each week

;-- 1. Update stream hydrological conditions ----------------------------------------------------------
  
  ask patches [ update-stream-conditions ] 
   
;-- New. Introduce stocked trout in the system --------------------------------------------------------

  ;; introduction of stocked trout
  if week-of-year = 27 and year >= stocking-start and year <= stocking-end [ intro-stocked-trout ]   
  
let selected-breed (list trout stocked hybrid)
foreach selected-breed 
[    
  
;-- 2. Kill trout in each stream ----------------------------------------------------------------------

  ask ? [ trout-die ]         
    
;-- 3. Update trout length, weight and condition factor -----------------------------------------------
  
  ask ? [ trout-grow ]      

;-- 4. Reproduce trout in each stream ----------------------------------------------------------------- 

  ;; spawning time window: duration = 11 weeks
  if week-of-year >= spawn-start and week-of-year <= spawn-end
  [   
    ;--- 4.1. Identify candidate spawners ---;
    ask ? [ trout-become-candidate-spawners ] 
    ;; select some of the candidate spawners born in stream L in order to make them reproduce in C
    let candidate-spawners-streamL ? with [ status = "candidate-spawner" and current-stream = "L" 
      and natal-stream = "L" and not moved-to-spawn? ]
    while [ (count ? with [status = "selected-candidate-spawner"]) < (moved-prop * count candidate-spawners-streamL) ]
    [ ask one-of candidate-spawners-streamL [ set status "selected-candidate-spawner" ] ]      
    
    ;--- 4.2. Move candidate spawners upstream ---;   
    ask ? [ trout-move-to-spawn ]         
    
    ;; adapt offspring production if abundance in C is strictly higher than streamC-capacity
    ifelse count ? with [ current-stream = "C" ] > streamC-capacity 
    [ set offprodC-max offprod / 10 ]
    [ set offprodC-max offprod ]        

    ;--- 4.3. Produce offspring in each stream ---;  
    trout-spawn-in-streamC
    trout-spawn-in-streamL
  ]
   
;-- 5. Increment trout age and update stage -----------------------------------------------------------

  if week-of-year = (hatch-start - 1) ;; one week before hatching
  [ 
    ask ? [ trout-update-age ]
    ask ? with [age > 6] [die!] ;; trout die at age 7    
  ]       

;-- 6. Reveal offspring -------------------------------------------------------------------------------   
  
  ;; hatching time window: duration = 11 weeks
  if week-of-year >= hatch-start and week-of-year <= hatch-end
  [ (foreach sort ? with [age = -1]
      [ ask ?
        [
          if (week-of-year - week-of-birth) = (hatch-start - spawn-start) ;; delay = 10 weeks
          [ set hidden? false set age 0 ]
        ]])
  ]

;-- 7. Move trout of stream C downstream ----------------------------------------------------------
    
  ;; migration time window: duration = 25 weeks
  if week-of-year >= move-start and week-of-year <= move-end
  [             
    ;--- 7.1. Identify candidate migrants among juveniles ---; 
    ask ? [ trout-become-candidate-migrants ]          
     
    ;--- 7.2. Update movement probabilities ---;     
    update-move-age1-prob   
    update-move-age2-prob      
            
    ;--- 7.3. Move candidate migrants ---;
    ask ? [ trout-move-downstream ]                  
  ]        

;-- 8. Move upswimming spawners back to stream L ----------------------------------------------------- 

  if week-of-year = (spawn-end + 1) ;; the week after the spawning process
  [ 
    ask ? [ trout-move-back ]
  ]               
  
;-- 9. Remove young trout of stream L from the system ------------------------------------------------    
  
  ;; at the end of the year
  if week-of-year = 52
  [ 
    ;; some juveniles born in C and living in stream L do not settle and go elsewhere 
    let bornC-in-streamL ? with [current-stream = "L" and natal-stream = "C" and status = "migrant"]    
    let bornC-leaving (leaving-propC * count bornC-in-streamL)
    ask n-of bornC-leaving bornC-in-streamL [ leave-streamL ]  
    ;; some juveniles born in L and living in stream L do not settle and go elsewhere  
    let bornL-in-streamL ? with [current-stream = "L" and natal-stream = "L" and (age = 1 or age = 2)]
    let bornL-leaving (leaving-propL * count bornL-in-streamL)
    ask n-of bornL-leaving bornL-in-streamL [ leave-streamL ]   
  ]                
  
; Trout reset --------------------------------------------------------------------------------------
  
  ;; at the end of the year
  if week-of-year = 52
  [      
    ;; reset trout status and boolean state variables    
    ask ? [ set status "non-spawner" set moved-to-spawn? false set spawned? false set returned? false ] 
    ;; kill all hidden turtles  
    ask gone [die]     
    ask dead [die]          
  ]
]

; Increment the week -------------------------------------------------------------------------------
   
  set week week + 1
end 

;;;;;;;;;;;;;;;;;;;;;;;;;;; STREAM PROCEDURE ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;; update water temperature and flow of each stream

to update-stream-conditions
  ifelse ticks < (6 * 52)
  ;; first 6 years (2004 to 2009)
  [
    ifelse stream = "C"
    [
      set flow item week streamC-discharge
      set temperature item week streamC-temperature 
    ]
    [
      set flow item week streamL-discharge
      set temperature item week streamL-temperature
    ]  
  ]
  ;; next years (2010 to 2038)
  [
    ifelse stream = "C"
    [
      set flow min (list max-dischargeC (item week streamC-discharge + random-lognormal mean-dischargeC sd-dischargeC))
      set temperature (item week streamC-temperature + random-normal mean-temperatureC sd-temperatureC) 
    ]
    [
      set flow min (list max-dischargeL (item week streamL-discharge + random-lognormal mean-dischargeL sd-dischargeL))
      set temperature (item week streamL-temperature + random-normal mean-temperatureL sd-temperatureL)
    ]  
  ]
end 

;;;;;;;;;;;;;;;;;;;;;;;;;; TROUT PROCEDURES ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;; trout mortality

to trout-die
  ;; in stream C
  if (breed = trout or breed = stocked) and stage = "fry" and current-stream = "C" [if random-float 1 > ((item week-of-year streamC-age0-survival) ^ (1 / 52)) [die!]]  
  if breed = hybrid and stage = "fry" and current-stream = "C" [if random-float 1 > (((item week-of-year streamC-age0-survival) * (1 - ((1 - (item week-of-year streamC-age0-survival)) / 2))) ^ (1 / 52)) [die!]]
  if (breed = trout or breed = stocked) and stage = "juvenile" and age = 1 and current-stream = "C" [if random-float 1 > ((item week-of-year streamC-age1-survival) ^ (1 / 52)) [die!]]
  if breed = hybrid and stage = "juvenile" and age = 1 and current-stream = "C" [if random-float 1 > (((item week-of-year streamC-age1-survival) * (1 - ((1 - (item week-of-year streamC-age1-survival)) / 2))) ^ (1 / 52)) [die!]]  
  if (breed = trout or breed = stocked) and stage = "juvenile" and age = 2 and current-stream = "C" [if random-float 1 > ((item week-of-year streamC-age2-survival) ^ (1 / 52)) [die!]]
  if breed = hybrid and stage = "juvenile" and age = 2 and current-stream = "C" [if random-float 1 > (((item week-of-year streamC-age2-survival) * (1 - ((1 - (item week-of-year streamC-age2-survival)) / 2))) ^ (1 / 52)) [die!]]    
  if (breed = trout or breed = stocked) and stage = "adult" and age < 6 and current-stream = "C" [if random-float 1 > ((item week-of-year streamC-age3-survival) ^ (1 / 52)) [die!]] 
  if breed = hybrid and stage = "adult" and age < 6 and current-stream = "C" [if random-float 1 > (((item week-of-year streamC-age3-survival) * (1 - ((1 - (item week-of-year streamC-age3-survival)) / 2))) ^ (1 / 52)) [die!]]    
  if week-of-year >= spawn-start and week-of-year <= spawn-end and (breed = trout or breed = stocked) and moved-to-spawn? = true and current-stream = "C" 
   [if random-float 1 > (((item week-of-year streamC-age3-survival) / predation-factor) ^ (1 / (spawn-end - spawn-start))) [die!]] 
  if week-of-year >= spawn-start and week-of-year <= spawn-end and breed = hybrid and moved-to-spawn? = true and current-stream = "C" 
   [if random-float 1 > ((((item week-of-year streamC-age3-survival) * (1 - ((1 - (item week-of-year streamC-age3-survival)) / 2))) / predation-factor) ^ (1 / (spawn-end - spawn-start))) [die!]]       
  ;; in stream L
  if (breed = trout or breed = stocked) and stage = "fry" and current-stream = "L" [if random-float 1 > ((item week-of-year streamL-age0-survival) ^ (1 / 52)) [die!]]
  if breed = hybrid and stage = "fry" and current-stream = "L" [if random-float 1 > (((item week-of-year streamL-age0-survival) * (1 - ((1 - (item week-of-year streamL-age0-survival)) / 2))) ^ (1 / 52)) [die!]]  
  if (breed = trout or breed = stocked) and stage = "juvenile" and age = 1 and current-stream = "L" [if random-float 1 > ((item week-of-year streamL-age1-survival) ^ (1 / 52)) [die!]]
  if breed = hybrid and stage = "juvenile" and age = 1 and current-stream = "L" [if random-float 1 > (((item week-of-year streamL-age1-survival) * (1 - ((1 - (item week-of-year streamL-age1-survival)) / 2))) ^ (1 / 52)) [die!]]  

  if breed = stocked and newly-stocked? = true and stage = "juvenile" and age = 2 and current-stream = "L" [if random-float 1 > (((item week-of-year streamL-age2-survival) / survival-factor) ^ (1 / 52)) [die!]]  
  if (breed = trout or breed = stocked) and stage = "juvenile" and age = 2 and current-stream = "L" [if random-float 1 > ((item week-of-year streamL-age2-survival) ^ (1 / 52)) [die!]]
  if breed = hybrid and stage = "juvenile" and age = 2 and current-stream = "L" [if random-float 1 > (((item week-of-year streamL-age2-survival) * (1 - ((1 - (item week-of-year streamL-age2-survival)) / 2))) ^ (1 / 52)) [die!]]
  
  if (breed = trout or breed = stocked) and stage = "adult" and age < 6 and current-stream = "L" [if random-float 1 > ((item week-of-year streamL-age3-survival) ^ (1 / 52)) [die!]]  
  if breed = hybrid and stage = "adult" and age < 6 and current-stream = "L" [if random-float 1 > (((item week-of-year streamL-age3-survival) * (1 - ((1 - (item week-of-year streamL-age3-survival)) / 2))) ^ (1 / 52)) [die!]]    
end 

;; individual growth

to trout-grow
  ifelse current-stream = "C"
  [
    ;; von Bertalanffy growth equation for trout in stream C
    set body-length (body-length + (streamC-parK * (streamC-max-length - body-length)))
    let healthy-weight (streamC-parA * ((body-length) ^ streamC-parB)) ;; weight-length regression 
    set body-weight (condition-factor * healthy-weight)      
  ]
  [
    ;; von Bertalanffy growth equation for trout in stream L
    set body-length (body-length + (streamL-parK * (streamL-max-length - body-length)))  
    let healthy-weight (streamL-parA * ((body-length) ^ streamL-parB)) ;; weight-length regression
    set body-weight (condition-factor * healthy-weight)      
  ]
  set condition-factor max (list 0.5 (condition-factor + (- 0.008 + random-float 0.016)))
  ;; test for negative length and negative weight
  if body-length < 0 [ user-message "Negative fish length" ]
  if body-weight < 0 [ user-message "Negative fish weight" ]    
end 

to die!
  set breed dead
  hide-turtle
end 

;; identification of candidate spawners

to trout-become-candidate-spawners
  if age >= spawn-min-age and status != "spawner" and not moved-to-spawn? 
  [ if random-normal spawn-mean-length spawn-sd-length < body-length and 
    random-normal spawn-mean-cond spawn-sd-cond < condition-factor
    [ set status "candidate-spawner" ] ]  
end 

;; movement to stream C for reproduction

to trout-move-to-spawn
 let temperature-streamL [temperature] of one-of patches with [ stream = "L" ]      
 let flow-streamL [flow] of one-of patches with [ stream = "L" ] 
 ;; spawners born in C or in L move to C
 if (status = "candidate-spawner" and not moved-to-spawn? and current-stream = "L" and natal-stream = "C") 
   or (status = "selected-candidate-spawner" and not moved-to-spawn?)     
 [ if random-lognormal spawn-mean-flow spawn-sd-flow < flow-streamL   
   [ set current-stream "C" set xcor 1 set moved-to-spawn? true set status "candidate-spawner" ] ]  
end 

;; update trout age and stage

to trout-update-age
  set age age + 1
  trout-update-stage 
end   

;; update trout stage: fry, juvenile, adult 

to trout-update-stage
  if age < 1 [ set stage "fry" stop ]
  if age >= 1 and age <= 2 [ set stage "juvenile"stop ]
  if age > 2 [ set stage "adult" stop ] 
end 

;; reproduction

to trout-spawn-in-streamC
  let trout-spawners trout with [ status = "candidate-spawner" or status = "spawner" and current-stream = "C" ] 
  let stocked-spawners-temp stocked with [ status = "candidate-spawner" or status = "spawner" and current-stream = "C" ]  
  let hybrid-spawners-temp hybrid with [ status = "candidate-spawner" or status = "spawner" and current-stream = "C" ]
  let num-stocked-spawners (floor ((count stocked-spawners-temp) * stocked-spawning-prob))
  let num-hybrid-spawners (floor ((count hybrid-spawners-temp) * hybrid-spawning-prob))  
  let stocked-spawners n-of num-stocked-spawners stocked-spawners-temp
  let hybrid-spawners n-of num-hybrid-spawners hybrid-spawners-temp  
  let spawners (turtle-set trout-spawners stocked-spawners hybrid-spawners) 
  ifelse count spawners < 2
  [ stop ]
  [  
    ;; length of parents when born (VBLF backwards)
    let born-length-parents VBLF-reverse spawners    
    ;; mean and variance of length of parents when born
    if length born-length-parents < 2 [ stop ]
    let mean-parents mean born-length-parents
    let var-parents variance born-length-parents
    let num-crossover ((count trout-spawners + count stocked-spawners + count hybrid-spawners) / 2)  
    ;; polygamous mating with satellite males (not in good condition)    
    repeat num-crossover
    [
      let num-males 1 + random 4 ; number of males drawn randomly from an uniform distribution from 1 to 4
      let all-parent-M spawners with [ sex = "M" ]
      if count all-parent-M < num-males [ stop ]         
      let no-parent-M max-n-of num-males spawners with [ sex = "M" ] [condition-factor]
      let sel-parent-M all-parent-M with [ not member? self no-parent-M and not spawned? ]  
      if count spawners with [ sex = "F" and not spawned? ] <= 1 [ stop ] 
      if count sel-parent-M < num-males [ stop ]  
      ;; select the parents: first, the spawners that have moved to spawn, then the other spawners  
      let parent-M n-of num-males sel-parent-M
      let parent-F max-one-of spawners with [ sex = "F" and not spawned? ] [condition-factor]     
      if (count spawners with [ sex = "M" and not spawned? and moved-to-spawn? ] - num-males) >= num-males  
      [ 
        if any? spawners with [ sex = "M" and not spawned? and moved-to-spawn? ] 
        [
          set all-parent-M spawners with [ sex = "M" and moved-to-spawn? ]
          set no-parent-M max-n-of num-males spawners with [ sex = "M" and moved-to-spawn? ] [condition-factor]
          set sel-parent-M all-parent-M with [ not member? self no-parent-M and not spawned? ]           
          set parent-M n-of num-males sel-parent-M
        ]
      ]
      if any? spawners with [ sex = "F" and not spawned? and moved-to-spawn?]
      [ set parent-F max-one-of spawners with [ sex = "F" and not spawned? and moved-to-spawn?] [condition-factor] ]
      ;; length deviances of parents M and F from mean-parents
      let dummy VBLF-reverse parent-M
      let dev-M 0
      let temp (random-normal meanl-birth-C sdl-birth-C)
      if temp < trdown-C [set temp trdown-C]   
      if temp > trup-C [set temp trup-C]                
      if length dummy = 0 [ set dev-M (mean-parents - temp) ]      
      if length dummy = 1 [ set dev-M (mean-parents - (item 0 dummy)) ]        
      if length dummy > 1 [ set dev-M (mean-parents - mean dummy) ]
      let dev-F (mean-parents - (VBLF-reverse parent-F))       
      ask parent-F
      [
        set spawned? true
        set status "spawner"
        set xcor 1
        let num-fry update-num-offspringC [body-length] of parent-F   
        hatch-trout num-fry
        [
          set hidden? true ;; hide trout until hatching
          set age -1 set stage "fry"  
          ;; genotype of parent-M is a mixture of the several genotypes of males
          let genotype-mix mixture ([genotype] of parent-M)
          ;; define genotypes for eggs
          let egg-genotype cross-genotype (genotype-mix) ([genotype] of parent-F)  
          set genotype egg-genotype   
          set breed item 0 assign-breed egg-genotype                                           
          set xcor 1
          set current-stream "C"
          set natal-stream "C"
          set num-offspring 0
          set week-of-birth week-of-year      
          set week-of-birth2 (week + 1)          
          ifelse random-float 1 > 0.5 [ set sex "M" ] [ set sex "F" ]
          set status "non-spawner" set spawned? false
          set moved-to-spawn? false set returned? false          
          ;; set body-length as function of parents' length and environment
          let genetic-dev (sqrt length-heritability) * (dev-M + dev-F)    
          let envi-var ((1 - length-heritability) ^ 2) * var-parents
          let envi-dev random-normal 0 (sqrt envi-var) 
          set body-length mean-parents + genetic-dev + envi-dev
          let temp2 (random-normal meanl-birth-C sdl-birth-C)  
          if temp2 < trdown-C [set temp2 trdown-C]   
          if temp2 > trup-C [set temp2 trup-C]                
          if body-length < trdown-C or body-length > trup-C [ set body-length temp2 ]           
          ;; set body-weight and condition-factor
          set condition-factor (random-normal mean-bcf-C sd-bcf-C)         
          set body-weight (condition-factor * ((body-length) ^ 3) / 100000)       
        ] 
        set num-offspring num-fry
      ]
      ask parent-M
      [
        ;set spawned? true ;; shut because males can reproduce more than once
        set status "spawner" 
        set xcor 1        
        set num-offspring [num-offspring] of parent-F               
      ] 
    ]
  ]               
end  

to trout-spawn-in-streamL
  let trout-spawners trout with [ status = "candidate-spawner" or status = "spawner" and current-stream = "L" ]
  let stocked-spawners-temp stocked with [ status = "candidate-spawner" or status = "spawner" and current-stream = "L" ]
  let hybrid-spawners-temp hybrid with [ status = "candidate-spawner" or status = "spawner" and current-stream = "L" ]
  let num-stocked-spawners (floor ((count stocked-spawners-temp) * stocked-spawning-prob))
  let num-hybrid-spawners (floor ((count hybrid-spawners-temp) * hybrid-spawning-prob))  
  let stocked-spawners n-of num-stocked-spawners stocked-spawners-temp
  let hybrid-spawners n-of num-hybrid-spawners hybrid-spawners-temp    
  let spawners (turtle-set trout-spawners stocked-spawners hybrid-spawners) 
  ifelse count spawners < 2
  [ stop ]
  [  
    let born-length-parents VBLF-reverse spawners 
    ;; mean and variance of length of parents when born
    if length born-length-parents < 2 [ stop ]  
    let mean-parents mean born-length-parents
    let var-parents variance born-length-parents  
    let num-crossover ((count trout-spawners + count stocked-spawners + count hybrid-spawners) / 2)  
    ;; polygamous mating with satellite males (not in good condition)    
    repeat num-crossover  
    [
      let num-males 1 + random 4 ; number of males drawn randomly from an uniform distribution from 1 to 4
      let all-parent-M spawners with [ sex = "M" ]
      if count all-parent-M < num-males [ stop ]         
      let no-parent-M max-n-of num-males spawners with [ sex = "M" ] [condition-factor]
      let sel-parent-M all-parent-M with [ not member? self no-parent-M and not spawned? ]  
      if count spawners with [ sex = "F" and not spawned? ] <= 1 [ stop ] 
      if count sel-parent-M < num-males [ stop ]  
      ;; select the parents: first, the spawners that have moved to spawn, then the other spawners  
      let parent-M n-of num-males sel-parent-M
      let parent-F max-one-of spawners with [ sex = "F" and not spawned? ] [condition-factor]     
      if (count spawners with [ sex = "M" and not spawned? and moved-to-spawn? ] - num-males) >= num-males  
      [ 
        if any? spawners with [ sex = "M" and not spawned? and moved-to-spawn? ] 
        [
          set all-parent-M spawners with [ sex = "M" and moved-to-spawn? ]
          set no-parent-M max-n-of num-males spawners with [ sex = "M" and moved-to-spawn? ] [condition-factor]
          set sel-parent-M all-parent-M with [ not member? self no-parent-M and not spawned? ]           
          set parent-M n-of num-males sel-parent-M
        ]
      ]
      if any? spawners with [ sex = "F" and not spawned? and moved-to-spawn?]
      [ set parent-F max-one-of spawners with [ sex = "F" and not spawned? and moved-to-spawn?] [condition-factor] ]
      ;; length deviances of parents M and F from mean-parents
      let dummy VBLF-reverse parent-M
      let dev-M 0
      let temp (random-normal meanl-birth-L sdl-birth-L)
      if temp < trdown-L [set temp trdown-L]   
      if temp > trup-L [set temp trup-L]                
      if length dummy = 0 [ set dev-M (mean-parents - temp) ]            
      if length dummy = 1 [ set dev-M (mean-parents - (item 0 dummy)) ]        
      if length dummy > 1 [ set dev-M (mean-parents - mean dummy) ]    
      let dev-F (mean-parents - (VBLF-reverse parent-F))      
      ask parent-F
      [
        set spawned? true
        set status "spawner"
        set xcor 0
        let num-fry update-num-offspringL [body-length] of parent-F 
        hatch-trout num-fry
        [
          set hidden? true ;; hide trout until hatching
          set age -1 set stage "fry"
          ;; genotype of parent-M is a mixture of the several genotypes of males
          let genotype-mix mixture ([genotype] of parent-M)
          ;; define genotypes for eggs
          let egg-genotype cross-genotype (genotype-mix) ([genotype] of parent-F)  
          set genotype egg-genotype   
          set breed item 0 assign-breed egg-genotype                                 
          set xcor 0
          set current-stream "L"
          set natal-stream "L"  
          set num-offspring 0   
          set week-of-birth week-of-year      
          set week-of-birth2 (week + 1)              
          ifelse random-float 1 > 0.5 [ set sex "M" ] [ set sex "F" ]    
          set status "non-spawner" set spawned? false
          set moved-to-spawn? false set returned? false                   
          ;; set body-length as function of parents' length and environment
          let genetic-dev (sqrt length-heritability) * (dev-M + dev-F)     
          let envi-var ((1 - length-heritability) ^ 2) * var-parents
          let envi-dev random-normal 0 (sqrt envi-var) 
          set body-length mean-parents + genetic-dev + envi-dev
          let temp2 (random-normal meanl-birth-L sdl-birth-L)  
          if temp2 < trdown-L [set temp2 trdown-L]   
          if temp2 > trup-L [set temp2 trup-L]                         
          if body-length < trdown-L or body-length > trup-L [ set body-length temp2 ]       
          ;; set body-weight and condition-factor
          set condition-factor (random-normal mean-bcf-L sd-bcf-L)
          set body-weight (condition-factor * ((body-length) ^ 3) / 100000)              
        ]
        set num-offspring num-fry
      ]
      ask parent-M
      [
        ;set spawned? true ;; shut because males can reproduce more than once
        set status "spawner"
        set xcor 0      
        set num-offspring [num-offspring] of parent-F
      ]       
    ]  
  ]      
end   

;; stream C

to-report update-num-offspringC [ female-length ] ;; linear function
  ;; compute the intermediate variables for the linear offspring production function for trout of stream C
  set offspringC-varA (offprodC-max - offprod-min) / (offprod-max-length - offprod-min-length)
  set offspringC-varB offprod-min - (offspringC-varA * offprod-min-length) 
  report ((offspringC-varA * female-length) + offspringC-varB)
end 

;; stream L

to-report update-num-offspringL [ female-length ] ;; linear function
  ;; compute the intermediate variables for the linear offspring production function  for trout of stream C
  set offspringL-varA (offprodL-max - offprod-min) / (offprod-max-length - offprod-min-length)
  set offspringL-varB offprod-min - (offspringL-varA * offprod-min-length)    
  report ((offspringL-varA * female-length) + offspringL-varB)
end 

to-report cross-genotype [ genotype1 genotype2 ]
  let new-genotype []
  let bit 0
  repeat length genotype1
  [
    let choice random 4
    if choice = 0
    [ set new-genotype (lput (word(substring (item bit genotype1) 0 4)(substring (item bit genotype2) 0 3)) new-genotype)]
    if choice = 1
    [ set new-genotype (lput (word(substring (item bit genotype1) 0 3) (substring (item bit genotype2) 3 7)) new-genotype)]
    if choice = 2
    [ set new-genotype (lput (word(substring (item bit genotype2) 0 3) (substring (item bit genotype1) 3 7)) new-genotype)]
    if choice = 3
    [ set new-genotype (lput (word(substring (item bit genotype1) 4 7) (substring (item bit genotype2) 3 7)) new-genotype)]      
    set bit bit + 1
  ]
  report new-genotype
end 

to-report mixture [ genotype-temp ]
  let genotype-mix []
  let bit 0
  repeat length one-of genotype-temp
  [
    let choice random (length genotype-temp) ; choose randomly one genotype among n males
    set genotype-mix lput item bit (item choice genotype-temp) genotype-mix
    set bit bit + 1
  ] 
  report genotype-mix
end 

to-report VBLF-reverse [ trout-indiv ]  
  ifelse is-agentset? trout-indiv
  [
    let length-when-born []
    (foreach sort trout-indiv
      [
        let time 0
        let length-diff 0
        let length-when-born-temp 0
        ask ?
        [
          set time (week - week-of-birth2)
          ifelse natal-stream = "C" 
          [ 
            set length-diff (streamC-max-length - body-length)
            set length-when-born-temp (streamC-max-length - (length-diff / ((1 - streamC-parK) ^ (time))))            
          ]
          [ 
            set length-diff (streamL-max-length - body-length)
            set length-when-born-temp (streamL-max-length - (length-diff / ((1 - streamL-parK) ^ (time))))            
          ]
        ]     
        set length-when-born lput length-when-born-temp length-when-born                
      ])
    report length-when-born 
  ]  
  [
    let time (week - ([week-of-birth2] of trout-indiv))      
    ifelse [natal-stream] of trout-indiv = "C"
    [ 
      let length-when-born (streamC-max-length - ((streamC-max-length - [body-length] of trout-indiv) / ((1 - streamC-parK) ^ (time)))) 
      report length-when-born
    ]
    [ 
      let length-when-born (streamL-max-length - ((streamL-max-length - [body-length] of trout-indiv) / ((1 - streamL-parK) ^ (time)))) 
      report length-when-born  
    ]   
  ]   
end 

to trout-become-candidate-migrants
  if (age = move-min-age or age = move-max-age) and current-stream = "C" and natal-stream = "C" 
  [ if random-normal move-mean-length move-sd-length < body-length
    [ set status "candidate-migrant" ] ]
end 

;; movement from C to L

to trout-move-downstream
  let temperature-streamC [temperature] of one-of patches with [ stream = "C" ]  
  let flow-streamC [flow] of one-of patches with [ stream = "C" ]    
  if status = "candidate-migrant"
  [ if random-normal move-mean-temperature move-sd-temperature < temperature-streamC 
    and random-lognormal move-mean-flow move-sd-flow < flow-streamC
    [ ifelse age = 1
      ;; juveniles age 1
      [ if random-float 1 < move-age1-prob 
        [ set xcor 0 set current-stream "L" set status "migrant" ] ]
      ;; juveniles age 2
      [ if random-float 1 < move-age2-prob
        [ set xcor 0 set current-stream "L" set status "migrant" ] ]
    ] 
  ]   
end     

to update-move-age1-prob ;; logistic function
  let nb1 count trout with [current-stream = "C" and body-length > 70]
  let Z1 (exp((move-age1-varA * nb1) + move-age1-varB))
  set move-age1-prob (Z1 / (1 + Z1))  
end 

to update-move-age2-prob ;; logistic function
  let nb2 count trout with [current-stream = "C" and body-length > 70]
  let Z1 (exp((move-age2-varA * nb2) + move-age2-varB))
  set move-age2-prob (Z1 / (1 + Z1))  
end 

to trout-move-back
  ;; candidate spawners return to previous stream
  if (status = "candidate-spawner" and current-stream = "C" and moved-to-spawn?)
  ;; effective spawners return to previous stream
    or (status = "spawner" and current-stream = "C" and moved-to-spawn?)
  [ set current-stream "L" set xcor 0 set returned? true ]  
end 

to leave-streamL
  set breed gone
  hide-turtle
end 

to intro-stocked-trout
  if year = 1
  [
    let num-trout count trout with [current-stream = "L"]
    set num-stocked round (stocking-coefficient * num-trout)
    ;print num-stocked
  ]
  create-stocked num-stocked
  [ 
    set breed stocked
    set newly-stocked? true
    setxy random-xcor -15
    set shape "box" set size 0.8
    set current-stream "L"
    set natal-stream "X"
    ifelse random-float 1 > 0.5
      [ set sex "M" ]
      [ set sex "F" ]
    ;; attribute trout genotypes at 12 microsatellites markers (loci)     
    let markers []
    file-open "input-genotypes-stocking.txt"
    set markers (sentence file-read (list ["999/999"]))  
    file-close
    let freq []
    file-open "input-genofreq-stocking.txt"
    set freq (sentence file-read (list [1]))
    file-close    
    set genotype []          
    set genotype assign-genotype (markers) (freq)
    set num-offspring 0     
    set status "non-spawner"
    set spawned? false set moved-to-spawn? false set returned? false      
    set age 2 
    trout-update-stage ;; a trout procedure setting stage from age  
    ;; attribute body-length, body-weight and condition-factor
    set body-length random-normal 248.47 26.71 set condition-factor 1.1 
    set body-weight (condition-factor * ((body-length) ^ 3) / 100000)     
    ;; test for negative length and negative weight
    if body-length < 0 [ user-message "Negative fish length" ]
    if body-weight < 0 [ user-message "Negative fish weight" ]               
  ] ;; end of create-stocked in stream L  
end 

to-report assign-genotype [markers freq]
  let locus []
  let bit 0
  repeat length markers
  [
    set locus assign-locus (bit) (markers) (freq)     
    set genotype lput (first locus) genotype  
    set bit bit + 1
  ] 
  report genotype
end 

to-report assign-locus [bit markers freq]
    let locus []
    let q 0
    let ran random-float 1.0
    (foreach (item bit markers) (item bit freq)
    [
      set q q + ?2
      if ran <= q [set locus lput ?1 locus] 
      if empty? locus and ?1 = last (item bit markers)
      [ set locus assign-locus (bit) (markers) (freq) ]
    ])    
    report locus
end 

;; breed attribution to offspring in function of 13th loci in genotype

to-report assign-breed [ genotype-temp ]
  ;; wild trout
  if (last genotype-temp) = "000/000" [ report (list trout)  ]
  ;; stocked trout 
  if (last genotype-temp) = "999/999" [ report (list stocked)]
  ;; hybrids
  if (last genotype-temp) = "000/999" [ report (list hybrid) ]
  if (last genotype-temp) = "999/000" [ report (list hybrid) ]
end 

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

to-report random-lognormal [mu sigma]
  let S sqrt(ln(((sigma / mu) ^ 2) + 1))
  let M ln (mu) - ((S ^ 2) / 2)
  report exp(random-normal M S)
end 

There is only one version of this model, created about 12 years ago by Béatrice Frank.

Attached files

File Type Description Last updated
DemGenTrout-V1-3_data.zip data External files for 'DemGenTrout 1.3' over 11 years ago, by Béatrice Frank Download

Parent: DemGenTrout 1.1

This model does not have any descendants.

Graph of models related to 'DemGenTrout 1.3'