mirror of
https://github.com/opencv/opencv_contrib.git
synced 2025-10-24 20:01:12 +08:00

Author: Vitaliy Lyudvichenko Mentor: Anatoly Baksheev Squashed commits are: commit2f6d743
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sun May 31 00:05:31 2015 +0300 Added dnn module with draft interface. commitcfb9cfa
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 3 17:54:13 2015 +0300 Added libprotobuf to CMake. Added some Caffe files. commita6963b4
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 3 22:28:12 2015 +0300 Updated CMakeLists.txt to support protobuf Messages auto generation. commit6e23d93
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jun 6 19:08:12 2015 +0300 Added simple .prototxt Caffe importer. commit77321e3
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Jun 8 16:59:27 2015 +0300 Added binary .caffemodel import support. Some changes in API. Caffe source files was cleared from unnecessary code. commit24a9eff
Merge:77321e3
844c30e
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Jun 8 17:01:54 2015 +0300 Merge branch 'master' of https://github.com/Itseez/opencv_contrib commit62feeec
Author: Anatoly Baksheev <no@email> Date: Mon Jun 8 19:41:11 2015 +0300 fixed compilation witn C++11 compiler commit42b36fb
Author: Anatoly Baksheev <no@email> Date: Mon Jun 8 19:48:32 2015 +0300 more compilation commit10c3a13
Author: Anatoly Baksheev <no@email> Date: Mon Jun 8 20:00:37 2015 +0300 umbrealla header commiteb95846
Author: Anatoly Baksheev <no@email> Date: Mon Jun 8 20:26:47 2015 +0300 some warnings disabled commit1fd9304
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 9 13:58:35 2015 +0300 Dnn API changes (removed NetConfiguration, added LayerRegister, improved Blob). commitcae0bd4
Merge:1fd9304
eb95846
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 9 14:25:35 2015 +0300 Merge branch 'master' of github.com:ludv1x/opencv_contrib Conflicts: modules/dnn/include/opencv2/dnn.hpp commitee837c1
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 9 21:36:18 2015 +0300 Updated CMakeLists.txt commit194271d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sun Jun 14 22:20:01 2015 +0300 Implemented allocation of DAG and it's forward pass. Added wrappers for basic layers. commited1c569
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 16 19:31:15 2015 +0300 [Bomb commit] Implemented 4 main layers. Changes in API. Added worked classification example from GTSRB into tests. commit51df95d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 16 19:31:38 2015 +0300 Added GSTRB test data. commit2638433
Merge:51df95d
2a199bc
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 16 22:55:35 2015 +0300 Merge branch 'master' of https://github.com/Itseez/opencv_contrib commiteba62d5
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jun 18 16:58:57 2015 +0300 Layers implementations divided onto separated files. commit383715d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jun 18 23:55:16 2015 +0300 libprotobuf is optional dependency now commit2c501f3
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Fri Jun 19 00:01:53 2015 +0300 Replace CMake WARNING onto STATUS commit29966ee
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Fri Jun 19 16:50:25 2015 +0300 added HAVE_PROTOBUF macro commit48ab440
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jun 20 01:59:56 2015 +0300 Changed default parameter commit09ffc43
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jun 20 11:58:56 2015 +0300 Fixed CMake and CPP build errors commiteef4d1d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Jun 22 23:49:54 2015 +0300 Added LRN and SoftMax layers, some fixes commit22272e8
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 23 14:27:30 2015 +0300 Many fixes. commit9cddccf
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 23 14:29:42 2015 +0300 Added AlexNet sample. Removed big .caffemodel files from repo. commit66fa1e1
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jun 23 17:33:48 2015 +0300 Random changes in matlab/* module was reverted commitd80c272
Author: Anatoly Baksheev <no@email> Date: Wed Jun 24 11:48:44 2015 +0300 fixed stand alone link errors commit0cd5459
Author: Anatoly Baksheev <no@email> Date: Wed Jun 24 12:25:19 2015 +0300 added incdes to project so that it could be visible in some IDEs (ex. qtcreator) commit13edaaa
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 24 18:25:34 2015 +0300 Added group param to convolution_layer.cpp commit49b5e5e
Merge:13edaaa
0cd5459
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 24 18:25:50 2015 +0300 Merge branch 'master' of github.com:ludv1x/opencv_contrib commit99b8dac
Merge:49b5e5e
8a05bdb
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 24 18:26:10 2015 +0300 Merge branch 'master' of https://github.com/Itseez/opencv_contrib commit0f7907d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 24 19:28:55 2015 +0300 updated example commit2717765
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 24 20:02:31 2015 +0300 Fixed some warnings commitd117983
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jun 24 22:18:05 2015 +0300 Deleted trailing whitespaces commitcfdf060
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jun 25 12:16:11 2015 +0300 Fixed more warnings. Updated glog_emulator.hpp: commit761b037
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Fri Jun 26 17:57:55 2015 +0300 Fixed critical bug in dnn::Dict. Fixed LRN layer implementation. Added layers test. commit6fd67d4
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jul 1 12:12:49 2015 +0300 Updated test. Added and successfuly passed AlexNet reproducibility test. Small fixes. commit9838234
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 2 12:25:30 2015 +0300 Some layer fixes. Added concat layer and avg. pooling to sucesfully run GoogLeNet. Added concat layer, implemented average pooling to run GoogLeNet. Fixed transpose error in FullyConnected layer (hotfix in softmax layer). Added GoogleNet test and updated AlexNet test (both nets now work fine). commit6f8a73b
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 2 12:31:48 2015 +0300 Replaced CMake if() condition for standalone build. commit0ebe30a
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jul 4 22:41:55 2015 +0300 Blob class was significantly refactored commitd02bced
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sun Jul 5 22:52:34 2015 +0300 More refactoring over Blob. More refactoring over Blob. Fix warnings and eliminated zlib dependency in cnpy.h commit85ad43d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Jul 6 14:51:10 2015 +0300 Generalized Blob constructor and added vector of images support. AlexNet and GoogLeNet tests updated. commit75e09fd
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jul 8 19:05:36 2015 +0300 Implement ambiguous blobs naming scheme like: "layerName[.OutputName]". Old Caffe-like blob naming scheme was deleted. commitb9e85ed
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Jul 8 19:15:51 2015 +0300 fixed sign type mismatch warnings in cnpy commit9783bba
Merge:b9e85ed
6f8a73b
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 9 18:26:08 2015 +0300 Merge branch 'master' into work commitde4d800
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sun Jul 12 23:19:07 2015 +0300 Added .caffemodel files downloader for tests on post-build step. commitec74678
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 16 20:24:12 2015 +0300 Added element-wise layers. Fixed downloader and ConcatLayer. commit0362da9
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Fri Jul 17 17:24:59 2015 +0300 Added array support for Dict. commit3aa37d2
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jul 18 01:12:08 2015 +0300 Array of parmaters support into caffe_importer.cpp commit172419e
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sun Jul 19 21:31:22 2015 +0300 Added Reshape layer and altered importer to correctly handle its params. commit71cfae4
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Jul 20 23:29:42 2015 +0300 Added Split and Slice layer. commit527fa65
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jul 21 16:10:29 2015 +0300 Rewrited concat_layer.cpp in OpenCV-style. Fixed slice layer, added test for slice, split and reshape layers. commit9b1e28e
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 23 00:09:15 2015 +0300 Refactored ConvolutionLayer, added Deconvolution. commitff45c22
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 23 21:19:25 2015 +0300 Fixed gcc build errors. commit6548839
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jul 25 12:24:54 2015 +0300 Added testdata images. Fixed Dict copy constructor. commitdb4ff21
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Jul 25 22:26:29 2015 +0300 Updated classification example commit4da1046
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Jul 28 16:00:07 2015 +0300 Implemented draft Torch importer commit7d795af
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Jul 30 15:43:47 2015 +0300 Fixed Torch parser commit5e5cc96
Merge:6f8a73b
f9d4288
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 3 20:18:01 2015 +0300 Merge branch 'master' of https://github.com/Itseez/opencv_contrib commitdd15521
Merge:5e5cc96
db4ff21
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 3 20:18:28 2015 +0300 Merge branch 'master' of github.com:ludv1x/opencv_contrib commitc1f4410
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 3 20:20:00 2015 +0300 cnpy warns fix commit2905c03
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 4 19:16:34 2015 +0300 Multiple layers support added into Torch importer. Also DictValue was refactored. commit8df8936
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 5 13:14:52 2015 +0300 Added Torch blob reader and torch convolution test. commit1c220cf
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 6 13:29:45 2015 +0300 Added simple tests for Torch importer, fixed some importing issues. commit436d929
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 6 14:37:56 2015 +0300 Resolve reference counting problem in Torch importer. commitb2f4ba3
Merge:c1f4410
172fdb3
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Fri Aug 7 13:27:45 2015 +0300 Merge branch 'master' of https://github.com/Itseez/opencv_contrib commit5b08053
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 10 12:53:44 2015 +0300 Added ability to remove singleton dimensions in Reshape layer. Updated torch importer commitd0875b1
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 11 01:49:27 2015 +0300 Fixed average pooling error commitf8119ea
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 11 22:12:48 2015 +0300 Fixed Deconvolution layer. Added more wide layers test coverage. commitdf5eec6
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 12 16:54:44 2015 +0300 Added MVN layer. Renamed layer test data. commitf28effb
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 12 19:49:54 2015 +0300 Cleaned caffe dependencies commitb3dcc39
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 12 20:04:23 2015 +0300 Moved caffe.proto commit7d2e745
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 13 00:53:50 2015 +0300 Minor test changes commitc65d032
Merge:7d2e745
b2f4ba3
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 13 01:25:00 2015 +0300 Merge branch 'master' of https://github.com/ludv1x/opencv_contrib commit160d864
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 13 11:45:40 2015 +0300 Fixed small warn and example error commit06f949a
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 13 17:52:46 2015 +0300 Added initModule() procedure to explicitly init builtin layers commit23d3ede
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 17 15:10:04 2015 +0300 Added OpenCL im2col commit7acfda2
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 18 01:40:41 2015 +0300 Fixed im2col_ocl bug caused non-zero UMat offset commit9d932af
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 18 01:55:05 2015 +0300 Add new method to Net commit0903d79
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 19 01:28:44 2015 +0300 Added libprotobuf 2.5 as thridparty library commit4929177
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 19 01:32:51 2015 +0300 Add compiled caffe protobuf files commitfc9795b
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 19 18:57:12 2015 +0300 libprotobuf is a separate 3rdparty lib now commit93a372f
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 19 19:53:52 2015 +0300 Try fix msvc error and cmake error on android commit44e52a0
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 20 01:34:05 2015 +0300 Try fix msvc warnings commit519167e
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 20 18:51:44 2015 +0300 Refactored cmake and disabled AlexNet test commite644b5a
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 20 21:52:41 2015 +0300 Changed Blob::ptr and Blob::offset methods commitf07c564
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 20 22:53:02 2015 +0300 Add test data for layers commitfb66acb
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Fri Aug 21 01:59:17 2015 +0300 API refactoring renamed learnedParams blobs field added new fields: name and type for Layer commitf8715f3
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sat Aug 22 18:31:53 2015 +0300 Added licence headers commit945094b
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Sun Aug 23 03:06:24 2015 +0300 Update doc, small changes in Blob methods commitc681508
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 24 01:45:32 2015 +0300 Add more docs commitbd242d1
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 24 20:44:34 2015 +0300 Add docs for remaning functions commiteced23c
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Mon Aug 24 20:44:56 2015 +0300 Updated dnn example commit57a2194
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 25 15:18:21 2015 +0300 Add tutorial_dnn_build commitefde664
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 25 17:09:00 2015 +0300 Move binary testdata from opencv_contrib to opencv_extra commite52a7ee
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Tue Aug 25 19:01:05 2015 +0300 Add bvlc_googlenet.prototxt to samples commit3154fc0
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 26 01:43:53 2015 +0300 Add googlenet tutorial commit467cd96
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 26 13:32:27 2015 +0300 Updated dnn build tutorial commit83e39a9
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Wed Aug 26 19:56:36 2015 +0300 Fix typos commit0a64a9d
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 27 02:30:20 2015 +0300 Changed Caffe googlenet tutorial commitd2b6011
Author: Vitaliy Lyudvichenko <ludv1x@yandex.ru> Date: Thu Aug 27 14:01:40 2015 +0300 Fix documentation warning commit248577a
Author: Anatoly Baksheev <no@email> Date: Thu Sep 3 18:33:26 2015 +0300 fixed signed/unsigned cast warning
295 lines
12 KiB
C++
295 lines
12 KiB
C++
/*M///////////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
|
|
//
|
|
// By downloading, copying, installing or using the software you agree to this license.
|
|
// If you do not agree to this license, do not download, install,
|
|
// copy or use the software.
|
|
//
|
|
//
|
|
// License Agreement
|
|
// For Open Source Computer Vision Library
|
|
//
|
|
// Copyright (C) 2013, OpenCV Foundation, all rights reserved.
|
|
// Third party copyrights are property of their respective owners.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without modification,
|
|
// are permitted provided that the following conditions are met:
|
|
//
|
|
// * Redistribution's of source code must retain the above copyright notice,
|
|
// this list of conditions and the following disclaimer.
|
|
//
|
|
// * Redistribution's in binary form must reproduce the above copyright notice,
|
|
// this list of conditions and the following disclaimer in the documentation
|
|
// and/or other materials provided with the distribution.
|
|
//
|
|
// * The name of the copyright holders may not be used to endorse or promote products
|
|
// derived from this software without specific prior written permission.
|
|
//
|
|
// This software is provided by the copyright holders and contributors "as is" and
|
|
// any express or implied warranties, including, but not limited to, the implied
|
|
// warranties of merchantability and fitness for a particular purpose are disclaimed.
|
|
// In no event shall the Intel Corporation or contributors be liable for any direct,
|
|
// indirect, incidental, special, exemplary, or consequential damages
|
|
// (including, but not limited to, procurement of substitute goods or services;
|
|
// loss of use, data, or profits; or business interruption) however caused
|
|
// and on any theory of liability, whether in contract, strict liability,
|
|
// or tort (including negligence or otherwise) arising in any way out of
|
|
// the use of this software, even if advised of the possibility of such damage.
|
|
//
|
|
//M*/
|
|
|
|
//Copyright (C) 2011 Carl Rogers
|
|
//Released under MIT License
|
|
//license available in LICENSE file, or at http://www.opensource.org/licenses/mit-license.php
|
|
|
|
#ifndef LIBCNPY_H_
|
|
#define LIBCNPY_H_
|
|
|
|
#include<string>
|
|
#include<stdexcept>
|
|
#include<sstream>
|
|
#include<vector>
|
|
#include<cstdio>
|
|
#include<typeinfo>
|
|
#include<iostream>
|
|
#include<cassert>
|
|
#include<map>
|
|
#if defined(HAVE_ZLIB) && HAVE_ZLIB
|
|
#include<zlib.h>
|
|
#endif
|
|
|
|
#ifndef NDEBUG
|
|
#define cnpy_assert(expression) assert(expression)
|
|
#else
|
|
#define cnpy_assert(expression) ((void)(expression))
|
|
#endif
|
|
|
|
namespace cnpy {
|
|
|
|
struct NpyArray {
|
|
char* data;
|
|
std::vector<unsigned int> shape;
|
|
unsigned int word_size;
|
|
bool fortran_order;
|
|
void destruct() {delete[] data;}
|
|
};
|
|
|
|
struct npz_t : public std::map<std::string, NpyArray>
|
|
{
|
|
void destruct()
|
|
{
|
|
npz_t::iterator it = this->begin();
|
|
for(; it != this->end(); ++it) (*it).second.destruct();
|
|
}
|
|
};
|
|
|
|
char BigEndianTest();
|
|
char map_type(const std::type_info& t);
|
|
template<typename T> std::vector<char> create_npy_header(const T* data, const unsigned int* shape, const unsigned int ndims);
|
|
void parse_npy_header(FILE* fp,unsigned int& word_size, unsigned int*& shape, unsigned int& ndims, bool& fortran_order);
|
|
void parse_zip_footer(FILE* fp, unsigned short& nrecs, unsigned int& global_header_size, unsigned int& global_header_offset);
|
|
npz_t npz_load(std::string fname);
|
|
NpyArray npz_load(std::string fname, std::string varname);
|
|
NpyArray npy_load(std::string fname);
|
|
|
|
template<typename T> std::vector<char>& operator+=(std::vector<char>& lhs, const T rhs) {
|
|
//write in little endian
|
|
for(char byte = 0; byte < sizeof(T); byte++) {
|
|
char val = *((char*)&rhs+byte);
|
|
lhs.push_back(val);
|
|
}
|
|
return lhs;
|
|
}
|
|
|
|
template<> std::vector<char>& operator+=(std::vector<char>& lhs, const std::string rhs);
|
|
template<> std::vector<char>& operator+=(std::vector<char>& lhs, const char* rhs);
|
|
|
|
|
|
template<typename T> std::string tostring(T i, int = 0, char = ' ') {
|
|
std::stringstream s;
|
|
s << i;
|
|
return s.str();
|
|
}
|
|
|
|
template<typename T> void npy_save(std::string fname, const T* data, const unsigned int* shape, const unsigned int ndims, std::string mode = "w") {
|
|
FILE* fp = NULL;
|
|
|
|
if(mode == "a") fp = fopen(fname.c_str(),"r+b");
|
|
|
|
if(fp) {
|
|
//file exists. we need to append to it. read the header, modify the array size
|
|
unsigned int word_size, tmp_dims;
|
|
unsigned int* tmp_shape = 0;
|
|
bool fortran_order;
|
|
parse_npy_header(fp,word_size,tmp_shape,tmp_dims,fortran_order);
|
|
cnpy_assert(!fortran_order);
|
|
|
|
if(word_size != sizeof(T)) {
|
|
std::cout<<"libnpy error: "<<fname<<" has word size "<<word_size<<" but npy_save appending data sized "<<sizeof(T)<<"\n";
|
|
cnpy_assert( word_size == sizeof(T) );
|
|
}
|
|
if(tmp_dims != ndims) {
|
|
std::cout<<"libnpy error: npy_save attempting to append misdimensioned data to "<<fname<<"\n";
|
|
cnpy_assert(tmp_dims == ndims);
|
|
}
|
|
|
|
for(unsigned i = 1; i < ndims; i++) {
|
|
if(shape[i] != tmp_shape[i]) {
|
|
std::cout<<"libnpy error: npy_save attempting to append misshaped data to "<<fname<<"\n";
|
|
cnpy_assert(shape[i] == tmp_shape[i]);
|
|
}
|
|
}
|
|
tmp_shape[0] += shape[0];
|
|
|
|
fseek(fp,0,SEEK_SET);
|
|
std::vector<char> header = create_npy_header(data,tmp_shape,ndims);
|
|
fwrite(&header[0],sizeof(char),header.size(),fp);
|
|
fseek(fp,0,SEEK_END);
|
|
|
|
delete[] tmp_shape;
|
|
}
|
|
else {
|
|
fp = fopen(fname.c_str(),"wb");
|
|
std::vector<char> header = create_npy_header(data,shape,ndims);
|
|
fwrite(&header[0],sizeof(char),header.size(),fp);
|
|
}
|
|
|
|
unsigned int nels = 1;
|
|
for(unsigned i = 0;i < ndims;i++) nels *= shape[i];
|
|
|
|
fwrite(data,sizeof(T),nels,fp);
|
|
fclose(fp);
|
|
}
|
|
|
|
template<typename T> void npz_save(std::string zipname, std::string fname, const T* data, const unsigned int* shape, const unsigned int ndims, std::string mode = "w")
|
|
{
|
|
//first, append a .npy to the fname
|
|
fname += ".npy";
|
|
|
|
//now, on with the show
|
|
FILE* fp = NULL;
|
|
unsigned short nrecs = 0;
|
|
unsigned int global_header_offset = 0;
|
|
std::vector<char> global_header;
|
|
|
|
if(mode == "a") fp = fopen(zipname.c_str(),"r+b");
|
|
|
|
if(fp) {
|
|
//zip file exists. we need to add a new npy file to it.
|
|
//first read the footer. this gives us the offset and size of the global header
|
|
//then read and store the global header.
|
|
//below, we will write the the new data at the start of the global header then append the global header and footer below it
|
|
unsigned int global_header_size;
|
|
parse_zip_footer(fp,nrecs,global_header_size,global_header_offset);
|
|
fseek(fp,global_header_offset,SEEK_SET);
|
|
global_header.resize(global_header_size);
|
|
size_t res = fread(&global_header[0],sizeof(char),global_header_size,fp);
|
|
if(res != global_header_size){
|
|
throw std::runtime_error("npz_save: header read error while adding to existing zip");
|
|
}
|
|
fseek(fp,global_header_offset,SEEK_SET);
|
|
}
|
|
else {
|
|
fp = fopen(zipname.c_str(),"wb");
|
|
}
|
|
|
|
std::vector<char> npy_header = create_npy_header(data,shape,ndims);
|
|
|
|
unsigned long nels = 1;
|
|
for (unsigned m=0; m<ndims; m++ ) nels *= shape[m];
|
|
int nbytes = nels*sizeof(T) + npy_header.size();
|
|
|
|
//get the CRC of the data to be added
|
|
#if defined(HAVE_ZLIB) && HAVE_ZLIB
|
|
unsigned int crc = crc32(0L,(unsigned char*)&npy_header[0],npy_header.size());
|
|
crc = crc32(crc,(unsigned char*)data,nels*sizeof(T));
|
|
#else
|
|
unsigned int crc = 0;
|
|
#endif
|
|
|
|
//build the local header
|
|
std::vector<char> local_header;
|
|
local_header += "PK"; //first part of sig
|
|
local_header += (unsigned short) 0x0403; //second part of sig
|
|
local_header += (unsigned short) 20; //min version to extract
|
|
local_header += (unsigned short) 0; //general purpose bit flag
|
|
local_header += (unsigned short) 0; //compression method
|
|
local_header += (unsigned short) 0; //file last mod time
|
|
local_header += (unsigned short) 0; //file last mod date
|
|
local_header += (unsigned int) crc; //crc
|
|
local_header += (unsigned int) nbytes; //compressed size
|
|
local_header += (unsigned int) nbytes; //uncompressed size
|
|
local_header += (unsigned short) fname.size(); //fname length
|
|
local_header += (unsigned short) 0; //extra field length
|
|
local_header += fname;
|
|
|
|
//build global header
|
|
global_header += "PK"; //first part of sig
|
|
global_header += (unsigned short) 0x0201; //second part of sig
|
|
global_header += (unsigned short) 20; //version made by
|
|
global_header.insert(global_header.end(),local_header.begin()+4,local_header.begin()+30);
|
|
global_header += (unsigned short) 0; //file comment length
|
|
global_header += (unsigned short) 0; //disk number where file starts
|
|
global_header += (unsigned short) 0; //internal file attributes
|
|
global_header += (unsigned int) 0; //external file attributes
|
|
global_header += (unsigned int) global_header_offset; //relative offset of local file header, since it begins where the global header used to begin
|
|
global_header += fname;
|
|
|
|
//build footer
|
|
std::vector<char> footer;
|
|
footer += "PK"; //first part of sig
|
|
footer += (unsigned short) 0x0605; //second part of sig
|
|
footer += (unsigned short) 0; //number of this disk
|
|
footer += (unsigned short) 0; //disk where footer starts
|
|
footer += (unsigned short) (nrecs+1); //number of records on this disk
|
|
footer += (unsigned short) (nrecs+1); //total number of records
|
|
footer += (unsigned int) global_header.size(); //nbytes of global headers
|
|
footer += (unsigned int) (global_header_offset + nbytes + local_header.size()); //offset of start of global headers, since global header now starts after newly written array
|
|
footer += (unsigned short) 0; //zip file comment length
|
|
|
|
//write everything
|
|
fwrite(&local_header[0],sizeof(char),local_header.size(),fp);
|
|
fwrite(&npy_header[0],sizeof(char),npy_header.size(),fp);
|
|
fwrite(data,sizeof(T),nels,fp);
|
|
fwrite(&global_header[0],sizeof(char),global_header.size(),fp);
|
|
fwrite(&footer[0],sizeof(char),footer.size(),fp);
|
|
fclose(fp);
|
|
}
|
|
|
|
template<typename T> std::vector<char> create_npy_header(const T*, const unsigned int* shape, const unsigned int ndims) {
|
|
|
|
std::vector<char> dict;
|
|
dict += "{'descr': '";
|
|
dict += BigEndianTest();
|
|
dict += map_type(typeid(T));
|
|
dict += tostring(sizeof(T));
|
|
dict += "', 'fortran_order': False, 'shape': (";
|
|
dict += tostring(shape[0]);
|
|
for(unsigned i = 1;i < ndims;i++) {
|
|
dict += ", ";
|
|
dict += tostring(shape[i]);
|
|
}
|
|
if(ndims == 1) dict += ",";
|
|
dict += "), }";
|
|
//pad with spaces so that preamble+dict is modulo 16 bytes. preamble is 10 bytes. dict needs to end with \n
|
|
int remainder = 16 - (10 + dict.size()) % 16;
|
|
dict.insert(dict.end(),remainder,' ');
|
|
dict.back() = '\n';
|
|
|
|
std::vector<char> header;
|
|
header += (unsigned char) 0x93;
|
|
header += "NUMPY";
|
|
header += (char) 0x01; //major version of numpy format
|
|
header += (char) 0x00; //minor version of numpy format
|
|
header += (unsigned short) dict.size();
|
|
header.insert(header.end(),dict.begin(),dict.end());
|
|
|
|
return header;
|
|
}
|
|
|
|
|
|
}
|
|
|
|
#endif
|