forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Phergie
 | |
|  *
 | |
|  * PHP version 5
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://phergie.org/license
 | |
|  *
 | |
|  * @category  Phergie
 | |
|  * @package   Phergie_Plugin_Temperature
 | |
|  * @author    Phergie Development Team <team@phergie.org>
 | |
|  * @copyright 2008-2010 Phergie Development Team (http://phergie.org)
 | |
|  * @license   http://phergie.org/license New BSD License
 | |
|  * @link      http://pear.phergie.org/package/Phergie_Plugin_Temperature
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Performs temperature calculations for other plugins.
 | |
|  *
 | |
|  * @category Phergie
 | |
|  * @package  Phergie_Plugin_Temperature
 | |
|  * @author   Phergie Development Team <team@phergie.org>
 | |
|  * @license  http://phergie.org/license New BSD License
 | |
|  * @link     http://pear.phergie.org/package/Phergie_Plugin_Temperature
 | |
|  */
 | |
| class Phergie_Plugin_Temperature extends Phergie_Plugin_Abstract
 | |
| {
 | |
|     /**
 | |
|      * Converts a temperature in Celsius to Fahrenheit.
 | |
|      *
 | |
|      * @param int $temp Temperature in Celsius
 | |
|      *
 | |
|      * @return int Temperature converted to Fahrenheit
 | |
|      */
 | |
|     public function convertCelsiusToFahrenheit($temp)
 | |
|     {
 | |
|         return round(((((int) $temp * 9) / 5) + 32));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Converts a temperature in Fahrenheit to Celsius.
 | |
|      *
 | |
|      * @param int $temp Temperature in Fahrenheit
 | |
|      *
 | |
|      * @return int Temperature converted to Celsius
 | |
|      */
 | |
|     public function convertFahrenheitToCelsius($temp)
 | |
|     {
 | |
|         return round(((((int) $temp - 32) * 5) / 9));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Calculates the heat index (i.e. "feels like" temperature) based on
 | |
|      * temperature and relative humidity.
 | |
|      *
 | |
|      * @param int $temperature Temperature in degrees Fahrenheit
 | |
|      * @param int $humidity Relative humidity (ex: 68)
 | |
|      * @return int Heat index in degrees Fahrenheit
 | |
|      */
 | |
|     public function getHeatIndex($temperature, $humidity)
 | |
|     {
 | |
|         $temperature2 = $temperature * $temperature;
 | |
|         $humidity2 = $humidity * $humidity;
 | |
|         return round(
 | |
|             -42.379 +
 | |
|             (2.04901523 * $temperature) +
 | |
|             (10.14333127 * $humidity) -
 | |
|             (0.22475541 * $temperature * $humidity) -
 | |
|             (0.00683783 * $temperature2) -
 | |
|             (0.05481717 * $humidity2) +
 | |
|             (0.00122874 * $temperature2 * $humidity) +
 | |
|             (0.00085282 * $temperature * $humidity2) -
 | |
|             (0.00000199 * $temperature2 * $humidity2)
 | |
|         );
 | |
|     }
 | |
| }
 |