Sample State Transitions
Learn about thesample state transitions.
Object’s life cycle
Let’s look at the life cycles of Sample
objects. An object’s life cycle starts with object creation, then state changes, and (in some cases) the end of its processing life when there are no more references to it. We have three scenarios:
Initial load
We’ll need a load()
method to populate a TrainingData
object from some source of raw data. We can imagine a load()
method using a CSV reader to create Sample
objects with a species value, making them KnownSample
objects. The load()
method splits the KnownSample
objects into the training and testing lists, which is an important state change for a TrainingData
object.
Hyperparameter testing
We’ll need a test()
method in
the Hyperparameter
class. The body of the test()
method works with the test samples in the associated TrainingData
object. For each sample, it applies the classifier and counts the matches between botanist-assigned species and the best guess of our AI algorithm. This points out the need for a classify()
method for a single sample that’s used by the test()
method for a batch of samples. The test()
method will update the state of the Hyperparameter
object by setting the quality score.
User-initiated classification
A RESTful web application is often decomposed into separate view functions to handle requests. When handling a request to classify an unknown sample, the view()
function will have a Hyperparameter
object used for classification; the Botanist will choose this to produce the best results. The user input will be an UnknownSample
instance. The view()
function applies the Hyperparameter.classify()
method to create a response to the user with the species the iris has been classed as. Does the state change that happens when the AI classifies an UnknownSample
really matter? Here are two views:
-
Each
UnknownSample
can have aclassified
attribute. Setting this is a change in the state of theSample
. It’s not clear that there’s any behavior change associated with this state change. -
The classification result is not part of the
Sample
at all. It’s a local variable in theview
function. This state change in the function is used to respond to the user but has no life within theSample
object.
There’s a key concept underlying this detailed decomposition of these alternatives:
Explication for updated UML
Some design decisions are based on non-functional and non-technical considerations. These might include the longevity of the application, future use cases, additional users who might be enticed, current schedules and budgets, pedagogical value, technical risk, the creation of intellectual property, and how cool the demo will look in a conference call.
It’s better to start with something of a manageable level of complexity and then refine and expand it until it does everything they need."
Because of that, we’ll consider a change in state from UnknownSample
to ClassifiedSample
to be very important. The Sample
objects will live in a database for additional marketing campaigns or possibly reclassification when new products are available and the training data changes.
We’ll decide to keep the classification and the species data in the UnknownSample
class.
This analysis suggests we can coalesce all the various Sample details into the following design:
Get hands-on with 1300+ tech skills courses.