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


Java Primitive64Array類代碼示例

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


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

示例1: SparseTableau

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
@SuppressWarnings("unchecked")
SparseTableau(final int numberOfConstraints, final int numberOfProblemVariables, final int numberOfSlackVariables) {

    super(numberOfConstraints, numberOfProblemVariables, numberOfSlackVariables);

    // Including artificial variables
    final int totNumbVars = this.countVariablesTotally();

    final Factory<Double> denseFactory = Primitive64Array.FACTORY;
    final SparseFactory<Double> sparseFactory = SparseArray.factory(denseFactory, totNumbVars).initial(3).limit(totNumbVars);
    final Array1D.Factory<Double> factory1D = Array1D.factory(denseFactory);

    myRows = new SparseArray[numberOfConstraints];
    for (int r = 0; r < numberOfConstraints; r++) {
        myRows[r] = sparseFactory.make();
    }

    myRHS = factory1D.makeZero(numberOfConstraints);

    myObjectiveWeights = factory1D.makeZero(totNumbVars);
    myPhase1Weights = denseFactory.makeZero(totNumbVars);
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:23,代碼來源:SimplexTableau.java

示例2: testP20150809

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
/**
 * Issue reported at GitHub. A set of problems related to when Q is zero - a linear problem. Generally the
 * ConvexSolver is not the right option to handle linear problems, but there is some desireable behaviour.
 */
public void testP20150809() {

    final Primitive64Array tmpExpectedSolution = Primitive64Array.wrap(new double[] { 0.12, -0.05, 0.08, 0.07 });
    final Primitive64Array tmpBoundedSolution = Primitive64Array.wrap(new double[] { 99999, -99999, 99999, 99999 });

    ConvexSolver tmpSolver = P20150809.buildModel(true, false);
    Result tmpResult = tmpSolver.solve();
    TestUtils.assertStateNotLessThanOptimal(tmpResult);
    TestUtils.assertEquals(tmpExpectedSolution, tmpResult);

    tmpSolver = P20150809.buildModel(true, true);
    tmpResult = tmpSolver.solve();
    TestUtils.assertStateNotLessThanOptimal(tmpResult);
    TestUtils.assertEquals(tmpExpectedSolution, tmpResult);

    tmpSolver = P20150809.buildModel(false, false);
    tmpResult = tmpSolver.solve();
    TestUtils.assertEquals(Optimisation.State.UNBOUNDED, tmpResult.getState());

    tmpSolver = P20150809.buildModel(false, true);
    tmpResult = tmpSolver.solve();
    TestUtils.assertStateNotLessThanOptimal(tmpResult); // Since it is now constrained, the solver should be able find the optimal solution.
    TestUtils.assertEquals(tmpBoundedSolution, tmpResult);
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:29,代碼來源:ConvexProblems.java

示例3: toModelState

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public Result toModelState(final Result solverState, final ExpressionsBasedModel model) {

            final int numbVariables = model.countVariables();

            if (this.isSolutionMapped()) {

                final List<Variable> freeVariables = model.getFreeVariables();
                final Set<IntIndex> fixedVariables = model.getFixedVariables();

                if (solverState.count() != freeVariables.size()) {
                    throw new IllegalStateException();
                }

                final Primitive64Array modelSolution = Primitive64Array.make(numbVariables);

                for (final IntIndex fixedIndex : fixedVariables) {
                    modelSolution.set(fixedIndex.index, model.getVariable(fixedIndex.index).getValue());
                }

                for (int f = 0; f < freeVariables.size(); f++) {
                    final int freeIndex = model.indexOf(freeVariables.get(f));
                    modelSolution.set(freeIndex, solverState.doubleValue(f));
                }

                return new Result(solverState.getState(), modelSolution);

            } else {

                if (solverState.count() != numbVariables) {
                    throw new IllegalStateException();
                }

                return solverState;
            }
        }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:36,代碼來源:ExpressionsBasedModel.java

示例4: divideAndCopyColumn

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public void divideAndCopyColumn(final int row, final int column, final BasicArray<Double> destination) {

        final double[] tmpData = data;
        final int tmpRowDim = myRowDim;

        final double[] tmpDestination = ((Primitive64Array) destination).data;

        int tmpIndex = row + (column * tmpRowDim);
        final double tmpDenominator = tmpData[tmpIndex];

        for (int i = row + 1; i < tmpRowDim; i++) {
            tmpDestination[i] = tmpData[++tmpIndex] /= tmpDenominator;
        }
    }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:15,代碼來源:PrimitiveDenseStore.java

示例5: getValues

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public Primitive64Array getValues() {

        final int tmpLength = myProcesses.length;
        final Primitive64Array retVal = Primitive64Array.make(tmpLength);

        for (int p = 0; p < tmpLength; p++) {
            retVal.set(p, myProcesses[p].getValue());
        }

        return retVal;
    }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:12,代碼來源:Process1D.java

示例6: make

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public static SampleSet make(final RandomNumber randomNumber, final int size) {

        final Primitive64Array retVal = Primitive64Array.make(size);
        final double[] tmpData = retVal.data;

        for (int i = 0; i < size; i++) {
            tmpData[i] = randomNumber.doubleValue();
        }

        return new SampleSet(retVal);
    }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:12,代碼來源:SampleSet.java

示例7: testEmptySet

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public void testEmptySet() {

        final Primitive64Array tmpSamples = Primitive64Array.wrap(new double[] { });
        final SampleSet tmpSampleSet = SampleSet.wrap(tmpSamples);

        try {

            // The key thing is that all methods return something
            // 0.0, NaN, Inf... doesn't really matter...
            TestUtils.assertEquals(0.0, tmpSampleSet.getFirst());
            TestUtils.assertEquals(0.0, tmpSampleSet.getInterquartileRange());
            TestUtils.assertEquals(0.0, tmpSampleSet.getLargest());
            TestUtils.assertEquals(0.0, tmpSampleSet.getLast());
            TestUtils.assertEquals(0.0, tmpSampleSet.getMaximum());
            TestUtils.assertEquals(Double.NaN, tmpSampleSet.getMean());
            TestUtils.assertEquals(0.0, tmpSampleSet.getMedian());
            TestUtils.assertEquals(0.0, tmpSampleSet.getMinimum());
            TestUtils.assertEquals(0.0, tmpSampleSet.getQuartile1());
            TestUtils.assertEquals(0.0, tmpSampleSet.getQuartile2());
            TestUtils.assertEquals(0.0, tmpSampleSet.getQuartile3());
            TestUtils.assertTrue(Double.isInfinite(tmpSampleSet.getSmallest()));
            TestUtils.assertEquals(0.0, tmpSampleSet.getStandardDeviation());
            TestUtils.assertEquals(0.0, tmpSampleSet.getSumOfSquares());
            TestUtils.assertEquals(0.0, tmpSampleSet.getVariance());

        } catch (final Exception exception) {
            // Important NOT to throw an exception!
            TestUtils.fail(exception.getMessage());
        }
    }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:31,代碼來源:SampleSetTest.java

示例8: solve

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public Result solve(final Result kickStarter) {

        final int tmpNumberOfVariables = myTask.getnumvar();

        Optimisation.State tmpSate = Optimisation.State.FAILED;
        double tmpValue = Double.NaN;
        final double[] tmpSolution = new double[tmpNumberOfVariables];

        try {

            final Env tmpEnvironment = INTEGRATION.getEnvironment();

            DEFAULT.configure(tmpEnvironment, myTask, myOptions);
            final Optional<Configurator> optional = myOptions.getConfigurator(Configurator.class);
            if (optional.isPresent()) {
                optional.get().configure(tmpEnvironment, myTask, myOptions);
            }

            if (myTask.optimize() == rescode.ok) {

                final solsta[] tmpSolverState = new solsta[1];
                myTask.getsolsta(mySolutionType, tmpSolverState);

                myTask.getxx(mySolutionType, tmpSolution);

                switch (tmpSolverState[0]) {
                case optimal:
                case near_optimal:
                    tmpSate = Optimisation.State.OPTIMAL;
                    tmpValue = myTask.getprimalobj(mySolutionType);
                    break;
                case dual_infeas_cer:
                case prim_infeas_cer:
                case near_dual_infeas_cer:
                case near_prim_infeas_cer:
                    tmpSate = Optimisation.State.INFEASIBLE;
                    break;
                default:
                    tmpSate = Optimisation.State.FAILED;
                    break;
                }
            }

        } catch (final Exception xcptn) {
            throw xcptn;
        }

        return new Optimisation.Result(tmpSate, tmpValue, Primitive64Array.wrap(tmpSolution));
    }
 
開發者ID:optimatika,項目名稱:ojAlgo-extensions,代碼行數:50,代碼來源:SolverMosek.java

示例9: makePrimitive

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
static Tensor<Double> makePrimitive(final int rank, final int dimensions) {
    return new AnyTensor<>(rank, dimensions, Primitive64Array.FACTORY);
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:4,代碼來源:Tensor.java

示例10: toSolverState

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public Result toSolverState(final Result modelState, final ExpressionsBasedModel model) {

            if (this.isSolutionMapped()) {

                final List<Variable> tmpFreeVariables = model.getFreeVariables();
                final int numbFreeVars = tmpFreeVariables.size();

                final Primitive64Array solverSolution = Primitive64Array.make(numbFreeVars);

                for (int i = 0; i < numbFreeVars; i++) {
                    final Variable variable = tmpFreeVariables.get(i);
                    final int modelIndex = model.indexOf(variable);
                    solverSolution.set(i, modelState.doubleValue(modelIndex));
                }

                return new Result(modelState.getState(), solverSolution);

            } else {

                return modelState;
            }
        }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:23,代碼來源:ExpressionsBasedModel.java

示例11: Equation

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public Equation(final int row, final long numberOfColumns, final double rhs) {
    super();
    index = row;
    myElements = SparseArray.factory(Primitive64Array.FACTORY, numberOfColumns).make();
    myRHS = rhs;
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:7,代碼來源:Equation.java

示例12: makeSingularValues

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
protected Array1D<Double> makeSingularValues() {
    return Array1D.PRIMITIVE64.wrap(Primitive64Array.wrap(s));
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:4,代碼來源:SingularValueDecomposition.java

示例13: makeD

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
@Override
protected MatrixStore<N> makeD() {
    final DiagonalBasicArray<Double> tmpDiagonal = new DiagonalBasicArray<>(Primitive64Array.wrap(d), null, null, ZERO);
    return this.wrap(tmpDiagonal).diagonal(false).get();
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:6,代碼來源:HermitianEvD.java

示例14: array

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public DenseArray.Factory<Double> array() {
    return Primitive64Array.FACTORY;
}
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:4,代碼來源:PrimitiveDenseStore.java

示例15: applyCholesky

import org.ojalgo.array.Primitive64Array; //導入依賴的package包/類
public void applyCholesky(final int iterationPoint, final BasicArray<Double> multipliers) {

        final double[] tmpData = data;
        final double[] tmpColumn = ((Primitive64Array) multipliers).data;

        if ((myColDim - iterationPoint - 1) > ApplyCholesky.THRESHOLD) {

            final DivideAndConquer tmpConquerer = new DivideAndConquer() {

                @Override
                protected void conquer(final int first, final int limit) {
                    ApplyCholesky.invoke(tmpData, myRowDim, first, limit, tmpColumn);
                }
            };

            tmpConquerer.invoke(iterationPoint + 1, myColDim, ApplyCholesky.THRESHOLD);

        } else {

            ApplyCholesky.invoke(tmpData, myRowDim, iterationPoint + 1, myColDim, tmpColumn);
        }
    }
 
開發者ID:optimatika,項目名稱:ojAlgo,代碼行數:23,代碼來源:PrimitiveDenseStore.java


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