Arduino: incorrect calculation of long integer
I'm doing a simple calculation with integers (on Arduino with ESP8266 12E), but I can't get the expected result and can't find the error. Can someone guide me?
#define A 200
#define B A * 62
#define C 500
void setup() {
Serial.begin(9600);
Serial.println("");
unsigned long aux = 0;
aux = (B * 500) / C; // (12400 * 500) / 500 = 12400
Serial.printf("aux = %dn", aux);
aux = aux * C; // 12400 * 500 = 6200000
Serial.printf("aux = %dn", aux);
// ERROR: Should result in "500", but is resulting in "1922000"
aux = aux / B; // 6200000 / 12400 = 500
Serial.printf("aux = %dn", aux); // It's printing "1922000"
}
esp8266
migrated from electronics.stackexchange.com 17 mins ago
This question came from our site for electronics and electrical engineering professionals, students, and enthusiasts.
add a comment |
I'm doing a simple calculation with integers (on Arduino with ESP8266 12E), but I can't get the expected result and can't find the error. Can someone guide me?
#define A 200
#define B A * 62
#define C 500
void setup() {
Serial.begin(9600);
Serial.println("");
unsigned long aux = 0;
aux = (B * 500) / C; // (12400 * 500) / 500 = 12400
Serial.printf("aux = %dn", aux);
aux = aux * C; // 12400 * 500 = 6200000
Serial.printf("aux = %dn", aux);
// ERROR: Should result in "500", but is resulting in "1922000"
aux = aux / B; // 6200000 / 12400 = 500
Serial.printf("aux = %dn", aux); // It's printing "1922000"
}
esp8266
migrated from electronics.stackexchange.com 17 mins ago
This question came from our site for electronics and electrical engineering professionals, students, and enthusiasts.
add a comment |
I'm doing a simple calculation with integers (on Arduino with ESP8266 12E), but I can't get the expected result and can't find the error. Can someone guide me?
#define A 200
#define B A * 62
#define C 500
void setup() {
Serial.begin(9600);
Serial.println("");
unsigned long aux = 0;
aux = (B * 500) / C; // (12400 * 500) / 500 = 12400
Serial.printf("aux = %dn", aux);
aux = aux * C; // 12400 * 500 = 6200000
Serial.printf("aux = %dn", aux);
// ERROR: Should result in "500", but is resulting in "1922000"
aux = aux / B; // 6200000 / 12400 = 500
Serial.printf("aux = %dn", aux); // It's printing "1922000"
}
esp8266
I'm doing a simple calculation with integers (on Arduino with ESP8266 12E), but I can't get the expected result and can't find the error. Can someone guide me?
#define A 200
#define B A * 62
#define C 500
void setup() {
Serial.begin(9600);
Serial.println("");
unsigned long aux = 0;
aux = (B * 500) / C; // (12400 * 500) / 500 = 12400
Serial.printf("aux = %dn", aux);
aux = aux * C; // 12400 * 500 = 6200000
Serial.printf("aux = %dn", aux);
// ERROR: Should result in "500", but is resulting in "1922000"
aux = aux / B; // 6200000 / 12400 = 500
Serial.printf("aux = %dn", aux); // It's printing "1922000"
}
esp8266
esp8266
asked 2 hours ago
wBB
1133
1133
migrated from electronics.stackexchange.com 17 mins ago
This question came from our site for electronics and electrical engineering professionals, students, and enthusiasts.
migrated from electronics.stackexchange.com 17 mins ago
This question came from our site for electronics and electrical engineering professionals, students, and enthusiasts.
add a comment |
add a comment |
2 Answers
2
active
oldest
votes
In your #define of B you missed parenthesis (). Change your definition to:
#define B (A * 62)
Without parenthesis you first divide 6200000 by 200 and then multiply result by 62, which is not what you intend.
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
add a comment |
Fully-parenthesizing macros (as noted in answer by dmz) solves one class of problem.
Another thing you should do is, in any arithmetic expression which involves literal constants, use the L
suffix on at least one of the constants involved if there's any chance the result will exceed 32767 (the maximum guaranteed-representable value for int
). The type of an arithmetic operation in C is based on the types of the operands of that operation only; the type of the variable to which the result is assigned is irrelevant.
1
...and the format specifier for anunsigned long
is%lu
not%d
- the compiler for the asker's esp8266 uses a 32-bitint
so they get away with some things they would not on an ATmega-based Arduino where anint
is the minimum 16 bit size allowed by the specification.
– Chris Stratton
32 mins ago
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
return StackExchange.using("schematics", function () {
StackExchange.schematics.init();
});
}, "cicuitlab");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "540"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2farduino.stackexchange.com%2fquestions%2f60097%2farduino-incorrect-calculation-of-long-integer%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
2 Answers
2
active
oldest
votes
2 Answers
2
active
oldest
votes
active
oldest
votes
active
oldest
votes
In your #define of B you missed parenthesis (). Change your definition to:
#define B (A * 62)
Without parenthesis you first divide 6200000 by 200 and then multiply result by 62, which is not what you intend.
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
add a comment |
In your #define of B you missed parenthesis (). Change your definition to:
#define B (A * 62)
Without parenthesis you first divide 6200000 by 200 and then multiply result by 62, which is not what you intend.
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
add a comment |
In your #define of B you missed parenthesis (). Change your definition to:
#define B (A * 62)
Without parenthesis you first divide 6200000 by 200 and then multiply result by 62, which is not what you intend.
In your #define of B you missed parenthesis (). Change your definition to:
#define B (A * 62)
Without parenthesis you first divide 6200000 by 200 and then multiply result by 62, which is not what you intend.
answered 2 hours ago
dmz
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
add a comment |
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
Dude, you're 100% right. I've spent several hours trying to figure out what was wrong ... Thank you so much!
– wBB
2 hours ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
@wBB remember that in C, macros are replaced in the code, exactly as you wrote them, in the preprocessor step before the code gets compiled. So it helps as a sanity-check in these cases to expand the macros yourself in your code to see if you're getting what you intended.
– brhans
1 hour ago
add a comment |
Fully-parenthesizing macros (as noted in answer by dmz) solves one class of problem.
Another thing you should do is, in any arithmetic expression which involves literal constants, use the L
suffix on at least one of the constants involved if there's any chance the result will exceed 32767 (the maximum guaranteed-representable value for int
). The type of an arithmetic operation in C is based on the types of the operands of that operation only; the type of the variable to which the result is assigned is irrelevant.
1
...and the format specifier for anunsigned long
is%lu
not%d
- the compiler for the asker's esp8266 uses a 32-bitint
so they get away with some things they would not on an ATmega-based Arduino where anint
is the minimum 16 bit size allowed by the specification.
– Chris Stratton
32 mins ago
add a comment |
Fully-parenthesizing macros (as noted in answer by dmz) solves one class of problem.
Another thing you should do is, in any arithmetic expression which involves literal constants, use the L
suffix on at least one of the constants involved if there's any chance the result will exceed 32767 (the maximum guaranteed-representable value for int
). The type of an arithmetic operation in C is based on the types of the operands of that operation only; the type of the variable to which the result is assigned is irrelevant.
1
...and the format specifier for anunsigned long
is%lu
not%d
- the compiler for the asker's esp8266 uses a 32-bitint
so they get away with some things they would not on an ATmega-based Arduino where anint
is the minimum 16 bit size allowed by the specification.
– Chris Stratton
32 mins ago
add a comment |
Fully-parenthesizing macros (as noted in answer by dmz) solves one class of problem.
Another thing you should do is, in any arithmetic expression which involves literal constants, use the L
suffix on at least one of the constants involved if there's any chance the result will exceed 32767 (the maximum guaranteed-representable value for int
). The type of an arithmetic operation in C is based on the types of the operands of that operation only; the type of the variable to which the result is assigned is irrelevant.
Fully-parenthesizing macros (as noted in answer by dmz) solves one class of problem.
Another thing you should do is, in any arithmetic expression which involves literal constants, use the L
suffix on at least one of the constants involved if there's any chance the result will exceed 32767 (the maximum guaranteed-representable value for int
). The type of an arithmetic operation in C is based on the types of the operands of that operation only; the type of the variable to which the result is assigned is irrelevant.
answered 35 mins ago
mlp
101
101
1
...and the format specifier for anunsigned long
is%lu
not%d
- the compiler for the asker's esp8266 uses a 32-bitint
so they get away with some things they would not on an ATmega-based Arduino where anint
is the minimum 16 bit size allowed by the specification.
– Chris Stratton
32 mins ago
add a comment |
1
...and the format specifier for anunsigned long
is%lu
not%d
- the compiler for the asker's esp8266 uses a 32-bitint
so they get away with some things they would not on an ATmega-based Arduino where anint
is the minimum 16 bit size allowed by the specification.
– Chris Stratton
32 mins ago
1
1
...and the format specifier for an
unsigned long
is %lu
not %d
- the compiler for the asker's esp8266 uses a 32-bit int
so they get away with some things they would not on an ATmega-based Arduino where an int
is the minimum 16 bit size allowed by the specification.– Chris Stratton
32 mins ago
...and the format specifier for an
unsigned long
is %lu
not %d
- the compiler for the asker's esp8266 uses a 32-bit int
so they get away with some things they would not on an ATmega-based Arduino where an int
is the minimum 16 bit size allowed by the specification.– Chris Stratton
32 mins ago
add a comment |
Thanks for contributing an answer to Arduino Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2farduino.stackexchange.com%2fquestions%2f60097%2farduino-incorrect-calculation-of-long-integer%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown