|
Trouver une ressource
Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !
EVALUER LES EXPRESSIONS MATHÉMATIQUES COMPLEXES
Information sur la source
Description
eh bon, voici la première version avec ce script vous pouvez calculer des expressions mathématiques complexes genre "cos15+20*sin(3+4)*tan54+(3+(21-4))" ... priorité entre les opérateurs.. mon but c'est d'arriver a faire un traceur des fonctions demo: http://abdilah.freehostia.com/math/ amez-abdel@msn.com
Source
- <?php
- function Calculer($str)
- {
- $tab=array();
- $operateurs=array("+","-","*","/","^","&","%");
- $fonc_math=array("c","s","t");
- $operateurs_prioritaires=array("*","/","&","%","^");
- $cur=0;
- $i=0;
- while($i<strlen($str))
- {
- $char=substr($str,$i,1);
- if(in_array($char,$operateurs) and !$i==0)
- {
- $tab[$cur+1]=$char;
- $cur +=2;
- $i++;
- }else if(in_array($char,$fonc_math))
- {
- switch($char)
- {
- case "c":
- $tab[$cur]=round(cos(deg2rad(doubleval(substr($str,$i+3)))),3);
- break;
- case "s":
- $tab[$cur]=round(sin(deg2rad(doubleval(substr($str,$i+3)))),3);
- break;
- case "t":
- $tab[$cur]=round(tan(deg2rad(doubleval(substr($str,$i+3)))),3);
- break;
- }
- $lng=doubleval(substr($str,$i+3));
- settype($lng,"string");
- $i +=strlen($lng)+3;
- }else{
- if(!array_key_exists($cur,$tab))
- {
- $tab[$cur]=$char;
- }
- else
- {
- $tab[$cur] .=$char;
- }
- $i++;
- }
- }
- unset($i);
- $somme=doubleval($tab[0]);
- $i=1;
- while($i<count($tab))
- {
- switch($tab[$i])
- {
- case "+":
- if((count($tab)-$i > 30) and (in_array($tab[$i+2],$operateurs_prioritaires)))
- {
- switch($tab[$i+2])
- {
- case "*":
- $somme += (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
- break;
- case "/":
- if(doubleval($tab[$i+3]==0))
- {
- return "zero";
- exit;
- }
- $somme += (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
- break;
- case "&":
- $somme -= (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
- break;
- case "%":
- if(doubleval($tab[$i+3]==0))
- {
- return "zero";
- exit;
- }
- $somme -= (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
- break;
- case "^":
- $somme += pow(doubleval($tab[$i+1]),doubleval($tab[$i+3]));
- break;
- }
- $i +=4;
- }
- else
- {
- $somme += doubleval($tab[$i+1]);
- $i +=2;
- }
- break;
- case "-":
- if((count($tab)- $i > 30) and (in_array($tab[$i+2],$operateurs_prioritaires)))
- {
- switch($tab[$i+2])
- {
- case "*":
- $somme -= (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
- break;
- case "/":
- if(doubleval($tab[$i+3]==0))
- {
- return "zero";
- exit;
- }
- $somme -= (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
- break;
- case "&":
- $somme += (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
- break;
- case "%":
- if(doubleval($tab[$i+3]==0))
- {
- return "zero";
- exit;
- }
- $somme += (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
- break;
- case "^":
- $somme -= pow(doubleval($tab[$i+1]),doubleval($tab[$i+3]));
- break;
- }
- $i +=4;
- }
- else
- {
- $somme -= doubleval($tab[$i+1]);
- $i +=2;
- }
- break;
-
- case "*":
- $somme *= doubleval($tab[$i+1]);
- $i+=2;
- break;
-
- case "/":
- if(doubleval($tab[$i+1]==0))
- {
- return "zero";
- exit;
- }
- $somme /= doubleval($tab[$i+1]);
- $i+=2;
- break;
-
- case "&":
- $somme *= -doubleval($tab[$i+1]);
- $i+=2;
- break;
-
- case "%":
- $somme /= -doubleval($tab[$i+1]);
- $i+=2;
- break;
-
- case "^":
- $somme = pow( $somme , doubleval( $tab[$i+1 ] ) );
- $i+=2;
- break;
- }
- }
- return $somme;
- }
-
- /*
- fin de la fonction Calculer
- */
-
- function Evaluer($str)
- {
- $error = strrpos($str, "zero");
- if($error >=0 )
- {
- return "null";
- exit;
- }
- ///////////////////////////////////////////
- $str=str_replace("--","+",$str);
- $str=str_replace("+-","-",$str);
- $str=str_replace("*-","&",$str);
- $str=str_replace("/-","%",$str);
- ///////////////////////////////////////////
- $position1 = strrpos($str, "(");// en cherche la derniere occurence pour "("
- if (is_bool($position1) && !$position1)
- {
- return Calculer($str);
- }
- else
- {
- $position2=strpos(substr($str,$position1),")");
- $valeur=Calculer(substr($str,$position1+1,$position2-1));
- $str=str_replace(substr($str,$position1,$position2+1),$valeur,$str);
- $str=str_replace("--","+",$str);
- $str=str_replace("+-","-",$str);
- $str=str_replace("*-","&",$str);
- $str=str_replace("/-","%",$str);
- return Evaluer($str);
- }
- }
-
- ?>
<?php
function Calculer($str)
{
$tab=array();
$operateurs=array("+","-","*","/","^","&","%");
$fonc_math=array("c","s","t");
$operateurs_prioritaires=array("*","/","&","%","^");
$cur=0;
$i=0;
while($i<strlen($str))
{
$char=substr($str,$i,1);
if(in_array($char,$operateurs) and !$i==0)
{
$tab[$cur+1]=$char;
$cur +=2;
$i++;
}else if(in_array($char,$fonc_math))
{
switch($char)
{
case "c":
$tab[$cur]=round(cos(deg2rad(doubleval(substr($str,$i+3)))),3);
break;
case "s":
$tab[$cur]=round(sin(deg2rad(doubleval(substr($str,$i+3)))),3);
break;
case "t":
$tab[$cur]=round(tan(deg2rad(doubleval(substr($str,$i+3)))),3);
break;
}
$lng=doubleval(substr($str,$i+3));
settype($lng,"string");
$i +=strlen($lng)+3;
}else{
if(!array_key_exists($cur,$tab))
{
$tab[$cur]=$char;
}
else
{
$tab[$cur] .=$char;
}
$i++;
}
}
unset($i);
$somme=doubleval($tab[0]);
$i=1;
while($i<count($tab))
{
switch($tab[$i])
{
case "+":
if((count($tab)-$i > 30) and (in_array($tab[$i+2],$operateurs_prioritaires)))
{
switch($tab[$i+2])
{
case "*":
$somme += (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
break;
case "/":
if(doubleval($tab[$i+3]==0))
{
return "zero";
exit;
}
$somme += (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
break;
case "&":
$somme -= (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
break;
case "%":
if(doubleval($tab[$i+3]==0))
{
return "zero";
exit;
}
$somme -= (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
break;
case "^":
$somme += pow(doubleval($tab[$i+1]),doubleval($tab[$i+3]));
break;
}
$i +=4;
}
else
{
$somme += doubleval($tab[$i+1]);
$i +=2;
}
break;
case "-":
if((count($tab)- $i > 30) and (in_array($tab[$i+2],$operateurs_prioritaires)))
{
switch($tab[$i+2])
{
case "*":
$somme -= (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
break;
case "/":
if(doubleval($tab[$i+3]==0))
{
return "zero";
exit;
}
$somme -= (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
break;
case "&":
$somme += (doubleval($tab[$i+1])*doubleval($tab[$i+3]));
break;
case "%":
if(doubleval($tab[$i+3]==0))
{
return "zero";
exit;
}
$somme += (doubleval($tab[$i+1])/doubleval($tab[$i+3]));
break;
case "^":
$somme -= pow(doubleval($tab[$i+1]),doubleval($tab[$i+3]));
break;
}
$i +=4;
}
else
{
$somme -= doubleval($tab[$i+1]);
$i +=2;
}
break;
case "*":
$somme *= doubleval($tab[$i+1]);
$i+=2;
break;
case "/":
if(doubleval($tab[$i+1]==0))
{
return "zero";
exit;
}
$somme /= doubleval($tab[$i+1]);
$i+=2;
break;
case "&":
$somme *= -doubleval($tab[$i+1]);
$i+=2;
break;
case "%":
$somme /= -doubleval($tab[$i+1]);
$i+=2;
break;
case "^":
$somme = pow( $somme , doubleval( $tab[$i+1 ] ) );
$i+=2;
break;
}
}
return $somme;
}
/*
fin de la fonction Calculer
*/
function Evaluer($str)
{
$error = strrpos($str, "zero");
if($error >=0 )
{
return "null";
exit;
}
///////////////////////////////////////////
$str=str_replace("--","+",$str);
$str=str_replace("+-","-",$str);
$str=str_replace("*-","&",$str);
$str=str_replace("/-","%",$str);
///////////////////////////////////////////
$position1 = strrpos($str, "(");// en cherche la derniere occurence pour "("
if (is_bool($position1) && !$position1)
{
return Calculer($str);
}
else
{
$position2=strpos(substr($str,$position1),")");
$valeur=Calculer(substr($str,$position1+1,$position2-1));
$str=str_replace(substr($str,$position1,$position2+1),$valeur,$str);
$str=str_replace("--","+",$str);
$str=str_replace("+-","-",$str);
$str=str_replace("*-","&",$str);
$str=str_replace("/-","%",$str);
return Evaluer($str);
}
}
?>
Fichier Zip
Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
Télécharger le zip
Historique
- 26 décembre 2006 23:39:48 :
- oups, zip...$-)
- 23 janvier 2007 23:44:02 :
- un petit correctif
- 24 janvier 2007 18:08:15 :
- autre correctif
maintenant l'algo pris en compte la priorité entre + et ( + - )
- 24 janvier 2007 23:29:57 :
- mis en forme l'algo ( indentation)
- 25 janvier 2007 22:41:56 :
- autres correctifs
Sources du même auteur
Sources de la même categorie
Sources en rapport avec celle ci
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Convertir un nombre en expression literrale en PL/SQL [ par ThReM ]
bonjour je cherche une source pour convertir un nombre en ce meme nombre mais ecris en toutes lettre (99 ==> quatre vingt dix neuf) en langage PL/S
Expression régulière pour retrouver tous les tags php [ par ninatomb ]
Je recherche une expression régulière qui me retrouve tous les tags php dans une page html, sans modifier l'htmlEt une qui fonctionne !!!!!Celle ci ne
Expression reguliere [ par wonesek ]
$mois = array( "01" => "Janvier", "02" => "Fevrier", "03" => "Mars", "04" => "Avril", "05" => "Mai", "06" => "Juin", "07" =>
expression toute bete avec des ' et des ", qui resiste... [ par sbastian ]
bonjour! j'ai ce bout de code (remplacement de l'expression "d' " par "espace") qui me resiste... $ligne=str_replace("d'"," ",$ligne); = marche pas,
Nombre Complexe [ par TiotBour ]
Bonjour, je voudrai savoir si il est^possible de gerer les nombres complexes via php, et surtout comment ?Sous forme polaire et rectangulaire aussi :)
expression reguliere [ par wonesek ]
bonsoir tout le monde j'ai actullement un petit probleme avec une expression reguliere PCRE:code source------------------<pre><?$a = "[a]1[/a
utilisation expression reguliere avec tabulation (aide) [ par nunor ]
bjr, j'ai un fichier texte avec les données suivantes Code: Date d'activation Date de fin Catégorie Mot clé Position moyenne Impressions T
Explications sur mail() complexe [ par romalafrite ]
http://www.zend.com/zend/spotlight/sendmimeemailpart1.phpBonjour à tous,J'aimerais avoir des explications (parce que je suis mauvais en anglais) sur l
Expression régulière [ par redsungraphics ]
Je voudrais remplacer un mot par un lien. J'utilise actuellement str_replace. y-aurait-il une alternative qui fasse que s'il reconnait une racine d'un
expression reguliere [ par Rochon ]
Avec les expressions regulière je voudrait que tout les mots print et if qui sont entre des balises <php> et </php> soient surlignés:j'uti
|
Téléchargements
Logiciels à télécharger sur le même thème :
Comparez les prix Nouvelle version
|