Skip to content
This repository has been archived by the owner on Jan 30, 2023. It is now read-only.

Commit

Permalink
Rename matrix_mod2e_dense to matrix_gf2e_dense
Browse files Browse the repository at this point in the history
  • Loading branch information
jdemeyer committed Sep 18, 2015
1 parent aeeddeb commit 1e6264d
Show file tree
Hide file tree
Showing 6 changed files with 69 additions and 61 deletions.
2 changes: 1 addition & 1 deletion src/doc/en/reference/matrices/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ objects like operation tables (e.g. the multiplication table of a group).
sage/matrix/matrix_integer_dense_saturation
sage/matrix/matrix_integer_sparse
sage/matrix/matrix_mod2_dense
sage/matrix/matrix_mod2e_dense
sage/matrix/matrix_gf2e_dense
sage/matrix/matrix_modn_dense_double
sage/matrix/matrix_modn_dense_float
sage/matrix/matrix_rational_sparse
Expand Down
4 changes: 2 additions & 2 deletions src/module_list.py
Original file line number Diff line number Diff line change
Expand Up @@ -900,8 +900,8 @@ def uname_specific(name, value, alternative):
extra_compile_args = m4ri_extra_compile_args,
depends = [SAGE_INC + "/png.h", SAGE_INC + "/m4ri/m4ri.h"]),

Extension('sage.matrix.matrix_mod2e_dense',
sources = ['sage/matrix/matrix_mod2e_dense.pyx'],
Extension('sage.matrix.matrix_gf2e_dense',
sources = ['sage/matrix/matrix_gf2e_dense.pyx'],
libraries = ['m4rie', 'm4ri', 'm'],
depends = [SAGE_INC + "/m4rie/m4rie.h"],
extra_compile_args = m4ri_extra_compile_args),
Expand Down
12 changes: 12 additions & 0 deletions src/sage/matrix/matrix_gf2e_dense.pxd
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
from sage.libs.m4rie cimport mzed_t

cimport matrix_dense

cdef class Matrix_gf2e_dense(matrix_dense.Matrix_dense):
cdef mzed_t *_entries
cdef object _one
cdef object _zero

cpdef Matrix_gf2e_dense _multiply_newton_john(Matrix_gf2e_dense self, Matrix_gf2e_dense right)
cpdef Matrix_gf2e_dense _multiply_karatsuba(Matrix_gf2e_dense self, Matrix_gf2e_dense right)
cpdef Matrix_gf2e_dense _multiply_strassen(Matrix_gf2e_dense self, Matrix_gf2e_dense right, cutoff=*)
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ The M4RIE library offers two matrix representations:
words such that each element is filled with zeroes until the next
power of two. Thus, for example, elements of `\GF{2^3}` are
represented as ``[0xxx|0xxx|0xxx|0xxx|...]``. This representation is
wrapped as :class:`Matrix_mod2e_dense` in Sage.
wrapped as :class:`Matrix_gf2e_dense` in Sage.
Multiplication and elimination both use "Newton-John" tables. These
tables are simply all possible multiples of a given row in a matrix
Expand Down Expand Up @@ -50,7 +50,7 @@ AUTHOR:
TESTS::
sage: TestSuite(sage.matrix.matrix_mod2e_dense.Matrix_mod2e_dense).run(verbose=True)
sage: TestSuite(sage.matrix.matrix_gf2e_dense.Matrix_gf2e_dense).run(verbose=True)
running ._test_pickling() . . . pass
TODO:
Expand All @@ -66,6 +66,16 @@ REFERENCES:
http://arxiv.org/abs/0901.1413
"""

#*****************************************************************************
# Copyright (C) 2010 Martin Albrecht <[email protected]>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
# http://www.gnu.org/licenses/
#*****************************************************************************

include "sage/ext/interrupt.pxi"

cimport matrix_dense
Expand Down Expand Up @@ -100,17 +110,17 @@ cdef class M4RIE_finite_field:
"""
EXAMPLE::
sage: from sage.matrix.matrix_mod2e_dense import M4RIE_finite_field
sage: from sage.matrix.matrix_gf2e_dense import M4RIE_finite_field
sage: K = M4RIE_finite_field(); K
<sage.matrix.matrix_mod2e_dense.M4RIE_finite_field object at 0x...>
<sage.matrix.matrix_gf2e_dense.M4RIE_finite_field object at 0x...>
"""
pass

def __dealloc__(self):
"""
EXAMPLE::
sage: from sage.matrix.matrix_mod2e_dense import M4RIE_finite_field
sage: from sage.matrix.matrix_gf2e_dense import M4RIE_finite_field
sage: K = M4RIE_finite_field()
sage: del K
"""
Expand All @@ -123,7 +133,7 @@ cdef m4ri_word poly_to_word(f):
cdef object word_to_poly(w, F):
return F.fetch_int(w)

cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
cdef class Matrix_gf2e_dense(matrix_dense.Matrix_dense):
########################################################################
# LEVEL 1 functionality
########################################################################
Expand Down Expand Up @@ -336,19 +346,19 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
[a^3 + a^2 + 1 a^3 + a^2 + a a^3 + a^2 + a a^3 + 1]
[a^3 + a^2 + 1 a^3 + a^2 a^3 + a^2 a^2]
"""
cdef Matrix_mod2e_dense A
A = Matrix_mod2e_dense.__new__(Matrix_mod2e_dense, self._parent, 0, 0, 0, alloc=False)
cdef Matrix_gf2e_dense A
A = Matrix_gf2e_dense.__new__(Matrix_gf2e_dense, self._parent, 0, 0, 0, alloc=False)
if self._nrows == 0 or self._ncols == 0:
return A
A._entries = mzed_add(NULL, self._entries, (<Matrix_mod2e_dense>right)._entries)
A._entries = mzed_add(NULL, self._entries, (<Matrix_gf2e_dense>right)._entries)

return A

cpdef ModuleElement _sub_(self, ModuleElement right):
"""
EXAMPLE::
sage: from sage.matrix.matrix_mod2e_dense import Matrix_mod2e_dense
sage: from sage.matrix.matrix_gf2e_dense import Matrix_gf2e_dense
sage: K.<a> = GF(2^4)
sage: m,n = 3, 4
sage: MS = MatrixSpace(K,m,n)
Expand Down Expand Up @@ -406,13 +416,13 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if self._ncols != right._nrows:
raise ArithmeticError("left ncols must match right nrows")

cdef Matrix_mod2e_dense ans
cdef Matrix_gf2e_dense ans

ans = self.new_matrix(nrows = self.nrows(), ncols = right.ncols())
if self._nrows == 0 or self._ncols == 0 or right._ncols == 0:
return ans
sig_on()
ans._entries = mzed_mul_naive(ans._entries, self._entries, (<Matrix_mod2e_dense>right)._entries)
ans._entries = mzed_mul_naive(ans._entries, self._entries, (<Matrix_gf2e_dense>right)._entries)
sig_off()
return ans

Expand Down Expand Up @@ -449,17 +459,17 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if self._ncols != right._nrows:
raise ArithmeticError("left ncols must match right nrows")

cdef Matrix_mod2e_dense ans
cdef Matrix_gf2e_dense ans

ans = self.new_matrix(nrows = self.nrows(), ncols = right.ncols())
if self._nrows == 0 or self._ncols == 0 or right._ncols == 0:
return ans
sig_on()
ans._entries = mzed_mul(ans._entries, self._entries, (<Matrix_mod2e_dense>right)._entries)
ans._entries = mzed_mul(ans._entries, self._entries, (<Matrix_gf2e_dense>right)._entries)
sig_off()
return ans

cpdef Matrix_mod2e_dense _multiply_newton_john(Matrix_mod2e_dense self, Matrix_mod2e_dense right):
cpdef Matrix_gf2e_dense _multiply_newton_john(Matrix_gf2e_dense self, Matrix_gf2e_dense right):
"""
Return A*B using Newton-John tables.
Expand Down Expand Up @@ -510,18 +520,18 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if self._ncols != right._nrows:
raise ArithmeticError("left ncols must match right nrows")

cdef Matrix_mod2e_dense ans
cdef Matrix_gf2e_dense ans

ans = self.new_matrix(nrows = self.nrows(), ncols = right.ncols())
if self._nrows == 0 or self._ncols == 0 or right._ncols == 0:
return ans

sig_on()
ans._entries = mzed_mul_newton_john(ans._entries, self._entries, (<Matrix_mod2e_dense>right)._entries)
ans._entries = mzed_mul_newton_john(ans._entries, self._entries, (<Matrix_gf2e_dense>right)._entries)
sig_off()
return ans

cpdef Matrix_mod2e_dense _multiply_karatsuba(Matrix_mod2e_dense self, Matrix_mod2e_dense right):
cpdef Matrix_gf2e_dense _multiply_karatsuba(Matrix_gf2e_dense self, Matrix_gf2e_dense right):
"""
Matrix multiplication using Karatsuba over polynomials with
matrix coefficients over GF(2).
Expand Down Expand Up @@ -558,18 +568,18 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if self._ncols != right._nrows:
raise ArithmeticError("left ncols must match right nrows")

cdef Matrix_mod2e_dense ans
cdef Matrix_gf2e_dense ans

ans = self.new_matrix(nrows = self.nrows(), ncols = right.ncols())
if self._nrows == 0 or self._ncols == 0 or right._ncols == 0:
return ans

sig_on()
ans._entries = mzed_mul_karatsuba(ans._entries, self._entries, (<Matrix_mod2e_dense>right)._entries)
ans._entries = mzed_mul_karatsuba(ans._entries, self._entries, (<Matrix_gf2e_dense>right)._entries)
sig_off()
return ans

cpdef Matrix_mod2e_dense _multiply_strassen(Matrix_mod2e_dense self, Matrix_mod2e_dense right, cutoff=0):
cpdef Matrix_gf2e_dense _multiply_strassen(Matrix_gf2e_dense self, Matrix_gf2e_dense right, cutoff=0):
"""
Winograd-Strassen matrix multiplication with Newton-John
multiplication as base case.
Expand Down Expand Up @@ -609,17 +619,17 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if self._ncols != right._nrows:
raise ArithmeticError("left ncols must match right nrows")

cdef Matrix_mod2e_dense ans
cdef Matrix_gf2e_dense ans

ans = self.new_matrix(nrows = self.nrows(), ncols = right.ncols())
if self._nrows == 0 or self._ncols == 0 or right._ncols == 0:
return ans

if cutoff == 0:
cutoff = _mzed_strassen_cutoff(ans._entries, self._entries, (<Matrix_mod2e_dense>right)._entries)
cutoff = _mzed_strassen_cutoff(ans._entries, self._entries, (<Matrix_gf2e_dense>right)._entries)

sig_on()
ans._entries = mzed_mul_strassen(ans._entries, self._entries, (<Matrix_mod2e_dense>right)._entries, cutoff)
ans._entries = mzed_mul_strassen(ans._entries, self._entries, (<Matrix_gf2e_dense>right)._entries, cutoff)
sig_off()
return ans

Expand Down Expand Up @@ -660,7 +670,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
[ a 1 0 a a + 1 0 0 a + 1 1 a + 1]
"""
cdef m4ri_word a = poly_to_word(right)
cdef Matrix_mod2e_dense C = Matrix_mod2e_dense.__new__(Matrix_mod2e_dense, self._parent, 0, 0, 0)
cdef Matrix_gf2e_dense C = Matrix_gf2e_dense.__new__(Matrix_gf2e_dense, self._parent, 0, 0, 0)
mzed_mul_scalar(C._entries, a, self._entries)
return C

Expand Down Expand Up @@ -696,7 +706,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
"""
if self._nrows == 0 or self._ncols == 0:
return 0
return mzed_cmp(self._entries, (<Matrix_mod2e_dense>right)._entries)
return mzed_cmp(self._entries, (<Matrix_gf2e_dense>right)._entries)

def __copy__(self):
"""
Expand All @@ -718,8 +728,8 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
sage: A2[0,0]
a^2
"""
cdef Matrix_mod2e_dense A
A = Matrix_mod2e_dense.__new__(Matrix_mod2e_dense, self._parent, 0, 0, 0)
cdef Matrix_gf2e_dense A
A = Matrix_gf2e_dense.__new__(Matrix_gf2e_dense, self._parent, 0, 0, 0)

if self._nrows and self._ncols:
mzed_copy(A._entries, <const_mzed_t *>self._entries)
Expand Down Expand Up @@ -997,8 +1007,8 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
[0 1 0]
[0 0 1]
"""
cdef Matrix_mod2e_dense A
A = Matrix_mod2e_dense.__new__(Matrix_mod2e_dense, self._parent, 0, 0, 0)
cdef Matrix_gf2e_dense A
A = Matrix_gf2e_dense.__new__(Matrix_gf2e_dense, self._parent, 0, 0, 0)

if self._nrows and self._nrows == self._ncols:
mzed_invert_newton_john(A._entries, self._entries)
Expand Down Expand Up @@ -1132,7 +1142,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
"""
mzed_col_swap(self._entries, col1, col2)

def augment(self, Matrix_mod2e_dense right):
def augment(self, Matrix_gf2e_dense right):
"""
Augments ``self`` with ``right``.
Expand Down Expand Up @@ -1190,7 +1200,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
sage: M.augment(N)
[]
"""
cdef Matrix_mod2e_dense A
cdef Matrix_gf2e_dense A

if self._nrows != right._nrows:
raise TypeError, "Both numbers of rows must match."
Expand All @@ -1206,7 +1216,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
A._entries = mzed_concat(A._entries, self._entries, right._entries)
return A

def stack(self, Matrix_mod2e_dense other):
def stack(self, Matrix_gf2e_dense other):
"""
Stack ``self`` on top of ``other``.
Expand Down Expand Up @@ -1269,7 +1279,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if other._nrows == 0:
return self.__copy__()

cdef Matrix_mod2e_dense A
cdef Matrix_gf2e_dense A
A = self.new_matrix(nrows = self._nrows + other._nrows)
if self._ncols == 0:
return A
Expand Down Expand Up @@ -1335,7 +1345,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
if highr > self._entries.nrows:
raise TypeError("Expected highr <= self.nrows(), but got %d > %d instead."%(highr, self._entries.nrows))

cdef Matrix_mod2e_dense A = self.new_matrix(nrows = nrows, ncols = ncols)
cdef Matrix_gf2e_dense A = self.new_matrix(nrows = nrows, ncols = ncols)
if ncols == 0 or nrows == 0:
return A
A._entries = mzed_submatrix(A._entries, self._entries, row, col, highr, highc)
Expand Down Expand Up @@ -1388,8 +1398,8 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
sage: K.<a> = GF(2^8)
sage: A = random_matrix(K,70,70)
sage: f, s= A.__reduce__()
sage: from sage.matrix.matrix_mod2e_dense import unpickle_matrix_mod2e_dense_v0
sage: f == unpickle_matrix_mod2e_dense_v0
sage: from sage.matrix.matrix_gf2e_dense import unpickle_matrix_gf2e_dense_v0
sage: f == unpickle_matrix_gf2e_dense_v0
True
sage: f(*s) == A
True
Expand All @@ -1400,7 +1410,7 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
MS = MatrixSpace(GF(2), self._entries.x.nrows, self._entries.x.ncols)
A = Matrix_mod2_dense.__new__(Matrix_mod2_dense, MS, 0, 0, 0, alloc = False)
A._entries = mzd_copy( NULL, self._entries.x)
return unpickle_matrix_mod2e_dense_v0, (A, self.base_ring(), self.nrows(), self.ncols())
return unpickle_matrix_gf2e_dense_v0, (A, self.base_ring(), self.nrows(), self.ncols())

def slice(self):
r"""
Expand Down Expand Up @@ -1587,22 +1597,22 @@ cdef class Matrix_mod2e_dense(matrix_dense.Matrix_dense):
mzed_cling(self._entries, v)
mzd_slice_free(v)

def unpickle_matrix_mod2e_dense_v0(Matrix_mod2_dense a, base_ring, nrows, ncols):
def unpickle_matrix_gf2e_dense_v0(Matrix_mod2_dense a, base_ring, nrows, ncols):
"""
EXAMPLE::
sage: K.<a> = GF(2^2)
sage: A = random_matrix(K,10,10)
sage: f, s= A.__reduce__()
sage: from sage.matrix.matrix_mod2e_dense import unpickle_matrix_mod2e_dense_v0
sage: f == unpickle_matrix_mod2e_dense_v0
sage: from sage.matrix.matrix_gf2e_dense import unpickle_matrix_gf2e_dense_v0
sage: f == unpickle_matrix_gf2e_dense_v0
True
sage: f(*s) == A
True
"""
from sage.matrix.matrix_space import MatrixSpace

MS = MatrixSpace(base_ring, nrows, ncols)
cdef Matrix_mod2e_dense A = Matrix_mod2e_dense.__new__(Matrix_mod2e_dense, MS, 0, 0, 0)
cdef Matrix_gf2e_dense A = Matrix_gf2e_dense.__new__(Matrix_gf2e_dense, MS, 0, 0, 0)
mzd_copy(A._entries.x, a._entries)
return A
14 changes: 0 additions & 14 deletions src/sage/matrix/matrix_mod2e_dense.pxd

This file was deleted.

4 changes: 2 additions & 2 deletions src/sage/matrix/matrix_space.py
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@
import matrix_modn_sparse

import matrix_mod2_dense
import matrix_mod2e_dense
import matrix_gf2e_dense

import matrix_integer_dense
import matrix_integer_sparse
Expand Down Expand Up @@ -1012,7 +1012,7 @@ def _get_matrix_class(self):
return matrix_modn_dense_double.Matrix_modn_dense_double
return matrix_generic_dense.Matrix_generic_dense
elif sage.rings.finite_rings.constructor.is_FiniteField(R) and R.characteristic() == 2 and R.order() <= 65536:
return matrix_mod2e_dense.Matrix_mod2e_dense
return matrix_gf2e_dense.Matrix_gf2e_dense
elif sage.rings.polynomial.multi_polynomial_ring_generic.is_MPolynomialRing(R) and R.base_ring() in _Fields:
return matrix_mpolynomial_dense.Matrix_mpolynomial_dense
#elif isinstance(R, sage.rings.padics.padic_ring_capped_relative.pAdicRingCappedRelative):
Expand Down

0 comments on commit 1e6264d

Please sign in to comment.