10#include "utils/dynamic_arg_resolver.hpp"
14#include <initializer_list>
20 #include "backend/Scalar.hpp"
21 #include "backend/Storage.hpp"
22 #include "backend/Tensor_impl.hpp"
31 Tensor
operator+(
const Tensor &lhs,
const T &rc);
33 Tensor
operator-(
const Tensor &lhs,
const T &rhs);
35 Tensor
operator*(
const Tensor &lhs,
const T &rhs);
37 Tensor
operator/(
const Tensor &lhs,
const T &rhs);
47 boost::intrusive_ptr<Tensor_impl>
_insimpl;
48 std::vector<cytnx::Accessor>
_accs;
49 Tproxy(boost::intrusive_ptr<Tensor_impl>
_ptr,
const std::vector<cytnx::Accessor> &
accs)
65 this->_insimpl->set(
_accs,
tmp._impl);
207 Scalar::Sproxy
item()
const {
233 template <
class...
Ts>
239 template <
class...
Ts>
245 template <
class...
Ts>
251 template <
class...
Ts>
252 const Tproxy operator()(
const std::string &
e1,
const Ts &...
elems)
const {
257 template <
class...
Ts>
262 template <
class...
Ts>
271 std::vector<cytnx::Accessor>
tmp =
accs;
282 std::vector<cytnx::Accessor>
tmp =
accs;
287 std::vector<cytnx_int64>
tmp =
accs;
291 std::vector<cytnx::Accessor>
acc_in;
292 for (
int i = 0;
i <
accs.size();
i++) {
298 std::vector<cytnx_int64>
tmp =
accs;
302 std::vector<cytnx::Accessor>
acc_in;
303 for (
int i = 0;
i <
accs.size();
i++) {
309 std::vector<cytnx::Accessor>
acc_in;
310 for (
int i = 0;
i <
accs.size();
i++) {
319 void _Save(std::fstream &
f)
const;
320 void _Load(std::fstream &
f);
400 boost::intrusive_ptr<Tensor_impl>
_impl;
501 template <
typename Variant>
504 template <
typename First,
typename...
Rest>
506 using type = std::variant<Rest...>;
521 template <
typename T>
525 "[ERROR] Attempt to convert dtype %d (%s) to pointer of type %s",
527 Type_class::getname(Type_class::cy_typeid_v<std::remove_cv_t<T>>).
c_str());
529 return reinterpret_cast<T *
>(this->_impl->_storage._impl->data());
543 template <
typename T>
547 this->
dtype() != Type_class::cy_typeid_gpu_v<std::remove_cv_t<T>>,
548 "[ERROR] Attempt to convert dtype %d (%s) to GPU pointer of type %s", this->
dtype(),
550 Type_class::getname(Type_class::cy_typeid_gpu_v<std::remove_cv_t<T>>).
c_str());
552 return reinterpret_cast<T *
>(this->_impl->_storage._impl->data());
574 unsigned int dtype()
const {
return this->_impl->dtype(); }
581 int device()
const {
return this->_impl->device(); }
588 std::string
dtype_str()
const {
return this->_impl->dtype_str(); }
595 std::string
device_str()
const {
return this->_impl->device_str(); }
601 const std::vector<cytnx_uint64> &
shape()
const {
return this->_impl->shape(); }
688 template <
class...
Ts>
691 this->_impl->permute_(
argv);
720 template <
class...
Ts>
795 this->_impl->reshape_(
shape);
803 template <
class...
Ts>
807 this->_impl->reshape_(
shape);
861 template <
class...
Ts>
932 const T &
at(
const std::vector<cytnx_uint64> &
locator)
const {
936 template <
class T,
class...
Ts>
939 return this->
at<T>(argv);
941 template <
class T,
class...
Ts>
944 return this->
at<T>(argv);
947 const Scalar::Sproxy
at(
const std::vector<cytnx_uint64> &
locator)
const {
948 return this->_impl->at(
locator);
951 Scalar::Sproxy
at(
const std::vector<cytnx_uint64> &
locator) {
return this->_impl->at(
locator); }
981 cytnx_error_msg(this->_impl->storage().size() != 1,
"[ERROR][Tensor.item<T>]%s",
982 "item can only be called from a Tensor with only one element\n");
983 return this->_impl->storage().at<
T>(0);
988 const T &
item()
const {
989 cytnx_error_msg(this->_impl->storage().size() != 1,
"[ERROR][Tensor.item<T>]%s",
990 "item can only be called from a Tensor with only one element\n");
991 return this->_impl->storage().at<
T>(0);
994 const Scalar::Sproxy
item()
const {
999 Scalar::Sproxy
item() {
1000 Scalar::Sproxy
out(this->
storage()._impl, 0);
1087 void set(
const std::initializer_list<cytnx::Accessor> &
accessors,
const T &
rc) {
1089 this->
set(args,
rc);
1120 this->_impl->fill(
val);
1128 if (this->
shape() != rhs.
shape())
return false;
1263 return *
this +=
rhs;
1283 return *
this -=
rhs;
1303 return *
this *=
rhs;
1325 return *
this /=
rhs;
1336 return *
this ==
rhs;
1448 "[ERROR] try to append a null Tensor.%s",
"\n");
1450 "[ERROR] try to append a Tensor with rank not match.%s",
"\n");
1452 for (
unsigned int i = 0;
i <
rhs.shape().
size();
i++) {
1454 "[ERROR] dimension mismatch @ rhs.rank: [%d] this: [%d] rhs: [%d]\n",
i,
1461 if (
rhs.dtype() !=
this->dtype()) {
1465 if (!
in.is_contiguous())
1470 this->_impl->_shape[0] += 1;
1473 memcpy(((
char *)this->_impl->_storage.data()) +
1475 in._impl->_storage.data(),
Type.typeSize(
in.dtype()) *
Nelem);
1509 "[ERROR] try to append a null Tensor.%s",
"\n");
1511 "[ERROR] append a storage to Tensor can only accept rank-2 Tensor.%s",
"\n");
1517 if (
srhs.dtype() !=
this->dtype()) {
1522 this->_impl->_shape[0] += 1;
1524 this->_impl->_storage.resize(
oldsize +
in.size());
1525 memcpy(((
char *)this->_impl->_storage.data()) +
1527 in._impl->data(),
Type.typeSize(
in.dtype()) *
in.size());
1569 "[ERROR] trying to append a scalar into multidimentional Tensor is not "
1570 "allow.\n Only rank-1 Tensor can accept scalar append.%s",
1573 "[ERROR] append require the Tensor to be contiguous. suggestion: call "
1574 "contiguous() or contiguous_() first.",
1576 this->_impl->_shape[0] += 1;
1577 this->_impl->_storage.append(
rhs);
1603 std::vector<Tensor>
Eigh(
const bool &
is_V =
true,
const bool &
row_v =
false)
const;
1714 std::ostream &operator<<(std::ostream &os,
const Tensor &in);
1715 std::ostream &operator<<(std::ostream &os,
const Tensor::Tproxy &in);
constexpr Type_class Type
data type
Definition Type.hpp:426
object that mimic the python slice to access elements in C++ [this is for c++ API only].
Definition Accessor.hpp:17
an tensor (multi-dimensional array)
Definition Tensor.hpp:41
void append(const Storage &srhs)
the append function of the Storage.
Definition Tensor.hpp:1504
Tensor & operator*=(const T &rc)
multiplication assignment operator with a Tensor or a scalar.
Tensor & Inv_(const double &clip)
the Inv_ member function. Same as cytnx::linalg::Inv_(Tensor &Tin, const double &clip)
Tensor & operator/=(const T &rc)
division assignment operator with a Tensor or a scalar.
Tensor operator-()
The negation function.
Definition Tensor.hpp:1388
void fill(const T &val)
fill all the element of current Tensor with the value.
Definition Tensor.hpp:1119
Tensor InvM() const
the InvM member function. Same as cytnx::linalg::InvM(const Tensor &Tin), where Tin is the current Te...
bool same_data(const Tensor &rhs) const
Check whether two tensors share the same internal memory.
void to_(const int &device)
move the current Tensor to the device.
Definition Tensor.hpp:675
Tensor & permute_(const std::vector< cytnx_uint64 > &rnks)
Definition Tensor.hpp:683
Tensor reshape(const std::vector< cytnx_uint64 > &new_shape) const
Definition Tensor.hpp:845
Tensor(const std::vector< cytnx_uint64 > &shape, const unsigned int &dtype=Type.Double, const int &device=-1, const bool &init_zero=1)
Construct a new Tensor object.
Definition Tensor.hpp:480
void append(const T &rhs)
the append function of the scalar.
Definition Tensor.hpp:1567
Tensor & operator-=(const T &rc)
subtraction assignment operator with a Tensor or a scalar.
Tensor & Add_(const T &rhs)
Addition function with a Tensor or a scalar, inplacely. Same as operator+=(const T &rhs).
Definition Tensor.hpp:1262
Tensor Abs() const
the Abs member function. Same as linalg::Abs(const Tensor &Tin), where Tin is the current Tensor.
Tensor reshape(const std::initializer_list< cytnx_int64 > &new_shape) const
Definition Tensor.hpp:856
std::string device_str() const
the device (in string) of the Tensor
Definition Tensor.hpp:595
Tensor contiguous_()
Make the Tensor contiguous by coalescing the memory (storage), inplacely.
Definition Tensor.hpp:762
Tensor Mul(const T &rhs)
Multiplication function with a Tensor or a scalar. Same as cytnx::operator*(const Tensor &self,...
Definition Tensor.hpp:1292
unsigned int dtype() const
the dtype-id of the Tensor
Definition Tensor.hpp:574
Tensor Sub(const T &rhs)
Subtraction function with a Tensor or a scalar. Same as cytnx::operator-(const Tensor &self,...
Definition Tensor.hpp:1272
Tensor Inv(const double &clip) const
the Inv member function. Same as cytnx::linalg::Inv(const Tensor &Tin, const double &clip)
Tensor contiguous() const
Make the Tensor contiguous by coalescing the memory (storage).
Definition Tensor.hpp:742
void Tofile(const std::string &fname) const
Save current Tensor to the binary file.
T & at(const std::vector< cytnx_uint64 > &locator)
Get an element at specific location.
Definition Tensor.hpp:924
Tensor reshape(const std::vector< cytnx_int64 > &new_shape) const
return a new Tensor that is reshaped.
Definition Tensor.hpp:836
static Tensor Fromfile(const std::string &fname, const unsigned int &dtype, const cytnx_int64 &count=-1)
Load current Tensor from the binary file.
T & item()
get the element from a rank-0 Tensor.
Definition Tensor.hpp:980
Tensor clone() const
return a clone of the current Tensor.
Definition Tensor.hpp:626
std::vector< Tensor > Eigh(const bool &is_V=true, const bool &row_v=false) const
the Eigh member function. Same as cytnx::linalg::Eigh(const Tensor &Tin, const bool &is_V,...
void Tofile(const char *fname) const
void append(const Tensor &rhs)
the append function.
Definition Tensor.hpp:1442
static Tensor Load(const char *fname)
void Save(const char *fname) const
void set(const std::vector< cytnx::Accessor > &accessors, const Tensor &rhs)
set elements with the input Tensor using Accessor (C++ API) / slices (python API)
Definition Tensor.hpp:1059
static Tensor Fromfile(const char *fname, const unsigned int &dtype, const cytnx_int64 &count=-1)
Tensor Norm() const
the Norm member function. Same as linalg::Norm(const Tensor &Tin), where Tin is the current Tensor.
Tensor astype(const int &new_type) const
return a new Tensor that cast to different dtype.
Definition Tensor.hpp:889
Tensor & Div_(const T &rhs)
Division function with a Tensor or a scalar, inplacely. Same as operator/=(const T &rhs).
Definition Tensor.hpp:1324
make_variant_from_transform_t< typename internal::exclude_first< Type_list >::type, std::add_pointer > pointer_types
Definition Tensor.hpp:514
pointer_types ptr() const
static Tensor Load(const std::string &fname)
Load current Tensor from file.
Tensor & operator+=(const T &rc)
addition assignment operator with a Tensor or a scalar.
Tensor Conj() const
the Conj member function. Same as cytnx::linalg::Conj(const Tensor &Tin), where Tin is the current Te...
Tensor Trace(const cytnx_uint64 &a=0, const cytnx_uint64 &b=1) const
the Trace member function. Same as linalg::Trace(const Tensor &Tin, const cytnx_uint64 &a,...
bool equivshape(const Tensor &rhs)
compare the shape of two tensors.
Definition Tensor.hpp:1127
Tensor & Pow_(const cytnx_double &p)
the Pow_ member function. Same as linalg::Pow_(Tensor &Tin, const cytnx_double &p),...
std::vector< Tensor > Svd(const bool &is_UvT=true) const
the SVD member function. Same as cytnx::linalg::Svd(const Tensor &Tin, const bool &is_UvT) ,...
std::string dtype_str() const
the dtype (in string) of the Tensor
Definition Tensor.hpp:588
Tensor & Mul_(const T &rhs)
Multiplication function with a Tensor or a scalar, inplacely. Same as operator*=(const T &rhs).
Definition Tensor.hpp:1302
cytnx_uint64 rank() const
the rank of the Tensor
Definition Tensor.hpp:607
const bool & is_contiguous() const
return whether the Tensor is contiguous or not.
Definition Tensor.hpp:681
Tensor Exp() const
the Exp member function. Same as linalg::Exp(const Tensor &Tin), where Tin is the current Tensor.
Tensor & Abs_()
the Abs_ member function. Same as linalg::Abs_(Tensor &Tin), where Tin is the current Tensor.
Tensor Add(const T &rhs)
Addition function with a Tensor or a scalar. Same as cytnx::operator+(const Tensor &self,...
Definition Tensor.hpp:1252
void flatten_()
The flatten function, inplacely.
Definition Tensor.hpp:1411
void Save(const std::string &fname) const
Save current Tensor to file.
Tensor flatten() const
The flatten function.
Definition Tensor.hpp:1397
Tensor & Conj_()
the Conj_ member function. Same as cytnx::linalg::Conj_(Tensor &Tin), where Tin is the current Tensor...
Tensor Pow(const cytnx_double &p) const
the Pow member function. Same as linalg::Pow(const Tensor &Tin, const cytnx_double &p),...
int device() const
the device-id of the Tensor
Definition Tensor.hpp:581
Tensor real()
return the real part of the tensor.
Tensor imag()
return the imaginary part of the tensor.
Tensor to(const int &device) const
copy a tensor to new device
Definition Tensor.hpp:652
T * ptr_as(bool check_type=true) const
Definition Tensor.hpp:522
Tensor & reshape_(const std::vector< cytnx_int64 > &new_shape)
reshape the Tensor, inplacely
Definition Tensor.hpp:788
void Tofile(std::fstream &f) const
Tensor get(const std::vector< cytnx::Accessor > &accessors) const
get elements using Accessor (C++ API) / slices (python API)
Definition Tensor.hpp:1027
void set(const std::vector< cytnx::Accessor > &accessors, const T &rc)
set elements with the input constant using Accessor (C++ API) / slices (python API)
Definition Tensor.hpp:1082
Tensor Max() const
the Max member function. Same as linalg::Max(const Tensor &Tin), where Tin is the current Tensor.
Tensor permute(const std::vector< cytnx_uint64 > &rnks) const
perform tensor permute on the cytnx::Tensor and return a new instance.
Definition Tensor.hpp:714
Tensor Div(const T &rhs)
Division function with a Tensor or a scalar. Same as cytnx::operator/(const Tensor &self,...
Definition Tensor.hpp:1313
Tensor Mod(const T &rhs)
Definition Tensor.hpp:1378
void Init(const std::vector< cytnx_uint64 > &shape, const unsigned int &dtype=Type.Double, const int &device=-1, const bool &init_zero=true)
initialize a Tensor
Definition Tensor.hpp:450
Tensor Cpr(const T &rhs)
The comparison function.
Definition Tensor.hpp:1335
Tensor & Exp_()
the Exp_ member function. Same as linalg::Exp_(Tensor &Tin), where Tin is the current Tensor.
Tensor & InvM_()
the InvM_ member function. Same as cytnx::linalg::InvM_(Tensor &Tin), where Tin is the current Tensor...
const std::vector< cytnx_uint64 > & shape() const
the shape of the Tensor
Definition Tensor.hpp:601
Tensor Min() const
the Min member function. Same as linalg::Min(const Tensor &Tin), where Tin is the current Tensor.
const T & at(const std::vector< cytnx_uint64 > &locator) const
Definition Tensor.hpp:932
Storage & storage() const
return the storage of current Tensor.
Definition Tensor.hpp:1102
static Tensor from_storage(const Storage &in)
Convert a Storage to Tensor.
Definition Tensor.hpp:561
Tensor & Sub_(const T &rhs)
Subtraction function with a Tensor or a scalar, inplacely. Same as operator-=(const T &rhs).
Definition Tensor.hpp:1282
#define cytnx_error_msg(is_true, format,...)
Definition cytnx_error.hpp:18
Definition Accessor.hpp:12
cytnx::UniTensor operator*(const cytnx::UniTensor &Lt, const cytnx::UniTensor &Rt)
The multiplication operator between two UniTensor.
cytnx::UniTensor operator-(const cytnx::UniTensor &Lt, const cytnx::UniTensor &Rt)
The subtraction operator between two UniTensor.
cytnx::UniTensor operator+(const cytnx::UniTensor &Lt, const cytnx::UniTensor &Rt)
The addition operator between two UniTensor.
cytnx::UniTensor operator/(const cytnx::UniTensor &Lt, const cytnx::UniTensor &Rt)
The division operator between two UniTensor.