1

私は .mod ファイルを持っていて、それを Java で実行できます (netbeans を使用)。このファイルは別のファイル .dat からデータを取得します。これは、開発者が GUSEK を使用していたためです。Javaで実装する必要がありますが、.modファイルのK定数にデータを入れる方法がわかりません。

方法は関係ありません。データベース クエリまたはファイルの読み取りを使用できます。

数学プログラミングについては何も知りません。既に作成された glpk 関数に値を追加するだけです。

.mod 関数は次のとおりです。

# OPRE

set K;

param mc {k in K};
param phi {k in K};
param cman {k in K};
param ni {k in K};
param cesp;
param mf;

var x {k in K} binary;

minimize custo: sum {k in K} (mc[k]*phi[k]*(1-x[k]) + cman[k]*phi[k]*x[k]);

s.t. recursos: sum {k in K} (cman[k]*phi[k]*x[k]) - cesp <= 0;
s.t. ocorrencias: sum {k in K} (ni[k] + (1-x[k])*phi[k]) - mf <= 0;

end;

そして、ここにJavaコードがあります:

package br.com.genera.service.otimi;

import org.gnu.glpk.*;

public class Gmpl implements GlpkCallbackListener, GlpkTerminalListener {

    private boolean hookUsed = false;

    public static void main(String[] arg) {

        String[] nomeArquivo = new String[2];
        nomeArquivo[0] = "C:\\PodaEquipamento.mod";

        System.out.println(nomeArquivo[0]);
        GLPK.glp_java_set_numeric_locale("C");
        System.out.println(nomeArquivo[0]);
        new Gmpl().solve(nomeArquivo);
    }

    public void solve(String[] arg) {
        glp_prob lp = null;
        glp_tran tran;
        glp_iocp iocp;

        String fname;
        int skip = 0;
        int ret;

        // listen to callbacks
        GlpkCallback.addListener(this);
        // listen to terminal output
        GlpkTerminal.addListener(this);

        fname = arg[0];

        lp = GLPK.glp_create_prob();
        System.out.println("Problem created");
        tran = GLPK.glp_mpl_alloc_wksp();
        ret = GLPK.glp_mpl_read_model(tran, fname, skip);
        if (ret != 0) {
            GLPK.glp_mpl_free_wksp(tran);
            GLPK.glp_delete_prob(lp);
            throw new RuntimeException("Model file not found: " + fname);
        }

        // generate model
        GLPK.glp_mpl_generate(tran, null);
        // build model
        GLPK.glp_mpl_build_prob(tran, lp);
        // set solver parameters
        iocp = new glp_iocp();
        GLPK.glp_init_iocp(iocp);
        iocp.setPresolve(GLPKConstants.GLP_ON);

        // do not listen to output anymore
        GlpkTerminal.removeListener(this);
        // solve model
        ret = GLPK.glp_intopt(lp, iocp);
        // postsolve model
        if (ret == 0) {
            GLPK.glp_mpl_postsolve(tran, lp, GLPKConstants.GLP_MIP);
        }
        // free memory
        GLPK.glp_mpl_free_wksp(tran);
        GLPK.glp_delete_prob(lp);

        // do not listen for callbacks anymore
        GlpkCallback.removeListener(this);

        // check that the hook function has been used for terminal output.
        if (!hookUsed) {
            System.out.println("Error: The terminal output hook was not used.");
            System.exit(1);
        }
    }

    @Override
    public boolean output(String str) {
        hookUsed = true;
        System.out.print(str);
        return false;
    }

    @Override
    public void callback(glp_tree tree) {
        int reason = GLPK.glp_ios_reason(tree);
        if (reason == GLPKConstants.GLP_IBINGO) {
            System.out.println("Better solution found");
        }
    }
}

そして、私はコンソールでこれを取得しています:

Reading model section from C:\PodaEquipamento.mod...
33 lines were read
Generating custo...
C:\PodaEquipamento.mod:24: no value for K
glp_mpl_build_prob: invalid call sequence

誰かが助けてくれることを願っています、ありがとう。

4

2 に答える 2

3

最善の方法は、モデル ファイルを読み取るのと同じ方法でデータ ファイルを読み取ることです。

ret = GLPK.glp_mpl_read_data(tran, fname_data, skip);
if (ret != 0) {
    GLPK.glp_mpl_free_wksp(tran);
    GLPK.glp_delete_prob(lp);
    throw new RuntimeException("Data file not found: " + fname_data);
}
于 2015-03-31T08:49:19.497 に答える
0

データブロックを .data ファイルから .mod ファイルにコピーするだけで解決しました。

とにかく、puhgeeに感謝します。

于 2015-04-08T10:58:58.250 に答える