609 lines
17 KiB
C++
609 lines
17 KiB
C++
// clang-format off
|
|
/* ----------------------------------------------------------------------
|
|
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
|
|
https://www.lammps.org/, Sandia National Laboratories
|
|
LAMMPS development team: developers@lammps.org
|
|
|
|
Copyright (2003) Sandia Corporation. Under the terms of Contract
|
|
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
|
|
certain rights in this software. This software is distributed under
|
|
the GNU General Public License.
|
|
|
|
See the README file in the top-level LAMMPS directory.
|
|
------------------------------------------------------------------------- */
|
|
|
|
#include "dump_atom.h"
|
|
|
|
#include "atom.h"
|
|
#include "domain.h"
|
|
#include "error.h"
|
|
#include "memory.h"
|
|
#include "update.h"
|
|
|
|
#include <cstring>
|
|
|
|
using namespace LAMMPS_NS;
|
|
|
|
#define ONELINE 256
|
|
#define DELTA 1048576
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
DumpAtom::DumpAtom(LAMMPS *lmp, int narg, char **arg) : Dump(lmp, narg, arg)
|
|
{
|
|
if (narg != 5) error->all(FLERR,"Illegal dump atom command");
|
|
|
|
scale_flag = 1;
|
|
image_flag = 0;
|
|
buffer_allow = 1;
|
|
buffer_flag = 1;
|
|
format_default = nullptr;
|
|
key2col = { { "id", 0 }, { "type", 1 }, { "x", 2 }, { "y", 3 },
|
|
{ "z", 4 }, { "ix", 5 }, { "iy", 6 }, { "iz", 7 } };
|
|
keyword_user = { "", "", "", "", "", "", "", "" };
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::init_style()
|
|
{
|
|
if (image_flag == 0) size_one = 5;
|
|
else size_one = 8;
|
|
|
|
// format = copy of default or user-specified line format
|
|
// default depends on image flags
|
|
|
|
delete[] format;
|
|
if (format_line_user) {
|
|
format = utils::strdup(std::string(format_line_user) + "\n");
|
|
} else {
|
|
if (image_flag == 0) format = utils::strdup(TAGINT_FORMAT " %d %g %g %g\n");
|
|
else format = utils::strdup(TAGINT_FORMAT " %d %g %g %g %d %d %d\n");
|
|
}
|
|
|
|
// setup boundary string
|
|
|
|
domain->boundary_string(boundstr);
|
|
|
|
// setup column string
|
|
|
|
std::string default_columns;
|
|
|
|
if (scale_flag == 0 && image_flag == 0)
|
|
default_columns = "id type x y z";
|
|
else if (scale_flag == 0 && image_flag == 1)
|
|
default_columns = "id type x y z ix iy iz";
|
|
else if (scale_flag == 1 && image_flag == 0)
|
|
default_columns = "id type xs ys zs";
|
|
else if (scale_flag == 1 && image_flag == 1)
|
|
default_columns = "id type xs ys zs ix iy iz";
|
|
|
|
int icol = 0;
|
|
columns.clear();
|
|
for (const auto &item : utils::split_words(default_columns)) {
|
|
if (columns.size()) columns += " ";
|
|
if (keyword_user[icol].size()) columns += keyword_user[icol];
|
|
else columns += item;
|
|
++icol;
|
|
}
|
|
|
|
// setup function ptrs
|
|
|
|
if (binary && domain->triclinic == 0)
|
|
header_choice = &DumpAtom::header_binary;
|
|
else if (binary && domain->triclinic == 1)
|
|
header_choice = &DumpAtom::header_binary_triclinic;
|
|
else if (!binary && domain->triclinic == 0)
|
|
header_choice = &DumpAtom::header_item;
|
|
else if (!binary && domain->triclinic == 1)
|
|
header_choice = &DumpAtom::header_item_triclinic;
|
|
|
|
if (scale_flag == 1 && image_flag == 0 && domain->triclinic == 0)
|
|
pack_choice = &DumpAtom::pack_scale_noimage;
|
|
else if (scale_flag == 1 && image_flag == 1 && domain->triclinic == 0)
|
|
pack_choice = &DumpAtom::pack_scale_image;
|
|
else if (scale_flag == 1 && image_flag == 0 && domain->triclinic == 1)
|
|
pack_choice = &DumpAtom::pack_scale_noimage_triclinic;
|
|
else if (scale_flag == 1 && image_flag == 1 && domain->triclinic == 1)
|
|
pack_choice = &DumpAtom::pack_scale_image_triclinic;
|
|
else if (scale_flag == 0 && image_flag == 0)
|
|
pack_choice = &DumpAtom::pack_noscale_noimage;
|
|
else if (scale_flag == 0 && image_flag == 1)
|
|
pack_choice = &DumpAtom::pack_noscale_image;
|
|
|
|
if (image_flag == 0) convert_choice = &DumpAtom::convert_noimage;
|
|
else convert_choice = &DumpAtom::convert_image;
|
|
|
|
if (binary) write_choice = &DumpAtom::write_binary;
|
|
else if (buffer_flag == 1) write_choice = &DumpAtom::write_string;
|
|
else if (image_flag == 0) write_choice = &DumpAtom::write_lines_noimage;
|
|
else if (image_flag == 1) write_choice = &DumpAtom::write_lines_image;
|
|
|
|
// open single file, one time only
|
|
|
|
if (multifile == 0) openfile();
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
int DumpAtom::modify_param(int narg, char **arg)
|
|
{
|
|
if (strcmp(arg[0],"scale") == 0) {
|
|
if (narg < 2) error->all(FLERR,"Illegal dump_modify command");
|
|
scale_flag = utils::logical(FLERR,arg[1],false,lmp);
|
|
for (auto &item : keyword_user) item.clear();
|
|
return 2;
|
|
} else if (strcmp(arg[0],"image") == 0) {
|
|
if (narg < 2) error->all(FLERR,"Illegal dump_modify command");
|
|
image_flag = utils::logical(FLERR,arg[1],false,lmp);
|
|
for (auto &item : keyword_user) item.clear();
|
|
return 2;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::write_header(bigint ndump)
|
|
{
|
|
if (multiproc) (this->*header_choice)(ndump);
|
|
else if (me == 0) (this->*header_choice)(ndump);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack(tagint *ids)
|
|
{
|
|
(this->*pack_choice)(ids);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
int DumpAtom::convert_string(int n, double *mybuf)
|
|
{
|
|
return (this->*convert_choice)(n,mybuf);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::write_data(int n, double *mybuf)
|
|
{
|
|
(this->*write_choice)(n,mybuf);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::format_magic_string_binary()
|
|
{
|
|
// use negative ntimestep as marker for new format
|
|
bigint fmtlen = strlen(MAGIC_STRING);
|
|
bigint marker = -fmtlen;
|
|
fwrite(&marker, sizeof(bigint), 1, fp);
|
|
fwrite(MAGIC_STRING, sizeof(char), fmtlen, fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::format_endian_binary()
|
|
{
|
|
int endian = ENDIAN;
|
|
fwrite(&endian, sizeof(int), 1, fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::format_revision_binary()
|
|
{
|
|
int revision = FORMAT_REVISION;
|
|
fwrite(&revision, sizeof(int), 1, fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_unit_style_binary()
|
|
{
|
|
int len = 0;
|
|
if (unit_flag && !unit_count) {
|
|
++unit_count;
|
|
len = strlen(update->unit_style);
|
|
fwrite(&len, sizeof(int), 1, fp);
|
|
fwrite(update->unit_style, sizeof(char), len, fp);
|
|
} else {
|
|
fwrite(&len, sizeof(int), 1, fp);
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_columns_binary()
|
|
{
|
|
int len = columns.size();
|
|
fwrite(&len, sizeof(int), 1, fp);
|
|
fwrite(columns.c_str(), sizeof(char), len, fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_time_binary()
|
|
{
|
|
char flag = time_flag ? 1 : 0;
|
|
fwrite(&flag, sizeof(char), 1, fp);
|
|
|
|
if (time_flag) {
|
|
double t = compute_time();
|
|
fwrite(&t, sizeof(double), 1, fp);
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_format_binary()
|
|
{
|
|
format_magic_string_binary();
|
|
format_endian_binary();
|
|
format_revision_binary();
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_binary(bigint ndump)
|
|
{
|
|
header_format_binary();
|
|
|
|
fwrite(&update->ntimestep,sizeof(bigint),1,fp);
|
|
fwrite(&ndump,sizeof(bigint),1,fp);
|
|
fwrite(&domain->triclinic,sizeof(int),1,fp);
|
|
fwrite(&domain->boundary[0][0],6*sizeof(int),1,fp);
|
|
fwrite(&boxxlo,sizeof(double),1,fp);
|
|
fwrite(&boxxhi,sizeof(double),1,fp);
|
|
fwrite(&boxylo,sizeof(double),1,fp);
|
|
fwrite(&boxyhi,sizeof(double),1,fp);
|
|
fwrite(&boxzlo,sizeof(double),1,fp);
|
|
fwrite(&boxzhi,sizeof(double),1,fp);
|
|
fwrite(&size_one,sizeof(int),1,fp);
|
|
|
|
header_unit_style_binary();
|
|
header_time_binary();
|
|
header_columns_binary();
|
|
|
|
if (multiproc) fwrite(&nclusterprocs,sizeof(int),1,fp);
|
|
else fwrite(&nprocs,sizeof(int),1,fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_binary_triclinic(bigint ndump)
|
|
{
|
|
header_format_binary();
|
|
|
|
fwrite(&update->ntimestep,sizeof(bigint),1,fp);
|
|
fwrite(&ndump,sizeof(bigint),1,fp);
|
|
fwrite(&domain->triclinic,sizeof(int),1,fp);
|
|
fwrite(&domain->boundary[0][0],6*sizeof(int),1,fp);
|
|
fwrite(&boxxlo,sizeof(double),1,fp);
|
|
fwrite(&boxxhi,sizeof(double),1,fp);
|
|
fwrite(&boxylo,sizeof(double),1,fp);
|
|
fwrite(&boxyhi,sizeof(double),1,fp);
|
|
fwrite(&boxzlo,sizeof(double),1,fp);
|
|
fwrite(&boxzhi,sizeof(double),1,fp);
|
|
fwrite(&boxxy,sizeof(double),1,fp);
|
|
fwrite(&boxxz,sizeof(double),1,fp);
|
|
fwrite(&boxyz,sizeof(double),1,fp);
|
|
fwrite(&size_one,sizeof(int),1,fp);
|
|
|
|
header_unit_style_binary();
|
|
header_time_binary();
|
|
header_columns_binary();
|
|
|
|
if (multiproc) fwrite(&nclusterprocs,sizeof(int),1,fp);
|
|
else fwrite(&nprocs,sizeof(int),1,fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_item(bigint ndump)
|
|
{
|
|
if (unit_flag && !unit_count) {
|
|
++unit_count;
|
|
fmt::print(fp,"ITEM: UNITS\n{}\n",update->unit_style);
|
|
}
|
|
if (time_flag) fmt::print(fp,"ITEM: TIME\n{:.16}\n",compute_time());
|
|
|
|
fmt::print(fp, "ITEM: TIMESTEP\n{}\nITEM: NUMBER OF ATOMS\n{}\n", update->ntimestep, ndump);
|
|
|
|
fmt::print(fp,"ITEM: BOX BOUNDS {}\n"
|
|
"{:>1.16e} {:>1.16e}\n"
|
|
"{:>1.16e} {:>1.16e}\n"
|
|
"{:>1.16e} {:>1.16e}\n",
|
|
boundstr,boxxlo,boxxhi,boxylo,boxyhi,boxzlo,boxzhi);
|
|
|
|
fmt::print(fp,"ITEM: ATOMS {}\n",columns);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::header_item_triclinic(bigint ndump)
|
|
{
|
|
if (unit_flag && !unit_count) {
|
|
++unit_count;
|
|
fmt::print(fp,"ITEM: UNITS\n{}\n",update->unit_style);
|
|
}
|
|
if (time_flag) fmt::print(fp,"ITEM: TIME\n{:.16}\n",compute_time());
|
|
|
|
fmt::print(fp, "ITEM: TIMESTEP\n{}\nITEM: NUMBER OF ATOMS\n{}\n", update->ntimestep, ndump);
|
|
|
|
fmt::print(fp,"ITEM: BOX BOUNDS xy xz yz {}\n"
|
|
"{:>1.16e} {:>1.16e} {:>1.16e}\n"
|
|
"{:>1.16e} {:>1.16e} {:>1.16e}\n"
|
|
"{:>1.16e} {:>1.16e} {:>1.16e}\n",
|
|
boundstr,boxxlo,boxxhi,boxxy,boxylo,boxyhi,boxxz,boxzlo,boxzhi,boxyz);
|
|
|
|
fmt::print(fp,"ITEM: ATOMS {}\n",columns);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack_scale_image(tagint *ids)
|
|
{
|
|
int m,n;
|
|
|
|
tagint *tag = atom->tag;
|
|
int *type = atom->type;
|
|
imageint *image = atom->image;
|
|
int *mask = atom->mask;
|
|
double **x = atom->x;
|
|
int nlocal = atom->nlocal;
|
|
|
|
double invxprd = 1.0/domain->xprd;
|
|
double invyprd = 1.0/domain->yprd;
|
|
double invzprd = 1.0/domain->zprd;
|
|
|
|
m = n = 00;
|
|
for (int i = 0; i < nlocal; i++)
|
|
if (mask[i] & groupbit) {
|
|
buf[m++] = tag[i];
|
|
buf[m++] = type[i];
|
|
buf[m++] = (x[i][0] - boxxlo) * invxprd;
|
|
buf[m++] = (x[i][1] - boxylo) * invyprd;
|
|
buf[m++] = (x[i][2] - boxzlo) * invzprd;
|
|
buf[m++] = (image[i] & IMGMASK) - IMGMAX;
|
|
buf[m++] = (image[i] >> IMGBITS & IMGMASK) - IMGMAX;
|
|
buf[m++] = (image[i] >> IMG2BITS) - IMGMAX;
|
|
if (ids) ids[n++] = tag[i];
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack_scale_noimage(tagint *ids)
|
|
{
|
|
int m,n;
|
|
|
|
tagint *tag = atom->tag;
|
|
int *type = atom->type;
|
|
int *mask = atom->mask;
|
|
double **x = atom->x;
|
|
int nlocal = atom->nlocal;
|
|
|
|
double invxprd = 1.0/domain->xprd;
|
|
double invyprd = 1.0/domain->yprd;
|
|
double invzprd = 1.0/domain->zprd;
|
|
|
|
m = n = 0;
|
|
for (int i = 0; i < nlocal; i++)
|
|
if (mask[i] & groupbit) {
|
|
buf[m++] = tag[i];
|
|
buf[m++] = type[i];
|
|
buf[m++] = (x[i][0] - boxxlo) * invxprd;
|
|
buf[m++] = (x[i][1] - boxylo) * invyprd;
|
|
buf[m++] = (x[i][2] - boxzlo) * invzprd;
|
|
if (ids) ids[n++] = tag[i];
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack_scale_image_triclinic(tagint *ids)
|
|
{
|
|
int m,n;
|
|
|
|
tagint *tag = atom->tag;
|
|
int *type = atom->type;
|
|
imageint *image = atom->image;
|
|
int *mask = atom->mask;
|
|
double **x = atom->x;
|
|
int nlocal = atom->nlocal;
|
|
|
|
double lamda[3];
|
|
|
|
m = n = 0;
|
|
for (int i = 0; i < nlocal; i++)
|
|
if (mask[i] & groupbit) {
|
|
buf[m++] = tag[i];
|
|
buf[m++] = type[i];
|
|
domain->x2lamda(x[i],lamda);
|
|
buf[m++] = lamda[0];
|
|
buf[m++] = lamda[1];
|
|
buf[m++] = lamda[2];
|
|
buf[m++] = (image[i] & IMGMASK) - IMGMAX;
|
|
buf[m++] = (image[i] >> IMGBITS & IMGMASK) - IMGMAX;
|
|
buf[m++] = (image[i] >> IMG2BITS) - IMGMAX;
|
|
if (ids) ids[n++] = tag[i];
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack_scale_noimage_triclinic(tagint *ids)
|
|
{
|
|
int m,n;
|
|
|
|
tagint *tag = atom->tag;
|
|
int *type = atom->type;
|
|
int *mask = atom->mask;
|
|
double **x = atom->x;
|
|
int nlocal = atom->nlocal;
|
|
|
|
double lamda[3];
|
|
|
|
m = n = 0;
|
|
for (int i = 0; i < nlocal; i++)
|
|
if (mask[i] & groupbit) {
|
|
buf[m++] = tag[i];
|
|
buf[m++] = type[i];
|
|
domain->x2lamda(x[i],lamda);
|
|
buf[m++] = lamda[0];
|
|
buf[m++] = lamda[1];
|
|
buf[m++] = lamda[2];
|
|
if (ids) ids[n++] = tag[i];
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack_noscale_image(tagint *ids)
|
|
{
|
|
int m,n;
|
|
|
|
tagint *tag = atom->tag;
|
|
int *type = atom->type;
|
|
imageint *image = atom->image;
|
|
int *mask = atom->mask;
|
|
double **x = atom->x;
|
|
int nlocal = atom->nlocal;
|
|
|
|
m = n = 0;
|
|
for (int i = 0; i < nlocal; i++)
|
|
if (mask[i] & groupbit) {
|
|
buf[m++] = tag[i];
|
|
buf[m++] = type[i];
|
|
buf[m++] = x[i][0];
|
|
buf[m++] = x[i][1];
|
|
buf[m++] = x[i][2];
|
|
buf[m++] = (image[i] & IMGMASK) - IMGMAX;
|
|
buf[m++] = (image[i] >> IMGBITS & IMGMASK) - IMGMAX;
|
|
buf[m++] = (image[i] >> IMG2BITS) - IMGMAX;
|
|
if (ids) ids[n++] = tag[i];
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::pack_noscale_noimage(tagint *ids)
|
|
{
|
|
int m,n;
|
|
|
|
tagint *tag = atom->tag;
|
|
int *type = atom->type;
|
|
int *mask = atom->mask;
|
|
double **x = atom->x;
|
|
int nlocal = atom->nlocal;
|
|
|
|
m = n = 0;
|
|
for (int i = 0; i < nlocal; i++)
|
|
if (mask[i] & groupbit) {
|
|
buf[m++] = tag[i];
|
|
buf[m++] = type[i];
|
|
buf[m++] = x[i][0];
|
|
buf[m++] = x[i][1];
|
|
buf[m++] = x[i][2];
|
|
if (ids) ids[n++] = tag[i];
|
|
}
|
|
}
|
|
|
|
/* ----------------------------------------------------------------------
|
|
convert mybuf of doubles to one big formatted string in sbuf
|
|
return -1 if strlen exceeds an int, since used as arg in MPI calls in Dump
|
|
------------------------------------------------------------------------- */
|
|
|
|
int DumpAtom::convert_image(int n, double *mybuf)
|
|
{
|
|
int offset = 0;
|
|
int m = 0;
|
|
for (int i = 0; i < n; i++) {
|
|
if (offset + ONELINE > maxsbuf) {
|
|
if ((bigint) maxsbuf + DELTA > MAXSMALLINT) return -1;
|
|
maxsbuf += DELTA;
|
|
memory->grow(sbuf,maxsbuf,"dump:sbuf");
|
|
}
|
|
|
|
offset += sprintf(&sbuf[offset],format,
|
|
static_cast<tagint> (mybuf[m]),
|
|
static_cast<int> (mybuf[m+1]),
|
|
mybuf[m+2],mybuf[m+3],mybuf[m+4],
|
|
static_cast<int> (mybuf[m+5]),
|
|
static_cast<int> (mybuf[m+6]),
|
|
static_cast<int> (mybuf[m+7]));
|
|
m += size_one;
|
|
}
|
|
|
|
return offset;
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
int DumpAtom::convert_noimage(int n, double *mybuf)
|
|
{
|
|
int offset = 0;
|
|
int m = 0;
|
|
for (int i = 0; i < n; i++) {
|
|
if (offset + ONELINE > maxsbuf) {
|
|
if ((bigint) maxsbuf + DELTA > MAXSMALLINT) return -1;
|
|
maxsbuf += DELTA;
|
|
memory->grow(sbuf,maxsbuf,"dump:sbuf");
|
|
}
|
|
|
|
offset += sprintf(&sbuf[offset],format,
|
|
static_cast<tagint> (mybuf[m]),
|
|
static_cast<int> (mybuf[m+1]),
|
|
mybuf[m+2],mybuf[m+3],mybuf[m+4]);
|
|
m += size_one;
|
|
}
|
|
|
|
return offset;
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::write_binary(int n, double *mybuf)
|
|
{
|
|
n *= size_one;
|
|
fwrite(&n,sizeof(int),1,fp);
|
|
fwrite(mybuf,sizeof(double),n,fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::write_string(int n, double *mybuf)
|
|
{
|
|
if (mybuf)
|
|
fwrite(mybuf,sizeof(char),n,fp);
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::write_lines_image(int n, double *mybuf)
|
|
{
|
|
int m = 0;
|
|
for (int i = 0; i < n; i++) {
|
|
fprintf(fp,format,
|
|
static_cast<tagint> (mybuf[m]), static_cast<int> (mybuf[m+1]),
|
|
mybuf[m+2],mybuf[m+3],mybuf[m+4], static_cast<int> (mybuf[m+5]),
|
|
static_cast<int> (mybuf[m+6]), static_cast<int> (mybuf[m+7]));
|
|
m += size_one;
|
|
}
|
|
}
|
|
|
|
/* ---------------------------------------------------------------------- */
|
|
|
|
void DumpAtom::write_lines_noimage(int n, double *mybuf)
|
|
{
|
|
int m = 0;
|
|
for (int i = 0; i < n; i++) {
|
|
fprintf(fp,format,
|
|
static_cast<tagint> (mybuf[m]), static_cast<int> (mybuf[m+1]),
|
|
mybuf[m+2],mybuf[m+3],mybuf[m+4]);
|
|
m += size_one;
|
|
}
|
|
}
|