1
0
mirror of https://github.com/kalmarek/PropertyT.jl.git synced 2024-11-30 01:55:28 +01:00
Commit Graph

522 Commits

Author SHA1 Message Date
d73f041c3c single definition o check_property_T 2018-09-05 09:06:00 +02:00
19e52909ac move Laplacians to separate file 2018-09-05 08:58:46 +02:00
278a62da2f move filename, etc to its section 2018-09-05 08:56:55 +02:00
c929b0f149 Move Settings to PropertyT.jl 2018-09-05 08:55:13 +02:00
859a751b01 fix typo 2018-09-03 10:23:08 +02:00
92d1d69177 separate non-zero indices 2018-08-20 04:02:44 +02:00
db6fe7f2cf use the new interpret results 2018-08-20 04:02:04 +02:00
6c247e73fc update check_property_T 2018-08-20 04:01:34 +02:00
c9b226f550 add compute/load prefixes 2018-08-20 04:00:58 +02:00
684283fd56 update addconstraints! to the new OrbitData 2018-08-20 04:00:14 +02:00
9cdcf27215 use SOS_problem-style "interface" for Symmetrized version as well 2018-08-20 03:59:39 +02:00
9c674ec284 update ortSVD to "where" syntax 2018-08-20 03:58:09 +02:00
1825cc0b3d simplify compute_orbit_data
by reusing of compute/load-Laplacian, etc
2018-08-20 03:57:33 +02:00
66ac37a6a7 slighlty more performant reconstruct_sol 2018-08-20 03:55:40 +02:00
5acc00a4d0 remove unused orbitLHS version 2018-08-20 03:54:29 +02:00
aad4359832 greatly simplify OrbitData struct 2018-08-20 03:54:03 +02:00
ed181d14f8 make orbit_constraint use new constraints indexing 2018-08-20 03:53:17 +02:00
45923d9597 indent 2018-08-20 03:52:16 +02:00
7f09e7c8b5 instead of recomputing Delta, just pass it 2018-08-20 03:51:51 +02:00
86e0ed373d Id = G() or one(G) is solved 2018-08-20 03:50:56 +02:00
668d403171 add selective constraint(pm, k) 2018-08-20 03:50:16 +02:00
33fc456879 constraints return linear indices 2018-08-20 03:50:03 +02:00
13bc1bef8b clearly separate creation of the optimization problem 2018-08-20 03:46:44 +02:00
d2f6682a39 mv logging to solve_SDP function 2018-08-20 03:45:50 +02:00
b509f3686d sparate logic and IO
IO is moved to the upper level
2018-08-20 03:44:24 +02:00
ebe9490465 rename: add load or compute prefixes to function names
to clarify their meaning
2018-08-20 03:42:57 +02:00
2ef67b5195 fix the G() <-> one(G) dispatch dillema 2018-08-20 03:35:34 +02:00
540946528c remove references to logger! 2018-08-19 20:05:45 +02:00
21bff490dd remove Memento's solverlog 2018-08-18 23:47:15 +02:00
0dfd85adba finally proper redirection of STDOUT to a file 2018-08-18 23:28:06 +02:00
28fe0820bc use where instead of f{T}(args) 2018-08-15 19:20:55 +02:00
e6ad20cb23 replace loop by array comprehension 2018-08-15 19:20:28 +02:00
e33800cfa1 use the simple string constructor for perm 2018-08-15 19:19:49 +02:00
6047d496d5 replace custom GroupRing constructor by alternating_emb function 2018-08-15 19:17:37 +02:00
854ddb42a1 function goes first in GroupRing constructor 2018-08-15 19:16:24 +02:00
677ae32ee2 rankOne_projections take a GroupRing now 2018-08-15 19:13:26 +02:00
0c2f5b1a9a extract checking if lambda > 0 ... block to a separate function 2018-08-15 19:10:38 +02:00
2d62aa26f2 add missing L1_norm 2018-08-15 19:09:01 +02:00
e4b5c59bd7 fix: use GroupRingElem constructor directly, when no basis is attached 2018-08-15 19:08:40 +02:00
c4a708ec8d central projections has full support 2018-08-15 17:21:31 +02:00
617f2f3410 rename to augmentation -> aug 2018-08-14 20:19:54 +02:00
919e1bb103 update Orbit-wise to changes in CheckSolution.jl 2018-08-14 19:21:46 +02:00
ddfc4dc47b update PropertyT.jl top changes in CheckSolution.jl 2018-08-14 19:21:09 +02:00
68a3cca76d remove overloads of ± 2018-08-14 19:18:58 +02:00
ff8f5d45c2 rework distance_to_cone 2018-08-14 19:18:36 +02:00
f9180d5d68 update autIdproj 2018-08-14 18:18:25 +02:00
6b0cbd0114 remove l (length) from args of 2018-08-14 18:17:38 +02:00
cdb3c39d2a rework IntervalArithmetic.± application 2018-08-14 17:21:35 +02:00
4f2caf84cd don't check correctness of permutations in preps 2018-08-08 19:38:44 +02:00
a26893f533 update to the Memento-0.9.0 2018-07-31 10:25:17 +02:00
81e08eb857 migrate to AbstractAlgebra 2018-07-31 10:21:54 +02:00
75c249abb8 remove iterator for FinField 2018-07-31 10:19:06 +02:00
d3a228cfa7 rework sparsify! Remove rank check which becomes very expensive
We check that the sizes of projection matrices add-up anyway
2018-07-31 10:18:03 +02:00
1ca77f1f19 add (RG::GroupRing)(::Vector, ::Type; alt=false)
this was previously defined in GroupRings
2018-07-31 09:49:55 +02:00
16dc0c7591 move OrbitSelector to orbit_selector outside of function
to avoid potential closure
2018-07-31 09:48:24 +02:00
f5afcf4dfb migrate Projections to AbstractAlgebra 2018-07-31 09:44:12 +02:00
5d6c4f8290 we work over PermutationGroup{Int8} 2018-04-10 12:21:08 +02:00
58fa849df0 fastm in rankOne_projections doesnt' change much in terms of speed 2018-04-09 12:56:20 +02:00
9d2140b5a8 fix nature of idempotents 2018-04-09 11:55:38 +02:00
a0cc9d62c9 fix: PermCharacter is in Projections, not in PropertyT 2018-04-09 11:14:39 +02:00
27569c11d8 export PermCharacter, DirectProdCharacter, rankOne_projection
from Projections module
2018-04-09 11:13:39 +02:00
44e3c9c0b9 add generator of characters for PermGroup, DirectProductGroup 2018-04-09 11:10:57 +02:00
11365bf5b2 big overhaul of rankOne_projections for WreathProduct Group 2018-04-09 11:07:12 +02:00
094abd74b8 simplify rankOne_projections for PermGroup 2018-04-08 22:50:31 +02:00
50588bc792 streamline logic in rankOne_projection from a character 2018-04-08 22:49:45 +02:00
5bed58de2c fix hacks around DirectProdCharacter
It should work over different groups as well
2018-04-08 22:48:42 +02:00
589e1882cd fix indentation 2018-04-08 22:46:28 +02:00
2d89c38657 separate Projections into a module 2018-04-08 22:45:18 +02:00
e5b4b9220b make orbit decomposition slightly faster by allocating orbit only once 2018-03-22 10:52:53 +01:00
db455df852 replace missing sett.warmstart by simple warm 2018-03-21 14:20:48 +01:00
94fa72ae80 update to parametrised perms in Nemo 2018-01-26 13:20:56 +01:00
550d69d78e no need to prefix 2018-01-25 21:39:06 +01:00
7a56aad3dc add warmstarting 2018-01-25 21:38:38 +01:00
cb3c6a0ef5 better printing of lambda 2018-01-04 20:13:41 +01:00
46ac64a207 use the same directory structure as the orbit version 2018-01-02 03:53:01 +01:00
dc91735bfc logtime of sdp solution; print the reresentation of SDP to log 2018-01-02 03:52:24 +01:00
6affa6876f sparsify prints only to stdout 2018-01-02 03:32:24 +01:00
f7534c2b97 logtime of lambdaandP; use LOGGER everywere 2018-01-02 03:32:04 +01:00
ac4ef92ef0 no need to pass both Group and S as arguments 2018-01-02 03:28:34 +01:00
f478081d4e reduce code duplication 2018-01-02 03:22:46 +01:00
955c8fc49e remove init_orbit_data 2018-01-02 03:19:57 +01:00
a87b587c1a add logger field to sett 2018-01-02 03:19:29 +01:00
35615c34cf logged and clean version of Laplacian 2018-01-02 03:02:22 +01:00
fd88de171b get rid of global loggers 2018-01-02 02:59:43 +01:00
7d22e8dce0 another rework of filenames 2018-01-02 02:58:43 +01:00
0d17e4b877 rework lambdaandP && solve_SDP 2018-01-02 02:52:45 +01:00
13f49027dd rename Delta -> Laplacian, splaplacian -> spLaplacian 2018-01-02 00:07:05 +01:00
b43482325d check_distance_to_cone returns single float 2018-01-02 00:02:00 +01:00
e5366b7305 decouple obtaining Delta from constraints 2018-01-02 00:01:24 +01:00
523003cc2a move fillfrominternal! to SDPs.jl 2018-01-01 23:59:31 +01:00
d5a4f4957a rework filename logic 2018-01-01 23:59:00 +01:00
f48e8ba8d7 return the global logger for now 2018-01-01 23:55:07 +01:00
7ac194f98a fix logtime macro 2018-01-01 23:54:36 +01:00
3066046fdb move checking logic to check_distance_to_cone function 2018-01-01 23:50:36 +01:00
b2f4360ef4 distence_to_cone(...) where {T<:...} does all the logging 2018-01-01 23:49:27 +01:00
5918e20569 replace distance_to_cone by distances_to_cone without logging 2018-01-01 23:48:17 +01:00
923d892da0 fix indentation, again 2018-01-01 23:45:49 +01:00
47f6d3637e fix indentation to 4 spaces 2018-01-01 14:06:33 +01:00
fc54803b58 fix Memento deprecations; make clear when logger is global 2018-01-01 13:13:44 +01:00
7054fcffe2 remove old loging 2017-12-02 23:21:00 +01:00
29f347a228 only check the solution when not warmstarting 2017-12-01 18:28:48 +01:00
5e4b2203c3 Nemo.perm is a function in julia v0.6.0 2017-12-01 18:26:55 +01:00
53d413633b add warmstart to Settings 2017-12-01 18:26:08 +01:00
c849ead0ac look for warmstart in the solutions dir 2017-12-01 17:27:18 +01:00
e94662e615 fill the JuMP model variables from its internal model 2017-12-01 17:06:20 +01:00
659e5e03a1 grab warmstart, P, lambda from the solved model 2017-12-01 17:05:35 +01:00
bbcaec5bae build JuMP.Model first 2017-12-01 17:04:53 +01:00
56adccdfd1 using MathProgBase 2017-12-01 17:03:24 +01:00
e53486f394 since we warmstart internal model, optimize! it
JuMP.solve discards the internal one
2017-12-01 17:02:45 +01:00
10808583e3 Merge remote-tracking branch 'origin/enh/warmstart' into enh/warmstart-0.6
# Conflicts:
#	src/OrbitDecomposition.jl
2017-12-01 14:21:10 +01:00
02cdee0708 remove old check for the existence of solver.log 2017-12-01 14:13:19 +01:00
da6a2df814 save primal, dual solutions and slack for future warmstart 2017-12-01 14:12:52 +01:00
7ee7a30829 fix rankOne_projections for the new type of GroupRingElem 2017-11-17 15:29:09 +01:00
bdadac33f4 import Generic.perm 2017-11-17 15:28:11 +01:00
0d20df8207 add dim function for Characters 2017-11-16 20:01:12 +01:00
498a6700ec Merge branch 'master' into enh/julia-v0.6 2017-11-15 20:28:57 +01:00
39bef16aa7 filter Upis and dims at LOADTIME for only those which are non-zeros 2017-11-13 10:58:22 +01:00
04a13616c6 Allow different AbstractMathProgSolvers in Settings 2017-11-13 10:57:02 +01:00
a35122f8bb cosmetic 2017-11-08 15:40:38 +01:00
38ae1e0656 remove minimalprojections in favour of rankOne_projections 2017-11-08 15:40:22 +01:00
e746aaeeff rankOne_projections MUST be computed over exact field (e.g. Rational{Int}) 2017-11-08 15:39:51 +01:00
d7652c4e02 make AbstractCharacter just an abstract type 2017-11-08 15:38:51 +01:00
6f0087b8c7 indentation 2017-11-08 11:10:30 +01:00
ea6a6722be init model on number and size of SD blocks, not on Uπs 2017-11-08 10:02:38 +01:00
bcbf8a03c8 store the dense Uπs, sparsify at read-time 2017-11-08 10:01:45 +01:00
fe1e9ee37c let sparsify actually return sparse matrix 2017-11-08 10:00:34 +01:00
2aa82db1ac specify exact types for OrbitData 2017-11-08 09:58:37 +01:00
c1dc3850dd rename AutS -> autS 2017-11-08 09:57:51 +01:00
4ba2f54bb4 improve slightly orthSVD 2017-11-08 09:50:58 +01:00
3c51a463dc rename variables 2017-11-08 09:38:56 +01:00
ff14b33199 AutS_mreps -> reps 2017-11-08 09:37:39 +01:00
95e19e6f9d replace stray constraints_from_pm() -> constraints() 2017-11-08 09:36:34 +01:00
80deaebb9f remove matrix_reprs - we create them through perm_reprs 2017-11-08 09:35:26 +01:00
72261afdeb use preps_reprs instead of matrix_reprs
and save them in preps.jld
2017-11-08 09:33:00 +01:00
2d02c98947 faster & simpler Cstar_repr 2017-11-08 09:29:12 +01:00
e636c97738 unified marix_reps and perm_reps 2017-11-08 09:28:04 +01:00
0c9fb40e65 constraints_from_pm -> constraints
returns a vector of constraints, i.e. vectors of Tuple{Int, Int}
2017-11-08 09:25:40 +01:00
31715701cc de-thread Projections
to avoid UndefRefError: access to undefined reference in
rankOne_projections(::WreathProduct)
2017-11-07 09:44:10 +01:00
12c5c47ca8 add Nemo.isone(::GroupElem) 2017-11-06 11:31:15 +01:00
84813fedc4 indentation 2017-11-05 20:55:53 +01:00
093cced764 Merge branch 'enh/logtime' 2017-11-05 20:55:05 +01:00
bc8c28170e missing @logtime in orbit-check_property_T 2017-11-05 20:54:33 +01:00
cda741cc0c Merge branch 'enh/check_solution' 2017-11-05 19:30:58 +01:00
36e5979774 @logtime Q = sqrtm(P) 2017-11-05 19:30:11 +01:00
f7f9ceef07 pass only the i-th column in @parallel mode
this cuts on memory per worker drastically
2017-11-05 19:28:51 +01:00
c3ea80e6a9 replace remaining @time with '@logtime logger' 2017-11-05 16:38:51 +01:00
c0dc6937a5 cut on allocations in compute_SOS 2017-11-03 16:54:41 +01:00
fba2464a80 Specify concrete Interval types in augIdproj 2017-11-03 16:42:53 +01:00
a000290074 remove rationalization functions 2017-11-03 16:41:12 +01:00
79d5c7f933 rename parameter S -> T 2017-11-02 13:48:20 +01:00