Tensor Flow increment nested variable_scope
up vote
2
down vote
favorite
I know I can increment a variable_scope using the 'default_name' argument:
import tensorflow as tf
tf.variable_scope("A") # This is scope "A"
tf.variable_scope(None, "A") # incremented scope "A_1"
However, this no longer works when an outer context is re-entered
reuse= tf.AUTO_REUSE
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope("B", reuse=tf.AUTO_REUSE):
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0'
with tf.variable_scope(None, "B"): # Increment B, as expected
print tf.get_variable("x", (), tf.float32) # 'A/B_1/x:0'
# Re-enter A and try to increment B
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope(None, "B"): # Does not increment B !!!
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0' !!!
- Is there a way to increment "B" after re-entering "A" ?
- The re-entered context shares its variable with the initial context A, but not the way it increments its inner context. I find this very confusing, and wonder about the rationale.
Thank you !
python tensorflow scope
add a comment |
up vote
2
down vote
favorite
I know I can increment a variable_scope using the 'default_name' argument:
import tensorflow as tf
tf.variable_scope("A") # This is scope "A"
tf.variable_scope(None, "A") # incremented scope "A_1"
However, this no longer works when an outer context is re-entered
reuse= tf.AUTO_REUSE
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope("B", reuse=tf.AUTO_REUSE):
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0'
with tf.variable_scope(None, "B"): # Increment B, as expected
print tf.get_variable("x", (), tf.float32) # 'A/B_1/x:0'
# Re-enter A and try to increment B
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope(None, "B"): # Does not increment B !!!
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0' !!!
- Is there a way to increment "B" after re-entering "A" ?
- The re-entered context shares its variable with the initial context A, but not the way it increments its inner context. I find this very confusing, and wonder about the rationale.
Thank you !
python tensorflow scope
add a comment |
up vote
2
down vote
favorite
up vote
2
down vote
favorite
I know I can increment a variable_scope using the 'default_name' argument:
import tensorflow as tf
tf.variable_scope("A") # This is scope "A"
tf.variable_scope(None, "A") # incremented scope "A_1"
However, this no longer works when an outer context is re-entered
reuse= tf.AUTO_REUSE
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope("B", reuse=tf.AUTO_REUSE):
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0'
with tf.variable_scope(None, "B"): # Increment B, as expected
print tf.get_variable("x", (), tf.float32) # 'A/B_1/x:0'
# Re-enter A and try to increment B
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope(None, "B"): # Does not increment B !!!
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0' !!!
- Is there a way to increment "B" after re-entering "A" ?
- The re-entered context shares its variable with the initial context A, but not the way it increments its inner context. I find this very confusing, and wonder about the rationale.
Thank you !
python tensorflow scope
I know I can increment a variable_scope using the 'default_name' argument:
import tensorflow as tf
tf.variable_scope("A") # This is scope "A"
tf.variable_scope(None, "A") # incremented scope "A_1"
However, this no longer works when an outer context is re-entered
reuse= tf.AUTO_REUSE
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope("B", reuse=tf.AUTO_REUSE):
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0'
with tf.variable_scope(None, "B"): # Increment B, as expected
print tf.get_variable("x", (), tf.float32) # 'A/B_1/x:0'
# Re-enter A and try to increment B
with tf.variable_scope("A", reuse=reuse):
with tf.variable_scope(None, "B"): # Does not increment B !!!
print tf.get_variable("x", (), tf.float32) # 'A/B/x:0' !!!
- Is there a way to increment "B" after re-entering "A" ?
- The re-entered context shares its variable with the initial context A, but not the way it increments its inner context. I find this very confusing, and wonder about the rationale.
Thank you !
python tensorflow scope
python tensorflow scope
edited 8 hours ago
pfm
3,48622036
3,48622036
asked 11 hours ago
nath
112
112
add a comment |
add a comment |
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
active
oldest
votes
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53412391%2ftensor-flow-increment-nested-variable-scope%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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