Skip to content

PGVSNH20/the-train-track-grupp3-net

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

82 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Project 2 - The train track

For the procedures used in this project see : Procedures

For the documentation by the team see: Documentation/readme.md

The train track

The goal of this project is to create a small train simulator (see suggested Getting started in the bottom).

The track consist if four stations, two end stations and two in-between, on separate tracks. Arial photo of the track

The trains on the track is controlled by the control tower where the operator (mr Carlos), makes sure the trains follows the time plan by starting and stopping the trains at the stations, the plan also controls the level crossing (the trains can't parse an open crossing thanks to the ETCS system) and the railroad switches (advanced).

The control tower

A level crossing and a railway switch

The track have currently two active trains going back and forward Golden Arrow and Lapplandståget, it has previously been operated by other trains, but these are no longer in service.

The two trains

Each train have a wagon with passengers, and these gets on and of at different stations.

There can only be one train at each station at the time. If there is currently not room for the train must it wait until the other train has left.

Your assignment

The project is parted into three parts, and the suggestion is to implement the project in the suggested order. Remember to create unit tests, where possible throughout the project.

Make sure to start simple, and then extend the program.

Part 1 - A fluent API to plan the trains

Produce a fluent API used by mr Carlos to manually plan the trains, it could maybe look something like this:

Train train1 = new Train("Name of train");
Station station1 = new Station("Gothenburg");
Station station2 = new Station("Stockholm");

ITravelPlan travelPlan = new TrainPlaner(train1, station1)
        .HeadTowards(station2)
        .StartTrainAt("10:23")
        .StopTrainAt(station2, "14:53")
    .GeneratePlan();

Part 2 - Develop an ORM for reading the data

Create your own mini ORM for the data provided.

It should also be possible to save and load a travel plan made using the Fluent API. You can choose to implement this in the data format you prefer (eg json)

travelPlan.Save("Data/travelplan-train1.txt"); //json, yaml, bin, csv
travelPlan.Load("Data/travelplan-train1.txt"); //json, yaml, bin, csv

Part 3 - Simulate train track

It should be possible to start the trains on the track, a bit like this:

// example Solution1
Train train1 = new Train1();
train1.Start(travelplan1);
train1.Stop(); // maybe not need

// example Solution2
travelplan1.Train.Start()
travelplan1.Train.Stop(); // maybe not needed

// example Solution3
ITravelPlan travelplan = TravelPlan.Load("file.travelplan");
travelplan.Simulate(fakeClock);

The though is that each train should have it's own thread running without the knowledge of other trains in the track. But aware of signals on the track. The train is automatically stopping at all stations but are signaled by Mr Carlos when to go on (according to the time table).

If you need the notion of length, assume that each track ( - ) in the trackfile is eg 10 km and the takes the train 1 min drive that distance.

Given

Some files are given in this repository.

Data

This folder contains five files (three different):

  • Stations (stations.txt): All trains stations on the track,

    • Read only (you need to implement writing of this file into the ORM)
    • columns separated by '|'
  • Trains (trains.txt): contains a list of trains, some trains are not active

    • Read only (you need to implement writing of this file into the ORM)
    • columns separated by ','
  • Train track, there is three versions of this file

    • Read only (you need to implement writing of this file into the ORM)

    • Elements in the file

      • The stations placement with ID eg: [1], [2]
      • The start station: *
      • Tracks: -, / and \
    • traintrack1.txt: Describes an absolute basic track consisting of just two stations

    • traintrack2.txt: A track with three stations and a level crossing.

      • Introduces Level crossing: =
    • traintrack3.txt: An advanced track with two parallel tracks.

      • Tracks, introduces: / and \
      • Railroad switches: < and >

Documentation

The folder initially only contains one file called readme.md, this file is more or less empty.

In this folder should you place digital representations of all documentation you do. Screenshots, photos (of CRC cards, mindmaps, diagrams).

Please make a link and descriptive text in the readme.md using the markdown notation:

# Our train project
What we have done can be explained by this mindmap.
![Mindmap of train track](mindmap.jpg)
Bla bla bla bla

Source

The source folder contains a solution with three projects. With a small code outline.

  • TrainEngine, .NET Standard 2.1, This project should contain all the logic of you program
  • TrainConsole, NET 5, This project is what starts when you start the project, is a console application
  • TrainEngine.Tests, .NET 5, This project should contain all of your automated tests

Getting started

This is some suggestions on how you can get started on this project:

  1. Discuss how to get started and describe you agreements in readme.md file in the Documentation folder
  2. Start be creating a very basic fluent API which can create a TravelPlan, eg: new TravelPlan().StartAt("station1", "10:30").ArriveAt("station2","12:30").GeneratePlan()
    • Remember unit tests
  3. Create ORM for reading the three files:
    • stations.txt
    • trains.txt
    • traintrack1.txt
    • Remember unit tests
  4. Implement possibility to read and save the TravelPlan
  5. Extend the ORM for the train track so it can handle traintrack2.txt
    • Remember unit tests
  6. If needed extend the fluent API so that it eg:
    • Takes a train track as input
    • Takes one or more trains as input
    • Takes can control the level crossing (to open or close)
    • Remember unit tests
  7. If needed implement a fake time, so that the simulation will not run for hours, it could be a class called Clock
  8. Implement a thread on one train or on the TravelPlan, so that the simulation of the TravelPlan following the time table can be simulated
  9. See that everything works (with one train)
  10. Go to advanced level:
    • Extend the ORM to support traintrack3.txt
    • Make sure the TravelPlan handles railroad switches
    • See that everything works (first with one train, then with two), and that the trains don't crash :)

About

the-train-track-grupp3-net created by GitHub Classroom

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages