Overloading assignment operators in proxy class for matrix and vector?












1














I have a slight problem. I have a Matrix class defined as follows (in row-major form):



template<typename T>
class Matrix {
// must be inline
friend std::ostream &operator<<(std::ostream &lhs, const Matrix &rhs) {
std::size_t maxlen;
std::max_element(rhs._data.begin(), rhs._data.end(),
[&maxlen](auto &a1, auto &a2) {
std::ostringstream temp;
temp << a1;
std::size_t len1 = temp.str().size();
temp.str("");
temp << a2;
maxlen = (len1 < (temp.str().size()) ? temp.str().size() : len1);
return (len1 < (temp.str().size()));
});
for (std::size_t i = 0; i < rhs._m; i++) {
for (std::size_t j = 0; j < rhs._n; j++)
lhs << std::setw(maxlen) << rhs[i][j] << ' ';
lhs << std::endl;
}
return lhs;
}

private:
class RowVector {
private:
T *_vec;
std::size_t _l;

public:
RowVector(T *vec, std::size_t l);

const T &operator(std::size_t index) const;
T &operator(std::size_t index);

operator std::vector<T>() const;
};

std::vector<T> _data;
std::size_t _m;
std::size_t _n;

public:
Matrix(std::size_t m, size_t n, const T &elem = T());

const RowVector operator(std::size_t index) const;
RowVector operator(std::size_t index);

std::size_t getm() const;
std::size_t getn() const;
void fill(const T &elem);
void fillRow(std::size_t index, const T &elem);
void fillCol(std::size_t index, const T &elem);

Matrix &transpose(unsigned int i = 1);

const std::vector<T> &data() const;
};


and wish to overload two RowVector operators=



typename Matrix<T>::RowVector &operator=(const std::vector<T> &vec);
typename Matrix<T>::RowVector &operator=(const Matrix<T> &mat);


so I can return a RowVector & using A[0] and reassign its value using either a vector or a matrix. Keep in mind that I (presumably) can ignore the rule of three because I provide no explicit way for the client to construct a RowVector object.



However, in attempting to write the function bodies for the overloads, I have come across a problem: that



(1) I cannot copy-construct a vector/Matrix object that will persist outside of the operator='s scope so that I can assign its data() to _vec and its size() to _l.



(2) I cannot directly modify _data since it is not a static variable; even if I could, I have no way to discover the index so I can overwrite the relevant region of memory in the enclosing Matrix object.



Do you know of any way in which this can be done? These would be two very useful assets for my class.



Edit: To make it more clear, I would like to be able to write something like this:



Matrix<int> A(3, 4);
std::vector<int> v {1, 2, 3, 4};
Matrix<int> row(1, 4, 3);
// *****************
A[0] = v;
A[1] = row;
// *****************


(Hopefully my variable names are self-explanatory)
I think my prototypes are correct, but I just can't find a way to do this.



Thanks!










share|improve this question
























  • You need to boil the question down to a more conceptual level. Right now it is quite unclear. See stackoverflow.com/help/how-to-ask
    – darune
    Nov 13 at 8:46


















1














I have a slight problem. I have a Matrix class defined as follows (in row-major form):



template<typename T>
class Matrix {
// must be inline
friend std::ostream &operator<<(std::ostream &lhs, const Matrix &rhs) {
std::size_t maxlen;
std::max_element(rhs._data.begin(), rhs._data.end(),
[&maxlen](auto &a1, auto &a2) {
std::ostringstream temp;
temp << a1;
std::size_t len1 = temp.str().size();
temp.str("");
temp << a2;
maxlen = (len1 < (temp.str().size()) ? temp.str().size() : len1);
return (len1 < (temp.str().size()));
});
for (std::size_t i = 0; i < rhs._m; i++) {
for (std::size_t j = 0; j < rhs._n; j++)
lhs << std::setw(maxlen) << rhs[i][j] << ' ';
lhs << std::endl;
}
return lhs;
}

private:
class RowVector {
private:
T *_vec;
std::size_t _l;

public:
RowVector(T *vec, std::size_t l);

const T &operator(std::size_t index) const;
T &operator(std::size_t index);

operator std::vector<T>() const;
};

std::vector<T> _data;
std::size_t _m;
std::size_t _n;

public:
Matrix(std::size_t m, size_t n, const T &elem = T());

const RowVector operator(std::size_t index) const;
RowVector operator(std::size_t index);

std::size_t getm() const;
std::size_t getn() const;
void fill(const T &elem);
void fillRow(std::size_t index, const T &elem);
void fillCol(std::size_t index, const T &elem);

Matrix &transpose(unsigned int i = 1);

const std::vector<T> &data() const;
};


and wish to overload two RowVector operators=



typename Matrix<T>::RowVector &operator=(const std::vector<T> &vec);
typename Matrix<T>::RowVector &operator=(const Matrix<T> &mat);


so I can return a RowVector & using A[0] and reassign its value using either a vector or a matrix. Keep in mind that I (presumably) can ignore the rule of three because I provide no explicit way for the client to construct a RowVector object.



However, in attempting to write the function bodies for the overloads, I have come across a problem: that



(1) I cannot copy-construct a vector/Matrix object that will persist outside of the operator='s scope so that I can assign its data() to _vec and its size() to _l.



(2) I cannot directly modify _data since it is not a static variable; even if I could, I have no way to discover the index so I can overwrite the relevant region of memory in the enclosing Matrix object.



Do you know of any way in which this can be done? These would be two very useful assets for my class.



Edit: To make it more clear, I would like to be able to write something like this:



Matrix<int> A(3, 4);
std::vector<int> v {1, 2, 3, 4};
Matrix<int> row(1, 4, 3);
// *****************
A[0] = v;
A[1] = row;
// *****************


(Hopefully my variable names are self-explanatory)
I think my prototypes are correct, but I just can't find a way to do this.



Thanks!










share|improve this question
























  • You need to boil the question down to a more conceptual level. Right now it is quite unclear. See stackoverflow.com/help/how-to-ask
    – darune
    Nov 13 at 8:46
















1












1








1


2





I have a slight problem. I have a Matrix class defined as follows (in row-major form):



template<typename T>
class Matrix {
// must be inline
friend std::ostream &operator<<(std::ostream &lhs, const Matrix &rhs) {
std::size_t maxlen;
std::max_element(rhs._data.begin(), rhs._data.end(),
[&maxlen](auto &a1, auto &a2) {
std::ostringstream temp;
temp << a1;
std::size_t len1 = temp.str().size();
temp.str("");
temp << a2;
maxlen = (len1 < (temp.str().size()) ? temp.str().size() : len1);
return (len1 < (temp.str().size()));
});
for (std::size_t i = 0; i < rhs._m; i++) {
for (std::size_t j = 0; j < rhs._n; j++)
lhs << std::setw(maxlen) << rhs[i][j] << ' ';
lhs << std::endl;
}
return lhs;
}

private:
class RowVector {
private:
T *_vec;
std::size_t _l;

public:
RowVector(T *vec, std::size_t l);

const T &operator(std::size_t index) const;
T &operator(std::size_t index);

operator std::vector<T>() const;
};

std::vector<T> _data;
std::size_t _m;
std::size_t _n;

public:
Matrix(std::size_t m, size_t n, const T &elem = T());

const RowVector operator(std::size_t index) const;
RowVector operator(std::size_t index);

std::size_t getm() const;
std::size_t getn() const;
void fill(const T &elem);
void fillRow(std::size_t index, const T &elem);
void fillCol(std::size_t index, const T &elem);

Matrix &transpose(unsigned int i = 1);

const std::vector<T> &data() const;
};


and wish to overload two RowVector operators=



typename Matrix<T>::RowVector &operator=(const std::vector<T> &vec);
typename Matrix<T>::RowVector &operator=(const Matrix<T> &mat);


so I can return a RowVector & using A[0] and reassign its value using either a vector or a matrix. Keep in mind that I (presumably) can ignore the rule of three because I provide no explicit way for the client to construct a RowVector object.



However, in attempting to write the function bodies for the overloads, I have come across a problem: that



(1) I cannot copy-construct a vector/Matrix object that will persist outside of the operator='s scope so that I can assign its data() to _vec and its size() to _l.



(2) I cannot directly modify _data since it is not a static variable; even if I could, I have no way to discover the index so I can overwrite the relevant region of memory in the enclosing Matrix object.



Do you know of any way in which this can be done? These would be two very useful assets for my class.



Edit: To make it more clear, I would like to be able to write something like this:



Matrix<int> A(3, 4);
std::vector<int> v {1, 2, 3, 4};
Matrix<int> row(1, 4, 3);
// *****************
A[0] = v;
A[1] = row;
// *****************


(Hopefully my variable names are self-explanatory)
I think my prototypes are correct, but I just can't find a way to do this.



Thanks!










share|improve this question















I have a slight problem. I have a Matrix class defined as follows (in row-major form):



template<typename T>
class Matrix {
// must be inline
friend std::ostream &operator<<(std::ostream &lhs, const Matrix &rhs) {
std::size_t maxlen;
std::max_element(rhs._data.begin(), rhs._data.end(),
[&maxlen](auto &a1, auto &a2) {
std::ostringstream temp;
temp << a1;
std::size_t len1 = temp.str().size();
temp.str("");
temp << a2;
maxlen = (len1 < (temp.str().size()) ? temp.str().size() : len1);
return (len1 < (temp.str().size()));
});
for (std::size_t i = 0; i < rhs._m; i++) {
for (std::size_t j = 0; j < rhs._n; j++)
lhs << std::setw(maxlen) << rhs[i][j] << ' ';
lhs << std::endl;
}
return lhs;
}

private:
class RowVector {
private:
T *_vec;
std::size_t _l;

public:
RowVector(T *vec, std::size_t l);

const T &operator(std::size_t index) const;
T &operator(std::size_t index);

operator std::vector<T>() const;
};

std::vector<T> _data;
std::size_t _m;
std::size_t _n;

public:
Matrix(std::size_t m, size_t n, const T &elem = T());

const RowVector operator(std::size_t index) const;
RowVector operator(std::size_t index);

std::size_t getm() const;
std::size_t getn() const;
void fill(const T &elem);
void fillRow(std::size_t index, const T &elem);
void fillCol(std::size_t index, const T &elem);

Matrix &transpose(unsigned int i = 1);

const std::vector<T> &data() const;
};


and wish to overload two RowVector operators=



typename Matrix<T>::RowVector &operator=(const std::vector<T> &vec);
typename Matrix<T>::RowVector &operator=(const Matrix<T> &mat);


so I can return a RowVector & using A[0] and reassign its value using either a vector or a matrix. Keep in mind that I (presumably) can ignore the rule of three because I provide no explicit way for the client to construct a RowVector object.



However, in attempting to write the function bodies for the overloads, I have come across a problem: that



(1) I cannot copy-construct a vector/Matrix object that will persist outside of the operator='s scope so that I can assign its data() to _vec and its size() to _l.



(2) I cannot directly modify _data since it is not a static variable; even if I could, I have no way to discover the index so I can overwrite the relevant region of memory in the enclosing Matrix object.



Do you know of any way in which this can be done? These would be two very useful assets for my class.



Edit: To make it more clear, I would like to be able to write something like this:



Matrix<int> A(3, 4);
std::vector<int> v {1, 2, 3, 4};
Matrix<int> row(1, 4, 3);
// *****************
A[0] = v;
A[1] = row;
// *****************


(Hopefully my variable names are self-explanatory)
I think my prototypes are correct, but I just can't find a way to do this.



Thanks!







c++ oop vector reference operator-overloading






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 14 at 0:16

























asked Nov 13 at 7:21









Jonathan Lee

707




707












  • You need to boil the question down to a more conceptual level. Right now it is quite unclear. See stackoverflow.com/help/how-to-ask
    – darune
    Nov 13 at 8:46




















  • You need to boil the question down to a more conceptual level. Right now it is quite unclear. See stackoverflow.com/help/how-to-ask
    – darune
    Nov 13 at 8:46


















You need to boil the question down to a more conceptual level. Right now it is quite unclear. See stackoverflow.com/help/how-to-ask
– darune
Nov 13 at 8:46






You need to boil the question down to a more conceptual level. Right now it is quite unclear. See stackoverflow.com/help/how-to-ask
– darune
Nov 13 at 8:46



















active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53275797%2foverloading-assignment-operators-in-proxy-class-for-matrix-and-vector%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown






























active

oldest

votes













active

oldest

votes









active

oldest

votes






active

oldest

votes
















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.





Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


Please pay close attention to the following guidance:


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53275797%2foverloading-assignment-operators-in-proxy-class-for-matrix-and-vector%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Guess what letter conforming each word

Port of Spain

Run scheduled task as local user group (not BUILTIN)