/usr/include/itpp/base/itfile.h is in libitpp-dev 4.3.1-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973 974 975 976 977 978 979 980 981 982 983 984 985 986 987 988 989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173 | /*!
* \file
* \brief Definition of classes for the IT++ file format
* \author Tony Ottosson, Tobias Ringstrom and Adam Piatyszek
*
* -------------------------------------------------------------------------
*
* Copyright (C) 1995-2010 (see AUTHORS file for a list of contributors)
*
* This file is part of IT++ - a C++ library of mathematical, signal
* processing, speech processing, and communications classes and functions.
*
* IT++ is free software: you can redistribute it and/or modify it under the
* terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any
* later version.
*
* IT++ is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along
* with IT++. If not, see <http://www.gnu.org/licenses/>.
*
* -------------------------------------------------------------------------
*/
#ifndef ITFILE_H
#define ITFILE_H
#include <itpp/base/vec.h>
#include <itpp/base/array.h>
#include <itpp/base/binfile.h>
#include <itpp/base/ittypes.h>
#include <itpp/itexports.h>
namespace itpp
{
/*!
\addtogroup itfile
\brief The IT++ file format
\author Tony Ottosson, Tobias Ringstrom and Adam Piatyszek
The IT++ file format is a file format that can be used to save (load)
variables to (from) files. These files can also be read an written by
Matlab or Octave using the m-files \c itload.m and \c itsave.m.
The class it_ifile is used for reading only, whereas the class it_file
can be used for both reading and writing.
Saving of a variable is done in two steps. The first step is to supply
the name and optionally description of the variable to be saved. This
can be done either by calling the function it_file::set_next_name() or
by using the helper class Name:
\code
vec v("1 2 3");
bvec b = "0 1 0 1";
it_file f("file.it");
f << Name("v", "A double vector of tree values") << v;
f.set_next_name("b");
f << b;
\endcode
The reading is done in a similar way:
\code
vec v;
bvec b;
it_ifile f("file.it");
f >> Name("v") >> v;
f.seek("b");
f >> b;
\endcode
\note Since version 3, IT++ file format uses the IEEE little endian byte
ordering ("ieee-le" in Matlab/Octave). This version is not backward
compatible with previous versions. If you need to read/write data in
IT++ file format version 2, you can use the it_ifile_old and it_file_old
classes. Please have in mind that these "old" classes are deprecated and
will be removed from the IT++ library in future.
\warning Do not use the names that begin with an existing type.
*/
/*!
\brief Base class for it_ifile and it_file.
\ingroup itfile
*/
class ITPP_EXPORT it_file_base
{
public:
//! Data header structure
struct data_header {
//! Number of bytes of the header
uint64_t hdr_bytes;
//! Number of bytes of the data
uint64_t data_bytes;
//! Number of bytes of the header + data
uint64_t block_bytes;
//! Data name
std::string name;
//! Data type, e.g. int32, float32, etc. type = "" means deleted
std::string type;
//! Data description
std::string desc;
};
protected:
//! File header structure
struct file_header {
//! IT++ file marker: "IT++"
char magic[4];
//! IT++ file format version
char version;
};
//! IT++ file marker: "IT++"
static char file_magic[4];
//! IT++ file version
static char file_version;
};
/*!
\brief The IT++ file format reading class.
\ingroup itfile
*/
class ITPP_EXPORT it_ifile : public it_file_base
{
public:
//! Default constructor
it_ifile();
//! Constructor that calls open(filename)
explicit it_ifile(const std::string& filename);
//! Destructor
virtual ~it_ifile() { }
//! Open an existing file in read-only mode
void open(const std::string& filename);
//! Close the file
virtual void close();
//! Returns pointer to the underlying \c bfstream used
bfstream& low_level() { return s; }
//! Read and check the file header. Return true if the header is valid and false otherwise.
bool read_check_file_header();
//! Read data header and return the result in the variable \c h
void read_data_header(it_file_base::data_header& h);
//! Read a char value at the current file pointer position
void low_level_read(char& x);
//! Read a 64-bit unsigned integer value at the current file pointer position
void low_level_read(uint64_t& x);
//! Read a bool value at the current file pointer position
void low_level_read(bool &x);
//! Read a binary value at the current file pointer position
void low_level_read(bin& x);
//! Read a short value at the current file pointer position
void low_level_read(short& x);
//! Read an integer value at the current file pointer position
void low_level_read(int& x);
//! Read a float value at the current file pointer position
void low_level_read(float& x);
//! Read a double value at the current file pointer position
void low_level_read(double& x);
//! Read a float complex value at the current file pointer position
void low_level_read(std::complex<float>& x);
//! Read a double complex value at the current file pointer position
void low_level_read(std::complex<double>& x);
//! Read a vector of binary values at the current file pointer position
void low_level_read(bvec& v);
//! Read a vector of short integer values at the current file pointer position
void low_level_read(svec& v);
//! Read a vector of integer values at the current file pointer position
void low_level_read(ivec& v);
//! Read a vector of float values at the current file pointer position
void low_level_read_lo(vec& v);
//! Read a vector of double values at the current file pointer position
void low_level_read_hi(vec& v);
//! Read a vector of float complex values at the current file pointer position
void low_level_read_lo(cvec& v);
//! Read a vector of double complex values at the current file pointer position
void low_level_read_hi(cvec& v);
//! Read a string at the current file pointer position
void low_level_read(std::string& str);
//! Read a matrix of binary values at the current file pointer position
void low_level_read(bmat& m);
//! Read a matrix of short integer values at the current file pointer position
void low_level_read(smat& m);
//! Read a matrix of integer values at the current file pointer position
void low_level_read(imat& m);
//! Read a matrix of float values at the current file pointer position
void low_level_read_lo(mat& m);
//! Read a matrix of double values at the current file pointer position
void low_level_read_hi(mat& m);
//! Read a matrix of float complex values at the current file pointer position
void low_level_read_lo(cmat& m);
//! Read a matrix of double complex values at the current file pointer position
void low_level_read_hi(cmat& m);
//! Read an Array of binary values at the current file pointer position
void low_level_read(Array<bin>& v);
//! Read an Array of short integer values at the current file pointer position
void low_level_read(Array<short>& v);
//! Read an Array of integer values at the current file pointer position
void low_level_read(Array<int>& v);
//! Read an Array of float values at the current file pointer position
void low_level_read(Array<float>& v);
//! Read an Array of float values at the current file pointer position
void low_level_read_lo(Array<double>& v);
//! Read an Array of double values at the current file pointer position
void low_level_read_hi(Array<double>& v);
//! Read an Array of float complex values at the current file pointer position
void low_level_read(Array<std::complex<float> >& v);
//! Read an Array of float complex values at the current file pointer position
void low_level_read_lo(Array<std::complex<double> >& v);
//! Read an Array of double complex values at the current file pointer position
void low_level_read_hi(Array<std::complex<double> >& v);
//! Find the variable \c name
bool seek(const std::string& name);
//! Find the variable number \c n
bool seek(int n);
//! Get information about the current variable
void info(std::string& name, std::string& type, std::string& desc,
uint64_t& bytes);
protected:
//! Protected binary file stream
bfstream s;
};
/*!
\brief The IT++ file format reading and writing class
\ingroup itfile
*/
class ITPP_EXPORT it_file : public it_ifile
{
public:
//! ACTION: Add documentation for this typedef
typedef it_file& (*it_manip)(it_file&);
//! Default constructor
it_file();
/*!
\brief Constructor that calls open()
If the file does not exist it will be created. If \c trunc is true,
the file will be truncated.
*/
explicit it_file(const std::string& filename, bool trunc = false);
//! Destructor
virtual ~it_file() { delete _strings;}
/*!
\brief Open a file for reading and writing
If the file does not exist it will be created. If \c trunc is true,
the file will be truncated.
*/
void open(const std::string& filename, bool trunc = false);
//! Close the file
void close();
//! Flush the data to disk
void flush();
//! Returns pointer to the underlying \c bfstream used
bfstream& low_level() { return s; }
//! Set the precision. Low precision means floats, high means doubles.
void set_low_precision(bool p = true) { low_prec = p; }
//! Get the precision
bool get_low_precision() const { return low_prec; }
//! Set the name and optionally description of the next variable to be saved
void set_next_name(const std::string& name,
const std::string& description = "")
{ next_name() = name; next_desc() = description; }
//! Write the header for the \c it_file
void write_file_header();
//! Write the data header for a variable, specifying the type and size of the data to follow.
void write_data_header(const std::string& type, uint64_t size);
//! Write the data header for a variable, specifying the type, name, size and optionally description of the data to follow.
void write_data_header(const std::string& type, const std::string& name,
uint64_t size, const std::string& description = "");
//! Write a char value at the current file pointer position
void low_level_write(char x);
//! Write an unsigned integer 64-bit value at the current file pointer position
void low_level_write(uint64_t x);
//! Write a bool value at the current file pointer position
void low_level_write(bool x);
//! Write a binary value at the current file pointer position
void low_level_write(bin x);
//! Write a short value at the current file pointer position
void low_level_write(short x);
//! Write an integer value at the current file pointer position
void low_level_write(int x);
//! Write a float value at the current file pointer position
void low_level_write(float x);
//! Write a double value at the current file pointer position
void low_level_write(double x);
//! Write a float complex value at the current file pointer position
void low_level_write(const std::complex<float>& x);
//! Write a double complex value at the current file pointer position
void low_level_write(const std::complex<double>& x);
//! Write a bvec at the current file pointer position
void low_level_write(const bvec& v);
//! Write an svec at the current file pointer position
void low_level_write(const svec& v);
//! Write an ivec at the current file pointer position
void low_level_write(const ivec& v);
//! Write a vec at the current file pointer position
void low_level_write(const vec& v);
//! Write a cvec at the current file pointer position
void low_level_write(const cvec& v);
//! Write a string at the current file pointer position
void low_level_write(const std::string& str);
//! Write a bmat at the current file pointer position
void low_level_write(const bmat& m);
//! Write an smat at the current file pointer position
void low_level_write(const smat& m);
//! Write an imat at the current file pointer position
void low_level_write(const imat& m);
//! Write a mat at the current file pointer position
void low_level_write(const mat& m);
//! Write a cmat at the current file pointer position
void low_level_write(const cmat& m);
//! Write a bin Array at the current file pointer position
void low_level_write(const Array<bin>& v);
//! Write a short Array at the current file pointer position
void low_level_write(const Array<short>& v);
//! Write an integer Array at the current file pointer position
void low_level_write(const Array<int>& v);
//! Write a float Array at the current file pointer position
void low_level_write(const Array<float>& v);
//! Write a double Array at the current file pointer position
void low_level_write(const Array<double>& v);
//! Write a float complex Array at the current file pointer position
void low_level_write(const Array<std::complex<float> >& v);
//! Write a double complex Array at the current file pointer position
void low_level_write(const Array<std::complex<double> >& v);
//!ACTION: ADD DOCUMENTATION FOR THIS MEMBER !!!!!!!!
it_file& operator<<(it_manip func) { return (*func)(*this); }
//! Removes the variable \c name from the file
void remove(const std::string& name);
//! Returns true if the variable \c name exists in the file
bool exists(const std::string& name);
//! Remove slack space from the file
void pack();
protected:
//! Remove the current variable, denoted by \c next_name
void remove();
//! Write data header \c h at the current file position
void write_data_header_here(const data_header& h);
//! Low precision flag. If true, use float type, otherwise double
bool low_prec;
//! Name to be used for saving the next variable
std::string& next_name() {return _strings->_next_name;}
//! Description to be used for saving the next variable
std::string& next_desc() {return _strings->_next_desc;}
private:
struct Strings_Holder
{
std::string _next_name;
std::string _next_desc;
std::string _fname;
Strings_Holder():_next_name(""),_next_desc(""),_fname(""){}
};
Strings_Holder* _strings;
// Name of the opened file. Needed by the pack() method.
std::string& fname() {return _strings->_fname;}
};
/*!
\brief Flush operator
\ingroup itfile
Flushes the data. Usage:
\code
vec v1("1 2 3"), v2;
it_file f("file.it");
f << Name("v") << v1 << flush;
\endcode
*/
inline it_file& flush(it_file& f)
{
f.flush();
return f;
}
/*!
\brief Automatic naming when saving
\ingroup itfile
An easy way to give a variable a name and optionally description when
saving. Usage:
\code
vec v1("1 2 3"), v2;
it_file f("file.it");
f << Name("v", "A vector of consecutive double values") << v1;
f >> Name("v") >> v2;
\endcode
*/
class ITPP_EXPORT Name
{
public:
//! Constructor
Name(const std::string& n, const std::string& d = ""): name(n), desc(d) {}
//! Dummy assignment operator - MSVC++ warning C4512
Name &operator=(const Name&) { return *this; }
//! The name string
const std::string& name;
//! The description
const std::string& desc;
};
/*! \addtogroup itfile */
//!@{
//! Finds the variable \c Name in the \c it_ifile. Returns file pointer for reading.
inline it_ifile& operator>>(it_ifile& f, const Name& s)
{
f.seek(s.name);
return f;
}
//! Finds the variable \c Name in the \c it_file. Returns file pointer for writing.
inline it_file& operator<<(it_file& f, const Name& s)
{
f.set_next_name(s.name, s.desc);
return f;
}
//! Read the char variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, char& v);
//! Read the bool variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile &f, bool &v);
//! Read the binary variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, bin& v);
//! Read the short variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, short& v);
//! Read the integer variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, int& v);
//! Read the float variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, float& v);
//! Read the double variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, double& v);
//! Read the float complex variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, std::complex<float>& v);
//! Read the double complex variable \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, std::complex<double>& v);
//! Read the bvec \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, bvec& v);
//! Read the svec \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, svec& v);
//! Read the ivec \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, ivec& v);
//! Read the vec \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, vec& v);
//! Read the cvec \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, cvec& v);
//! Read the string \c str from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, std::string& str);
//! Read the bmat \c m from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, bmat& m);
//! Read the smat \c m from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, smat& m);
//! Read the imat \c m from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, imat& m);
//! Read the mat \c m from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, mat& m);
//! Read the cmat \c m from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, cmat& m);
//! Read the binary Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<bin>& v);
//! Read the short integer Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<short>& v);
//! Read the integer Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<int>& v);
//! Read the float Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<float>& v);
//! Read the double Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<double>& v);
//! Read the float complex Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<std::complex<float> >& v);
//! Read the double complex Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<std::complex<double> >& v);
//! Read the bvec Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<bvec>& v);
//! Read the svec Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<svec>& v);
//! Read the ivec Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<ivec>& v);
//! Read the vec Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<vec>& v);
//! Read the cvec Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<cvec>& v);
//! Read the string Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<std::string>& v);
//! Read the bmat Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<bmat>& v);
//! Read the bmat Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<smat>& v);
//! Read the imat Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<imat>& v);
//! Read the mat Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<mat>& v);
//! Read the cmat Array \c v from the \c it_ifile pointer
ITPP_EXPORT it_ifile& operator>>(it_ifile& f, Array<cmat>& v);
//! Write the char variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, char x);
//! Write the bool variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file &f, bool x);
//! Write the binary variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, bin x);
//! Write the short variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, short x);
//! Write the integer variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, int x);
//! Write the float variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, float x);
//! Write the double variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, double x);
//! Write the float complex variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, std::complex<float> x);
//! Write the double complex variable \c x to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, std::complex<double> x);
//! Write the bvec \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const bvec& v);
//! Write the svec \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const svec& v);
//! Write the ivec \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const ivec& v);
//! Write the vec \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const vec& v);
//! Write the cvec \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const cvec& v);
//! Write the string \c str to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const std::string& str);
//! Write the bmat \c m to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const bmat& m);
//! Write the smat \c m to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const smat& m);
//! Write the imat \c m to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const imat& m);
//! Write the mat \c m to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const mat& m);
//! Write the cmat \c m to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const cmat& m);
//! Write the bin Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<bin>& v);
//! Write the short int Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<short>& v);
//! Write the int Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<int>& v);
//! Write the float Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<float>& v);
//! Write the double Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<double>& v);
//! Write the float complex Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<std::complex<float> >& v);
//! Write the double complex Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<std::complex<double> >& v);
//! Write the bvec Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<bvec>& v);
//! Write the svec Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<svec>& v);
//! Write the ivec Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<ivec>& v);
//! Write the vec Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<vec>& v);
//! Write the cvec Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<cvec>& v);
//! Write the string Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<std::string>& v);
//! Write the bmat Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<bmat>& v);
//! Write the smat Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<smat>& v);
//! Write the imat Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<imat>& v);
//! Write the mat Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<mat>& v);
//! Write the cmat Array \c v to the \c it_file pointer
ITPP_EXPORT it_file& operator<<(it_file& f, const Array<cmat>& v);
//! Save the variable v in the file name.it as the name name.
template <class T> inline
void it_save_var_as(const T& v, const std::string& name)
{
it_file f(name + ".it");
f << Name(name) << v;
f.close();
}
//! Load the variable v from the file name.it as the name name.
template <class T> inline
void it_load_var_as(T& v, const std::string& name)
{
it_ifile f(name + ".it");
f.seek(name);
f >> v;
f.close();
}
//! A convenient macro. Calling it_save_var(M) saves M as 'M' in the file 'M.it'.
#define it_save_var(v) it_save_var_as(v,#v)
//! A convenient macro. Calling it_load_var(M) loads M as 'M' in the file 'M.it'.
#define it_load_var(v) it_load_var_as(v,#v)
//!@}
// ----------------------------------------------------------------------
// Deprecated implementation of IT++ file format version 2
// Will be removed in future versions
// ----------------------------------------------------------------------
/*!
\brief Base class for it_ifile_old and it_file_old.
\warning This class is deprecated and will be removed in future.
\ingroup itfile
*/
class ITPP_EXPORT it_file_base_old
{
public:
//! Data header structure
struct data_header {
//! 0=little, 1=big
char endianity;
/*! size variables
* @{ */
uint32_t hdr_bytes, data_bytes, block_bytes;
/*! @} */
//! data name
std::string name;
//! data type, e.g. int32, float32, etc. type = "" means deleted
std::string type;
};
protected:
//! File header structure
struct file_header {
//! ACTION: Add documentation
char magic[4];
//! ACTION: Add documentation
char version;
};
//! ACTION: Add documentation
static char file_magic[4];
//! ACTION: Add documentation
static char file_version;
};
/*!
\brief The old (version 2) IT++ file format reading class.
\warning This class is deprecated and will be removed in future.
\ingroup itfile
*/
class ITPP_EXPORT it_ifile_old : public it_file_base_old
{
public:
//!Constructor.
it_ifile_old();
//!Constructor. Calls open().
explicit it_ifile_old(const std::string& name);
//!Destructor.
virtual ~it_ifile_old() { }
//!Open a file. The file must exist.
void open(const std::string& name);
//!Close a file.
virtual void close();
//!Returns pointer to the underlying \c bfstream used
bfstream& low_level() { return s; }
//!Reads and checks the file data header. Returns true if the header is valid and false otherwise.
bool read_check_file_header();
//!Read the data header and return the result in the variable \c h
void read_data_header(data_header& h);
//!Read a char value at the current file pointer position
void low_level_read(char& x);
//!Read a binary value at the current file pointer position
void low_level_read(bin& x);
//!Read a short value at the current file pointer position
void low_level_read(short& x);
//!Read an integer value at the current file pointer position
void low_level_read(int& x);
//!Read a float value at the current file pointer position
void low_level_read(float& x);
//!Read a double value at the current file pointer position
void low_level_read(double& x);
//!Read a float complex value at the current file pointer position
void low_level_read(std::complex<float>& x);
//!Read a double complex value at the current file pointer position
void low_level_read(std::complex<double>& x);
//!Read a vector of float values at the current file pointer position
void low_level_read_lo(vec& v);
//!Read a vector of double values at the current file pointer position
void low_level_read_hi(vec& v);
//!Read a vector of integer values at the current file pointer position
void low_level_read(ivec& v);
//!Read a vector of binary values at the current file pointer position
void low_level_read(bvec& v);
//!Read a vector of float complex values at the current file pointer position
void low_level_read_lo(cvec& v);
//!Read a vector of double complex values at the current file pointer position
void low_level_read_hi(cvec& v);
//!Read a string at the current file pointer position
void low_level_read(std::string& str);
//!Read a matrix of float values at the current file pointer position
void low_level_read_lo(mat& m);
//!Read a matrix of double values at the current file pointer position
void low_level_read_hi(mat& m);
//!Read a matrix of integer values at the current file pointer position
void low_level_read(imat& m);
//!Read a matrix of binary values at the current file pointer position
void low_level_read(bmat& m);
//!Read a matrix of float complex values at the current file pointer position
void low_level_read_lo(cmat& m);
//!Read a matrix of double complex values at the current file pointer position
void low_level_read_hi(cmat& m);
//!Read an Array of float values at the current file pointer position
void low_level_read_lo(Array<float>& v);
//!Read an Array of float values at the current file pointer position
void low_level_read_lo(Array<double>& v);
//!Read an Array of double values at the current file pointer position
void low_level_read_hi(Array<double>& v);
//!Read an Array of integer values at the current file pointer position
void low_level_read(Array<int>& v);
//!Read an Array of binary values at the current file pointer position
void low_level_read(Array<bin>& v);
//!Read an Array of float complex values at the current file pointer position
void low_level_read_lo(Array<std::complex<float> >& v);
//!Read an Array of float complex values at the current file pointer position
void low_level_read_lo(Array<std::complex<double> >& v);
//!Read an Array of double complex values at the current file pointer position
void low_level_read_hi(Array<std::complex<double> >& v);
//! Find the variable \c name.
bool seek(const std::string& name);
//! Find the variable number \c n.
bool seek(int n);
//! Get information about the current variable.
void info(std::string& name, std::string& type, int& bytes);
protected:
//! Protected binary file stream
bfstream s;
};
/*!
\brief The old (version 2) IT++ file format reading and writing class.
\warning This class is deprecated and will be removed in future.
\ingroup itfile
*/
class ITPP_EXPORT it_file_old : public it_ifile_old
{
public:
//! ACTION: Add documentation for this typedef
typedef it_file_old& (*it_manip)(it_file_old&);
//! Constructor.
it_file_old();
/*!
\brief Constructor.
If the file does not exist it will be created. If \c trunc is true,
the file will be truncated.
*/
explicit it_file_old(const std::string& name, bool trunc = false);
//! Destructor.
virtual ~it_file_old() { delete _string;}
/*!
\brief Open a file for reading and writing.
If the file does not exist it will be created. If \c trunc is true,
the file will be truncated.
*/
void open(const std::string& name, bool trunc = false);
//! Close the file.
void close();
//! Flush the data to disk.
void flush();
//! Returns pointer to the underlying \c bfstream used
bfstream& low_level() { return s; }
//! Set the precision. Low precision means floats, high means doubles.
void set_low_precision(bool p = true) { low_prec = p; }
//! Get the precision.
bool get_low_precision() { return low_prec; }
//! Set the name of the next name to be saved. See also the \c Name class.
void set_next_name(const std::string& n) { next_name() = n; }
//!Write the header for the \c it_file_old
void write_file_header();
//!Write the data header for a variable, specifying the type and size of the data to follow.
void write_data_header(const std::string& type, uint32_t size);
//!Write the data header for a variable, specifying the type, name, and size of the data to follow.
void write_data_header(const std::string& type, const std::string& name,
uint32_t size);
//!Write a char value at the current file pointer position
void low_level_write(char x);
//!Write a binary value at the current file pointer position
void low_level_write(bin x);
//!Write a short value at the current file pointer position
void low_level_write(short x);
//!Write an integer value at the current file pointer position
void low_level_write(int x);
//!Write a float value at the current file pointer position
void low_level_write(float x);
//!Write a double value at the current file pointer position
void low_level_write(double x);
//!Write a float complex value at the current file pointer position
void low_level_write(const std::complex<float>& x);
//!Write a double complex value at the current file pointer position
void low_level_write(const std::complex<double>& x);
//!Write a vec at the current file pointer position
void low_level_write(const vec& v);
//!Write an ivec at the current file pointer position
void low_level_write(const ivec& v);
//!Write a bvec at the current file pointer position
void low_level_write(const bvec& v);
//!Write a cvec at the current file pointer position
void low_level_write(const cvec& v);
//!Write a string at the current file pointer position
void low_level_write(const std::string& str);
//!Write a mat at the current file pointer position
void low_level_write(const mat& m);
//!Write a imat at the current file pointer position
void low_level_write(const imat& m);
//!Write a bmat at the current file pointer position
void low_level_write(const bmat& m);
//!Write a cmat at the current file pointer position
void low_level_write(const cmat& m);
//!Write a float Array at the current file pointer position
void low_level_write(const Array<float>& v);
//!Write a double Array at the current file pointer position
void low_level_write(const Array<double>& v);
//!Write a integer Array at the current file pointer position
void low_level_write(const Array<int>& v);
//!Write a bin Array at the current file pointer position
void low_level_write(const Array<bin>& v);
//!Write a float complex Array at the current file pointer position
void low_level_write(const Array<std::complex<float> >& v);
//!Write a double complex Array at the current file pointer position
void low_level_write(const Array<std::complex<double> >& v);
//!ACTION: ADD DOCUMENTATION FOR THIS MEMBER !!!!!!!!
it_file_old& operator<<(it_manip func) { return (*func)(*this); }
//! Removes the variable \c name from the file.
void remove(const std::string& name);
//! Returns true if the variable \c name exists in the file.
bool exists(const std::string& name);
//! Remove slack space from the file.
void pack();
protected:
//! ACTION: Add documenation for this protected member
void remove();
//! ACTION: Add documenation for this protected member
void write_data_header_here(const data_header& h);
//! ACTION: Add documenation for this protected member
bool low_prec;
//! ACTION: Add documenation for this protected member
std::string& next_name() {return _string->_next_name;}
private:
struct String_Holder
{
std::string _next_name;
String_Holder():_next_name(""){}
};
String_Holder* _string;
};
/*!
\brief Flush operator.
\ingroup itfile
Flushes the data. Usage:
\code
vec v1("1 2 3"), v2;
it_file_old f("file.it");
f << Name("v") << v1 << flush;
\endcode
*/
inline it_file_old& flush(it_file_old& f)
{
f.flush();
return f;
}
/*! \addtogroup itfile */
//!@{
//!Finds the variable \c Name in the \c it_ifile_old. Returns file pointer for reading.
inline it_ifile_old& operator>>(it_ifile_old& f, const Name& s)
{
f.seek(s.name);
return f;
}
//!Finds the variable \c Name in the \c it_file_old. Returns file pointer for writing.
inline it_file_old& operator<<(it_file_old& f, const Name& s)
{
f.set_next_name(s.name);
return f;
}
//!Read the char variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, char& v);
//!Read the binary variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, bin& v);
//!Read the short variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, short& v);
//!Read the integer variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, int& v);
//!Read the float variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, float& v);
//!Read the double variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, double& v);
//!Read the float complex variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, std::complex<float>& v);
//!Read the double complex variable \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, std::complex<double>& v);
//!Read the vec \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, vec& v);
//!Read the ivec \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, ivec& v);
//!Read the bvec \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, bvec& v);
//!Read the cvec \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, cvec& v);
//!Read the string \c str from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, std::string& str);
//!Read the mat \c m from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, mat& m);
//!Read the imat \c m from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, imat& m);
//!Read the bmat \c m from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, bmat& m);
//!Read the cmat \c m from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, cmat& m);
//!Read the float Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<float>& v);
//!Read the double Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<double>& v);
//!Read the integer Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<int>& v);
//!Read the binary Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<bin>& v);
//!Read the float complex Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<std::complex<float> >& v);
//!Read the double complex Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<std::complex<double> >& v);
//!Read the vec Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<vec>& v);
//!Read the ivec Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<ivec>& v);
//!Read the bvec Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<bvec>& v);
//!Read the cvec Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<cvec>& v);
//!Read the string Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<std::string>& v);
//!Read the mat Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<mat>& v);
//!Read the imat Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<imat>& v);
//!Read the bmat Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<bmat>& v);
//!Read the cmat Array \c v from the \c it_ifile_old pointer
ITPP_EXPORT it_ifile_old& operator>>(it_ifile_old& f, Array<cmat>& v);
//!Write the char variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, char x);
//!Write the binary variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, bin x);
//!Write the short variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, short x);
//!Write the integer variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, int x);
//!Write the float variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, float x);
//!Write the double variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, double x);
//!Write the float complex variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, std::complex<float> x);
//!Write the double complex variable \c x to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, std::complex<double> x);
//!Write the vec \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const vec& v);
//!Write the ivec \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const ivec& v);
//!Write the bvec \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const bvec& v);
//!Write the cvec \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const cvec& v);
//!Write the string \c str to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const std::string& str);
//!Write the mat \c m to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const mat& m);
//!Write the imat \c m to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const imat& m);
//!Write the bmat \c m to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const bmat& m);
//!Write the cmat \c m to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const cmat& m);
//!Write the float Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<float>& v);
//!Write the double Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<double>& v);
//!Write the int Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<int>& v);
//!Write the bin Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<bin>& v);
//!Write the float complex Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<std::complex<float> >& v);
//!Write the double complex Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<std::complex<double> >& v);
//!Write the vec Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<vec>& v);
//!Write the ivec Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<ivec>& v);
//!Write the bvec Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<bvec>& v);
//!Write the cvec Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<cvec>& v);
//!Write the string Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<std::string>& v);
//!Write the mat Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<mat>& v);
//!Write the imat Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<imat>& v);
//!Write the bmat Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<bmat>& v);
//!Write the cmat Array \c v to the \c it_file_old pointer
ITPP_EXPORT it_file_old& operator<<(it_file_old& f, const Array<cmat>& v);
//!@}
// ----------------------------------------------------------------------
// End of the deprecated implementation of IT++ file format version 2
// Will be removed in future versions
// ----------------------------------------------------------------------
} // namespace itpp
#endif // #ifndef IT_FILE_H
|