Update code
This commit is contained in:
@@ -33,7 +33,6 @@ sequenceDiagram
|
|||||||
System->>Fingrid API: Get data
|
System->>Fingrid API: Get data
|
||||||
Fingrid API-->>System: Return data
|
Fingrid API-->>System: Return data
|
||||||
System->>Files: Store data in files
|
System->>Files: Store data in files
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
- The system provides a view of the power plant's energy generation and storage capacity, allowing operators to adjust the power plant's operation as needed. This view shows the data stored in the file.
|
- The system provides a view of the power plant's energy generation and storage capacity, allowing operators to adjust the power plant's operation as needed. This view shows the data stored in the file.
|
||||||
@@ -119,5 +118,7 @@ classDiagram
|
|||||||
+alertUser()
|
+alertUser()
|
||||||
+scanSystem(data: List[String])
|
+scanSystem(data: List[String])
|
||||||
}
|
}
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Video
|
||||||
|
|
||||||
|
|||||||
@@ -88,6 +88,7 @@ object Main {
|
|||||||
): Unit = {
|
): Unit = {
|
||||||
// Read the energy sources
|
// Read the energy sources
|
||||||
println("Reading sources...")
|
println("Reading sources...")
|
||||||
|
try {
|
||||||
val bufferedSource = Source.fromFile(energySources)
|
val bufferedSource = Source.fromFile(energySources)
|
||||||
def readSourcesHelper(lines: Iterator[String]): Unit = {
|
def readSourcesHelper(lines: Iterator[String]): Unit = {
|
||||||
if (lines.hasNext) {
|
if (lines.hasNext) {
|
||||||
@@ -99,6 +100,11 @@ object Main {
|
|||||||
}
|
}
|
||||||
readSourcesHelper(bufferedSource.getLines)
|
readSourcesHelper(bufferedSource.getLines)
|
||||||
bufferedSource.close
|
bufferedSource.close
|
||||||
|
} catch {
|
||||||
|
case e: Exception =>
|
||||||
|
println("No sources found")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
print("Enter your choice:\n1) Modify\n2) Exit\n")
|
print("Enter your choice:\n1) Modify\n2) Exit\n")
|
||||||
val choice = readLine()
|
val choice = readLine()
|
||||||
@@ -266,6 +272,7 @@ object Main {
|
|||||||
"Sources:\n1) Wind\n2) Hydro\n3) Nuclear\n4) All\n5) Exit\nEnter your choice: "
|
"Sources:\n1) Wind\n2) Hydro\n3) Nuclear\n4) All\n5) Exit\nEnter your choice: "
|
||||||
)
|
)
|
||||||
val choice = readLine()
|
val choice = readLine()
|
||||||
|
try {
|
||||||
val bufferedSource = choice match {
|
val bufferedSource = choice match {
|
||||||
case "1" =>
|
case "1" =>
|
||||||
Source.fromFile("wind.csv")
|
Source.fromFile("wind.csv")
|
||||||
@@ -284,6 +291,11 @@ object Main {
|
|||||||
val data = bufferedSource.getLines.toList
|
val data = bufferedSource.getLines.toList
|
||||||
bufferedSource.close
|
bufferedSource.close
|
||||||
data
|
data
|
||||||
|
} catch {
|
||||||
|
case e: Exception =>
|
||||||
|
println("File not found")
|
||||||
|
null
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sort the data by timestamp or value
|
// Sort the data by timestamp or value
|
||||||
@@ -360,6 +372,7 @@ object Main {
|
|||||||
|
|
||||||
// Alert user if energy production is below the threshold
|
// Alert user if energy production is below the threshold
|
||||||
def alertUser(): Unit = {
|
def alertUser(): Unit = {
|
||||||
|
try {
|
||||||
val sources = dataSources.values.toList.dropRight(1)
|
val sources = dataSources.values.toList.dropRight(1)
|
||||||
sources.map { source =>
|
sources.map { source =>
|
||||||
val bufferedSource = Source.fromFile(source)
|
val bufferedSource = Source.fromFile(source)
|
||||||
@@ -376,10 +389,14 @@ object Main {
|
|||||||
}
|
}
|
||||||
if (alert) {
|
if (alert) {
|
||||||
println(
|
println(
|
||||||
s"ALERT: ${source} has production values below the threshold of ${alertThreshold}MW. Please scan systems for details!"
|
s"ALERT: ${source} has production values below the threshold of ${alertThreshold}MW. Please scan system for details!"
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} catch {
|
||||||
|
case e: Exception =>
|
||||||
|
return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Scan data for anomalies
|
// Scan data for anomalies
|
||||||
|
|||||||
Reference in New Issue
Block a user