1
Fork 0
mirror of https://github.com/Steffo99/turtle007.git synced 2024-11-23 21:44:20 +00:00

È successo un disastro, ma per fortuna sono riuscito a sistemare

ooooooooooooooooooops
This commit is contained in:
Steffo 2020-06-17 18:39:58 +02:00
parent e12eaeb8e0
commit 3decc22084
Signed by: steffo
GPG key ID: 896A80F55F7C97F0
2 changed files with 145 additions and 192 deletions

View file

@ -1,7 +1,7 @@
breed [ants ant]
patches-own [pheromone food nest distance-from-nest]
ants-own [carrying-food speed metabolism hunger]
globals [ant-deaths ant-hatches ants-to-respawn]
globals [ant-deaths ant-hatches ants-to-respawn mutazioni]
to setup
clear-all
@ -13,6 +13,7 @@ to setup
ask ants [t-paint-ant]
set ant-deaths 0
set ants-to-respawn 0
set mutazioni 0
end
to p-paint-patch
@ -225,6 +226,11 @@ to t-inherit [parents]
set metabolism (bottom-metabolism + random (top-metabolism - bottom-metabolism + 1))
end
to t-mutation
set speed (random(max-speed-with-mutation) + 1)
set metabolism (random(max-metabolism) + 1)
end
to t-hatch
let partners t-partners
if any? partners [
@ -235,7 +241,9 @@ to t-hatch
]
hatch-ants 1 [
t-setup-ant
t-inherit parents
ifelse random 100 > mutation-chance [t-inherit parents]
[t-mutation
set mutazioni (mutazioni + 1)]
]
set ant-hatches ant-hatches + 1
]
@ -784,7 +792,7 @@ INPUTBOX
875
570
max-speed
2.0
3.0
1
0
Number
@ -817,7 +825,7 @@ INPUTBOX
950
570
min-metabolism
1.0
3.0
1
0
Number
@ -926,7 +934,7 @@ Ant speeds
NIL
NIL
1.0
3.0
7.0
0.0
10.0
true
@ -1011,7 +1019,7 @@ count ants with [metabolism = 5]
MONITOR
1440
245
1535
1490
290
Speed 1
count ants with [speed = 1]
@ -1020,9 +1028,9 @@ count ants with [speed = 1]
11
MONITOR
1540
1495
245
1635
1545
290
Speed 2
count ants with [speed = 2]
@ -1139,80 +1147,109 @@ partner-radius
0
Number
SLIDER
730
640
875
673
mutation-chance
mutation-chance
0
100
2.0
1
1
%
HORIZONTAL
INPUTBOX
880
640
1032
700
max-speed-with-mutation
6.0
1
0
Number
MONITOR
1550
245
1600
290
Speed 3
count ants with [speed = 3]
17
1
11
MONITOR
1605
245
1655
290
Speed 4
count ants with [speed = 4]
17
1
11
MONITOR
1660
245
1710
290
Speed 5
count ants with [speed = 5]
17
1
11
MONITOR
1715
245
1765
290
Speed 6
count ants with [speed = 6]
17
1
11
MONITOR
1660
295
1765
340
Mutazioni
mutazioni
17
1
11
@#$#@#$#@
# `2-evoluzione`
Questo progetto estende il progetto [`2-metabolismo`](https://github.com/Steffo99/turtle007/tree/2-metabolismo). In questa versione vengono aggiunti i parametri riproduttivi e i meccanismi di scelta del partner, che portano ad unevoluzione del formicaio nel suo complesso.
# `2-Random-Mutation`
Questo progetto estende il progetto [`2-evoluzione`](https://github.com/Steffo99/turtle007/tree/2-evoluzione). In questa versione viene aggiunta l'aspetto della mutazione casuale nel modello: le caratteristiche migliori, come la velocità più alta o il metabolismo più basso, possono venire ottenute solo mediante mutazione in quanto non presenti nella popolazione originale.
## Ambiente
### Variabili globali
Sono state aggiunte al modello le seguenti variabili globali:
- `reproduction-hunger`, la quantità di `hunger` al di sopra della quale una formica può tentare di riprodursi;
- `reproduction-cost`, la quantità di `hunger` che sarà sottratta alle formiche dopo essersi riprodotte;
- `partner-radius`, la distanza massima a cui una formica può scegliere il suo partner.
- `mutazioni`, contiene il numero di mutazioni che si sono verificate dall'inizio della simulazione;
- `mutation-chance`, la probabilità che si verifichi una mutazione;
- `max-speed-with-mutation`, la velocità massima ottenibile mediante mutazione.
### Comportamento delle formiche
Il comportamento delle formiche è stato cambiato nei seguenti modi:
#### Modificato: `t-die`
#### Modificato: `t-hatch`
```
to t-die
set ant-deaths ant-deaths + 1
set ants-to-respawn ants-to-respawn + 1
; Die interrompe la funzione!
die
end
```
Dopo che sono morte, le formiche non respawnano più.
#### Modificato: `t-consume-food`
```
to t-consume-food
set hunger hunger - metabolism
if hunger <= 0 [
t-die
]
if hunger >= reproduction-hunger [
t-hatch
]
end
```
Se le formiche hanno abbastanza cibo per riprodursi, chiameranno la procedura `t-hatch` descritta in seguito.
#### Aggiunto: `t-partners`
```
to-report t-partners
report other turtles in-radius partner-radius with [hunger >= reproduction-hunger]
end
```
Nella scelta dei partner, le formiche considerano solo le altre formiche entro `partner-radius` patch di distanza aventi abbastanza `hunger` per riprodursi.
> Nota: La funzione `in-radius` rallenta significativamente il modello all'aumentare delle formiche presenti dall'interno di esso.
>
> È possibile realizzare una versione più efficiente utilizzando:
> ```
> to-report t-partners
> report other turtles-here with [hunger >= reproduction-hunger]
> end
> ```
>
> Ciò però sacrifica la possibilità di decidere il raggio a cui le formiche si possono riprodurre, limitandolo al valore "0" (ovvero, la patch stessa in cui si trova attualmente la formica).
#### Aggiunto: `t-hatch`
```
to t-hatch
let partners t-partners
```diff
let partners t-partners
if any? partners [
let partner item 0 sort-on [hunger] partners
let parents (turtle-set self partner)
@ -1221,43 +1258,28 @@ to t-hatch
]
hatch-ants 1 [
t-setup-ant
t-inherit parents
]
+ ifelse random 100 > mutation-chance [t-inherit parents]
+ [t-mutation
+ set mutazioni (mutazioni + 1)]
+ ]
set ant-hatches ant-hatches + 1
]
end
```
Se le formiche trovano almeno un partner con cui riprodursi, scelgono il partner con il valore di `hunger` più alto e creano una nuova formica, che eredita i valori di `speed` e `metabolism` dei genitori con `t-inherit` (descritta sotto).
### Aggiunto: `t-inherit`
```
to t-inherit [parents]
let top-speed max [speed] of parents
let bottom-speed min [speed] of parents
set speed (bottom-speed + random (top-speed - bottom-speed + 1))
let top-metabolism max [metabolism] of parents
let bottom-metabolism min [metabolism] of parents
set metabolism (bottom-metabolism + random (top-metabolism - bottom-metabolism + 1))
end
#### Aggiunto: `t-mutation`
```diff
+to t-mutation
+ set speed (random(max-speed-with-mutation) + 1)
+ set metabolism (random(max-metabolism) + 1)
+end
```
Le nuove formiche nate prendono come `speed` e `metabolism` un valore casuale tra i valori dei rispettivi parametri posseduti dai genitori.
## Feedback del sistema
In aggiunta ai feedback precedenti, in questo progetto abbiamo nuovi feedback:
- <span style="background-color: lightgreen; color: darkgreen;">**Positivo**: Le formiche con più `hunger` (praticamente la funzione *fitness* del modello), hanno più possibilità di riprodursi e passare i loro parametri ai figli.</span>
- <span style="background-color: lightcoral; color: darkred;">**Negativo**: Il `reproduction-cost` fa diminuire l'`hunger` dei genitori, rendendo più probabile la loro morte (e quindi sostituzione).</spaw>
## Dinamica del sistema
Le formiche con i parametri migliori si riprodurranno più spesso, e passeranno i loro parametri ai loro figli.
*Il sistema tende allottimo*: dopo un certo numero di ticks (~2100 con la configurazione predefinita), le uniche formiche restanti nel sistema saranno quelle con valori ideali per le variabili `speed` e `metabolism`; tutte le altre si saranno **estinte**.
La dinamica del sistema rimane pressochè invariata rispetto alla precedente versione, seppur rendendo inaccessibili le caratteristiche migliori se non mediante mutazione. La presenza di mutazione, inoltre, evita una stagnazione in una situazione sub-ottimale.
@#$#@#$#@
default
true

123
README.md
View file

@ -1,6 +1,8 @@
# `2-evoluzione`
# `2-random-mutation`
Questo progetto estende il progetto [`2-metabolismo`](https://github.com/Steffo99/turtle007/tree/2-metabolismo). In questa versione vengono aggiunti i parametri riproduttivi e i meccanismi di scelta del partner, che portano ad unevoluzione del formicaio nel suo complesso.
Questo branch estende il progetto [`2-evoluzione`](https://github.com/Steffo99/turtle007/tree/2-evoluzione).
In questa versione viene aggiunta l'aspetto della mutazione casuale nel modello: le caratteristiche migliori, come la velocità più alta o il metabolismo più basso, possono venire ottenute solo mediante mutazione in quanto non presenti nella popolazione originale.
## Ambiente
@ -8,115 +10,44 @@ Questo progetto estende il progetto [`2-metabolismo`](https://github.com/Steffo9
Sono state aggiunte al modello le seguenti variabili globali:
- `reproduction-hunger`, la quantità di `hunger` al di sopra della quale una formica può tentare di riprodursi;
- `reproduction-cost`, la quantità di `hunger` che sarà sottratta alle formiche dopo essersi riprodotte;
- `partner-radius`, la distanza massima a cui una formica può scegliere il suo partner.
- `mutazioni`, contiene il numero di mutazioni che si sono verificate dall'inizio della simulazione;
- `mutation-chance`, la probabilità che si verifichi una mutazione;
- `max-speed-with-mutation`, la velocità massima ottenibile mediante mutazione.
### Comportamento delle formiche
Il comportamento delle formiche è stato cambiato nei seguenti modi:
#### Modificato: `t-die`
#### Modificato: `t-hatch`
```diff
to t-die
set ant-deaths ant-deaths + 1
- set ants-to-respawn ants-to-respawn + 1
; Die interrompe la funzione!
die
end
```
Dopo che sono morte, le formiche non respawnano più.
#### Modificato: `t-consume-food`
```diff
to t-consume-food
set hunger hunger - metabolism
if hunger <= 0 [
t-die
let partners t-partners
if any? partners [
let partner item 0 sort-on [hunger] partners
let parents (turtle-set self partner)
ask parents [
set hunger hunger - reproduction-cost
]
+ if hunger >= reproduction-hunger [
+ t-hatch
hatch-ants 1 [
t-setup-ant
+ ifelse random 100 > mutation-chance [t-inherit parents]
+ [t-mutation
+ set mutazioni (mutazioni + 1)]
+ ]
end
set ant-hatches ant-hatches + 1
]
```
Se le formiche hanno abbastanza cibo per riprodursi, chiameranno la procedura `t-hatch` descritta in seguito.
#### Aggiunto: `t-partners`
#### Aggiunto: `t-mutation`
```diff
+to-report t-partners
+ report other turtles in-radius partner-radius with [hunger >= reproduction-hunger]
+to t-mutation
+ set speed (random(max-speed-with-mutation) + 1)
+ set metabolism (random(max-metabolism) + 1)
+end
```
Nella scelta dei partner, le formiche considerano solo le altre formiche entro `partner-radius` patch di distanza aventi abbastanza `hunger` per riprodursi.
> Nota: La funzione `in-radius` rallenta significativamente il modello all'aumentare delle formiche presenti dall'interno di esso.
>
> È possibile realizzare una versione più efficiente utilizzando:
> ```
> to-report t-partners
> report other turtles-here with [hunger >= reproduction-hunger]
> end
> ```
>
> Ciò però sacrifica la possibilità di decidere il raggio a cui le formiche si possono riprodurre, limitandolo al valore "0" (ovvero, la patch stessa in cui si trova attualmente la formica).
#### Aggiunto: `t-hatch`
```diff
+to t-hatch
+ let partners t-partners
+ if any? partners [
+ let partner item 0 sort-on [hunger] partners
+ let parents (turtle-set self partner)
+ ask parents [
+ set hunger hunger - reproduction-cost
+ ]
+ hatch-ants 1 [
+ t-setup-ant
+ t-inherit parents
+ ]
+ set ant-hatches ant-hatches + 1
+ ]
+end
```
Se le formiche trovano almeno un partner con cui riprodursi, scelgono il partner con il valore di `hunger` più alto e creano una nuova formica, che eredita i valori di `speed` e `metabolism` dei genitori con `t-inherit` (descritta sotto).
### Aggiunto: `t-inherit`
```diff
+to t-inherit [parents]
+ let top-speed max [speed] of parents
+ let bottom-speed min [speed] of parents
+ set speed (bottom-speed + random (top-speed - bottom-speed + 1))
+
+ let top-metabolism max [metabolism] of parents
+ let bottom-metabolism min [metabolism] of parents
+ set metabolism (bottom-metabolism + random (top-metabolism - bottom-metabolism + 1))
+end
```
Le nuove formiche nate prendono come `speed` e `metabolism` un valore casuale tra i valori dei rispettivi parametri posseduti dai genitori.
## Feedback del sistema
In aggiunta ai feedback precedenti, in questo progetto abbiamo nuovi feedback:
- <span style="background-color: lightgreen; color: darkgreen;">**Positivo**: Le formiche con più `hunger` (praticamente la funzione *fitness* del modello), hanno più possibilità di riprodursi e passare i loro parametri ai figli.</span>
- <span style="background-color: lightcoral; color: darkred;">**Negativo**: Il `reproduction-cost` fa diminuire l'`hunger` dei genitori, rendendo più probabile la loro morte (e quindi sostituzione).</spaw>
## Dinamica del sistema
Le formiche con i parametri migliori si riprodurranno più spesso, e passeranno i loro parametri ai loro figli.
*Il sistema tende allottimo*: dopo un certo numero di ticks (~2100 con la configurazione predefinita), le uniche formiche restanti nel sistema saranno quelle con valori ideali (o prevalenti, in caso di convergenza prematura) per le variabili `speed` e `metabolism`; tutte le altre si saranno **estinte**. Il sistema tende quindi ad una condizione in cui tutte le formiche sono uguali, oppure estinte in caso di convergenza prematura tremendamente sfavorevole (ad esempio, velocità 1 e metabolismo 5).
## Branches
E' presente una variazione di questo modello, [`2-random-mutation`](https://github.com/Steffo99/turtle007/tree/2-random-mutation).
La dinamica del sistema rimane pressochè invariata rispetto alla precedente versione, seppur rendendo inaccessibili le caratteristiche migliori se non mediante mutazione. La presenza di mutazione, inoltre, evita una stagnazione in una situazione sub-ottimale.