Example #1
0
        public override void Execute_Simulation()
        {
            var simulation = new Simulation
            {
                Created = DateTime.Now, Name = "asd",
            };

            var voyage = new Voyage
            {
                Departing = DateTime.Today.AddDays(1),
                Orders = Scenario.Deliveries.Select(d=> d.Number).ToList()
            };
            simulation.Append_Voyage(voyage);

            var from = Scenario.Deliveries.First().Location;
            var to = Scenario.Deliveries.Last().Location;

            var current = from;
            var path = new List<Distance>();
            foreach (var delivery in Scenario.Deliveries.Skip(1))
            {
                if (delivery.Location == to)
                    break;

                var next = Scenario.Distances.Single(d => d.From == from && d.To == delivery.Location);
                path.Add(next);
                current = delivery.Location;
            }

            voyage.Extimated_Lenght_Km = path.Sum(p => p.Km);
            voyage.Exitmated_Time = path.Select(p => p.Time).Aggregate((a, b) => a + b);
        }
Example #2
0
        public override void Execute_Simulation()
        {
            var simulation = new Simulation
            {
                Created = DateTime.Now, Name = "asd",
            };

            var deliveries = Scenario.Deliveries.To_Queue();

            while(deliveries.Count() >0)
            {
                var usedDeliveries = deliveries.Dequeue(random.Next(Scenario.Deliveries.Count() % 4) + 1).ToList();

                var voyage = new Voyage
                {
                    Departing = DateTime.Today.AddDays(1),
                    Orders = usedDeliveries.Select(d => d.Number).ToList()
                };
                simulation.Append_Voyage(voyage);

                var from = usedDeliveries.First().Location;
                var to = usedDeliveries.Last().Location;

                var current = from;
                var path = new List<Distance>();
                if (usedDeliveries.Count == 1)
                    path.Add(new Distance { From= from, To = to });
                else
                    foreach (var delivery in usedDeliveries.Skip(1))
                    {
                        var next = Scenario.Distances.First(d => (d.From == from && d.To == delivery.Location) || (d.To == from && d.From == delivery.Location));
                        path.Add(next);
                        current = delivery.Location;

                        if (delivery.Location == to)
                            break;
                    }

                voyage.Extimated_Lenght_Km = path.Sum(p => p.Km);
                voyage.Exitmated_Time = path.Select(p => p.Time).Aggregate((a, b) => a + b);
            }
        }
Example #3
0
 public void Append_Simulation(Simulation simulation)
 {
     simulation.Number = _Simulations.Select(s=> s.Number).DefaultIfEmpty(0).Max() + 1;
     _Simulations.Add(simulation);
 }