in java could you showme how to build the UML diagrams, i have more to add to this but just confusedon how this all works together

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

in java could you showme how to build the UML diagrams, i have more to add to this but just confusedon how this all works together

Some comments on the Board class :
●
numLiveCell() and nextGen() are both abstract methods
When setBoard() is creating cells it uses the values of alive and dead in the cell
constructor as well as the value of s.
The Life and automata classes are very simple nearly identical.
Life
+Life(r:int, c:int, alive :char, dead :char)
automata
+automata (r:int, c:int, alive :char, dead This constructor calls the superclass constructor
:char)
This constructor calls the superclass constructor
Don't forget that both classes must also implement the abstract methods numLiveCell() and
nextGen()
Your main method will need to do the following:
1. prompt the user for the name of the file that contains configuration data
2. Read the configuration data from the file (you will need a FILE /SCANNER object)
3. create and initialize the board (Life or automata)
4. display all generations
The configuration file must have the following format:
1. the first line has three integers: number of rows (set it to 1 for automata), number
of columns and the number of generations to display
2. the second (and remaining lines) contain the initial configuration of live cells
here are two example files; one for the 1-D and another for the 2-D :
1 200 60
***** ******* **** *****
********
30 30 100
the initial configuration data in the file should be interpreted as follows:
each line give the configuration for a row of the board. A * in a certain column means that the
cell at that row and column location is alive; a space ('') means the cell is dead. If you have
fewer lines in the file than rows in your board, you can assume that the remaining rows have
all dead cells. If a particular row has fewer characters than the number of columns, once again
you can set the state of all remaining cells in that row to dead.
Transcribed Image Text:Some comments on the Board class : ● numLiveCell() and nextGen() are both abstract methods When setBoard() is creating cells it uses the values of alive and dead in the cell constructor as well as the value of s. The Life and automata classes are very simple nearly identical. Life +Life(r:int, c:int, alive :char, dead :char) automata +automata (r:int, c:int, alive :char, dead This constructor calls the superclass constructor :char) This constructor calls the superclass constructor Don't forget that both classes must also implement the abstract methods numLiveCell() and nextGen() Your main method will need to do the following: 1. prompt the user for the name of the file that contains configuration data 2. Read the configuration data from the file (you will need a FILE /SCANNER object) 3. create and initialize the board (Life or automata) 4. display all generations The configuration file must have the following format: 1. the first line has three integers: number of rows (set it to 1 for automata), number of columns and the number of generations to display 2. the second (and remaining lines) contain the initial configuration of live cells here are two example files; one for the 1-D and another for the 2-D : 1 200 60 ***** ******* **** ***** ******** 30 30 100 the initial configuration data in the file should be interpreted as follows: each line give the configuration for a row of the board. A * in a certain column means that the cell at that row and column location is alive; a space ('') means the cell is dead. If you have fewer lines in the file than rows in your board, you can assume that the remaining rows have all dead cells. If a particular row has fewer characters than the number of columns, once again you can set the state of all remaining cells in that row to dead.
state s ;
int x = 0;
if(0 == x)
S = state. DEAD; //access values via type name
else s state.ALIVE;
Lets start with the Cell class. Here is the the UML class diagram for it:
Cell
-s: state
-alive :char
-dead : char
+Cell(s:state)
+Cell(s:state, alive :char, dead :char)
+getState(): state
+setState(s:state) : void
+Draw(): void
Next we have the abstract class Board
Board
#curr : Cell[][]
#alive :char
#dead : char
// you can create a variable
// of the enumurated type
+setBoard (s:state) : void
+setCell(i :int, j : int, c: Cell): void
+getCell(i :int, j: int) :Cell
+Draw(): void
+numLiveCell((i :int, j : int) : int
+nextGen():void
The state of the cell
Character to draw on screen if cell is alive (default='#')
Character to draw on screen if cell is dead (default='')
Constructs a cell with the given state and default chars
Constructs a cell with the given state and characters
Returns state of cell
Sets state of cell.
Draw method implementation of Drawable interface
+Board(r:int; c:int)
Creates array curr with r rows and c columns
+Board (r:int, c:int, alive :char, dead :char) Like above but also changes printing characters
Creates and sets the state of ALL cells in curr to s.
A 2-D array used to represent the board (or row)
Character to draw on screen if cell is alive (default='#')
Character to draw on screen if cell is dead (default='')
Changes reference at curr[i][j] to c
Returns reference to cell found at curr[i][j]
Draw method implementation of Drawable interface
How many live cells exist around cell at curr[i][j]
Computes new generation based on old
Transcribed Image Text:state s ; int x = 0; if(0 == x) S = state. DEAD; //access values via type name else s state.ALIVE; Lets start with the Cell class. Here is the the UML class diagram for it: Cell -s: state -alive :char -dead : char +Cell(s:state) +Cell(s:state, alive :char, dead :char) +getState(): state +setState(s:state) : void +Draw(): void Next we have the abstract class Board Board #curr : Cell[][] #alive :char #dead : char // you can create a variable // of the enumurated type +setBoard (s:state) : void +setCell(i :int, j : int, c: Cell): void +getCell(i :int, j: int) :Cell +Draw(): void +numLiveCell((i :int, j : int) : int +nextGen():void The state of the cell Character to draw on screen if cell is alive (default='#') Character to draw on screen if cell is dead (default='') Constructs a cell with the given state and default chars Constructs a cell with the given state and characters Returns state of cell Sets state of cell. Draw method implementation of Drawable interface +Board(r:int; c:int) Creates array curr with r rows and c columns +Board (r:int, c:int, alive :char, dead :char) Like above but also changes printing characters Creates and sets the state of ALL cells in curr to s. A 2-D array used to represent the board (or row) Character to draw on screen if cell is alive (default='#') Character to draw on screen if cell is dead (default='') Changes reference at curr[i][j] to c Returns reference to cell found at curr[i][j] Draw method implementation of Drawable interface How many live cells exist around cell at curr[i][j] Computes new generation based on old
Expert Solution
steps

Step by step

Solved in 2 steps

Blurred answer
Knowledge Booster
Top down approach design
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education