当前位置: 首页>>代码示例>>C++>>正文


C++ Problem::getClient方法代码示例

本文整理汇总了C++中Problem::getClient方法的典型用法代码示例。如果您正苦于以下问题:C++ Problem::getClient方法的具体用法?C++ Problem::getClient怎么用?C++ Problem::getClient使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Problem的用法示例。


在下文中一共展示了Problem::getClient方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: getClosestSatellite

int getClosestSatellite(Client c, const Problem &p) {
    double distance = Config::DOUBLE_INFINITY;
    int closestSatellite;

    for (int i = 0; i < p.getSatellites().size(); i++) {
        if (p.getDistance(c, p.getClient(i)) < distance) {
            distance = p.getDistance(c, p.getClient(i));
            closestSatellite = i;
        }
    }

    return closestSatellite;
}
开发者ID:Plentyne,项目名称:Projet-de-Fin-d-Etudes,代码行数:13,代码来源:Heuristic.cpp

示例2: getClosestClient

/* TODO Review simpleHeuristic
 *      - Il arrive que le résultat de l'heuristique change
 *      - Peut causer la fin anormale du programme : certainement en relation avcv les warnings pour l'instanciation des tableaux
 *      - Revoir l'accès aux vecteurs de E1Route et de Solution et l'unifier
 *      - Mettre à jour les valeurs du Tableau Goods de E1Route pour garder trace de ui transporte quoi
*/
int getClosestClient(E2Route e2Route, const Problem &p, vector<int> &clientAffectation) {
    double distance = Config::DOUBLE_INFINITY;
    int closestClient = -1;

    for (int i = 0; i < p.getClients().size(); i++) {
        if (e2Route.departureSatellite != clientAffectation[i]) continue;

        if (e2Route.tour.size() > 0) {
            if (p.getDistance(p.getClient(e2Route.tour.back()), p.getClient(i)) < distance) {
                distance = p.getDistance(p.getClient(e2Route.tour.back()), p.getClient(i));
                closestClient = i;
            }
        } else {
            if (p.getDistance(p.getSatellite(e2Route.departureSatellite), p.getClient(i)) < distance) {
                distance = p.getDistance(p.getSatellite(e2Route.departureSatellite), p.getClient(i));
                closestClient = i;
            }
        }
    }
    if (closestClient >= 0) clientAffectation[closestClient] = -1;
    return closestClient;
}
开发者ID:Plentyne,项目名称:Projet-de-Fin-d-Etudes,代码行数:28,代码来源:Heuristic.cpp

示例3: simpleHeuristic

void Heuristic::simpleHeuristic(const Problem p, Solution &solution) {
    // Instanciation de la solution
    solution = Solution(&p);
    // Construction des tournées du 1er échelon
    // Affectation des clients aux satellties
    vector<int> clientsAffectation{static_cast<int>(p.getClients().size())};
    for (int i = 0; i < p.getClients().size(); ++i) {
        clientsAffectation[i] = getClosestSatellite(p.getClient(i), p);
    }

    // Calcul des tournées
    int closestClient;
    E2Route e2Route;
    e2Route.tour.clear();
    e2Route.load = 0;
    e2Route.cost = 0;
    for(Satellite satellite : p.getSatellites()) {
        e2Route.departureSatellite = satellite.getSatelliteId();
        solution.getSatelliteDemands()[e2Route.departureSatellite] = 0;
        while ((closestClient = getClosestClient(e2Route, p, clientsAffectation)) >= 0) {
            if ((e2Route.load + p.getClient(closestClient).getDemand()) > p.getE2Capacity()) {
                e2Route.cost += p.getDistance(satellite, p.getClient(e2Route.tour.back()));

                solution.getE2Routes().push_back(e2Route);
                solution.getSatelliteDemands()[e2Route.departureSatellite] += e2Route.load;
                solution.setTotalCost(solution.getTotalCost() + e2Route.cost);

                e2Route.tour.clear();
                e2Route.load = 0;
                e2Route.departureSatellite = satellite.getSatelliteId();
                e2Route.cost = 0;
            }

            if (e2Route.tour.size() > 0) {
                e2Route.cost += p.getDistance(p.getClient(e2Route.tour.back()), p.getClient(closestClient));
            } else {
                e2Route.cost += p.getDistance(satellite, p.getClient(closestClient));
            }
            e2Route.tour.push_back(p.getClient(closestClient).getClientId());
            e2Route.load += p.getClient(closestClient).getDemand();

        }

        if (e2Route.tour.size() > 0) {
            e2Route.cost += p.getDistance(p.getSatellite(e2Route.departureSatellite), p.getClient(e2Route.tour.back()));

            solution.getE2Routes().push_back(e2Route);
            solution.getSatelliteDemands()[e2Route.departureSatellite] += e2Route.load;
            solution.setTotalCost(solution.getTotalCost() + e2Route.cost);

        }
        e2Route.tour.clear();
        e2Route.load = 0;
        e2Route.departureSatellite = satellite.getSatelliteId();
        e2Route.cost = 0;
    }
    // Construction des tournées du 1er échelon
    E1Route e1Route;
    e1Route.tour.clear();
    e1Route.cost = 0;
    e1Route.load = 0;

    for (int j = 0; j < solution.getDeliveredQ().size(); ++j) {
        solution.getDeliveredQ()[j] = 0;
    }

    int closestSatellite;
    while ((closestSatellite = getClosestSatellite(e1Route, solution)) >= 0) {
        if ((e1Route.load + solution.getSatelliteDemands()[closestSatellite] -
             solution.getDeliveredQ()[closestSatellite]) > p.getE1Capacity()) {
            // Si la demande d'un satellite dépasse celle du véhicule
            // On prend une partie de sa demande et on la charge dans la tournée courantes
            if (solution.getSatelliteDemands()[closestSatellite] - solution.getDeliveredQ()[closestSatellite] >
                p.getE1Capacity()) {
                solution.getDeliveredQ()[closestSatellite] += (p.getE1Capacity() - e1Route.load);
                if (e1Route.tour.size() > 0) {
                    e1Route.cost += p.getDistance(p.getSatellite(e1Route.tour.back()),
                                                  p.getSatellite(closestSatellite));
                } else {
                    e1Route.cost += p.getDistance(p.getDepot(), p.getSatellite(closestSatellite));
                }
                e1Route.tour.push_back(p.getSatellite(closestSatellite).getSatelliteId());
                e1Route.load = p.getE1Capacity();
            }
            // Sinon

            e1Route.cost += p.getDistance(p.getDepot(), p.getSatellite(e1Route.tour.back()));

            solution.getE1Routes().push_back(e1Route);
            solution.setTotalCost(solution.getTotalCost() + e1Route.cost);

            e1Route.tour.clear();
            e1Route.load = 0;
            e1Route.cost = 0;
        }
        // Ajout du satellite dans la tournée actuelle
        if (e1Route.tour.size() > 0) {
            e1Route.cost += p.getDistance(p.getSatellite(e1Route.tour.back()), p.getSatellite(closestSatellite));
        } else {
            e1Route.cost += p.getDistance(p.getDepot(), p.getSatellite(closestSatellite));
//.........这里部分代码省略.........
开发者ID:Plentyne,项目名称:Projet-de-Fin-d-Etudes,代码行数:101,代码来源:Heuristic.cpp


注:本文中的Problem::getClient方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。