Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win

x
Solved

# Casting floating numbers

Posted on 2003-12-02
Medium Priority
441 Views
I am having trouble casting the following numbers. I am just trying print intergers. So, 1, 3, 42, 80, 4. If I cast those numbers to int, I have 1, 2, 41, 79, 4. Or is there any trick?

1.00021
3.00
42.00
80.00
4.00

Anybody has any idea?
0
Question by:dkim18
[X]
###### Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

• Help others & share knowledge
• Earn cash & points
• 6
• 5
• 5

LVL 19

Expert Comment

ID: 9861398
@dkim18:

> Anybody has any idea?

Casting as an Int truncates, but you want to round, so add .5 to it before the cast.
So try this:
int nVal = (int)(nFloat + 0.5f);

Hope That Helps,
Dex*
0

LVL 86

Assisted Solution

jkr earned 200 total points
ID: 9861418
>>If I cast those numbers to int, I have 1, 2, 41, 79, 4.

It seems that the display is not what the values actually are. Casting should always work, e.g.

float f = 80.00;
int n = (int) f;

However, you might have to take the machine accuracy (eps) into consideration, e.g.

#include <iostream>
#include <limits>

using namespace std;

float f = 80.00;
int n = (int) f + numeric_limits<float>::epsilon();
0

LVL 86

Expert Comment

ID: 9861428
>>Casting as an Int truncates, but you want to round, so add .5 to it before the cast.

Hm, wouldn't that make the following incorrect?

float f = 80.70;
int n = (int) f + 0.5f;
0

LVL 19

Expert Comment

ID: 9861508
@jkr:  Yes, what you listed is incorrect, but that's not what I said to do.  I said to do it like this:
int n = (int) (f + 0.5f);

Which works just fine.
0

LVL 86

Expert Comment

ID: 9861541
OK, then, what would be the result of

int n = (int) (88.70 + 0.5f);

?
0

LVL 19

Expert Comment

ID: 9861567
After that line, n will have the value of 89.

88.70 + 0.5 = 89.20, which, when truncated, gives you 89.

Am I missing something?

Dex*
0

LVL 86

Expert Comment

ID: 9861592
>>Am I missing something?

As the Q was about casting, not rounding...
0

LVL 19

Expert Comment

ID: 9861624
Yeah, that's true, and the question wasn't totally clear, but what I understood was that they expected 1, 3, 42, 80, 4 but were getting 1, 2, 41, 79, 4 instead...  Which looks like a rounding problem to me.  Maybe I'm way off.

Dex*
0

Author Comment

ID: 9861733
As I said, it is not rounding problem. I just want to print out integer only, but castinig is not working.
-----------------------
float keno_float_1 = 0.00;
float keno_float_2 = 0.00;
float keno_float_3 = 0.00;
int keno_int = 0;
while(order < 6)
{
keno_float_1 = keno_array[from_top];
keno_float_2 = float(int(keno_array[from_top]))*1.00;

cout<<keno_float_1 <<", "<<keno_float_2<<endl;
keno_float_3 = keno_float_1 - keno_float_2;
cout<<"keno_float_3 "<<(int)(keno_float_3*100.00)<<endl;
...
...
---------------------

99.01, 99
keno_float_3: 1
87.61
69.03, 69.00
keno_float_3: 2
61.06
58.42, 58.00
keno_float_3: 41
51.33
45.80, 45.00
keno_float_3: 79
39.82
37.04, 37.00
keno_float_3: 4
32.74
-----------
From above, casting is not working...,but the first one fifth one are working.
0

LVL 19

Accepted Solution

Dexstar earned 800 total points
ID: 9861876
Geez, I had to stare at that for a while to figure out what you were trying to do.

Try this:
cout<<"keno_float_3 "<<(int)((keno_float_3+0.5f)*100.00)<<endl;

Or maybe it is:
cout<<"keno_float_3 "<<(int)((keno_float_3*100.00)+0.5f)<<endl;

I can't tell without trying it out.  If neither of those work, would you please post the values from keno_array that you are using?

Dex*
0

LVL 86

Expert Comment

ID: 9861898
0

Author Comment

ID: 9862743
I have tried like this 'numeric_limits<float>::epsilon()',

keno_float_1 = keno_array[from_top];
keno_float_2 = float(int(keno_array[from_top]))*1.00;
keno_num = keno_float_1 - keno_float_2;

cout<<endl;
//prints number
int n = (int) keno_num + numeric_limits<float>::epsilon();

but I was having the following problem.
-----
AnalyzeOutput.cpp: In function `void Write_Analyzed_File(char *, char *)':
AnalyzeOutput.cpp:193: `numeric_limits' undeclared (first use this function)
AnalyzeOutput.cpp:193: (Each undeclared identifier is reported only once
AnalyzeOutput.cpp:193: for each function it appears in.)
AnalyzeOutput.cpp:193: parse error before `>'
------

Dexstar,
your solution worked this part, but didn't work for the other part.(two of numbers were incorrect.)
Sorry for my messy code. I was experimenting to solve this problem.
0

Author Comment

ID: 9862801
I wasn't sure how to use 'numeric_limits<float>::epsilon()' method.
Indeed,
#include <limits>
using namespace std;
didn't worked.
this gives me error, so I had to use #include <limits.h> even though I use for others like this
#include <iostream>
#include <fstream>
#include <string>
#include <iomanip>
#include <limits.h>

using namespace std;

By the way, I am using Sun Solaris system.
0

LVL 19

Expert Comment

ID: 9862972
@dkim18:  What are the values for keno_array[from_top] that you are using?
0

Author Comment

ID: 9863007
0

Author Comment

ID: 9863040
I solved problem!
Basically, Dexstar,'s method worked.
Thank you all.
0

## Featured Post

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article will show you some of the more useful Standard Template Library (STL) algorithms through the use of working examples.  You will learn about how these algorithms fit into the STL architecture, how they work with STL containers, and why tâ€¦
Looking for a way to avoid searching through large data sets for data that doesn't exist? A Bloom Filter might be what you need. This data structure is a probabilistic filter that allows you to avoid unnecessary searches when you know the data definâ€¦
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.
The viewer will be introduced to the technique of using vectors in C++. The video will cover how to define a vector, store values in the vector and retrieve data from the values stored in the vector.
###### Suggested Courses
Course of the Month12 days, 4 hours left to enroll