6d22c82ab3
create a general/saner homomorphism evaluation architecture
2020-03-25 15:43:38 +01:00
ebefc7e399
reshuffle AutGroup
2020-03-25 15:42:20 +01:00
0bee697ed8
update to AbstractAlgebra v0.9
2020-03-25 13:48:44 +01:00
622f5bc6b3
fix coercion to FPGroup
2020-03-25 13:46:32 +01:00
ac4ee69fc6
general cleanup
2020-03-25 05:24:34 +01:00
b125871697
unify the two definitions of generate_balls; rename to metric_ball
2020-03-25 05:23:06 +01:00
12be3b75bc
add missing constructors and converts
2020-03-25 05:21:57 +01:00
f8aedc207f
make FPGroups more connected to their freepreimages
2020-03-25 05:00:16 +01:00
2196b7d256
find and replace, finally
2020-03-25 04:42:47 +01:00
afa0988ebc
separate arithmetic
2020-03-25 04:41:23 +01:00
e84152a9cf
separate hashing and freereduce
2020-03-25 04:40:14 +01:00
43ad81d4dd
separate GWords
2020-03-25 04:19:02 +01:00
263444c2a9
add basic fallbacks
2020-03-25 04:16:21 +01:00
b92276ade2
separate GSymbols
2020-03-25 04:05:28 +01:00
5f0a33d335
overhaul findnext, findprev and replace
2020-03-25 03:54:12 +01:00
9bb2aba6f6
add issubword, issubsymbol
2020-03-25 03:38:33 +01:00
f7bf1598ee
make multiplication abstract
2020-03-25 03:36:36 +01:00
a3db467bd1
make one fully abstract method
2020-03-25 03:33:43 +01:00
99d5bc2f8c
fast equality for Automorphisms
2020-03-25 03:28:45 +01:00
8248039d63
simplify actions of PermAut and FlipAut
2020-03-25 00:51:53 +01:00
a1ebf530f4
in automoprhism evaluation no need to freereduce!
...
Symbols already do so, where appropriate
2020-03-25 00:47:45 +01:00
b9c2a90bae
rename *_autsymbol to more descriptive names
2020-03-25 00:46:23 +01:00
02ce259eb4
rewrite simplifyperms! in the new word api
2020-03-25 00:43:04 +01:00
6c53b3b7c0
favour append! and prepend! in place of rmul! and lmul!
2020-03-25 00:42:23 +01:00
189850858f
add to syllables commit
2020-03-25 00:38:07 +01:00
bc1063f0fd
use the new reduce for Automorphisms and FPWords
2020-03-25 00:27:47 +01:00
8688d42250
reduce defaults to freereduce now
2020-03-24 23:56:30 +01:00
8abebbbd0c
use the new api in freereduce!
2020-03-24 23:55:42 +01:00
b2d6c14515
use syllables api for GWords
2020-03-24 23:53:29 +01:00
7b211014e3
create and use uniform API for GSymbols
2020-03-24 23:47:50 +01:00
5810eeb4ae
create uniform hash interface using hash_internal
2020-03-24 23:44:03 +01:00
920bc1f28d
fix evaluate
2020-03-14 08:56:26 -07:00
68abfafd29
introduce evaluate function
2020-03-12 18:36:17 -05:00
6fd89c5a61
tweak the reduce! constant
2020-03-12 18:35:53 -05:00
5414988e98
periodically reduce words in automorphism evaluation
...
to avoid exponential explosion in length (when possible)
2020-03-12 00:18:33 -05:00
4bcd851031
fix FPGroups and add basic tests
2019-11-15 23:56:36 +01:00
dd4ed1497c
move from G() to Base.one(G)
2019-11-14 09:21:11 +01:00
32e968a79b
small update to hashing Automorphisms
2019-11-14 09:20:23 +01:00
8a42e33b6d
update to AA-v0.7 → bump to v0.2.3
2019-10-30 16:25:09 +01:00
998a9cdf43
remove MltGrp/AddGrp
2019-10-30 16:22:58 +01:00
fc4b01a193
broaden signature of generate_balls to include NCRingElems
2019-06-30 19:55:56 +02:00
54825b4964
add AbstractAlgebra.mul!
2019-06-05 10:58:44 +02:00
femtocleaner[bot]
be7b401762
Fix deprecations
2018-09-26 18:03:07 +00:00
883b85a7dc
re-parametrize WreathProducts
2019-01-09 16:44:04 +01:00
d579dd8f35
widen generate_balls's signature
2019-01-09 16:43:44 +01:00
1aa64647c8
replace strings with Symbols
2019-01-03 03:37:37 +01:00
3cc6262356
simplify type of AutSymbols
2019-01-03 03:37:02 +01:00
44f08716d2
iterate directly over groups (removes elements
)
2019-01-02 15:49:52 +01:00
4dcc9121a0
don't use try-catch in constructing WreatProductElements
2019-01-02 15:48:38 +01:00
74a559a17b
change WreathProducts accordingly
2019-01-02 15:47:58 +01:00
e8b90ab54a
base DirectPowerElem on N-tuples
2019-01-02 15:45:46 +01:00
38e327c385
replace DirectProduct -> DirectPower
2019-01-02 10:30:25 +01:00
3b1694f851
iteration for GFField
2018-09-21 19:10:28 +02:00
37af8ec218
remove automatic AdditiveGroup from WreathProductElem
2018-09-21 19:08:21 +02:00
68763ca37b
fix warnings with ^(..., n::Integer)
2018-09-21 18:47:02 +02:00
b5af5fc9b5
remove "Base.{...}"
2018-09-21 18:46:17 +02:00
fbc4d8aec7
fix problems with importing ×
2018-09-21 18:36:13 +02:00
46e2dc5faf
the new iterator protocol for AddGrp and MltGrp
2018-09-21 18:34:50 +02:00
0750a47853
rework DirectProdIter to the new iteration protocol
2018-09-21 18:14:48 +02:00
e28c296bce
PermGroup is iterable in AbstractAlgebra master
2018-09-21 18:10:34 +02:00
0286ca7c4d
replace converts by constructors
2018-09-21 18:09:13 +02:00
77efcdff3e
trivial changes for julia-0.7
2018-09-21 18:08:44 +02:00
e6d67ca3f7
add DirectPowerIter struct to iterate over DirectProduct
2018-08-08 14:12:55 +02:00
60c04f0dbd
fix type instability in domain
2018-08-07 23:51:15 +02:00
84d601817c
avoid creation of parent in perm_autsymbol and skip perm check
2018-08-01 23:21:47 +02:00
87a7285ba5
don't use length for permutation
2018-08-01 22:39:43 +02:00
d373a0c7c2
add comment why specialized deepcopy for GWords is necessary
2018-07-30 15:20:12 +02:00
7f25d96038
Automorphism: initialize hash to 0x0
2018-07-30 15:19:18 +02:00
e9ae22cfe9
convenience (S)Aut(G) and (G::WreathProduct)(n,p) constructors
2018-07-30 15:01:20 +02:00
0a20c5bb73
change hashing constant for reproducible hash of Automorphisms
2018-07-30 15:00:02 +02:00
192230c8d3
throw uniformly DomainError on check
2018-07-30 14:59:11 +02:00
0de75f1262
convenience constructors for DirectProduct
2018-07-30 14:56:28 +02:00
8a40d76143
add setindex!(::DirectProductGroupElem)
2018-07-30 14:54:54 +02:00
5ac1ea7ba8
rename Automorphism.typ -> Automorphism.fn
2018-07-30 14:54:09 +02:00
d78f1ec38a
remove specialized deepcopy
2018-07-30 14:53:20 +02:00
78abdc3181
fix elem_types: they dispatch on TYPE of parent
2018-07-30 14:07:42 +02:00
1783ba5065
fix indentation
2018-07-30 14:05:47 +02:00
0ab4df2ce5
WreathProduct uses the additive group of a ring by default
2018-07-30 14:03:51 +02:00
93253115ab
Introduce AddGrp, MltGrp etc.
...
for the additive group of a ring.
2018-07-30 14:03:04 +02:00
fe0e22f0bf
align to perms acting on the right
2018-07-30 13:54:15 +02:00
158ce5ee27
replace Nemo -> AbstractAlgebra
2018-07-30 08:30:27 +02:00
1597784ac5
add the standard linear representation for Automorphisms
2018-04-10 13:14:45 +02:00
df554480ea
parametrize WreathProduct over Integers
2018-04-10 13:09:50 +02:00
f2fb7f53cd
move ==(::GSymbol, ::GSymbol) to Groups.jl
2018-04-09 13:00:50 +02:00
b8abe64656
Parametrise Automorphisms on Integer type
2018-04-09 12:59:47 +02:00
3ac9231032
replace free_reduce! -> freereduce!
2018-04-02 18:19:55 +02:00
3ff1f1897e
fix simplify_perms! → simplifyperms!
...
Currently it passes twice over W.symbols, but should be correct
2018-04-02 18:18:12 +02:00
f9ede91343
replace delete_ids! -> deleteids!
2018-04-02 18:15:12 +02:00
c880b51346
remove isone(::GSymbol)
2018-03-29 19:37:32 +02:00
d1db939a63
newnew version of hash and ==
2018-03-29 19:24:15 +02:00
d83af99fbc
rework reduce! and sumplify_perms! using delete_ids!
2018-03-29 19:23:24 +02:00
40cf8a4e9f
new version of reduce! and free_reduce using delete_ids!
...
delete_ids requires second pass of W.symbols, but is so much easier to
get it right!
2018-03-29 19:19:34 +02:00
eed218da3c
rework hash, ==
2018-03-28 12:28:47 +02:00
e6b1b2a663
make id always have length 0
2018-03-28 12:21:50 +02:00
f493ed7283
rewrite simplify_perms!
2018-03-28 12:20:03 +02:00
6b0499005f
rename field of PermAut p->perm
2018-03-28 12:19:18 +02:00
17958fbd2c
accomodate to abstract GWord{T}
2018-03-27 21:48:36 +02:00
fc879f068b
clean-up findfirst, findnext
2018-03-27 21:48:02 +02:00
3a6506ae40
is_subsymbol -> issubsymbol
2018-03-27 21:31:23 +02:00
57dfc05221
shift documentation and GWord{T} definition
2018-03-27 21:30:36 +02:00
7139322d05
New version of hash and ==
...
evaluation of Automorphism on the standard basis is expensive
in hash(g::Automorphism, h::UInt) we
1. compute and store savedhash (evaluating f, if necessary) with a fixed value HASHINGCONST
2. xor h with savedhash
in == we evaluate f only at hash-colision (or when
This way we evaluate f multiple times only in ~2% of cases (for SAut(F_4))
2018-03-27 20:14:24 +02:00
6a7bb03d73
no need to store initial value of savedhash
...
it must be accessed after checking the modified filed
2018-03-27 18:24:40 +02:00
ffd5bbdc19
remove savedimage: Automorphism becomes prohibitively large
2018-03-27 18:23:43 +02:00
9e053df1a8
Add needed convert to Automorhphism{N}
2018-03-26 07:29:41 +02:00
a7bf32145c
replace AutGroupElem with Automorphism{N} <: GWord{AutSymbol}
...
this allows to store in the Automorphism struct
precomputed hash and
image of the canonical basis
2018-03-26 07:26:48 +02:00
0b800b5366
move includes to the top of the file
2018-03-26 07:25:32 +02:00
6939c0f00a
introduce GroupWord{T} <: GWord{T<:GSymbol}
...
This allows subtyping of GWord{T} with more specific group elements
2018-03-26 07:24:37 +02:00
02d947899f
immutable -> struct
2018-03-25 19:13:30 +02:00
c89ffbb4b4
constructing NTuple is faster than deepcopying it?
2018-03-25 19:12:29 +02:00
0233aedc41
use perms{Int8} in AutGroup and in tests
2018-03-22 17:24:23 +01:00
203e084ff3
don't print overly long presentations
2018-03-22 10:49:52 +01:00
d834935d05
be more specific on the type of objectGroup in AutGroup
2018-03-22 10:49:31 +01:00
c8f0ee04da
automorphisms apply in-place
2018-03-21 19:23:13 +01:00
dd4d23189b
domain(G::AutGroup) returns deepcopy of G.domain
2018-03-21 19:22:09 +01:00
49198dfdf4
use append! and prepend! instead of push! and unshift!
...
This also fixes a bug in l_multiply!
2018-03-21 19:21:03 +01:00
181073b517
use domain in hash and ==
2018-03-17 05:09:09 +01:00
acb1dbe6c8
use tuples in evaluation of AutSymbols
2018-03-17 05:08:42 +01:00
6a59c53c8f
add domain field to AutGroup
2018-03-17 05:01:21 +01:00
03b7590faa
fix merging master
2017-11-15 20:43:09 +01:00
c18e2156b5
Merge branch 'master' into enh/julia-v0.6
2017-11-15 20:34:30 +01:00
36279d2601
generate_balls for RingElem
2017-11-08 11:51:26 +01:00
99c07c6909
allow precompilation of the module
2017-11-08 09:06:50 +01:00
78881e1d79
more economical generate_balls using Base.product
2017-11-05 14:58:58 +01:00
04d1591c7d
actually cache and use savedhash + tests
2017-10-27 16:16:43 +02:00
5945462d45
no need for ispermauto function
...
handled easily by isa(..., PermAut)
2017-10-27 16:15:33 +02:00
5c14edc53c
update change_pow to the new AutSymbol
2017-10-27 16:14:28 +02:00
329e481d24
move getperm
2017-10-27 16:13:45 +02:00
0144c49372
AutSymbol evaluation -- much simpler
...
due to automorphism type carried as an attribute
2017-10-27 16:12:28 +02:00
3d2bc63723
creating AutSymbols
2017-10-27 16:11:18 +02:00
5f224f6713
Evaluation of {R,L}Transvec, PermAut, FlipAut types
2017-10-27 16:10:04 +02:00
e6a0ffd3d6
AutSymbol carries automorphism type, not expression
2017-10-27 16:09:23 +02:00
c593522ab9
fix the AutGroup gens
2017-10-24 15:27:43 +02:00
23d3787e34
evaluate AutSymbol
2017-10-24 15:26:27 +02:00
54e8eb0b43
remove .func field from autsymbol
2017-10-24 15:25:37 +02:00
30f44cca71
remove outer keyword (it was wrong!)
2017-10-04 21:34:59 +02:00
261f7761eb
use the new Nemo.Generic module
2017-09-15 18:54:32 +02:00
2e208032d2
use the new 0.6 syntax: structs, where etc.
...
one test broken
2017-09-13 16:47:31 +02:00
29d1b8364d
fix deprecation warnings
2017-09-13 15:48:40 +02:00
32a76f9efa
remove Compat
2017-09-13 11:22:21 +02:00
36b87c12fa
Merge branch 'master' into enh/julia-v0.6
...
# Conflicts:
# src/FPGroups.jl
2017-09-13 11:17:42 +02:00
a71f99670c
deepcopy S to avoid external changes
2017-08-08 19:15:55 +02:00
2e6372576e
argument name is not used in elem_type
2017-07-23 17:07:21 +02:00
cac6305852
trivial changes in docs
2017-07-23 17:04:22 +02:00
166c4c217b
parent_type dispatches after Type of element
2017-07-23 17:01:11 +02:00
b04a472063
combine * and inv under "Group Operations" label
2017-07-23 03:24:40 +02:00
251fdd4afa
fix setindex!
2017-07-23 03:24:05 +02:00
aad2907c51
fix: WreathProductElem is typed only after GroupElem
2017-07-21 17:14:55 +02:00
b7151d1fc2
docs
2017-07-21 16:05:49 +02:00
6fa01d87ef
faster versions of * and inv for products of rings
2017-07-21 16:04:45 +02:00
6f08259466
Don't multiply if not necessary -> directly create element
2017-07-21 16:04:11 +02:00