All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.fudaa.dodico.reflux.io.RefluxSolutionInitWriter Maven / Gradle / Ivy

The newest version!
/**
 * @creation 15 mars 2004
 * @modification $Date: 2007-06-29 15:10:25 $
 * @license GNU General Public License 2
 * @copyright (c)1998-2001 CETMEF 2 bd Gambetta F-60231 Compiegne
 * @mail [email protected]
 */
package org.fudaa.dodico.reflux.io;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;

import org.fudaa.ctulu.CtuluAnalyze;
import org.fudaa.ctulu.CtuluIOOperationSynthese;
import org.fudaa.ctulu.ProgressionInterface;
import org.fudaa.ctulu.ProgressionUpdater;
import org.fudaa.ctulu.fileformat.FileWriteOperationAbstract;
import org.fudaa.ctulu.fileformat.FortranInterface;

import org.fudaa.dodico.commun.DodicoLib;
import org.fudaa.dodico.ef.EfGridInterface;
import org.fudaa.dodico.fortran.FortranBinaryOutputStream;
import org.fudaa.dodico.h2d.reflux.H2dRefluxSolutionInitAdapterInterface;

/**
 * @author Fred Deniger
 * @version $Id: RefluxSolutionInitWriter.java,v 1.15 2007-06-29 15:10:25 deniger Exp $
 */
public class RefluxSolutionInitWriter extends FileWriteOperationAbstract {

  FortranBinaryOutputStream out_;

  public RefluxSolutionInitWriter() {
    super();
  }

  @Override
  protected FortranInterface getFortranInterface() {
    return new FortranInterface() {

      @Override
      public void close() throws IOException {
        if (out_ != null) {
          out_.close();
        }
      }
    };
  }

  @Override
  public void setFile(final File _f) {
    analyze_ = new CtuluAnalyze();
    analyze_.setResource(_f.getAbsolutePath());
    FileOutputStream out = null;
    try {
      out = new FileOutputStream(_f);
    } catch (final IOException _e) {
      analyze_.manageException(_e);
      _e.printStackTrace();
      return;
    }
    setOut(out);
  }

  private void setOut(final OutputStream _out) {
    out_ = new FortranBinaryOutputStream(_out, true);
  }

  @Override
  protected void internalWrite(final Object _o) {
    if ((_o instanceof double[])) {
      write((double[]) _o);
    } else {
      donneesInvalides(_o);
    }
  }

  private void write(final double[] _data) {
    if (out_ == null) {
      analyze_.addFatalError(DodicoLib.getS("Le flux de sortie est nul"));
      return;
    }
    if (_data == null) {
      analyze_.addFatalError(DodicoLib.getS("Les donn?es sont nulles"));
      return;
    }
    try {
      final ProgressionUpdater up = new ProgressionUpdater(progress_);
      up.setValue(4, _data.length);
      for (int i = 0; i < _data.length; i++) {
        out_.writeDoublePrecision(_data[i]);
        up.majAvancement();
      }
      out_.writeRecord();
    } catch (final IOException e) {
      analyze_.manageException(e);
    }
  }

  /**
   * @param _g le maillage associe
   * @param _f le fichier de dest
   * @param _init l'interface contenant les valeurs a ecrire
   * @param _prog la progression
   * @return la synthese de l'ecriture contenant le tableau de double generee comme source
   */
  public static CtuluIOOperationSynthese writeSI(final EfGridInterface _g,
      final H2dRefluxSolutionInitAdapterInterface _init, final File _f, final ProgressionInterface _prog) {
    final int nbPt = _g.getPtsNb();
    final double[] vals = new double[nbPt * 3];
    if (_prog != null) {
      _prog.setProgression(30);
    }
    int idxInVal = 0;
    final ProgressionUpdater up = new ProgressionUpdater(_prog);
    up.setValue(3, nbPt, 30, 70);
    up.majProgessionStateOnly();
    for (int i = 0; i < nbPt; i++) {
      vals[idxInVal++] = _init.getU(i);
      vals[idxInVal++] = _init.getV(i);
      if (_g.isExtremePoint(i)) {
        vals[idxInVal++] = _init.getCoteEau(i);
      }
      up.majAvancement();
    }
    final double[] fvals = new double[idxInVal];
    System.arraycopy(vals, 0, fvals, 0, fvals.length);
    return RefluxSolutionInitFileFormat.getInstance().getLastVersionInstance(null).write(_f, fvals, _prog);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy