Skip to content
GitLab
Menu
Projects
Groups
Snippets
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Menu
Open sidebar
Agriterix
simulator
Commits
b4fbc276
Commit
b4fbc276
authored
Sep 10, 2021
by
Dumoulin Nicolas
Browse files
Log for population dynamics and Logger API syntax enhancements
parent
6b753892
Pipeline
#40572
passed with stages
in 5 minutes and 19 seconds
Changes
2
Pipelines
1
Hide whitespace changes
Inline
Side-by-side
src/main/java/fr/inrae/agriterix/simulator/dynamics/DynamicsLogger.java
View file @
b4fbc276
...
...
@@ -19,7 +19,7 @@ public class DynamicsLogger {
private
String
separator
=
", "
;
private
String
path
=
"data/out"
;
public
DynamicsLogger
(
String
className
,
String
timeStamp
,
String
header
)
{
public
DynamicsLogger
(
String
className
,
String
timeStamp
,
String
...
header
s
)
{
try
{
Files
.
createDirectories
(
Paths
.
get
(
"data/out/"
+
timeStamp
+
"/logs/"
));
fileHandler
=
new
FileHandler
(
"data/out/"
+
timeStamp
+
"/logs/"
+
className
+
".csv"
,
false
);
...
...
@@ -29,7 +29,7 @@ public class DynamicsLogger {
logger
=
Logger
.
getLogger
(
className
);
logger
.
setUseParentHandlers
(
false
);
logger
.
addHandler
(
fileHandler
);
fileHandler
.
setFormatter
(
new
DynamicsLogFormatter
(
header
));
fileHandler
.
setFormatter
(
new
DynamicsLogFormatter
(
String
.
join
(
separator
,
header
s
)
));
}
...
...
@@ -41,6 +41,16 @@ public class DynamicsLogger {
logger
.
info
(
timestep
+
separator
+
message
);
}
public
void
log
(
int
timestep
,
Object
...
objects
)
{
StringBuilder
buffer
=
new
StringBuilder
();
buffer
.
append
(
timestep
);
for
(
Object
object
:
objects
)
{
buffer
.
append
(
separator
);
buffer
.
append
(
object
);
}
logger
.
info
(
buffer
.
toString
());
}
public
void
logQuantities
(
int
timestep
,
GeoArea
geoArea
,
Stocks
quantities
,
String
label
)
{
for
(
Map
.
Entry
<
Product
,
Float
>
quantity:
quantities
.
entrySet
())
{
logger
.
info
(
timestep
+
separator
+
geoArea
.
getLabel
()
+
separator
+
quantity
.
getKey
()
+
separator
...
...
src/main/java/fr/inrae/agriterix/simulator/dynamics/PopulationDynamicsByAgeClass.java
View file @
b4fbc276
...
...
@@ -55,6 +55,7 @@ public class PopulationDynamicsByAgeClass extends Dynamics {
idx
->
idx
>=
r_threshold
?
(
int
)
Math
.
round
(
r_factor
*
ageclasses
[
idx
])
:
0
).
toArray
();
transmission
.
process
(
context
,
geoAreas
,
farmers
,
installationsAges
,
retirements
);
logger
.
log
(
context
.
getTimestep
(),
farmers
.
size
(),
Arrays
.
stream
(
installations
).
sum
(),
Arrays
.
stream
(
retirements
).
sum
());
}
private
int
getAge
(
int
ageclass
)
{
...
...
@@ -63,7 +64,7 @@ public class PopulationDynamicsByAgeClass extends Dynamics {
@Override
public
void
initLogger
()
{
logger
=
new
DynamicsLogger
(
this
.
getClass
().
getSimpleName
(),
super
.
timeStamp
,
"
HEADER
"
);
logger
=
new
DynamicsLogger
(
this
.
getClass
().
getSimpleName
(),
super
.
timeStamp
,
"
Timestep"
,
"nb farmers"
,
"nb installations"
,
"nb retirements
"
);
}
@Override
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment