Difference between revisions of "ApCoCoA-1:CharP.IMXLSolve"

From ApCoCoAWiki
(New page: <command> <title>CharP.GBasisF2</title> <short_description>Computing the unique <tt>F_2-</tt>rational zero of a given polynomial system over <tt>F_2</tt>.</short_description> <synt...)
 
m (insert version info)
 
(6 intermediate revisions by 3 users not shown)
Line 1: Line 1:
 +
{{Version|1}}
 
<command>
 
<command>
     <title>CharP.GBasisF2</title>
+
     <title>CharP.IMXLSolve</title>
     <short_description>Computing the unique <tt>F_2-</tt>rational zero of a given polynomial system over <tt>F_2</tt>.</short_description>
+
     <short_description>Computes the unique <tt>F_2</tt>-rational zero of a given polynomial system over <tt>F_2</tt>.</short_description>
 
<syntax>
 
<syntax>
 
CharP.IMXLSolve(F:LIST):LIST
 
CharP.IMXLSolve(F:LIST):LIST
Line 9: Line 10:
  
 
<par/>
 
<par/>
This function computes the unique zero in <tt>F_2^n</tt> of a polynomial system over <tt>F_2 </tt>. It uses Improved Mutant XL-Algorithm to find the unique zero. The idea is to linearize the polynomial system by considering terms as indeterminates and then apply gaussian elimination to find a univariate polynomial. If no univariate polynomial is found then the system is extended by generating more polynomials in the ideal and gaussian elimination is applied again. In this way by appling gaussian elimination repeatedly we find the zero of the system. In fact Improved Mutant XL Algorithm is the XL Algorithm with improved mutant strategy. The Improved Mutant XL-Algorithm is impelemented only to find the unique zero. If the given polynomial system has more than one zeros in <tt>F_2^n </tt> then this function does not find any zero. In this case a massage for non-uniqueness will be displayed to the screen after reaching the maximum degree bound.  
+
This function computes the unique zero in <tt>F_2^n</tt> of a polynomial system over <tt>F_2 </tt>. It uses Improved Mutant XL-Algorithm to find the unique zero. The idea is to linearize the polynomial system by considering terms as indeterminates and then apply gaussian elimination to find a univariate polynomial. If no univariate polynomial is found then the system is extended by generating more polynomials in the ideal and gaussian elimination is applied again. In this way by applying gaussian elimination repeatedly we find the zero of the system. In fact Improved Mutant XL-Algorithm is the XL-Algorithm with improved mutant strategy. The Improved Mutant XL-Algorithm is implemented only to find the unique zero. If the given polynomial system has more than one zeros in <tt>F_2^n </tt> then this function does not find any zero. In this case a massage for non-uniqueness will be displayed to the screen after reaching the maximum degree bound.  
  
  
Line 210: Line 211:
 
     </description>
 
     </description>
 
     <seealso>
 
     <seealso>
       <see>CharP.XLSolve</see>
+
       <see>ApCoCoA-1:CharP.XLSolve|CharP.XLSolve</see>
     <see>Introduction to CoCoAServer</see>
+
     <see>ApCoCoA-1:Introduction to CoCoAServer|Introduction to CoCoAServer</see>
     <see>Introduction to Groebner Basis in CoCoA</see>
+
     <see>ApCoCoA-1:Introduction to Groebner Basis in CoCoA|Introduction to Groebner Basis in CoCoA</see>
     <see>CharP.IMNLASolve</see>
+
     <see>ApCoCoA-1:CharP.IMNLASolve|CharP.IMNLASolve</see>
     <see>CharP.MNLASolve</see>
+
     <see>ApCoCoA-1:CharP.MNLASolve|CharP.MNLASolve</see>
     <see>CharP.NLASolve</see>
+
     <see>ApCoCoA-1:CharP.NLASolve|CharP.NLASolve</see>
     <see>CharP.MXLSolve</see>
+
     <see>ApCoCoA-1:CharP.MXLSolve|CharP.MXLSolve</see>
     <see>CharP.GBasisF2</see>
+
     <see>ApCoCoA-1:CharP.GBasisF2|CharP.GBasisF2</see>    
   
 
 
   </seealso>
 
   </seealso>
  
 
     <types>
 
     <types>
 
       <type>apcocoaserver</type>
 
       <type>apcocoaserver</type>
       <type>ideal</type>
+
       <type>poly_system</type>
      <type>groebner</type>
 
 
     </types>
 
     </types>
  
     <key>charP.GBasisF2</key>
+
     <key>charP.imxlsolve</key>
     <key>GBasisF2</key>
+
     <key>imxlsolve</key>
 
     <key>finite field</key>
 
     <key>finite field</key>
     <wiki-category>Package_charP</wiki-category>
+
     <wiki-category>ApCoCoA-1:Package_charP</wiki-category>
 
   </command>
 
   </command>

Latest revision as of 09:56, 7 October 2020

This article is about a function from ApCoCoA-1.

CharP.IMXLSolve

Computes the unique F_2-rational zero of a given polynomial system over F_2.

Syntax

CharP.IMXLSolve(F:LIST):LIST

Description

Please note: The function(s) explained on this page is/are using the ApCoCoAServer. You will have to start the ApCoCoAServer in order to use it/them.


This function computes the unique zero in F_2^n of a polynomial system over F_2 . It uses Improved Mutant XL-Algorithm to find the unique zero. The idea is to linearize the polynomial system by considering terms as indeterminates and then apply gaussian elimination to find a univariate polynomial. If no univariate polynomial is found then the system is extended by generating more polynomials in the ideal and gaussian elimination is applied again. In this way by applying gaussian elimination repeatedly we find the zero of the system. In fact Improved Mutant XL-Algorithm is the XL-Algorithm with improved mutant strategy. The Improved Mutant XL-Algorithm is implemented only to find the unique zero. If the given polynomial system has more than one zeros in F_2^n then this function does not find any zero. In this case a massage for non-uniqueness will be displayed to the screen after reaching the maximum degree bound.


  • @param F: List of polynomials of given system.

  • @return The unique solution of the given system in F_2^n.

Example

Use Z/(2)[x[1..4]];
F:=[
    x[1]x[2] + x[2]x[3] + x[2]x[4] + x[3]x[4] + x[1] + x[3] + 1, 
    x[1]x[2] + x[1]x[3] + x[1]x[4] + x[3]x[4] + x[2] + x[3] + 1, 
    x[1]x[2] + x[1]x[3] + x[2]x[3] + x[3]x[4] + x[1] + x[4] + 1, 
    x[1]x[3] + x[2]x[3] + x[1]x[4] + x[2]x[4] + 1
    ];

-- Then we compute the solution with
CharP.IMXLSolve(F);

-- And we achieve the following information on the screen together with the solution at the end.
----------------------------------------
         The size of Matrix is:
		No. of Rows=4
		No. of Columns=11
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The size of Matrix is:
		No. of Rows=4
		No. of Columns=11
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=4
		No. of Columns=11
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=8
		No. of Columns=11
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 1
	The total No. of Mutants found are = 1
	The No. of Mutants of Minimum degree (Mutants used) are = 1
	The size of Matrix is:
		No. of Rows=11
		No. of Columns=11
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[0, 1, 0, 1]
[0, 1, 0, 1]



Example

Use Z/(2)[x[1..4]];
F:=[ 
    x[2]x[3] + x[1]x[4] + x[2]x[4] + x[3]x[4] + x[1] + x[2] + x[3] + x[4], 
    x[2]x[3] + x[2]x[4] + x[3]x[4] + x[2] + x[3] + x[4],  
    x[1]x[2] + x[2]x[3] + x[2]x[4] + x[3]x[4] + x[1] + x[2],  
    x[1]x[2] + x[2]x[3] + x[2]x[4] + x[3]x[4] + x[1] + x[2]
   ];

-- Solution is not unique i.e. [0, 1, 1, 1], [0, 0, 0, 0], and [1, 1, 1, 1] are solutions 

-- Then we compute the solution with
CharP.IMXLSolve(F);

-- And we achieve the following information on the screen.
----------------------------------------
       
	The size of Matrix is:
		No. of Rows=4
		No. of Columns=9
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The size of Matrix is:
		No. of Rows=3
		No. of Columns=9
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=7
		No. of Columns=14
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=14
		No. of Columns=14
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 4
	The total No. of Mutants found are = 4
	The No. of Mutants of Minimum degree (Mutants used) are = 2
	The size of Matrix is:
		No. of Rows=15
		No. of Columns=10
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The total No. of Mutants found are = 2
	The No. of Mutants of Minimum degree (Mutants used) are = 2
	The size of Matrix is:
		No. of Rows=15
		No. of Columns=14
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=12
		No. of Columns=14
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=17
		No. of Columns=14
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=25
		No. of Columns=15
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	No. of New Mutants found = 0
	The size of Matrix is:
		No. of Rows=13
		No. of Columns=15
Appling Gaussian Elimination...
-- CoCoAServer: computing Cpu Time = 0
-------------------------------
Gaussian Elimination Completed.
	The variables found till now are:
	[x[1], x[2], x[3], x[4]]
	Please Check the uniqueness of solution.
	The Given system of polynomials does not
	seem to have a unique solution.


See also

CharP.XLSolve

Introduction to CoCoAServer

Introduction to Groebner Basis in CoCoA

CharP.IMNLASolve

CharP.MNLASolve

CharP.NLASolve

CharP.MXLSolve

CharP.GBasisF2