-
Notifications
You must be signed in to change notification settings - Fork 2
/
default.cfg
860 lines (839 loc) · 30.1 KB
/
default.cfg
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
## Solver Configuration File
## Name: TEST
## Date: Sun Sep 02 15:22:22 CEST 2018
######################################
## Basic Settings
######################################
## Solver mode
## Type: enum(Initial,MPP)
Basic.Mode=Initial
## When finished
## Type: enum(No Action,Save,Save as New,Save and Unload,Save as New and Unload)
Basic.WhenFinished=No Action
## Students sectioning
## Type: boolean
General.SwitchStudents=true
## Load committed assignments
## Type: boolean
General.LoadCommittedAssignments=false
## Student course demands
## Type: enum(Last Like Student Course Demands,Weighted Last Like Student Course Demands,Projected Student Course Demands,Curricula Course Demands,Curricula Last Like Course Demands,Student Course Requests,Enrolled Student Course Demands)
Curriculum.StudentCourseDemadsClass=Projected Student Course Demands
## Committed student conflicts
## Type: enum(Load,Compute,Ignore)
General.CommittedStudentConflicts=Load
## Allow breaking of hard constraints
## Type: boolean
Basic.DisobeyHard=false
## General Settings
######################################
## Use conflict-based statistics
## Type: boolean
General.CBS=true
Extensions.Classes=org.cpsolver.ifs.extension.ConflictStatistics
## Minimal number of unassigned variables to save best solution found (-1 always save)
## Type: integer
General.SaveBestUnassigned=-1
## Use building distances
## Type: boolean
General.UseDistanceConstraints=true
## Use same subpart balancing
## Type: boolean
General.Spread=true
## Use automatic same_students constraints
## Type: boolean
General.AutoSameStudents=true
## Time preference normalization decrease factor
## Type: double
General.NormalizedPrefDecreaseFactor=0.77
## Use search intensification
## Type: boolean
## Default: true
General.SearchIntensification=false
## Load student enrollments from solution<BR>(faster, but it ignores new classes)
## Type: boolean
Global.LoadStudentEnrlsFromSolution=false
## Settings Id
## Type: integer
## Default: -1
General.SettingsId=2228224
## Use departmental balancing
## Type: boolean
General.DeptBalancing=false
## Solver Warnings
## Type: text
General.SolverWarnings=
## Automatic same student constraint
## Type: enum(SAME_STUDENTS,DIFF_TIME)
General.AutoSameStudentsConstraint=SAME_STUDENTS
## Ignore Room Sharing
## Type: boolean
General.IgnoreRoomSharing=false
## Do not load committed student conflicts (deprecated)
## Type: boolean
General.IgnoreCommittedStudentConflicts=false
## Weight last-like students (deprecated)
## Type: boolean
General.WeightStudents=true
## Automatic precedence constraint
## Type: enum(Required,Strongly Preferred,Preferred,Neutral)
General.AutoPrecedence=Neutral
## Number of unassignments for the discouraged room constraint to weaken
## Type: integer
DiscouragedRoom.Unassignments2Weaken=1000
## Curriculum Course Demands: Include Other Students
## Type: boolean
CurriculaCourseDemands.IncludeOtherStudents=true
## Additional Criteria (semicolon separated list of class names)
## Type: text
General.AdditionalCriteria=org.cpsolver.coursett.criteria.additional.ImportantStudentConflict;org.cpsolver.coursett.criteria.additional.ImportantStudentHardConflict
## Purge invalid placements during the data load
## Type: boolean
General.PurgeInvalidPlacements=true
## Important Curriculum Groups (regexp matching the group name -- all courses of a matching group are marked as important)
## Type: text
CurriculumEnrollmentPriority.GroupMatch=.*
## Precedence Constraint: consider date patterns
## Type: text
Precedence.ConsiderDatePatterns=true
## Joint Enrollment Constraint: conflict limit (% limit of the smaller class)
## Type: double
General.JenrlMaxConflicts=1.0
## Joint Enrollment Constraint: limit weakening
## Type: double
General.JenrlMaxConflictsWeaken=0.001
## Load student instructor conflicts
## Type: boolean
Global.LoadStudentInstructorConflicts=false
## Automatic hierarchical constraints (comma separated list of a preference, a constraint name and optional date pattern)
## Type: text
General.AutomaticHierarchicalConstraints=
## Fix complete solution interval (min number of iteration from the previous best solution)
## Type: integer
## Default: 1
General.CompleteSolutionFixInterval=-1
## Fix incomplete solution interval (min number of non improving iterations, -1 to disable)
## Type: integer
## Default: 5000
General.IncompleteSolutionFixInterval=-1
## Search Algorithm
## Type: enum(IFS,GD,SA,Default,Experimental)
General.SearchAlgorithm=GD
Neighbour.Class=org.cpsolver.ifs.algorithms.SimpleSearch
## Student Sectioning
## Type: enum(Default,Deterministic,Branch & Bound,Local Search,B&B Groups)
## Default: Default
General.StudentSectioning=Local Search
## Class Weights
## Type: enum(Default Class Weights,Average Hours A Week Class Weights)
ClassWeightProvider.Class=Default Class Weights
## Minimal-perturbation Setting
######################################
## Perturbation Penalty
######################################
## Different value than initial is assigned
## Type: double
Perturbations.DifferentPlacement=0.0
## Number of students which are enrolled in a class which is placed to a different location than initial
## Type: double
Perturbations.AffectedStudentWeight=0.1
## Number of classes which are placed to a different room than initial
## Type: double
Perturbations.AffectedInstructorWeight=0.0
## Number of classes which are placed to a different room than initial
## Type: double
Perturbations.DifferentRoomWeight=0.0
## Number of classes which are placed to a different building than initial
## Type: double
Perturbations.DifferentBuildingWeight=0.0
## Number of classes which are placed in a different time than initial
## Type: double
Perturbations.DifferentTimeWeight=0.0
## Number of classes which are placed in a different days than initial
## Type: double
Perturbations.DifferentDayWeight=0.0
## Number of classes which are placed in a different hours than initial
## Type: double
Perturbations.DifferentHourWeight=0.0
## Difference of student conflicts of classes assigned to current placements instead of initial placements
## Type: double
Perturbations.DeltaStudentConflictsWeight=0.0
## New created student conflicts -- particular students are taken into account
## Type: double
Perturbations.NewStudentConflictsWeight=0.0
## New placement of a class is too far from the intial placement (instructor-wise)
## Type: double
Perturbations.TooFarForInstructorsWeight=0.0
## New placement of a class is too far from the intial placement (student-wise)
## Type: double
Perturbations.TooFarForStudentsWeight=0.0
## Difference between number of instructor distance preferences of the initial
## Type: double
Perturbations.DeltaInstructorDistancePreferenceWeight=0.0
## Difference between room preferences of the initial and the current solution
## Type: double
Perturbations.DeltaRoomPreferenceWeight=0.0
## Difference between time preferences of the initial and the current solution
## Type: double
Perturbations.DeltaTimePreferenceWeight=0.0
## Number of students which are enrolled in a class which is placed to a different time than initial
## Type: double
Perturbations.AffectedStudentByTimeWeight=0.0
## Number of instructors which are assigned to classes which are placed to different time than initial
## Type: double
Perturbations.AffectedInstructorByTimeWeight=0.0
## Number of students which are enrolled in a class which is placed to a different room than initial
## Type: double
Perturbations.AffectedStudentByRoomWeight=0.0
## Number of instructors which are assigned to classes which are placed to different room than initial
## Type: double
Perturbations.AffectedInstructorByRoomWeight=0.0
## Number of students which are enrolled in a class which is placed to a different building than initial
## Type: double
Perturbations.AffectedStudentByBldgWeight=0.0
## Number of instructors which are assigned to classes which are placed to different building than initial
## Type: double
Perturbations.AffectedInstructorByBldgWeight=0.0
## Departmental Balancing
######################################
## Initial allowance of the slots for a particular time
## Type: double
DeptBalancing.SpreadFactor=1.2
## Increase the initial allowance when it causes the given number of unassignments
## Type: integer
DeptBalancing.Unassignments2Weaken=0
## Conflict-based Statistics
######################################
## Ageing (koef)
## Type: double
ConflictStatistics.Ageing=1.0
## Ageing -- half time (number of iteration)
## Type: integer
ConflictStatistics.AgeingHalfTime=0
## Print conflict statistics
## Type: boolean
ConflictStatistics.Print=true
## Number of iterations to print CBS (-1 just keep in memory and save within the solution)
## Type: integer
ConflictStatistics.PrintInterval=-1
## Termination Conditions
######################################
## Minimal allowed number of perturbances (-1 not use)
## Type: integer
Termination.MinPerturbances=-1
## Maximal number of iteration
## Type: integer
Termination.MaxIters=-1
## Maximal solver time (in sec)
## Type: integer
Termination.TimeOut=7200
## Stop computation when a complete solution is found
## Type: boolean
Termination.StopWhenComplete=false
## Solution Comparator Weights
######################################
## Weight of hard student conflict
## Type: double
## Default: 0.8
Comparator.HardStudentConflictWeight=8.0
## Weight of student conflict
## Type: double
## Default: 0.2
Comparator.StudentConflictWeight=2.0
## Time preferences weight
## Type: double
## Default: 0.3
Comparator.TimePreferenceWeight=1.0
## Distribution preferences weight
## Type: double
## Default: 2.0
Comparator.ContrPreferenceWeight=10.0
## Room preferences weight
## Type: double
Comparator.RoomPreferenceWeight=1.0
## Useless slots weight
## Type: double
## Default: 0.1
Comparator.UselessSlotWeight=0.0
## Too big room weight
## Type: double
## Default: 0.1
Comparator.TooBigRoomWeight=0.0
## Back-to-back instructor preferences weight
## Type: double
## Default: 1.0
Comparator.DistanceInstructorPreferenceWeight=0.0
## Perturbation penalty weight
## Type: double
## Default: 1.0
Comparator.PerturbationPenaltyWeight=0.0
## Weight of distance student conflict
## Type: double
## Default: 0.2
Comparator.DistStudentConflictWeight=2.0
## Department balancing weight
## Type: double
## Default: 1.0
Comparator.DeptSpreadPenaltyWeight=0.0
## Same subpart balancing weight
## Type: double
## Default: 1.0
Comparator.SpreadPenaltyWeight=0.0
## Commited student conflict weight
## Type: double
## Default: 1.0
Comparator.CommitedStudentConflictWeight=0.0
## Weight of important student conflict
## Type: double
Comparator.ImportantStudentConflictWeight=0.0
## Weight of important hard student conflict
## Type: double
Comparator.ImportantHardStudentConflictWeight=0.0
## Excessive room size weight
## Type: double
## Default: 0.001
Comparator.RoomSizeWeight=0.0
## Excessive room size factor
## Type: double
## Default: 1.05
Comparator.RoomSizeFactor=1.0
## Flexible constraint weight
## Type: double
## Default: %Comparator.ContrPreferenceWeight%
FlexibleConstraint.Weight=10.0
## Lecture Selection
######################################
## Roulette wheel selection
## Type: boolean
Lecture.RouletteWheelSelection=true
## Random walk probability
## Type: double
Lecture.RandomWalkProb=1.0
## Domain size weight
## Type: double
Lecture.DomainSizeWeight=30.0
## Number of assignments weight
## Type: double
Lecture.NrAssignmentsWeight=10.0
## Initial assignment weight
## Type: double
Lecture.InitialAssignmentWeight=20.0
## Number of constraint weight
## Type: double
Lecture.NrConstraintsWeight=0.0
## Hard student conflict weight
## Type: double
## Default: %Comparator.HardStudentConflictWeight%
Lecture.HardStudentConflictWeight=25.0
## Student conflict weight
## Type: double
## Default: %Comparator.StudentConflictWeight%
Lecture.StudentConflictWeight=5.0
## Time preference weight
## Type: double
## Default: %Comparator.TimePreferenceWeight%
Lecture.TimePreferenceWeight=2.0
## Constraint preference weight
## Type: double
## Default: %Comparator.ContrPreferenceWeight%
Lecture.ContrPreferenceWeight=5.0
## Distance student conflict weight
## Type: double
## Default: %Comparator.DistStudentConflictWeight%
Lecture.DistStudentConflictWeight=1.0
## Room preference weight
## Type: double
## Default: %Comparator.RoomPreferenceWeight%
Lecture.RoomPreferenceWeight=1.0
## Useless slot weight
## Type: double
## Default: %Comparator.UselessSlotWeight%
Lecture.UselessSlotWeight=0.0
## Too big room weight
## Type: double
## Default: %Comparator.TooBigRoomWeight%
Lecture.TooBigRoomWeight=0.0
## Back-to-back instructor preferences weight
## Type: double
## Default: %Comparator.DistanceInstructorPreferenceWeight%
Lecture.DistanceInstructorPreferenceWeight=0.0
## Department balancing weight
## Type: double
## Default: %Comparator.DeptSpreadPenaltyWeight%
Lecture.DeptSpreadPenaltyWeight=0.0
## Selection among subset of lectures (faster)
## Type: boolean
Lecture.SelectionSubSet=true
## Minimal subset size
## Type: integer
Lecture.SelectionSubSetMinSize=10
## Subset size in percentage of all lectures available for selection
## Type: double
Lecture.SelectionSubSetPart=0.2
## Same subpart balancing weight
## Type: double
## Default: %Comparator.SpreadPenaltyWeight%
Lecture.SpreadPenaltyWeight=0.0
## Commited student conflict weight
## Type: double
## Default: %Comparator.CommitedStudentConflictWeight%
Lecture.CommitedStudentConflictWeight=0.0
## Placement Selection
######################################
## Random walk probability
## Type: double
Placement.RandomWalkProb=0.00
## MPP initial selection probability
## Type: double
Placement.MPP_InitialProb=0.20
## MPP limit (-1 for no limit)
## Type: integer
Placement.MPP_Limit=-1
## Limit of the perturbations penalty (-1 for no limit)
## Type: double
Placement.MPP_PenaltyLimit=-1.0
## Number of assignments weight (level 1)
## Type: double
Placement.NrAssignmentsWeight1=0.0
## Number of conflicts weight (level 1)
## Type: double
## Default: 1.0
Placement.NrConflictsWeight1=1000.0
## Weighted conflicts weight (CBS, level 1)
## Type: double
## Default: 2.0
Placement.WeightedConflictsWeight1=2000.0
## Number of potential conflicts weight (CBS, level 1)
## Type: double
Placement.NrPotentialConflictsWeight1=0.0
## Delta initial assigments weight (MPP, level 1)
## Type: double
## Default: 0.1
Placement.MPP_DeltaInitialAssignmentWeight1=0.0
## Hard student conflicts weight (level 1)
## Type: double
## Default: 0.3
Placement.NrHardStudConfsWeight1=8.0
## Student conflicts weight (level 1)
## Type: double
## Default: 0.05
Placement.NrStudConfsWeight1=2.0
## Distance student conflict weight (level 1)
## Type: double
## Default: 0.05
Placement.NrDistStudConfsWeight1=2.0
## Time preference weight (level 1)
## Type: double
Placement.TimePreferenceWeight1=0.0
## Distance student conflict weight (level 2)
## Type: double
## Default: %Comparator.DistStudentConflictWeight%
Placement.NrDistStudConfsWeight2=2.0
## Time preference delta weight (level 1)
## Type: double
## Default: 0.2
Placement.DeltaTimePreferenceWeight1=1.0
## Distance student conflict weight (level 3)
## Type: double
Placement.NrDistStudConfsWeight3=0.0
## Constraint preference weight (level 1)
## Type: double
## Default: 0.25
Placement.ConstrPreferenceWeight1=10.0
## Room preference weight (level 1)
## Type: double
## Default: 0.1
Placement.RoomPreferenceWeight1=1.0
## Useless slot weight (level 1)
## Type: double
Placement.UselessSlotsWeight1=0.0
## Too big room weight (level 1)
## Type: double
## Default: 0.01
Placement.TooBigRoomWeight1=0.0
## Back-to-back instructor preferences weight (level 1)
## Type: double
## Default: 0.1
Placement.DistanceInstructorPreferenceWeight1=0.0
## Department balancing: penalty of when a slot over initial allowance is used (level 1)
## Type: double
## Default: 0.1
Placement.DeptSpreadPenaltyWeight1=0.0
## Threshold koeficient (level 1)
## Type: double
Placement.ThresholdKoef1=0.1
## Number of assignments weight (level 2)
## Type: double
Placement.NrAssignmentsWeight2=0.0
## Number of conflicts weight (level 2)
## Type: double
Placement.NrConflictsWeight2=0.0
## Weighted conflicts weight (CBS, level 2)
## Type: double
Placement.WeightedConflictsWeight2=0.0
## Number of potential conflicts weight (CBS, level 2)
## Type: double
Placement.NrPotentialConflictsWeight2=0.0
## Delta initial assigments weight (MPP, level 2)
## Type: double
## Default: %Comparator.PerturbationPenaltyWeight%
Placement.MPP_DeltaInitialAssignmentWeight2=0.0
## Hard student conflicts weight (level 2)
## Type: double
## Default: %Comparator.HardStudentConflictWeight%
Placement.NrHardStudConfsWeight2=8.0
## Student conflicts weight (level 2)
## Type: double
## Default: %Comparator.StudentConflictWeight%
Placement.NrStudConfsWeight2=2.0
## Time preference weight (level 2)
## Type: double
## Default: %Comparator.TimePreferenceWeight%
Placement.TimePreferenceWeight2=1.0
## Time preference delta weight (level 2)
## Type: double
Placement.DeltaTimePreferenceWeight2=0.0
## Constraint preference weight (level 2)
## Type: double
## Default: %Comparator.ContrPreferenceWeight%
Placement.ConstrPreferenceWeight2=10.0
## Room preference weight (level 2)
## Type: double
## Default: %Comparator.RoomPreferenceWeight%
Placement.RoomPreferenceWeight2=1.0
## Useless slot weight (level 2)
## Type: double
## Default: %Comparator.UselessSlotWeight%
Placement.UselessSlotsWeight2=0.0
## Too big room weight (level 2)
## Type: double
## Default: %Comparator.TooBigRoomWeight%
Placement.TooBigRoomWeight2=0.0
## Back-to-back instructor preferences weight (level 2)
## Type: double
## Default: %Comparator.DistanceInstructorPreferenceWeight%
Placement.DistanceInstructorPreferenceWeight2=0.0
## Department balancing: penalty of when a slot over initial allowance is used (level 2)
## Type: double
## Default: %Comparator.DeptSpreadPenaltyWeight%
Placement.DeptSpreadPenaltyWeight2=0.0
## Threshold koeficient (level 2)
## Type: double
Placement.ThresholdKoef2=0.1
## Number of assignments weight (level 3)
## Type: double
Placement.NrAssignmentsWeight3=0.0
## Number of conflicts weight (level 3)
## Type: double
Placement.NrConflictsWeight3=0.0
## Weighted conflicts weight (CBS, level 3)
## Type: double
Placement.WeightedConflictsWeight3=0.0
## Number of potential conflicts weight (CBS, level 3)
## Type: double
Placement.NrPotentialConflictsWeight3=0.0
## Delta initial assigments weight (MPP, level 3)
## Type: double
Placement.MPP_DeltaInitialAssignmentWeight3=0.0
## Hard student conflicts weight (level 3)
## Type: double
Placement.NrHardStudConfsWeight3=0.0
## Student conflicts weight (level 3)
## Type: double
Placement.NrStudConfsWeight3=0.0
## Time preference weight (level 3)
## Type: double
Placement.TimePreferenceWeight3=0.0
## Time preference delta weight (level 3)
## Type: double
Placement.DeltaTimePreferenceWeight3=0.0
## Constraint preference weight (level 3)
## Type: double
Placement.ConstrPreferenceWeight3=0.0
## Room preference weight (level 3)
## Type: double
Placement.RoomPreferenceWeight3=0.0
## Useless slot weight (level 3)
## Type: double
Placement.UselessSlotsWeight3=0.0
## Too big room weight (level 3)
## Type: double
Placement.TooBigRoomWeight3=0.0
## Back-to-back instructor preferences weight (level 3)
## Type: double
Placement.DistanceInstructorPreferenceWeight3=0.0
## Department balancing: penalty of when a slot over initial allowance is used (level 3)
## Type: double
Placement.DeptSpreadPenaltyWeight3=0.0
## Same subpart balancing: penalty of when a slot over initial allowance is used (level 1)
## Type: double
## Default: 0.1
Placement.SpreadPenaltyWeight1=0.0
## Same subpart balancing: penalty of when a slot over initial allowance is used (level 2)
## Type: double
## Default: %Comparator.SpreadPenaltyWeight%
Placement.SpreadPenaltyWeight2=0.0
## Same subpart balancing: penalty of when a slot over initial allowance is used (level 3)
## Type: double
Placement.SpreadPenaltyWeight3=0.0
## Commited student conlict weight (level 1)
## Type: double
## Default: 0.5
Placement.NrCommitedStudConfsWeight1=0.0
## Commited student conlict weight (level 2)
## Type: double
## Default: %Comparator.CommitedStudentConflictWeight%
Placement.NrCommitedStudConfsWeight2=0.0
## Commited student conlict weight (level 3)
## Type: double
Placement.NrCommitedStudConfsWeight3=0.0
## Can unassign a singleton value
## Type: boolean
## Default: true
Placement.CanUnassingSingleton=false
## Important student conflict weight (level 1)
## Type: double
Placement.NrImportantStudConfsWeight1=0.0
## Important student conflict weight (level 2)
## Type: double
## Default: %Comparator.ImportantStudentConflictWeight%
Placement.NrImportantStudConfsWeight2=0.0
## Important student conflict weight (level 3)
## Type: double
Placement.NrImportantStudConfsWeight3=0.0
## Important hard student conflict weight (level 1)
## Type: double
Placement.NrImportantHardStudConfsWeight1=0.0
## Important hard student conflict weight (level 2)
## Type: double
## Default: %Comparator.ImportantHardStudentConflictWeight%
Placement.NrImportantHardStudConfsWeight2=0.0
## Important hard student conflict weight (level 3)
## Type: double
Placement.NrImportantHardStudConfsWeight3=0.0
## Flexible constraint preference weight (level 1)
## Type: double
## Default: %Placement.ConstrPreferenceWeight1%
Placement.FlexibleConstrPreferenceWeight1=10.0
## Flexible constraint preference weight (level 2)
## Type: double
## Default: %FlexibleConstraint.Weight%
Placement.FlexibleConstrPreferenceWeight2=10.0
## Flexible constraint preference weight (level 3)
## Type: double
## Default: %Placement.ConstrPreferenceWeight3%
Placement.FlexibleConstrPreferenceWeight3=0.0
## Implementations
######################################
## Perturbations counter
## Type: text
PerturbationCounter.Class=org.cpsolver.coursett.heuristics.UniversalPerturbationsCounter
## Termination condition
## Type: text
Termination.Class=org.cpsolver.ifs.termination.MPPTerminationCondition
## Solution comparator
## Type: text
Comparator.Class=org.cpsolver.coursett.heuristics.TimetableComparator
## Lecture selection
## Type: text
Variable.Class=org.cpsolver.coursett.heuristics.LectureSelection
## Placement selection
## Type: text
Value.Class=org.cpsolver.coursett.heuristics.PlacementSelection
## Saver class
## Type: text
TimetableLoader=org.cpsolver.coursett.itc2019.ItcCompetitionLoader
## Saver class
## Type: text
TimetableSaver=org.cpsolver.coursett.itc2019.ItcCompetitionSaver
## Same Subpart Balancing
######################################
## Initial allowance of the slots for a particular time
## Type: double
Spread.SpreadFactor=1.2
## Increase the initial allowance when it causes the given number of unassignments
## Type: integer
Spread.Unassignments2Weaken=50
## Search Intensification
######################################
## Iteration limit (number of iteration after which the search is restarted to the best known solution)
## Type: integer
SearchIntensification.IterationLimit=100
## Number of consecutive restarts to increase iteration limit (if this number of restarts is reached, iteration limit is increased)
## Type: integer
SearchIntensification.ResetInterval=5
## Iteration limit incremental coefficient (when a better solution is found, iteration limit is changed back to initial)
## Type: integer
SearchIntensification.MultiplyInterval=2
## Reset conflict-based statistics (number of consecutive restarts after which CBS is cleared, zero means no reset of CBS)
## Type: integer
SearchIntensification.Multiply=2
## Default Time Preferences
######################################
## Time preferences weight
## Type: double
TimePreferences.Weight=0.0
## Time preferences
## Type: timepref
TimePreferences.Pref=2222222222222224222222222222222223333222222222222222222222222224222222222222222223333222222222222222222222222224222222222222222223333222222222222222222222222224222222222222222223333222222222222222222222222224222222222222222223333222222222222222222222
## Distances
######################################
## Instructor Constraint: No Preference Limit
## Type: double
Instructor.NoPreferenceLimit=0.0
## Instructor Constraint: Discouraged Limit
## Type: double
Instructor.DiscouragedLimit=50.0
## Instructor Constraint: Prohibited Limit
## Type: double
Instructor.ProhibitedLimit=200.0
## Student Conflict: Distance Limit (deprecated)
## Type: double
Student.DistanceLimit=67.0
## Student Conflict: Distance Limit (after 75min class, deprecated)
## Type: double
Student.DistanceLimit75min=100.0
## Ellipsoid to be used to compute distances
## Type: enum(DEFAULT,LEGACY,WGS84,GRS80,Airy1830,Intl1924,Clarke1880,GRS67)
## Default: DEFAULT
Distances.Ellipsoid=LEGACY
## Student speed in meters per minute
## Type: double
Distances.Speed=67.0
## Compute Distance Conflicts Between Non BTB Classes
## Type: boolean
## Default: false
Distances.ComputeDistanceConflictsBetweenNonBTBClasses=on
## Instructor Long Travel in Minutes (only when computing distances between non-BTB classes is enabled)
## Type: double
Instructor.InstructorLongTravelInMinutes=30.0
## Neighbour Selection
######################################
## Probability of using suggestions
## Type: double
Neighbour.SuggestionProbability=0.01
## Suggestions timeout
## Type: integer
Neighbour.SuggestionTimeout=500
## Suggestions depth
## Type: integer
Neighbour.SuggestionDepth=4
## Probability of using suggestions (when all classes are assigned)
## Type: double
Neighbour.SuggestionProbabilityAllAssigned=0.5
## Construction: heuristics
## Type: text
Construction.Class=org.cpsolver.coursett.heuristics.NeighbourSelectionWithSuggestions
## Construction: use construction heuristic untill a complete solution is found
## Type: boolean
Construction.UntilComplete=false
## Use great deluge (instead of simulated annealing)
## Type: boolean
Search.GreatDeluge=true
## Hill Climber: max idle iterations
## Type: integer
HillClimber.MaxIdle=10000
## Hill Climber: Additional neighbourhoods
## Type: text
HillClimber.AdditionalNeighbours=org.cpsolver.coursett.neighbourhoods.TimeChange;org.cpsolver.coursett.neighbourhoods.RoomChange;[email protected];[email protected]
## Great Deluge: cooling rate
## Type: double
GreatDeluge.CoolRate=0.9999999
## Great Deluge: upper bound
## Type: double
GreatDeluge.UpperBoundRate=1.05
## Great Deluge: lower bound
## Type: double
GreatDeluge.LowerBoundRate=0.95
## Great Deluge: Additional neighbourhoods
## Type: text
GreatDeluge.AdditionalNeighbours=org.cpsolver.coursett.neighbourhoods.TimeChange;org.cpsolver.coursett.neighbourhoods.RoomChange;[email protected];[email protected]
## Simulated Annealing: initial temperature
## Type: double
SimulatedAnnealing.InitialTemperature=1.5
## Simulated Annealing: temperature length (number of iterations between temperature decrements)
## Type: integer
SimulatedAnnealing.TemperatureLength=2500
## Simulated Annealing: cooling rate
## Type: double
SimulatedAnnealing.CoolingRate=0.95
## Simulated Annealing: temperature re-heat length coefficient
## Type: double
SimulatedAnnealing.ReheatLengthCoef=5.0
## Simulated Annealing: temperature re-heating rate (default (1/coolingRate)^(reheatLengthCoef*1.7))
## Type: double
SimulatedAnnealing.ReheatRate=-1
## Simulated Annealing: restore best length coefficient (default reheatLengthCoef^2)
## Type: double
SimulatedAnnealing.RestoreBestLengthCoef=-1
## Simulated Annealing: stochastic search acceptance
## Type: boolean
SimulatedAnnealing.StochasticHC=false
## Simulated Annealing: relative acceptance (compare with current solution, not the best one)
## Type: boolean
SimulatedAnnealing.RelativeAcceptance=true
## Simulated Annealing: Additional neighbourhoods
## Type: text
SimulatedAnnealing.AdditionalNeighbours=org.cpsolver.coursett.neighbourhoods.TimeChange;org.cpsolver.coursett.neighbourhoods.RoomChange;[email protected];[email protected]
## On Fly Student Sectioning
######################################
## Enable on fly sectioning (if enabled, students will be resectioned after each iteration)
## Type: boolean
OnFlySectioning.Enabled=false
## Recursively resection lectures affected by a student swap
## Type: boolean
OnFlySectioning.Recursive=true
## Resection students between configurations as well
## Type: boolean
OnFlySectioning.ConfigAsWell=false
## Instructor Lunch Breaks
######################################
## Enable Instructor Lunch Breaks
## Type: boolean
InstructorLunch.Enabled=false
## Weight
## Type: double
InstructorLunch.Weight=0.18
## Start slot
## Type: integer
InstructorLunch.StartSlot=132
## End slot
## Type: integer
InstructorLunch.EndSlot=162
## Minum break length (in slots)
## Type: integer
InstructorLunch.Length=6
## Violations multiplication factor
## Type: double
InstructorLunch.Multiplier=1.15
## Show violations in the solution info
## Type: boolean
InstructorLunch.InfoShowViolations=false
## Curriculum Conversion
######################################
## Search Phases
## Type: text
Curriculum.Phases=HC,Deluge
## Hill Climber: max idle iterations
## Type: integer
Curriculum.HC.MaxIdle=1000
## Great Deluge: cooling rate
## Type: double
Curriculum.Deluge.Factor=0.999999
## Great Deluge: upper bound
## Type: double
Curriculum.Deluge.UpperBound=1.25
## Great Deluge: lower bound
## Type: double
Curriculum.Deluge.LowerBound=0.75
## Student Sectioning parameters
#######################################
StudentSectioning.Class=org.cpsolver.coursett.sectioning.StudentSwapSectioning
StudentSwaps.UseCriteria=false
StudentSwaps.Deluge.Factor=0.999999
StudentSwaps.MaxIdleResection=10
## Other Properties
######################################
Parallel.NrSolvers=1
Xml.ShowNames=true
General.UseAmPm=true