本文整理汇总了C++中blitz::Array类的典型用法代码示例。如果您正苦于以下问题:C++ Array类的具体用法?C++ Array怎么用?C++ Array使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Array类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: netcdf_write_blitz
void netcdf_write_blitz(NcVar *nc_var, blitz::Array<T, rank> const &val)
{
long counts[rank];
for (int i=0; i<rank; ++i) counts[i] = val.extent(i);
//printf("netcdf_write_blitz: %p %p\n", nc_var, val.data());
nc_var->put(val.data(), counts);
}
示例2: global_to_local
void GridDomain::global_to_local(
blitz::Array<double,1> const &global,
std::vector<blitz::Array<double,1>> &olocal)
{
if (olocal.size() != this->num_local_indices) {
fprintf(stderr, "MatrixDomainer::get_rows() had bad dimension 1 = %d (expected %ld)\n", olocal.extent(1), this->num_local_indices);
throw std::exception();
}
for (auto ii = olocal.begin(); ii != olocal.end(); ++ii) {
// Make sure it has the right dimensions
if (olocal[i].extent(0) != global.extent(0)) {
fprintf(stderr, "MatrixDomainer::get_rows() had bad dimension 0 = %d (expected %ld)\n", olocal.extent(0), global.extent(0));
throw std::exception();
}
}
// Copy out data, translating to local coordinates
for (int j=0; j < global.extent(0); ++j) {
int lindex[this->num_local_indices];
this->global_to_local(global(j), lindex);
for (int i=0; i<this->num_local_indices; ++i)
olocal[i](j) = lindex[i];
}
}
示例3: runtime_error
void GmresWrapper<Rank>::ApplyOperator(blitz::Array<cplx, 1> &input, blitz::Array<cplx, 1> &output)
{
if (Psi == 0)
{
throw std::runtime_error("Psi is 0");
}
if (TempPsi == 0)
{
throw std::runtime_error("TempPsi is 0");
}
//Map the 1d vectors to a a blitz array of correct shape
DataVector shape = Psi->GetData().shape();
DataVector stride = Psi->GetData().stride();
DataArray inData(input.data(), shape, stride, blitz::neverDeleteData);
DataArray inData2(input.data(), shape, stride, blitz::neverDeleteData);
DataArray outData(output.data(), shape, stride, blitz::neverDeleteData);
DataArray outData2(output.data(), shape, stride, blitz::neverDeleteData);
outData = 0;
//Set psi and tempPsi to point to correct vectorsbuffers
DataArray oldData = Psi->GetData();
DataArray oldTempData = TempPsi->GetData();
Psi->SetData(inData);
TempPsi->SetData(outData);
OperatorCallback(Psi, TempPsi);
//Restore the former buffers
Psi->SetData(oldData);
TempPsi->SetData(oldTempData);
}
示例4: logLikelihood_
double bob::learn::em::GMMMachine::logLikelihood(const blitz::Array<double, 1> &x,
blitz::Array<double,1> &log_weighted_gaussian_likelihoods) const
{
// Check dimension
bob::core::array::assertSameDimensionLength(log_weighted_gaussian_likelihoods.extent(0), m_n_gaussians);
bob::core::array::assertSameDimensionLength(x.extent(0), m_n_inputs);
return logLikelihood_(x,log_weighted_gaussian_likelihoods);
}
示例5: Inverse_Matrix_with_lapack_and_Return_Determinant
inline double Inverse_Matrix_with_lapack_and_Return_Determinant (blitz::Array<double,2> & M, std::string message="")
{
assert (M.rows() ==M.cols());
int n = M.rows();
if (n==0) return 1;
ref<double,2> refM(M,false);//do not check the ordering since inverse and transposition commutes
double * p = refM;
return Inverse_Matrix_with_lapack_and_Return_Determinant(p,n,n,message);
}
示例6: printf
void IceModel_Decode::run_timestep(double time_s,
blitz::Array<int,1> const &indices,
std::map<IceField, blitz::Array<double,1>> const &vals2)
{
printf("BEGIN IceModel_Decode::run_timestep(%f) size=%ld\n", time_s, indices.size());
std::map<IceField, blitz::Array<double,1>> vals2d; /// Decoded fields
// Loop through the fields we require
std::set<IceField> fields;
get_required_fields(fields);
for (auto field = fields.begin(); field != fields.end(); ++field) {
printf("Looking for required field %s\n", field->str());
// Look up the field we require
auto ii = vals2.find(*field);
if (ii == vals2.end()) {
fprintf(stderr, "Cannot find required ice field = %s\n", field->str());
throw std::exception();
}
blitz::Array<double,1> vals(ii->second);
// Decode the field!
blitz::Array<double,1> valsd(ndata());
valsd = nan;
int n = indices.size();
for (int i=0; i < n; ++i) {
int ix = indices(i);
// Do our own bounds checking!
if (ix < 0 || ix >= ndata()) {
fprintf(stderr, "IceModel: index %d out of range [0, %d)\n", ix, ndata());
throw std::exception();
}
#if 0
// Sanity check for NaN coming through
if (std::isnan(vals(i))) {
fprintf(stderr, "IceModel::decode: vals[%d] (index=%d) is NaN!\n", i, ix);
throw std::exception();
}
#endif
// Add this value to existing field
double &oval = valsd(ix);
if (std::isnan(oval)) oval = vals(i);
else oval += vals(i);
}
// Store decoded field in our output
vals2d.insert(std::make_pair(*field, valsd));
printf("Done decoding required field, %s\n", field->str());
}
// Pass decoded fields on to subclass
run_decoded(time_s, vals2d);
printf("END IceModel_Decode::run_timestep(%ld)\n", time_s);
}
示例7: retval
blitz::Array<double,1> bob::example::library::reverse (const blitz::Array<double,1>& array){
// create new array in the desired shape
blitz::Array<double,1> retval(array.shape());
// copy data
for (int i = 0, j = array.extent(0)-1; i < array.extent(0); ++i, --j){
retval(j) = array(i);
}
// return the copied data
return retval;
}
示例8: setInputDivision
void Machine::setInputDivision (const blitz::Array<double,1>& v) {
if (m_weight.extent(0) != v.extent(0)) {
boost::format m("mismatch on the input division shape: expected a vector of size %d, but you input one with size = %d instead");
m % m_weight.extent(0) % v.extent(0);
throw std::runtime_error(m.str());
}
m_input_div.reference(bob::core::array::ccopy(v));
}
示例9: setBiases
void Machine::setBiases (const blitz::Array<double,1>& bias) {
if (m_weight.extent(1) != bias.extent(0)) {
boost::format m("mismatch on the bias shape: expected a vector of size %d, but you input one with size = %d instead");
m % m_weight.extent(1) % bias.extent(0);
throw std::runtime_error(m.str());
}
m_bias.reference(bob::core::array::ccopy(bias));
}
示例10: naiveBlitzToCvMat
Mat naiveBlitzToCvMat(blitz::Array<float, 2> a, float multiplier){
int i, j;
Mat b = Mat(a.rows(), a.cols(), CV_32FC1);
for (i=0; i< a.rows(); i++){
for(j=0; j<a.cols(); j++){
b.at<float>(i,j) = a(i, j) * multiplier;
}
}
return b;
}
示例11: binary_save
void binary_save(const blitz::Array<T,n> & M,std::string filename)
{
T z;assert(M.isStorageContiguous());
std::stringstream f;M.dumpStructureInformation(f);
std::ofstream out(filename.c_str(),std::ios::binary);
std::string s = f.str();int i=int(s.length())+1;char c='1';
out.write( (char*) &i,sizeof(i));
out.write( (s.c_str()) ,i*sizeof(c));
out.write( (char*)M.dataFirst(),M.numElements()*sizeof(z));
}
示例12: convert2rgb
void convert2rgb( blitz::Array<Imath::Color3f,2>& img)
{
vigra::BasicImageView<vigra::TinyVector<float,3> > img_view( (vigra::TinyVector<float,3> *) img.dataFirst(), img.cols(), img.rows());
for( int j=0;j<img.rows();++j)
for( int i=0;i<img.cols();++i)
img( j, i) *= lab_scale;
vigra::transformImage( vigra::srcImageRange( img_view), vigra::destImage( img_view), vigra::Lab2RGBFunctor<float>( 1.0f));
}
示例13: for_cons
inline void for_cons(const blitz::Array<T,n> & M, bool check_order){
need_copy = (!(M.isStorageContiguous()));
if (check_order) for (int i=0; i<n;i++) need_copy = (need_copy || (M.ordering(i)!=i));
#ifdef DEBUG_REF_WARNING
if (need_copy) std::cout<<"WARNING : REF : COPY NEEDED. Performance will be degraded"<<std::endl;
#endif
Mref = (blitz::Array<T,n> *)&M;
// The copy has the same shape but is ordered like a fortran array
if (need_copy) {Mcopy.resize(M.shape());Mcopy=M;}
}
示例14: binary_load
void binary_load(blitz::Array<T,n> & M,std::string filename)
{
assert(M.isStorageContiguous());T z;
std::ifstream out(filename.c_str(),std::ios::binary);
int i;char c='1';
out.read( (char*) &i,sizeof(i));
char *st = new char[i+1];
out.read( st ,i*sizeof(c)); std::string s(st);
std::stringstream f; M.dumpStructureInformation(f);
if (f.str() != s) FATAL("Can not load binary : array do not conform. Structure (file vs array)"<<s<<"----"<<f.str());
out.read( (char*)M.dataFirst(),M.numElements()*sizeof(z));
}
示例15:
Machine::Machine(const blitz::Array<double,2>& weight)
: m_input_sub(weight.extent(0)),
m_input_div(weight.extent(0)),
m_bias(weight.extent(1)),
m_activation(boost::make_shared<bob::learn::activation::IdentityActivation>()),
m_buffer(weight.extent(0))
{
m_input_sub = 0.0;
m_input_div = 1.0;
m_bias = 0.0;
m_weight.reference(bob::core::array::ccopy(weight));
}