Introduction
data:image/s3,"s3://crabby-images/3240e/3240e024e7c9ce7e2fb6e9524fd783c604d5922d" alt="1/38 Introduction"
data:image/s3,"s3://crabby-images/4cd2e/4cd2e6c4b6eaa38abcf3e97d2bd0465e4633415a" alt="2/38 Introduction"
Welcome to Designing Adaptable ML systems.
data:image/s3,"s3://crabby-images/afa35/afa356dedf47dd544a62ba6187066c8d3b48c1f2" alt="3/38 Introduction"
In this module, we’ll explore how to:
data:image/s3,"s3://crabby-images/5226c/5226c01d0cbc23d77609d203a11c8e648f1b0d2f" alt="4/38 Introduction"
Recognize the ways that a model is dependent on data
data:image/s3,"s3://crabby-images/b9d84/b9d84e86da0807575ae5fb28b1534f3de2e2d3e5" alt="5/38 Introduction"
Make cost-conscious engineering decisions
data:image/s3,"s3://crabby-images/5deb3/5deb31b0afd71f8d0524a4548b0ec564d72e23da" alt="6/38 Introduction"
Know when to roll back a model to an earlier version
data:image/s3,"s3://crabby-images/4e05e/4e05e55ff2fb2897bcf6aee9a0fcaaaa5f41c2d7" alt="7/38 Introduction"
Debug the causes of observed model behavior
data:image/s3,"s3://crabby-images/107a4/107a43fabe42f283c3b5161f77578c895c6be2cf" alt="8/38 Introduction"
Implement a pipeline that is immune to one type of dependency
data:image/s3,"s3://crabby-images/52d3d/52d3d90b2fcea6bce02a037e1fff63b19fc133ad" alt="9/38 Introduction"
In the 16th century, John Donne famously wrote in one of his poems that no man is an island.
data:image/s3,"s3://crabby-images/fe8d4/fe8d45d8382e500969a2241ed7463338e3d7c190" alt="10/38 Introduction"
He meant that human beings need to be part of a community to thrive.
data:image/s3,"s3://crabby-images/c9a02/c9a0288b4db6c88099904c1cde9ec7c91f345267" alt="11/38 Introduction"
In software engineering terms
data:image/s3,"s3://crabby-images/5f8b9/5f8b9e59eb581b066faf71b5ee783618cc2a4e83" alt="12/38 Introduction"
we would say that few software programs adopt a monolithic island-like design.
data:image/s3,"s3://crabby-images/629cc/629cc0683e7bbfba0260d6f6cc3e609e92017358" alt="13/38 Introduction"
Instead, most software today is modular, and depends on other software
data:image/s3,"s3://crabby-images/b3fd5/b3fd51f39c97430015fba498acad28ebf0b25836" alt="14/38 Introduction"
Modular programs are:
data:image/s3,"s3://crabby-images/66388/663885c3d2a012458ee35c555382838e27f0127f" alt="15/38 Introduction"
more maintainable,
data:image/s3,"s3://crabby-images/33ead/33eada1e835253ce7b143b722abb4226290e90c8" alt="16/38 Introduction"
as well as easier to reuse,
data:image/s3,"s3://crabby-images/1cc5b/1cc5b56183344750edce15c46a07bc9cbed389ed" alt="17/38 Introduction"
test,
data:image/s3,"s3://crabby-images/f9b34/f9b34828bd95ffd1f067f463fc4e36f400002a15" alt="18/38 Introduction"
and fix because they allow engineers to focus on small pieces of code rather than the entire program.
data:image/s3,"s3://crabby-images/a49ab/a49abb80ca980d04372ab1ac872fbfcd9916085e" alt="19/38 Introduction"
Containers make it easier to manage modular programs.
A container is an abstraction that packages applications and libraries together
data:image/s3,"s3://crabby-images/6932b/6932be4a2547f114db44f2e185cd96d2c4468441" alt="20/38 Introduction"
so that the applications can run on a greater variety of hardware and operating systems.
This ultimately makes hosting large applications better.
data:image/s3,"s3://crabby-images/edc11/edc11f0ce079e6aea5edaf9e426f3dd6263aaca2" alt="21/38 Introduction"
To learn more about Kubernetes, Google’s open source container orchestration software, check out the getting started with Google Kubernetes engine course.
data:image/s3,"s3://crabby-images/7c8fe/7c8fecf4463a71b56b1359b2bfbeed69ae263c38" alt="22/38 Introduction"
But what if there was no way to identify a specific version of a library
data:image/s3,"s3://crabby-images/c2664/c266471aabadf667d6590accc2b183a8ba1d877d" alt="23/38 Introduction"
and you had to rely on finding similar libraries at run-time?
data:image/s3,"s3://crabby-images/74778/74778bdcbe11a3621f3eca0ab24751eb795cf686" alt="24/38 Introduction"
Furthermore, what if someone else got to choose which version got run
data:image/s3,"s3://crabby-images/beec9/beec9b83b80698dcdd517b7506e095ab6bbbc7f3" alt="25/38 Introduction"
and they didn’t know or really care about your program?
data:image/s3,"s3://crabby-images/4f120/4f1203b066bf0ab135e60fe8624bc2d9c16cd990" alt="26/38 Introduction"
There would be no way of knowing what the run-time behavior would look like.
data:image/s3,"s3://crabby-images/cdaa5/cdaa51f05b2b63ceb1e55b7c12aa57bf6c3a3694" alt="27/38 Introduction"
Unfortunately, this is precisely the case for machine learning,
data:image/s3,"s3://crabby-images/4e82f/4e82f75b961d0e89f42ca5998533b99d62134e5a" alt="28/38 Introduction"
because the run-time instructions, for example, the model weights,
data:image/s3,"s3://crabby-images/98526/98526bd808d3f3ca4de7098b3a0492a45ae47bdc" alt="29/38 Introduction"
depend on the data that the model was trained on.
data:image/s3,"s3://crabby-images/5a637/5a637e0108ce50e26a2ddd37dbc995372893b8b2" alt="30/38 Introduction"
Additionally, similar data will yield similar instructions.
data:image/s3,"s3://crabby-images/7b5b2/7b5b22318ff8cd3b0743341b53c613452ebb1430" alt="31/38 Introduction"
And finally other people including other teams and our users create our data.
data:image/s3,"s3://crabby-images/4a909/4a909d994e66b619a18105f0d03b5fecc0d4d28f" alt="32/38 Introduction"
Just like in traditional software engineering, mismanaged dependencies say,
data:image/s3,"s3://crabby-images/62029/6202920ec5edb3ff4fc43a4856860ee7239b400c" alt="33/38 Introduction"
code that assumes one set of instructions, will be called
data:image/s3,"s3://crabby-images/f467b/f467b056b4ebf602d9e941bce7744c153ef60f92" alt="34/38 Introduction"
when another end up being called instead
data:image/s3,"s3://crabby-images/a38ec/a38ec74448e63cfb2faee6baf2dfa5a9ef355dc9" alt="35/38 Introduction"
can be expensive.
data:image/s3,"s3://crabby-images/d6bc2/d6bc2b93b73dda3d4c94ab4b6f30d5ef70bdc1d3" alt="36/38 Introduction"
Your models’ accuracy might go down or become unstable.
data:image/s3,"s3://crabby-images/abfe5/abfe5dd181d536d08ca08a1846b85619cc052001" alt="37/38 Introduction"
Sometimes, the errors are subtle and your team may end up spending a large proportion of its time debugging.
data:image/s3,"s3://crabby-images/4c8ea/4c8ea11ef5321fd3b0e80403ea323083b24d155c" alt="38/38 Introduction"