Short Circuit Evaluation
In this chapter we are going to learn about the Short Circuit Evaluation
Introduction
We can create this program quickly using the Quick Start component
data:image/s3,"s3://crabby-images/c2d3f/c2d3f2429dc56b766f2b55fecdf9c7018803c5b7" alt="ib_quickstart_shortcircuitevaluation.png"
Program Steps
After selecting the (Short Circuit Evaluation) template, we will get the next steps in the Goal Designer
data:image/s3,"s3://crabby-images/3d2a0/3d2a0edb4e147d045acb6ab336c6ac2a85b93d78" alt="gd_quickstart_shortcircuitevaluation.png"
The Steps Tree:
x = 0
y = 10
Print Test 1 (New Line)
If (x = 0 AND nice()) AND (y = 10 AND nice())
Print Great (New Line)
End of IF Statement
Print Test 2 (New Line)
If (x = 1 AND nice()) AND (y = 10 AND nice())
Print Great (New Line)
End of IF Statement
Print Test 3 (New Line)
If (x = 0 AND nice()) OR (y = 10 AND nice())
Print Great (New Line)
End of IF Statement
function nice
Print Nice (New Line)
Return 1
End of Function
Creating the Program
To create this program we will use the next components
Assignment
Print Text
If Statement
Define Function
Return
In the begining the Steps Tree is empty
data:image/s3,"s3://crabby-images/ff7c3/ff7c3a603560d5df1ed271fe6d4a85c01682ae6c" alt="1.png"
Set x = 0 using the Assignment component
data:image/s3,"s3://crabby-images/895e3/895e3f949e8b9f17d26f051922559e19099ebe14" alt="2.png"
data:image/s3,"s3://crabby-images/9f8cd/9f8cdbf721a5c1dfe9e782819cced324c1c232eb" alt="3.png"
data:image/s3,"s3://crabby-images/e1ff1/e1ff1a0be222a8d8c6c5643d3a289ea7b7c04909" alt="4.png"
Set y = 10 using the Assignment component
data:image/s3,"s3://crabby-images/c9e73/c9e733cfe4046af6af275edc8ae47c59b5f6e278" alt="5.png"
data:image/s3,"s3://crabby-images/2d0eb/2d0eba3e5bf8b5049c755d512775938da237e302" alt="6.png"
data:image/s3,"s3://crabby-images/03623/03623c5af9e22ef41e7acf3e669b3ef61c089f88" alt="7.png"
Print (Test 1)
data:image/s3,"s3://crabby-images/9b00e/9b00e2009c686889ce52def68d6c097bc5e70fa7" alt="8.png"
data:image/s3,"s3://crabby-images/e5f26/e5f26fa72aa3f883f92ee6938b067f2fbbfcf2be" alt="9.png"
data:image/s3,"s3://crabby-images/972a6/972a6a563e50c1c40c9b718f1312509c944b2ca9" alt="10.png"
Test the condition: (x = 0 AND nice()) AND (y = 10 AND nice())
data:image/s3,"s3://crabby-images/746ad/746adc8f9bcdaaf035c136ed375186c54ddcb28a" alt="11.png"
data:image/s3,"s3://crabby-images/c7e4f/c7e4f13fec433e0c2ef3046a1911b31fa1a79d6a" alt="12.png"
data:image/s3,"s3://crabby-images/b5b1c/b5b1c0b2fe45815eef437c6ab85fe9a347fbe5f7" alt="13.png"
Print (Great)
data:image/s3,"s3://crabby-images/58495/58495b65dd7aa2112af88448d6f9e0dfead6a0d3" alt="14.png"
data:image/s3,"s3://crabby-images/dc968/dc968060377b73e557fc5a0fc452ba75c496cb6c" alt="15.png"
data:image/s3,"s3://crabby-images/c7ed2/c7ed24c2aec61f11929a3d015a9668a41ddd17ef" alt="16.png"
Print (Test 2)
data:image/s3,"s3://crabby-images/8fb46/8fb464900a9e01decd5ac2f9a1f0f403ea0d903a" alt="17.png"
data:image/s3,"s3://crabby-images/3f6ac/3f6ac8317de07edc3b8750eebcd8e4a9e9530c3c" alt="18.png"
data:image/s3,"s3://crabby-images/78ae9/78ae9d24d04059ebc1c03f5d8a53df2b2fd69db7" alt="19.png"
Check the condition: (x = 1 AND nice()) AND (y = 10 AND nice())
data:image/s3,"s3://crabby-images/aac03/aac03d813f08d00cbe72b52374d0fd0af4ec1860" alt="20.png"
data:image/s3,"s3://crabby-images/70d41/70d4160c1191927ddaf3e220deb85022c3fb268b" alt="21.png"
data:image/s3,"s3://crabby-images/20e71/20e71a1b208636c9ead65a1c2b6dc633e919c337" alt="22.png"
Print (Great)
data:image/s3,"s3://crabby-images/4e7b8/4e7b82688d3cdae1fdc82a7d74bfad86e2008cfa" alt="23.png"
data:image/s3,"s3://crabby-images/fb6c9/fb6c9a205b5b74845d0d8c871ee94ec8a7d94f9d" alt="24.png"
data:image/s3,"s3://crabby-images/5a1a8/5a1a8f5bfdb05ae9a0d1a838b220b3921161f2ed" alt="25.png"
Print (Test 3)
data:image/s3,"s3://crabby-images/48052/4805249a69a7c30e5fa95680a20854170b0a59ce" alt="26.png"
data:image/s3,"s3://crabby-images/71249/71249728b34831107a2b4f8eb3486a736543bd0e" alt="27.png"
data:image/s3,"s3://crabby-images/44dae/44dae69d467970bf9bbbd8d5af72f671192479ec" alt="28.png"
Check the condition: (x = 0 AND nice()) OR (y = 10 AND nice())
data:image/s3,"s3://crabby-images/fc5dd/fc5dd2c8a514cb7daa30fbaf7a4d6e605a7da4de" alt="29.png"
data:image/s3,"s3://crabby-images/c654e/c654e719955fe3d34927e1cc9f72be76e8f96327" alt="30.png"
data:image/s3,"s3://crabby-images/93088/93088474768a5bc19e97b111f89acd48a844e141" alt="31.png"
Print (Great)
data:image/s3,"s3://crabby-images/f8d51/f8d51188ce3a13931491702282eabb38b8433867" alt="32.png"
data:image/s3,"s3://crabby-images/b5aa8/b5aa83f5d6bc40ba6dcc6e572ff190fff1bb10e7" alt="33.png"
data:image/s3,"s3://crabby-images/98724/987245a11a4a2be4d863721011f28120212c9d31" alt="34.png"
Define the (Nice) function
data:image/s3,"s3://crabby-images/2e3f7/2e3f7b61a33b4ca40fcd5d3c02eddd55d62fabe6" alt="35.png"
data:image/s3,"s3://crabby-images/9d19d/9d19d8641c41ccc42da23cfd8e4bf4e06e37666c" alt="36.png"
data:image/s3,"s3://crabby-images/44f23/44f2350a94e6518c3c0602d5d93be9115831995d" alt="37.png"
Print (Nice)
data:image/s3,"s3://crabby-images/9448a/9448a9d2d6860877565002517556700df38d88a8" alt="38.png"
data:image/s3,"s3://crabby-images/93e7e/93e7e35704d4a7afaacb7957c5eac651c9fdc744" alt="39.png"
data:image/s3,"s3://crabby-images/2cb3d/2cb3d2dccc65e7809762c831df0c2a6bd24cc4dd" alt="40.png"
Return (True) from the (Nice) function
data:image/s3,"s3://crabby-images/2935f/2935fe731e85a0b5464c39bc1408015257d3b6d7" alt="41.png"
data:image/s3,"s3://crabby-images/3f6c6/3f6c6f5466973b18ec4d7fbed0f4a6b0066b3c16" alt="42.png"
Now we have the final Steps Tree in our program
data:image/s3,"s3://crabby-images/dd39d/dd39d159a496c0a76e7bf1197da4158870086e84" alt="43.png"