Conditional if loop for addition of three consecutive numbers in app designer interface
3 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Greetings to all, I am trying to solve this code in app designer: If the sum of three consecutive numbers is >75 I should get the word 'OK' otherwise 'NO', this is the interface with the names and the respective code: thank you!
x1=app.EditField.Value
x2=app.EditField_2.Value
x3=app.EditField_3.Value
x4=app.EditField_4.Value
if x1+x2+x3>75
app.EditField_5.Value=disp('OK');
elseif x2+x3+x4>75
app.EditField_5.Value=disp('OK');
else app.EditField_5.Value=disp('NO');
end
0 commentaires
Réponses (2)
VBBV
le 28 Mai 2023
Modifié(e) : VBBV
le 28 Mai 2023
if (x1+x2+x3)>75
app.EditField_5.Value=disp('OK');
elseif (x2+x3+x4)>75
You need to use parenthesis ( ) in the if-else condition as shown
1 commentaire
Image Analyst
le 29 Mai 2023
Not needed. Addition takes place before >:
- Parentheses ()
- Transpose (.'), power (.^), complex conjugate transpose ('), matrix power (^)
- Power with unary minus (.^-), unary plus (.^+), or logical negation (.^~) as well as matrix power with unary minus (^-), unary plus (^+), or logical negation (^~).NoteAlthough most operators work from left to right, the operators (^-), (.^-), (^+), (.^+), (^~), and (.^~) work from second from the right to left. It is recommended that you use parentheses to explicitly specify the intended precedence of statements containing these operator combinations.
- Unary plus (+), unary minus (-), logical negation (~)
- Multiplication (.*), right division (./), left division (.\), matrix multiplication (*), matrix right division (/), matrix left division (\)
- Addition (+), subtraction (-)
- Colon operator (:)
- Less than (<), less than or equal to (<=), greater than (>), greater than or equal to (>=), equal to (==), not equal to (~=)
- Element-wise AND (&)
- Element-wise OR (|)
- Short-circuit AND (&&)
- Short-circuit OR (||)
Image Analyst
le 29 Mai 2023
Modifié(e) : Image Analyst
le 29 Mai 2023
Try it this way (untested and not using disp):
x1 = app.EditField.Value
x2 = app.EditField_2.Value
x3 = app.EditField_3.Value
x4 = app.EditField_4.Value
if x1 + x2 + x3 > 75
app.EditField_5.Value ='OK';
elseif x2 + x3 + x4 > 75
app.EditField_5.Value = 'OK';
else
app.EditField_5.Value = 'NO';
end
Or you can combine the first two:
x1 = app.EditField.Value
x2 = app.EditField_2.Value
x3 = app.EditField_3.Value
x4 = app.EditField_4.Value
if (x1 + x2 + x3 > 75) || (x2 + x3 + x4 > 75)
app.EditField_5.Value = 'OK';
else
app.EditField_5.Value = 'NO';
end
Attach your .mlapp file if you need more help.
2 commentaires
Image Analyst
le 30 Mai 2023
If this Answer solves your original question, then could you please click the "Accept this answer" link to award the answerer with "reputation points" for their efforts in helping you? They'd appreciate it. Thanks in advance. 🙂 Note: you can only accept one answer (so pick the best one) but you can click the "Vote" icon for as many Answers as you want. Voting for an answer will also award reputation points.
Voir également
Catégories
En savoir plus sur Matrix Indexing dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!