mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 02:30:57 +00:00 
			
		
		
		
	Initial import
This commit is contained in:
		
						commit
						c91b3c5006
					
				
					 14915 changed files with 590219 additions and 0 deletions
				
			
		
							
								
								
									
										34
									
								
								libc/math/modf.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								libc/math/modf.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,34 @@ | |||
| #include "libc/math/libm.h" | ||||
| 
 | ||||
| double modf(double x, double *iptr) | ||||
| { | ||||
| 	union {double f; uint64_t i;} u = {x}; | ||||
| 	uint64_t mask; | ||||
| 	int e = (int)(u.i>>52 & 0x7ff) - 0x3ff; | ||||
| 
 | ||||
| 	/* no fractional part */ | ||||
| 	if (e >= 52) { | ||||
| 		*iptr = x; | ||||
| 		if (e == 0x400 && u.i<<12 != 0) /* nan */ | ||||
| 			return x; | ||||
| 		u.i &= 1ULL<<63; | ||||
| 		return u.f; | ||||
| 	} | ||||
| 
 | ||||
| 	/* no integral part*/ | ||||
| 	if (e < 0) { | ||||
| 		u.i &= 1ULL<<63; | ||||
| 		*iptr = u.f; | ||||
| 		return x; | ||||
| 	} | ||||
| 
 | ||||
| 	mask = -1ULL>>12>>e; | ||||
| 	if ((u.i & mask) == 0) { | ||||
| 		*iptr = x; | ||||
| 		u.i &= 1ULL<<63; | ||||
| 		return u.f; | ||||
| 	} | ||||
| 	u.i &= ~mask; | ||||
| 	*iptr = u.f; | ||||
| 	return x - u.f; | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue