Changeset 595 for experiments/frams


Ignore:
Timestamp:
08/23/16 21:28:36 (8 years ago)
Author:
oriona
Message:

Rotation of creatures in z axis changed to random. LocalDrive? usage replaced by drive.

Location:
experiments/frams/foraminifera/data/scripts
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • experiments/frams/foraminifera/data/scripts/foraminifera.expdef

    r592 r595  
    323323}
    324324
     325function createAndRotate(geno, rotate_min, rotate_max, pop_num)
     326{
     327        var cr = Populations[pop_num].add(geno);
     328        cr.rotate(0,0,Math.rndUni(rotate_min, rotate_max));
     329        return cr;     
     330}
     331
     332//TODO unifiy addForam, foramGrow and createOffspring
    325333function addForam(species, iter, start_energy, ploid)
    326334{
     
    329337        var geno = create_genotype(radius, chambernum, colors[ploid], 1);
    330338        curColor = colors[ploid];
    331         var cr = Populations[0].add(geno);
     339        var cr = createAndRotate(geno, 0, 2*Math.pi, 0);
    332340        cr.name = "Initial creature" + species + "_" + iter;
    333341        placeRandomlyNotColliding(cr);
     
    448456                var ploid = cr.data->lifeparams->gen;
    449457                var geno = create_genotype(getPloidRadius(ploid), chamber_num+1, colors[ploid], lastchambergrowth);
    450                 var cr2 = Populations[0].add(geno);
    451 
     458                var cr2 = createAndRotate(geno, 0, 0, 0);
     459
     460                cr2.orient.set(cr.orient);
    452461                cr2.energy0 = cr.energy;
    453462                cr2.energy = cr2.energy0;
     
    507516function stepToNearest(cr)
    508517{
    509         var p = cr.getMechPart(0);
     518        var p = XYZ.new(cr.center_x, cr.center_y, cr.center_z);
    510519        var n = cr.signals.receiveSet("nutrient", getZoneRange(cr,2));
    511520
     
    523532                for (i = 0; i < n.size; i++)
    524533                {
    525                         mp = n[i].value.getMechPart(0);
    526                         distvec.set(mp.pos);
    527                         distvec.sub(p.pos);
     534                        mp = XYZ.new(n[i].value.center_x, n[i].value.center_y, n[i].value.center_z);
     535                        distvec.set(mp);
     536                        distvec.sub(p);
    528537                        dist = distvec.length;
    529538                        if (dist < getZoneRange(cr,1))
     
    546555                        mindistvec.z = 0;
    547556                        mindistvec.normalize();
    548                         mindistvec.scale(-1*movePerStep);
    549                         cr.localDrive = mindistvec;
     557                        mindistvec.scale(movePerStep);
     558                        cr.drive = mindistvec;
    550559                        moveEnergyDec(cr);
    551560                }
     
    601610        {
    602611                reverseHib(cr);
    603                 cr.localDrive = XYZ.new(0,0,0);
     612                cr.drive = XYZ.new(0,0,0);
    604613        }
    605614        //random move
     
    608617                cr.data->lifeparams->dir = randomDir();
    609618                cr.data->lifeparams->dir_counter = 0;
    610                 cr.localDrive = cr.data->lifeparams->dir;
     619                cr.drive = cr.data->lifeparams->dir;
    611620                moveEnergyDec(cr);
    612621        }
    613622        else
    614623        {
    615                 cr.localDrive = cr.data->lifeparams->dir;
     624                cr.drive = cr.data->lifeparams->dir;
    616625        }
    617626        moveReticulopodia(cr);
     
    623632        {
    624633                cr.data->reticulopodiacreature.moveAbs(cr.center_x-getZoneRange(cr,1), cr.center_y-getZoneRange(cr,1), cr.center_z-getZoneRange(cr,1));
    625                 cr.data->reticulopodiacreature.localDrive = cr.localDrive;
     634                cr.data->reticulopodiacreature.drive = cr.drive;
    626635        }
    627636}
     
    637646function energyTransfer(cr1, cr2)
    638647{
    639         cr1.localDrive = XYZ.new(0,0,0);
     648        cr1.drive = XYZ.new(0,0,0);
    640649        var e =  ExpProperties.feedtrans*cr1.energy*ExpProperties.secPerStep; //TODO efficiency dependent on age
    641650        //Simulator.print("transferring "+e +"("+e*ExpProperties.ingestion+")"+" to "+cr1.name +" ("+ cr1.energy+") " +" from "+cr2.uid+" ("+cr2.energy+") "+ e/ExpProperties.secPerStep+ " per sec");
  • experiments/frams/foraminifera/data/scripts/foraminifera.inc

    r593 r595  
    275275{
    276276        curColor = colors[1-parent_lifeparams->gen];
    277         var cr = Populations[0].add(geno);
     277        var cr = createAndRotate(geno, 0, 2*Math.pi, 0);
    278278        cr.energy0 = energy;
    279279        cr.energy = cr.energy0;
Note: See TracChangeset for help on using the changeset viewer.