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


Java DistanceConflict.Conflict方法代碼示例

本文整理匯總了Java中org.cpsolver.studentsct.extension.DistanceConflict.Conflict方法的典型用法代碼示例。如果您正苦於以下問題:Java DistanceConflict.Conflict方法的具體用法?Java DistanceConflict.Conflict怎麽用?Java DistanceConflict.Conflict使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.cpsolver.studentsct.extension.DistanceConflict的用法示例。


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

示例1: getWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
@Override
protected double getWeight(Enrollment enrollment, Set<DistanceConflict.Conflict> distanceConflicts,
        Set<TimeOverlapsCounter.Conflict> timeOverlappingConflicts) {
    double weight = super.getWeight(enrollment, distanceConflicts, timeOverlappingConflicts);
    if (enrollment.isCourseRequest() && iPreferredSections != null) {
        Set<Section> preferred = iPreferredSections.get(enrollment.getRequest());
        if (preferred != null && !preferred.isEmpty()) {
            double nrPreferred = 0;
            for (Section section : enrollment.getSections())
                if (preferred.contains(section))
                    nrPreferred++;
            double preferredFraction = nrPreferred / preferred.size();
            weight *= 1.0 + iPreferenceFactor * preferredFraction;
        }
    }
    return weight;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:18,代碼來源:SuggestionSelection.java

示例2: getDistanceConflicts

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
/**
 * Distance conflicts of idx-th assignment of the current schedule
 */
public Set<DistanceConflict.Conflict> getDistanceConflicts(Enrollment[] assignment, int idx) {
    if (getModel().getDistanceConflict() == null || assignment[idx] == null)
        return null;
    Set<DistanceConflict.Conflict> dist = getModel().getDistanceConflict().conflicts(assignment[idx]);
    for (int x = 0; x < idx; x++)
        if (assignment[x] != null)
            dist.addAll(getModel().getDistanceConflict().conflicts(assignment[x], assignment[idx]));
    return dist;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:13,代碼來源:OnlineSectioningCriterion.java

示例3: toString

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
public String toString(Assignment<Request, Enrollment> a) {
    if (getAssignments().isEmpty()) return "not assigned";
    Set<DistanceConflict.Conflict> dc = distanceConflicts(a);
    Set<TimeOverlapsCounter.Conflict> toc = timeOverlappingConflicts(a);
    int share = 0;
    if (toc != null)
        for (TimeOverlapsCounter.Conflict c: toc)
            share += c.getShare();
    String ret = toDouble(a) + "/" + sDF.format(getRequest().getBound())
            + (getPenalty() == 0.0 ? "" : "/" + sDF.format(getPenalty()))
            + (dc == null || dc.isEmpty() ? "" : "/dc:" + dc.size())
            + (share <= 0 ? "" : "/toc:" + share);
    if (getRequest() instanceof CourseRequest) {
        double sameGroup = 0.0; int groupCount = 0;
        for (RequestGroup g: ((CourseRequest)getRequest()).getRequestGroups()) {
            if (g.getCourse().equals(getCourse())) {
                sameGroup += g.getEnrollmentSpread(a, this, 1.0, 0.0);
                groupCount ++;
            }
        }
        if (groupCount > 0)
            ret += "/g:" + sDF.format(sameGroup / groupCount);
    }
    if (getRequest() instanceof CourseRequest) {
        ret += " ";
        for (Iterator<? extends SctAssignment> i = getAssignments().iterator(); i.hasNext();) {
            SctAssignment assignment = i.next();
            ret += assignment + (i.hasNext() ? ", " : "");
        }
    }
    if (getReservation() != null) ret = "(r) " + ret;
    return ret;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:34,代碼來源:Enrollment.java

示例4: distanceConflicts

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
/** Distance conflicts, in which this enrollment is involved. 
 * @param assignment current assignment
 * @return distance conflicts
 **/
public Set<DistanceConflict.Conflict> distanceConflicts(Assignment<Request, Enrollment> assignment) {
    if (!isCourseRequest())
        return null;
    if (getRequest().getModel() instanceof StudentSectioningModel) {
        DistanceConflict dc = ((StudentSectioningModel) getRequest().getModel()).getDistanceConflict();
        if (dc == null) return null;
        return dc.allConflicts(assignment, this);
    } else
        return null;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:15,代碼來源:Enrollment.java

示例5: getDistanceConflicts

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
/**
 * Distance conflicts of idx-th assignment of the current
 * schedule
 * @param idx index of the request
 * @return set of distance conflicts
 */
public Set<DistanceConflict.Conflict> getDistanceConflicts(int idx) {
    if (iDistanceConflict == null || iAssignment[idx] == null)
        return null;
    Set<DistanceConflict.Conflict> dist = iDistanceConflict.conflicts(iAssignment[idx]);
    for (int x = 0; x < idx; x++)
        if (iAssignment[x] != null)
            dist.addAll(iDistanceConflict.conflicts(iAssignment[x], iAssignment[idx]));
    return dist;
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:16,代碼來源:BranchBoundSelection.java

示例6: getDistanceConflictWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
@Override
public double getDistanceConflictWeight(Assignment<Request, Enrollment> assignment, DistanceConflict.Conflict c) {
    if (c.getR1().getPriority() < c.getR2().getPriority()) {
        return round(getWeight(assignment, c.getE2()) * (c.getStudent().isNeedShortDistances() ? iShortDistanceConflict : iDistanceConflict));
    } else {
        return round(getWeight(assignment, c.getE1()) * (c.getStudent().isNeedShortDistances() ? iShortDistanceConflict : iDistanceConflict));
    }
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:9,代碼來源:PriorityStudentWeights.java

示例7: getWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
@Override
public double getWeight(Assignment<Request, Enrollment> assignment, Enrollment enrollment, Set<DistanceConflict.Conflict> distanceConflicts, Set<TimeOverlapsCounter.Conflict> timeOverlappingConflicts) {
    int share = 0;
    if (timeOverlappingConflicts != null) 
        for (TimeOverlapsCounter.Conflict c: timeOverlappingConflicts)
            share += c.getShare();
    return getWeight(assignment, enrollment)
           * (distanceConflicts == null || distanceConflicts.isEmpty() ? 1.0 : Math.pow(iDistConfWeight, distanceConflicts.size()))
           * Math.max(share == 0 ? 1.0 : 1.0 - (((double)share) / enrollment.getNrSlots()) / 2.0, 0.5);
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:11,代碼來源:OriginalStudentWeights.java

示例8: getDistanceConflictWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
@Override
public double getDistanceConflictWeight(Assignment<Request, Enrollment> assignment, DistanceConflict.Conflict c) {
    if (c.getR1().getPriority() < c.getR2().getPriority()) {
        return (1.0 - iDistConfWeight) * getWeight(assignment, c.getE1());
    } else {
        return (1.0 - iDistConfWeight) * getWeight(assignment, c.getE2());
    }
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:9,代碼來源:OriginalStudentWeights.java

示例9: getDistanceConflictWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
@Override
public double getDistanceConflictWeight(Assignment<Request, Enrollment> assignment,
        DistanceConflict.Conflict distanceConflict) {
    return iParent.getDistanceConflictWeight(assignment, distanceConflict);
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:6,代碼來源:StudentSchedulingAssistantWeights.java

示例10: add

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
public void add(Assignment<Request, Enrollment> assignment, DistanceConflict.Conflict c) {
    iTotalValue += avg(c.getR1().getWeight(), c.getR2().getWeight()) * iStudentWeights.getDistanceConflictWeight(assignment, c);
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:4,代碼來源:StudentSectioningModel.java

示例11: remove

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
public void remove(Assignment<Request, Enrollment> assignment, DistanceConflict.Conflict c) {
    iTotalValue -= avg(c.getR1().getWeight(), c.getR2().getWeight()) * iStudentWeights.getDistanceConflictWeight(assignment, c);
}
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:4,代碼來源:StudentSectioningModel.java

示例12: getWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
/**
 * Return weight of the given enrollment 
 * @param assignment current assignment
 * @param enrollment given enrollment
 * @param distanceConflicts distance conflicts
 * @param timeOverlappingConflicts time overlapping conflicts
 * @return weight (higher weight means better value)
 */
public double getWeight(Assignment<Request, Enrollment> assignment, Enrollment enrollment, Set<DistanceConflict.Conflict> distanceConflicts, Set<TimeOverlapsCounter.Conflict> timeOverlappingConflicts);
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:10,代碼來源:StudentWeights.java

示例13: getDistanceConflictWeight

import org.cpsolver.studentsct.extension.DistanceConflict; //導入方法依賴的package包/類
/**
 * Return weight of a distance conflict
 * @param assignment current assignment
 * @param distanceConflict distance conflict
 * @return weight of the conflict
 */
public double getDistanceConflictWeight(Assignment<Request, Enrollment> assignment, DistanceConflict.Conflict distanceConflict);
 
開發者ID:UniTime,項目名稱:cpsolver,代碼行數:8,代碼來源:StudentWeights.java


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