Accueil > > > EVALUER LES EXPRESSIONS MATHÉMATIQUES COMPLEXES
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@ms n.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);
}
}
?>
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
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
|
Derniers Blogs
GESTION D'EXCEPTION AVEC LES TASKSGESTION D'EXCEPTION AVEC LES TASKS par richardc
Nous avons vu dans un précédent article comment utiliser Task pour effectuer des opérations dans un autre thread.
Malheureusement, comme tout le monde n'est pas parfait, il se peut que cette exécution se passe mal et qu'une exception se produise.
La...
Cliquez pour lire la suite de l'article par richardc DéMARRONS AVEC LES TASKSDéMARRONS AVEC LES TASKS par richardc
Que vous le vouliez ou non, le développement multi-tâche est maintenant une obligation pour toute nouvelle application. Il est donc vital d'en comprendre les mécanismes et de s'y mettre le plus tôt possible.
En attendant le .NET Framework 4.5 avec le...
Cliquez pour lire la suite de l'article par richardc SLIDE & DéMO TECHDAYS 2012 - FAST & FURIOUS XAML APPSSLIDE & DéMO TECHDAYS 2012 - FAST & FURIOUS XAML APPS par Vko
Retrouvez les slides et les démo de ma session Fast & Furious XAML Apps. A ceux qui se posent la question : "est-ce que le code de la DataGrid est disponible?", je vous répondrais "pas encore". Je vais mettre en place un projet codeplex pour part...
Cliquez pour lire la suite de l'article par Vko XNA IS DEAD!XNA IS DEAD! par richardc
Depuis la semaine dernière (et grâce aux TechDays 2012), je me penche activement sur la nouvelle version de Windows, aka Windows 8. Vous me direz, il était temps puisque la première preview date de Septembre dernier.
OK. Remarquez, on n'en est qu'aux...
Cliquez pour lire la suite de l'article par richardc TECHDAYS PARIS 2012 : WINDOWS SERVER "8" QUOI DE 9 !TECHDAYS PARIS 2012 : WINDOWS SERVER "8" QUOI DE 9 ! par ROMELARD Fabrice
Speakers: Fabrice Meillon et Stanislas Quastana Cette session est basée entièrement sur celle donnée lors de la BUILD cet hiver. Il n'y a pas d'ajout d'information en rapport avec cet évènement passé. Windows 8 Server sera intégralem...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Forum
SYSTEME D'AMISYSTEME D'AMI par moza2409
Cliquez pour lire la suite par moza2409
Logiciels
DocTranslate (V3.1.0.0)DOCTRANSLATE (V3.1.0.0)DocTranslate est un traducteur de document Microsoft Word, PowerPoint et Excel. Il permet d'autom... Cliquez pour télécharger DocTranslate Tribler (2012)TRIBLER (2012)Tribler est un client pair à pair (P2P/Peer-to-Peer) open source avec la capacité de regarder des... Cliquez pour télécharger Tribler OneSwarm (2012)ONESWARM (2012)Le peer-to-peer qui protège votre vie privée, c'est OneSwarm.
Ce logiciel de peer-to-peer crypté... Cliquez pour télécharger OneSwarm PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System
|