mirror of
				https://github.com/SEPPDROID/Digital-Research-Source-Code.git
				synced 2025-10-26 01:44:21 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
| 	Copyright 1982
 | |
| 	Alcyon Corporation
 | |
| 	8716 Production Ave.
 | |
| 	San Diego, Ca.  92121
 | |
| */
 | |
| 
 | |
| /*char *version "@(#) _ieeetof - dec 29, 1982"; */
 | |
| 
 | |
| /*
 | |
|  *	IEEE Floating Point Representation to Internal Representation :
 | |
|  *		IEEE Standard Single Precision Representation Floating Point
 | |
|  *
 | |
|  *	float
 | |
|  *	_ieeetof(lf)
 | |
|  *	long lf;
 | |
|  *
 | |
|  *	Largest positive number is 3.4 * 10^33 and the smallest positive
 | |
|  *	number is 1.2 * 10^-38.
 | |
|  *	Rely's on the fact that a long and a float are both 32 bits.
 | |
|  */
 | |
| 
 | |
| #define BIAS	127L
 | |
| 
 | |
| float
 | |
| _ieeetof(lf)
 | |
| long lf;
 | |
| {
 | |
| 	register long exp;
 | |
| 	register int count, fsign;
 | |
| 	float f;
 | |
| 
 | |
| 	if (lf == 0L)
 | |
| 		return(0.0);
 | |
| 	if (lf < 0L) {
 | |
| 		fsign = 1;
 | |
| 		lf =& 0x7fffffff;	/* mask MSB (sign) */
 | |
| 	}
 | |
| 	else
 | |
| 		fsign = 0;
 | |
| 	exp = (lf >> 23) & 0xff;		/* biased ieee exponent */
 | |
| 	exp =- BIAS;
 | |
| 	lf =& 0x7fffff;		/* 23 bits of fraction */
 | |
| 	f = lf;
 | |
| 	if (f != 0.0)
 | |
| 		f = f / 8388608.0;	/* 2 ^ 23 */
 | |
| 	f = f + 1.0;		/* ieee fraction : 1.F */
 | |
| 	while (exp < 0) {	/* negative exp : 2^-? */
 | |
| 		f = f / 2.0;
 | |
| 		exp++;
 | |
| 	}
 | |
| 	while (exp > 0) {	/* positive exp : 2^+? */
 | |
| 		f = f * 2.0;
 | |
| 		exp--;
 | |
| 	}
 | |
| 	if (fsign)
 | |
| 		f = -f;
 | |
| 	return(f);
 | |
| }
 |