Table of Contents
Introduction 2
Purpose of the system 2
Scope of the system 2
Major constraints 2
Definitions, acronyms, and abbreviations 2
Overview 3
Use case model 3
Brief Narrative Description 3
Constraints 4
Assumptions and dependencies 4
Specific requirements 5
Use case scenarios 5
Functional requirements 10
Non-functional requirements 11
Requirements traceability matrix 11
Appendix 11
Introduction
Purpose of the system
The purpose of our system is to allow from one to three players to play a game of Alien War. This will involve one user playing against the computer or multiple players playing against each other.
Scope of the system
Our system will consist of a video game developed with a graphical window interface. The system will be configured to allow one player to play against the computer. The option will also be made available for up to three players to play the game on multiple computers. There are three possible identifications for the players: the Earth, the Kranglons, and the Romulats.
In a one player game, the player is the Earth and the computer plays one of the alien vessels. In multiple player games, the players identifications will be determined by random selection. The alien spaceships and the Earth are divided into four sections. The alien players will determine which of these four sections represent their bridge, aft section, fore section, and the hold. The Earth player will determine which area will house the ground based lasers. In addition to ground based lasers, the Earth will have access to an undetectable satellite for alternative fire power.
The alien spaceships have 10,000 alien power units (APU) to allocate between their shields and their photon torpedoes. The Earth has 6,300 earth power units (EPU) to allocate between shields, satellite fire power, and ground based lasers. (1 EPU = 1 2/3 APU) The satellite EPU's must equal 1/10 the number given to the ground based lasers.
The game play begins when the first player selects their target. The destination of the shot (the section of the ship or Earth) and number of APU's or EPU's allocated must be determined. The target returns information to the enemy as to whether their shot was a hit or a miss. The alien firepower is accurate 50% of the time it fires at another alien ship and 25% accurate when firing against the Earth. The Earth's ground based lasers are 25% accurate when firing at the aliens. The satellite lasers are 50% accurate when firing. If the shot is a hit, the target's shields are diminished by 20% of the firepower allocated by the attacker.
The game continues in this manner until a player's shields have been reduced to zero. The player without shields remains active in the game until the enemy has determined the location of their hold. It will only take one APU to destroy the hold. The player may send a message of surrender at this time. The other players may accept the surrender or continue to fire on the ship and destroy it. (One additional hit will result in the ship blowing up.) Play continues until one player remains.
Major constraints
This system must work on Windows XP Pro. The system must have a graphical window interface. The prototype for this program must be submitted on May 3, 2004. The system must allow for multiple computer play.
Definitions, acronyms, and abbreviations
EPU – Earth Power Unit – determined to be the unit of power available to the Earth for battle purposes
APU – Alien Power Unit – determined to be the unit of power available to the Alien Spaceships for battle purposes
Kranglons – one of the warring Alien races
Romulats – one of the warring Alien races
Peeps - players
Overview
2.1 Use case model
2.1.1 Brief Narrative Description
Use case Initialization This initializes the game, the computer randomly decides if you are an alien race or the planet Earth. You also initialize the specifics of the game.
Use case Earth This is where you set your shields and your fire power if you are Earth.
Use case Alien This is where you set your shields and your fire power if you are an alien race.
Use case GameResults This is where at the end of the game it shows the results of what occurred during the game. Such as who won and who lost.
Use Case RoundResults This is where during game play it tells you whether or not you hit or missed the other combatants.
Use Case StatsScreen When a round is over, it shows you what APU's you have left if you are an alien race or EPU's you have left if you are the planet Earth.
Use case MovConfig After viewing the StatsScreen, you can choose how you
want to attack provided you have any APUs/EPUs left.
Use case Battle This is where the system will take the combatants' and /or computer's input and calculate who hit who and with what force.
2.2 Constraints
This program requires the computer to have an operating system of Windows XP or a compatible Linux OS. The computer must also have a Java virtual machine. The computer is required to have on-line capability. The system must be an interactive game allowing multiple users (up to 3) on multiple machines. The scheduled system completion date is May 3, 2003.
2.3 Assumptions and dependencies
The computer must work, and the user must have basic computer knowledge. The computer must also be networked to play multiple users.
Specific requirements
Use case scenarios
Use case: Initialization |
ID: UC1 |
Actors: Player |
Preconditions: |
Flow of Events:
<initializeEarth> <initializeAlienShip(s)> |
Alternative Flow:
|
Postconditions:
|
Extension use case: Earth |
ID: UC2 |
Actors: Player |
Preconditions:
|
Flow of Events:
|
Secondary Scenarios:
|
Postconditions:
|
Extension use case: Earth Secondary Scenario: invalidSatellitePowerUnit |
ID: UC3 |
Actors: Player |
Preconditions: |
Flow of Events:
|
Postconditions: |
Extension use case: Alien |
ID: UC4 |
Actors: Player |
Preconditions:
|
Flow of Events:
|
Postconditions:
|
Use case: Round Results |
ID: UC5 |
Actors: Player |
Preconditions:
|
Flow of Events:
|
Postconditions:
|
Use case: Game Results |
ID: UC6 |
Actors: Player |
Preconditions:
|
Flow of Events:
|
Postconditions:
|
Use case: StatsScreen |
ID: UC7 |
Actors: Player |
Preconditions:
|
Flow of Events:
|
Postconditions: |
Use case: MovConfig |
ID: UC8 |
Actors: Player |
Preconditions:
|
Flow of Events:
|
Postconditions: 1. The Player has decided all the elements necessary to make their move in the Battle. |
Use case: Battle |
ID: UC9 |
Actors: Player |
Preconditions: 1. The Player has selected the necessary options in UC8 to make their move. |
Flow of Events:
|
Postconditions:
|
3.2 Functional requirements
RF1 The Alien War System shall provide a means of entertainment for users in a graphical user environment.
RF2 The Alien War System shall automatically initialize any combatant objects (Earth and/or Alien spaceships) that are not initialized by a human player.
RF3 The Alien War System shall display a startup menu with a choice for number of players.
RF4 The Alien War System shall display interactive initialization screens for all combatants initialized by human players.
RF5 The Alien War System shall display statistical information during game play for each player.
RF6 The Alien War System shall display round results after each player takes a turn.
RF7 The Alien War System shall control any non-human player during game play.
RF8 The Alien War System shall display game results when there is only one combatant left during game play.
RF9 The Alien War System shall allow all users the ability to leave the game at any time during game play.
RF10 The Alien War System shall allow all users the ability to make strategic moves when setting up for a round of Battle.
3.3 Non-functional requirements
RN1 The Alien War System shall have a set time limit of 5 minutes for a Player to make a move during battle.
RN2 The Alien War System shall have graphical user interfaces that consist of several layers.
RN3 The Alien War System shall be written in the programming language Java.
RN4 The Alien War System shall be capable of multi-player interaction, though the maximum number of players is three through a network or the Internet.
3.4 Requirements traceability matrix
|
UC1 |
UC2 |
UC3 |
UC4 |
UC5 |
UC6 |
UC7 |
UC8 |
UC9 |
---|---|---|---|---|---|---|---|---|---|
RF1 |
|
|
|
|
|
|
|
|
x |
RF2 |
|
|
|
x |
|
|
|
|
|
RF3 |
x |
|
|
|
|
|
|
|
|
RF4 |
|
x |
x |
|
|
|
|
|
|
RF5 |
|
|
|
|
|
|
x |
|
|
RF6 |
|
|
|
|
x |
|
|
|
|
RF7 |
|
|
|
|
|
|
|
x |
|
RF8 |
|
|
|
|
|
x |
|
|
|
RF9 |
x |
|
|
|
|
|
|
|
|
RF10 |
|
|
|
|
|
|
|
x |
|
4. Appendix
Group Projects, Fries, Dr. T., February 2004.
Project Report – System Requirements Specification, Fries, T., February 2004.