{"title":"New results for random determination of equivalence of expressions","authors":"G. Gonnet","doi":"10.1145/32439.32465","DOIUrl":null,"url":null,"abstract":"We devise several procedures based on signatures (or hashing functions) to determine equivalence of expressions in Random Polynomial Time (also called Probabilistic Polynomial Time) (RPT). We extend the previous results known to include various new functions that can be tested. These procedures return as result: <italic>“equivalent”</italic> or <italic>“not-equivalent”</italic>. The result “not-equivalent” is always correct, while the result “equivalent” is correct with probability at least 1 — ε. This probability depends on a random number generator and is <italic>independent</italic> of the problem being solved. In all our procedures, the value ε can be made arbitrarily small. This method works for determining equivalence over an important class of functions as well as answering other questions like linearity, polynomial dependence, squareness, independence, etc.\nThe general scheme for all these algorithms is to use a basic heuristic <italic>“test”</italic> several times. I.e. solve( problem, epsilon ) repeat select suitable characteristic p randomly; assign random values to all variables; t := test( problem, p ); if t = “not-equivalent” then return( t ) until Prob of cumulative failures >= epsilon; return( “equivalent” );\nIt is assumed that <italic>“test”</italic> gives a wrong answer with probability δ, where δ remains bounded below 1. For all our <italic>“test”</italic> procedures, δ ≤ 1/2.\nIn what follows we will describe the <italic>“test”</italic> part of the different procedures, it is always assumed that these are used in the above context.\nWithout loss of generality we will assume that equivalence of expressions (<italic>A ≡ B</italic>) can be transformed into testing for 0 (<italic>A — B ≡ 0</italic>).\nThis test can be performed “quickly” in the sense that it can run in polynomial time on the size of the <italic>dag</italic> (directed acyclic graph) representation of the expression, also known as “linear program representation” of an expression.","PeriodicalId":314618,"journal":{"name":"Symposium on Symbolic and Algebraic Manipulation","volume":"110 1","pages":"0"},"PeriodicalIF":0.0000,"publicationDate":"1986-10-01","publicationTypes":"Journal Article","fieldsOfStudy":null,"isOpenAccess":false,"openAccessPdf":"","citationCount":"18","resultStr":null,"platform":"Semanticscholar","paperid":null,"PeriodicalName":"Symposium on Symbolic and Algebraic Manipulation","FirstCategoryId":"1085","ListUrlMain":"https://doi.org/10.1145/32439.32465","RegionNum":0,"RegionCategory":null,"ArticlePicture":[],"TitleCN":null,"AbstractTextCN":null,"PMCID":null,"EPubDate":"","PubModel":"","JCR":"","JCRName":"","Score":null,"Total":0}
引用次数: 18
Abstract
We devise several procedures based on signatures (or hashing functions) to determine equivalence of expressions in Random Polynomial Time (also called Probabilistic Polynomial Time) (RPT). We extend the previous results known to include various new functions that can be tested. These procedures return as result: “equivalent” or “not-equivalent”. The result “not-equivalent” is always correct, while the result “equivalent” is correct with probability at least 1 — ε. This probability depends on a random number generator and is independent of the problem being solved. In all our procedures, the value ε can be made arbitrarily small. This method works for determining equivalence over an important class of functions as well as answering other questions like linearity, polynomial dependence, squareness, independence, etc.
The general scheme for all these algorithms is to use a basic heuristic “test” several times. I.e. solve( problem, epsilon ) repeat select suitable characteristic p randomly; assign random values to all variables; t := test( problem, p ); if t = “not-equivalent” then return( t ) until Prob of cumulative failures >= epsilon; return( “equivalent” );
It is assumed that “test” gives a wrong answer with probability δ, where δ remains bounded below 1. For all our “test” procedures, δ ≤ 1/2.
In what follows we will describe the “test” part of the different procedures, it is always assumed that these are used in the above context.
Without loss of generality we will assume that equivalence of expressions (A ≡ B) can be transformed into testing for 0 (A — B ≡ 0).
This test can be performed “quickly” in the sense that it can run in polynomial time on the size of the dag (directed acyclic graph) representation of the expression, also known as “linear program representation” of an expression.