當前位置: 首頁>>代碼示例>>Java>>正文


Java Assignment類代碼示例

本文整理匯總了Java中org.cpsolver.ifs.assignment.Assignment的典型用法代碼示例。如果您正苦於以下問題:Java Assignment類的具體用法?Java Assignment怎麽用?Java Assignment使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Assignment類屬於org.cpsolver.ifs.assignment包,在下文中一共展示了Assignment類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: XStudent

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public XStudent(org.cpsolver.studentsct.model.Student student, Assignment<Request, Enrollment> assignment) {
 	super(student);
 	iStatus = student.getStatus();
 	iEmailTimeStamp = (student.getEmailTimeStamp() == null ? null : new Date(student.getEmailTimeStamp()));
 	for (AreaClassificationMajor acm: student.getAreaClassificationMajors()) {
 		iMajors.add(new XAreaClassificationMajor(acm.getArea(), acm.getClassification(), acm.getMajor()));
 	}
 	for (int i = 0; i < Math.min(student.getAcademicAreaClasiffications().size(), student.getMajors().size()); i++) {
 		iMajors.add(new XAreaClassificationMajor(student.getMajors().get(i).getArea(), student.getAcademicAreaClasiffications().get(i).getCode(), student.getMajors().get(i).getCode()));
 	}
 	for (AcademicAreaCode aac: student.getMinors()) {
 		if ("A".equals(aac.getArea()))
	iAccomodations.add(aac.getCode());
else
	iGroups.add(aac.getCode());
 	}
 	for (Request request: student.getRequests()) {
 		if (request instanceof FreeTimeRequest) {
 			iRequests.add(new XFreeTimeRequest((FreeTimeRequest)request));
 		} else if (request instanceof CourseRequest) {
 			iRequests.add(new XCourseRequest((CourseRequest)request, assignment == null ? null : assignment.getValue(request)));
 		}
 	}
 }
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:25,代碼來源:XStudent.java

示例2: getSection

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
protected Section getSection(TeachingClassRequest req) {
  	Class_ clazz = req.getTeachingClass();
CourseOffering course = clazz.getSchedulingSubpart().getControllingCourseOffering();
String room = null;
TimeLocation time = null;
org.unitime.timetable.model.Assignment assignment = clazz.getCommittedAssignment();
if (assignment != null) {
	time = assignment.getTimeLocation();
	for (Location location: assignment.getRooms()) {
		if (room == null) room = location.getLabel();
		else room += ", " + location.getLabel();
	}
}
return new Section(clazz.getUniqueId(), getClassExternalId(course, clazz),
		clazz.getSchedulingSubpart().getItypeDesc().trim(), clazz.getClassLabel(course),
		time, room, req.isCanOverlap(), req.isCommon());
  }
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:18,代碼來源:InstructorSchedulingDatabaseLoader.java

示例3: penalty

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public double penalty(Assignment<CurVariable, CurValue> assignment, CurStudent student) {
	return penalty(assignment, student, null);
	/*
	if (student == null) return 0.0;
	double penalty = 0;
	for (CurCourse course: iModel.getCourses()) {
		if (course.getCourseId().equals(getCourseId())) continue;
		double target = getTargetShare(course.getCourseId());
		double share = share(course);
		boolean contains = course.getStudents().contains(student);
		double size = course.getSize();
		if (!getStudents().contains(student)) {
			size += student.getWeight();
			if (contains) share += student.getWeight();
		}
		if ((share < target && !contains) || (share > target && contains))
			penalty += ((double)Math.abs(share - target)) / (contains ? share : size - share);
	}
	return penalty;
	*/
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:22,代碼來源:CurCourse.java

示例4: computeConflicts

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
@Override
public void computeConflicts(Assignment<CurVariable, CurValue> assignment, CurValue value, Set<CurValue> conflicts) {
	Set<CurCourse> courses = value.getStudent().getCourses(assignment);
	int nrCourses = courses.size();
	if (!courses.contains(value.variable().getCourse())) nrCourses++;
	for (CurValue conflict: conflicts) {
		if (conflict.getStudent().equals(value.getStudent()) && courses.contains(conflict.variable().getCourse()))
			nrCourses--;
	}
	if (nrCourses > iMaxLimit) {
		List<CurValue> adepts = new ArrayList<CurValue>();
		for (CurCourse course: courses) {
			if (course.equals(value.variable().getCourse())) continue;
			CurValue adept = course.getValue(assignment, value.getStudent());
			if (conflicts.contains(adept)) continue;
			adepts.add(adept);
		}
		conflicts.add(ToolBox.random(adepts));
		nrCourses --;
	}
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:22,代碼來源:CurStudentLimit.java

示例5: selectNeighbour

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
@Override
public Neighbour<CurVariable, CurValue> selectNeighbour(Solution<CurVariable, CurValue> solution) {
	CurModel model = (CurModel)solution.getModel();
	Assignment<CurVariable, CurValue> assignment = solution.getAssignment();
	int ix = ToolBox.random(model.variables().size());
	for (int i = 0; i < model.variables().size(); i++) {
		CurVariable course = model.variables().get((ix + i) % model.variables().size());
		CurValue current = assignment.getValue(course);
		if (!course.getCourse().isComplete(assignment) && current != null) continue;
		int jx = ToolBox.random(course.values(solution.getAssignment()).size());
		if (current != null && current.getStudent().getCourses(assignment).size() <= model.getStudentLimit().getMinLimit()) continue;
		for (int j = 0; j < course.values(solution.getAssignment()).size(); j++) {
			CurValue student = course.values(solution.getAssignment()).get((j + jx) % course.values(solution.getAssignment()).size());
			if (course.getCourse().getStudents(assignment).contains(student.getStudent())) continue;
			if (student.getStudent().getCourses(assignment).size() >= model.getStudentLimit().getMaxLimit()) continue;
			if (course.getCourse().getSize(assignment) + student.getStudent().getWeight() - (current == null ? 0.0 : current.getStudent().getWeight())
					> course.getCourse().getMaxSize()) continue;
			if (current != null && course.getCourse().getSize(assignment) + student.getStudent().getWeight() - current.getStudent().getWeight()
					< course.getCourse().getMaxSize() - model.getMinStudentWidth()) continue;
			return new CurSimpleAssignment(student);
		}
	}
	return null;
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:25,代碼來源:CurHillClimber.java

示例6: naive

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public void naive(DataProperties cfg, Assignment<CurVariable, CurValue> assignment) {
  	int maxIdle = cfg.getPropertyInt("Curriculum.Naive.MaxIdle", 1000);
  	sLog.debug("  -- running naive");
int idle = 0, it = 0;
double best = getTotalValue(assignment);
CurStudentSwap sw = new CurStudentSwap(cfg);
Solution<CurVariable, CurValue> solution = new Solution<CurVariable, CurValue>(this, assignment);
while (!getSwapCourses().isEmpty() && idle < maxIdle && canContinue()) {
	Neighbour<CurVariable, CurValue> n = sw.selectNeighbour(solution);
	if (n == null) break;
	double value = n.value(assignment);
	if (value < -0.00001) {
		idle = 0;
		n.assign(assignment, it);
	} else if (value <= 0.0) {
		n.assign(assignment, it);
	}
	if (getTotalValue(assignment) < best) {
		best = getTotalValue(assignment);
		sLog.debug("  -- best value: " + toString(assignment));
	}
	it++; idle++;
}
sLog.debug("  -- final value: " + toString(assignment));
  }
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:26,代碼來源:CurModel.java

示例7: DeptBalancingGroup

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public DeptBalancingGroup(Solver solver, DepartmentSpreadConstraint deptSpread) {
	Assignment<Lecture, Placement> assignment = solver.currentSolution().getAssignment();
	iDeptId = deptSpread.getDepartmentId();
	iDeptName = deptSpread.getName();
	iLimit = new int[iLastDaySlot - iFirstDaySlot + 1][iLastWorkDay - iFirstWorkDay + 1];
	iUsage = new int[iLastDaySlot - iFirstDaySlot + 1][iLastWorkDay - iFirstWorkDay + 1];
	iCourses = new HashSet[iLastDaySlot - iFirstDaySlot + 1][iLastWorkDay - iFirstWorkDay + 1];
	Hashtable detailCache = new Hashtable();
	SpreadConstraint.SpreadConstraintContext context = deptSpread.getContext(assignment);
	for (int i=0;i<iLastDaySlot - iFirstDaySlot + 1;i++) {
		for (int j=0;j<iLastWorkDay - iFirstWorkDay + 1;j++) {
			iLimit[i][j]=context.getMaxCourses(i + iFirstDaySlot, j + iFirstWorkDay);
			iUsage[i][j]=context.getCourses(i + iFirstDaySlot, j + iFirstWorkDay).size();
			iCourses[i][j]=new HashSet(context.getCourses(i + iFirstDaySlot, j + iFirstWorkDay).size());
			for (Placement placement: context.getCourses(i + iFirstDaySlot, j + iFirstWorkDay)) {
				Lecture lecture = (Lecture)placement.variable();
				ClassAssignmentDetails ca = (ClassAssignmentDetails)detailCache.get(lecture.getClassId());
				if (ca==null) {
					ca = new ClassAssignmentDetails(solver, lecture, false);
					detailCache.put(lecture.getClassId(),ca);
				}
				iCourses[i][j].add(ca);
			}
		}
	}
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:27,代碼來源:DeptBalancingReport.java

示例8: SameSubpartBalancingGroup

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public SameSubpartBalancingGroup(Solver solver, SpreadConstraint spread) {
	Assignment<Lecture, Placement> assignment = solver.currentSolution().getAssignment();
	SpreadConstraint.SpreadConstraintContext context = spread.getContext(assignment);
	iName = spread.getName();
	iLimit = new int[iLastDaySlot - iFirstDaySlot + 1][iLastWorkDay - iFirstWorkDay + 1];
	iUsage = new int[iLastDaySlot - iFirstDaySlot + 1][iLastWorkDay - iFirstWorkDay + 1];
	iCourses = new HashSet[iLastDaySlot - iFirstDaySlot + 1][iLastWorkDay - iFirstWorkDay + 1];
	Hashtable detailCache = new Hashtable();
	for (int i=0;i<iLastDaySlot - iFirstDaySlot + 1;i++) {
		for (int j=0;j<iLastWorkDay - iFirstWorkDay + 1;j++) {
			iLimit[i][j]=context.getMaxCourses(i + iFirstDaySlot, j + iFirstWorkDay);
			iUsage[i][j]=context.getCourses(i + iFirstDaySlot, j + iFirstWorkDay).size();
			iCourses[i][j]=new HashSet(context.getCourses(i + iFirstDaySlot, j + iFirstWorkDay).size());
			for (Placement placement: context.getCourses(i + iFirstDaySlot, j + iFirstWorkDay)) {
				Lecture lecture = (Lecture)placement.variable();
				ClassAssignmentDetails ca = (ClassAssignmentDetails)detailCache.get(lecture.getClassId());
				if (ca==null) {
					ca = new ClassAssignmentDetails(solver, lecture, false);
					detailCache.put(lecture.getClassId(),ca);
				}
				iCourses[i][j].add(ca);
			}
		}
	}
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:26,代碼來源:SameSubpartBalancingReport.java

示例9: createModel

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public static TimetableGridModel createModel(TimetableSolver solver, DepartmentSpreadConstraint department, TimetableGridContext context) {
	TimetableGridModel model = new TimetableGridModel(ResourceType.DEPARTMENT.ordinal(), department.getDepartmentId());
   	model.setName(department.getName());
   	model.setSize(department.variables().size());
   	model.setFirstDay(context.getFirstDay());
   	model.setFirstSessionDay(context.getFirstSessionDay());
   	model.setFirstDate(context.getFirstDate());

   	Assignment<Lecture, Placement> assignment = solver.currentSolution().getAssignment();
   	List<Placement> placements = new ArrayList<Placement>();
	for (Lecture lecture: department.variables()) {
		Placement placement = assignment.getValue(lecture);
		if (placement != null)
			placements.add(placement);
	}
	createCells(model, solver, placements, context, false);
	
	return model;
}
 
開發者ID:Jenner4S,項目名稱:unitimes,代碼行數:20,代碼來源:TimetableGridSolverHelper.java

示例10: ExamContext

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
@SuppressWarnings("unchecked")
public ExamContext(ExamModel model, Assignment<Exam, ExamPlacement> assignment) {
    iStudentTable = new Map[model.getNrPeriods()];
    for (int i = 0; i < iStudentTable.length; i++)
        iStudentTable[i] = new HashMap<ExamStudent, Set<Exam>>();
    iStudentDayTable = new Map[model.getNrDays()];
    for (int i = 0; i < iStudentDayTable.length; i++)
        iStudentDayTable[i] = new HashMap<ExamStudent, Set<Exam>>();
    iInstructorTable = new Map[model.getNrPeriods()];
    for (int i = 0; i < iInstructorTable.length; i++)
        iInstructorTable[i] = new HashMap<ExamInstructor, Set<Exam>>();
    iInstructorDayTable = new Map[model.getNrDays()];
    for (int i = 0; i < iInstructorDayTable.length; i++)
        iInstructorDayTable[i] = new HashMap<ExamInstructor, Set<Exam>>();
    for (Exam exam: model.variables()) {
        ExamPlacement placement = assignment.getValue(exam);
        if (placement != null)
            assigned(assignment, placement);
    }
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:21,代碼來源:ExamContext.java

示例11: toString

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
/**
 * String representation -- returns a list of values of objective criteria
 * @param assignment current assignment
 * @return comma separated string of {@link TimetablingCriterion#toString(Assignment)}
 */
public String toString(Assignment<V, T> assignment) {
    List<Criterion<V, T>> criteria = new ArrayList<Criterion<V,T>>(getCriteria());
    Collections.sort(criteria, new Comparator<Criterion<V, T>>() {
        @Override
        public int compare(Criterion<V, T> c1, Criterion<V, T> c2) {
            int cmp = -Double.compare(c1.getWeight(), c2.getWeight());
            if (cmp != 0) return cmp;
            return c1.getName().compareTo(c2.getName());
        }
    });
    String ret = "";
    for (Criterion<V, T> criterion: criteria) {
        String val = criterion.toString(assignment);
        if (val != null && !val.isEmpty())
            ret += ", " + val;
    }
    return (nrUnassignedVariables(assignment) == 0 ? "" : "V:" + nrAssignedVariables(assignment) + "/" + variables().size() + ", ") + "T:" + sDoubleFormat.format(getTotalValue(assignment)) + ret;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:24,代碼來源:Model.java

示例12: findRooms

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
public Set<ExamRoomPlacement> findRooms(Assignment<Exam, ExamPlacement> assignment, Exam exam, ExamPeriodPlacement period) {
    Set<ExamRoomPlacement> rooms = exam.findBestAvailableRooms(assignment, period);
    if (rooms != null) return rooms;
    
    rooms = new HashSet<ExamRoomPlacement>();
    int size = 0;
    while (size < exam.getSize()) {
        ExamRoomPlacement bestRoom = null; int bestSize = 0;
        for (ExamRoomPlacement r: exam.getRoomPlacements()) {
            if (!r.isAvailable(period.getPeriod())) continue;
            if (rooms.contains(r)) continue;
            if (!r.getRoom().getPlacements(assignment, period.getPeriod()).isEmpty()) continue;
            int s = r.getSize(exam.hasAltSeating());
            if (bestRoom == null || s > bestSize) {
                bestRoom = r;
                bestSize = s;
            }
        }
        if (bestRoom == null) return rooms;
        rooms.add(bestRoom); size += bestSize;
    }
    
    return rooms;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:25,代碼來源:ExamColoringConstruction.java

示例13: getPenaltyIfUnassigned

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
private int getPenaltyIfUnassigned(Assignment<Lecture, Placement> assignment, Placement placement, int[][] nrCourses) {
    SpreadConstraintContext context = getContext(assignment);
    int firstSlot = placement.getTimeLocation().getStartSlot();
    if (firstSlot > iLastDaySlot)
        return 0;
    int endSlot = firstSlot + placement.getTimeLocation().getNrSlotsPerMeeting() - 1;
    if (endSlot < iFirstDaySlot)
        return 0;
    int penalty = 0;
    for (int i = Math.max(firstSlot, iFirstDaySlot); i <= Math.min(endSlot, iLastDaySlot); i++) {
        for (int j = iFirstWorkDay; j <= iLastWorkDay; j++) {
            int dayCode = Constants.DAY_CODES[j % 7];
            if ((dayCode & placement.getTimeLocation().getDayCode()) != 0 && nrCourses[i - iFirstDaySlot][j - iFirstWorkDay] > context.getMaxCourses(i, j))
                penalty++;
        }
    }
    return penalty;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:19,代碼來源:SpreadConstraint.java

示例14: restoreBest

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
@Override
public void restoreBest(Assignment<Request, Enrollment> assignment) {
    restoreBest(assignment, new Comparator<Request>() {
        @Override
        public int compare(Request r1, Request r2) {
            Enrollment e1 = r1.getBestAssignment();
            Enrollment e2 = r2.getBestAssignment();
            // Reservations first
            if (e1.getReservation() != null && e2.getReservation() == null) return -1;
            if (e1.getReservation() == null && e2.getReservation() != null) return 1;
            // Then assignment iteration (i.e., order in which assignments were made)
            if (r1.getBestAssignmentIteration() != r2.getBestAssignmentIteration())
                return (r1.getBestAssignmentIteration() < r2.getBestAssignmentIteration() ? -1 : 1);
            // Then student and priority
            return r1.compareTo(r2);
        }
    });
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:19,代碼來源:StudentSectioningModel.java

示例15: accept

import org.cpsolver.ifs.assignment.Assignment; //導入依賴的package包/類
/**
 * True if the given neighboir is to be be accepted
 * 
 * @param solution
 *            current solution
 * @param neighbour
 *            proposed move
 * @return true if generated random number is below
 *         {@link ExamSimulatedAnnealing.Context#prob(double)}
 */
protected boolean accept(Solution<Exam, ExamPlacement> solution, Neighbour<Exam, ExamPlacement> neighbour) {
    if (neighbour instanceof LazyNeighbour) {
        ((LazyNeighbour<Exam, ExamPlacement>)neighbour).setAcceptanceCriterion(this);
        return true;
    }
    Assignment<Exam, ExamPlacement> assignment = solution.getAssignment();
    double value = (iRelativeAcceptance ? neighbour.value(assignment) : solution.getModel().getTotalValue(assignment) + neighbour.value(assignment) - solution.getBestValue());
    Context context = getContext(solution.getAssignment());
    double prob = context.prob(value);
    if (prob >= 1.0 || ToolBox.random() < prob) {
        context.accepted(neighbour.value(assignment));
        return true;
    }
    return false;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:26,代碼來源:ExamSimulatedAnnealing.java


注:本文中的org.cpsolver.ifs.assignment.Assignment類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。