Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
BornAgain
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package Registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Terms and privacy
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
mlz
BornAgain
Commits
a71cff88
Commit
a71cff88
authored
3 years ago
by
Matthias Puchner
Browse files
Options
Downloads
Patches
Plain Diff
simplify sample validator; reduce SessionItem usage
parent
7d5bf210
No related branches found
No related tags found
1 merge request
!513
Refactor sample model
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
GUI/Model/Sample/SampleValidator.cpp
+32
-87
32 additions, 87 deletions
GUI/Model/Sample/SampleValidator.cpp
GUI/Model/Sample/SampleValidator.h
+4
-11
4 additions, 11 deletions
GUI/Model/Sample/SampleValidator.h
with
36 additions
and
98 deletions
GUI/Model/Sample/SampleValidator.cpp
+
32
−
87
View file @
a71cff88
...
...
@@ -19,19 +19,6 @@
#include
"GUI/Model/Sample/ParticleCoreShellItem.h"
#include
"GUI/Model/Sample/ParticleLayoutItem.h"
#include
<boost/polymorphic_cast.hpp>
using
boost
::
polymorphic_cast
;
using
boost
::
polymorphic_downcast
;
SampleValidator
::
SampleValidator
()
:
m_valid_sample
(
true
)
{}
void
SampleValidator
::
initValidator
()
{
m_validation_message
.
clear
();
m_valid_sample
=
true
;
}
void
SampleValidator
::
iterateItems
(
const
SessionItem
*
parentItem
)
{
for
(
const
SessionItem
*
child
:
parentItem
->
children
())
{
...
...
@@ -42,87 +29,45 @@ void SampleValidator::iterateItems(const SessionItem* parentItem)
void
SampleValidator
::
validateItem
(
const
SessionItem
*
item
)
{
if
(
!
item
)
return
;
QString
diagnosis
;
if
(
item
->
hasModelType
<
MultiLayerItem
>
())
diagnosis
=
validateMultiLayerItem
(
polymorphic_downcast
<
const
MultiLayerItem
*>
(
item
));
else
if
(
item
->
hasModelType
<
ParticleLayoutItem
>
())
{
diagnosis
=
validateParticleLayoutItem
(
polymorphic_downcast
<
const
ParticleLayoutItem
*>
(
item
));
}
else
if
(
item
->
hasModelType
<
ParticleCoreShellItem
>
())
{
diagnosis
=
validateParticleCoreShellItem
(
polymorphic_cast
<
const
ParticleCoreShellItem
*>
(
item
));
}
else
if
(
item
->
hasModelType
<
ParticleCompositionItem
>
())
{
diagnosis
=
validateParticleCompositionItem
(
polymorphic_cast
<
const
ParticleCompositionItem
*>
(
item
));
}
if
(
!
diagnosis
.
isEmpty
())
{
m_valid_sample
=
false
;
m_validation_message
+=
QString
(
"* "
)
+
diagnosis
+
"
\n
"
;
}
if
(
auto
*
p
=
dynamic_cast
<
const
ParticleCoreShellItem
*>
(
item
))
{
if
(
!
p
->
core
())
addMessage
(
"Core/shell particle doesn't have core defined."
);
if
(
!
p
->
shell
())
addMessage
(
"Core/shell particle doesn't have shell defined."
);
}
else
if
(
auto
*
p
=
dynamic_cast
<
const
ParticleCompositionItem
*>
(
item
))
if
(
p
->
particles
().
isEmpty
())
addMessage
(
"Particle composition doesn't have any particles."
);
}
QString
SampleValidator
::
validateMultiLayerItem
(
const
MultiLayerItem
*
ite
m
)
void
SampleValidator
::
addMessage
(
const
QString
&
m
)
{
QString
result
;
QVector
<
LayerItem
*>
layers
=
item
->
layers
();
if
(
layers
.
isEmpty
())
result
=
"MultiLayer should contain at least one layer."
;
else
if
(
layers
.
size
()
==
1
)
{
if
(
layers
.
front
()
->
layouts
().
isEmpty
())
result
=
"The single layer in your MultiLayer should contain ParticleLayout."
;
}
return
result
;
}
QString
SampleValidator
::
validateParticleLayoutItem
(
const
ParticleLayoutItem
*
item
)
{
QString
result
;
QVector
<
ItemWithParticles
*>
particles
=
item
->
particles
();
if
(
particles
.
isEmpty
())
result
=
"ParticleLayout doesn't contain any particles."
;
return
result
;
}
QString
SampleValidator
::
validateParticleCoreShellItem
(
const
ParticleCoreShellItem
*
item
)
{
QString
result
;
const
ParticleItem
*
core
=
item
->
core
();
const
ParticleItem
*
shell
=
item
->
shell
();
if
(
core
==
nullptr
||
shell
==
nullptr
)
result
=
"ParticleCoreShell doesn't have either core or shell defined."
;
return
result
;
}
QString
SampleValidator
::
validateParticleCompositionItem
(
const
ParticleCompositionItem
*
item
)
{
QString
result
;
if
(
item
->
particles
().
isEmpty
())
result
=
"ParticleComposition doesn't have any particles."
;
return
result
;
m_messages
+=
QString
(
"* "
)
+
m
+
"
\n
"
;
}
bool
SampleValidator
::
isValidMultiLayer
(
const
MultiLayerItem
*
multilayer
)
{
initValidato
r
();
m_messages
.
clea
r
();
validateItem
(
multilayer
);
iterateItems
(
multilayer
);
QVector
<
LayerItem
*>
layers
=
multilayer
->
layers
();
if
(
!
m_valid_sample
)
{
m_validation_message
=
"Can't setup DWBA simulation for given MultiLayer.
\n
"
+
m_validation_message
;
}
return
m_valid_sample
;
if
(
layers
.
isEmpty
())
addMessage
(
"MultiLayer should contain at least one layer."
);
if
(
layers
.
size
()
==
1
)
if
(
layers
.
front
()
->
layouts
().
isEmpty
())
addMessage
(
"The single layer in your MultiLayer should contain a particle layout."
);
for
(
auto
*
layer
:
layers
)
for
(
auto
*
layout
:
layer
->
layouts
())
{
if
(
layout
->
particles
().
isEmpty
())
addMessage
(
"Particle layout doesn't contain any particles."
);
for
(
auto
*
particle
:
layout
->
particles
())
{
validateItem
(
particle
);
iterateItems
(
particle
);
}
}
if
(
!
m_messages
.
isEmpty
())
m_messages
=
"Can't setup DWBA simulation for given MultiLayer.
\n
"
+
m_messages
;
return
m_messages
.
isEmpty
();
}
This diff is collapsed.
Click to expand it.
GUI/Model/Sample/SampleValidator.h
+
4
−
11
View file @
a71cff88
...
...
@@ -26,25 +26,18 @@ class ParticleLayoutItem;
//! Validates SampleModel for MultiLayerItem suitable for simulation
class
SampleValidator
{
public:
SampleValidator
();
bool
isValidMultiLayer
(
const
MultiLayerItem
*
multilayer
);
QString
getValidationMessage
()
const
{
return
m_
validation_
message
;
}
QString
getValidationMessage
()
const
{
return
m_message
s
;
}
private
:
void
initValidator
();
void
iterateItems
(
const
SessionItem
*
parentItem
);
void
validateItem
(
const
SessionItem
*
item
);
QString
validateMultiLayerItem
(
const
MultiLayerItem
*
item
);
QString
validateParticleLayoutItem
(
const
ParticleLayoutItem
*
item
);
QString
validateParticleCoreShellItem
(
const
ParticleCoreShellItem
*
item
);
QString
validateParticleCompositionItem
(
const
ParticleCompositionItem
*
item
);
//! Adds this message to the report.
void
addMessage
(
const
QString
&
m
);
bool
m_valid_sample
;
QString
m_validation_message
;
QString
m_messages
;
};
#endif // BORNAGAIN_GUI_MODEL_SAMPLE_SAMPLEVALIDATOR_H
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment