Dynamic batch size in tensorflow
.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}
I have built a classifier using tesnorflow. I generate proposal regions from images and those proposals are individually classified by my classifier.
My problem is that I do not have a constant batch size when evaluating my model. Because every image has a different number of proposals, the number of proposals to be evaluated for every image is not constant.
Right now I have set the batch size to 1, but this is inefficient and limits the processing speed of my classifier.
Below is the placeholder for the input to the model
self.image_op = tf.placeholder(tf.float32, shape=[batch_size, 48, 48, 3], name='input_image')
And this is how I feed the input to the model
def predict(self,image):
cls_prob = self.sess.run([self.cls_prob], feed_dict={self.image_op: image})
return cls_prob
Is there any way of setting the batch size to a dynamic value without having to restore the model for every image?
python tensorflow deep-learning classification
add a comment |
I have built a classifier using tesnorflow. I generate proposal regions from images and those proposals are individually classified by my classifier.
My problem is that I do not have a constant batch size when evaluating my model. Because every image has a different number of proposals, the number of proposals to be evaluated for every image is not constant.
Right now I have set the batch size to 1, but this is inefficient and limits the processing speed of my classifier.
Below is the placeholder for the input to the model
self.image_op = tf.placeholder(tf.float32, shape=[batch_size, 48, 48, 3], name='input_image')
And this is how I feed the input to the model
def predict(self,image):
cls_prob = self.sess.run([self.cls_prob], feed_dict={self.image_op: image})
return cls_prob
Is there any way of setting the batch size to a dynamic value without having to restore the model for every image?
python tensorflow deep-learning classification
try with self.image_op = tf.placeholder(tf.float32, shape=[None, 48, 48, 3], name='input_image'). It should take variable batch sizes
– Biswadip Mandal
Nov 22 '18 at 4:29
That works. Thanks!
– user10664643
Nov 27 '18 at 1:51
add a comment |
I have built a classifier using tesnorflow. I generate proposal regions from images and those proposals are individually classified by my classifier.
My problem is that I do not have a constant batch size when evaluating my model. Because every image has a different number of proposals, the number of proposals to be evaluated for every image is not constant.
Right now I have set the batch size to 1, but this is inefficient and limits the processing speed of my classifier.
Below is the placeholder for the input to the model
self.image_op = tf.placeholder(tf.float32, shape=[batch_size, 48, 48, 3], name='input_image')
And this is how I feed the input to the model
def predict(self,image):
cls_prob = self.sess.run([self.cls_prob], feed_dict={self.image_op: image})
return cls_prob
Is there any way of setting the batch size to a dynamic value without having to restore the model for every image?
python tensorflow deep-learning classification
I have built a classifier using tesnorflow. I generate proposal regions from images and those proposals are individually classified by my classifier.
My problem is that I do not have a constant batch size when evaluating my model. Because every image has a different number of proposals, the number of proposals to be evaluated for every image is not constant.
Right now I have set the batch size to 1, but this is inefficient and limits the processing speed of my classifier.
Below is the placeholder for the input to the model
self.image_op = tf.placeholder(tf.float32, shape=[batch_size, 48, 48, 3], name='input_image')
And this is how I feed the input to the model
def predict(self,image):
cls_prob = self.sess.run([self.cls_prob], feed_dict={self.image_op: image})
return cls_prob
Is there any way of setting the batch size to a dynamic value without having to restore the model for every image?
python tensorflow deep-learning classification
python tensorflow deep-learning classification
asked Nov 22 '18 at 0:29
user10664643user10664643
297
297
try with self.image_op = tf.placeholder(tf.float32, shape=[None, 48, 48, 3], name='input_image'). It should take variable batch sizes
– Biswadip Mandal
Nov 22 '18 at 4:29
That works. Thanks!
– user10664643
Nov 27 '18 at 1:51
add a comment |
try with self.image_op = tf.placeholder(tf.float32, shape=[None, 48, 48, 3], name='input_image'). It should take variable batch sizes
– Biswadip Mandal
Nov 22 '18 at 4:29
That works. Thanks!
– user10664643
Nov 27 '18 at 1:51
try with self.image_op = tf.placeholder(tf.float32, shape=[None, 48, 48, 3], name='input_image'). It should take variable batch sizes
– Biswadip Mandal
Nov 22 '18 at 4:29
try with self.image_op = tf.placeholder(tf.float32, shape=[None, 48, 48, 3], name='input_image'). It should take variable batch sizes
– Biswadip Mandal
Nov 22 '18 at 4:29
That works. Thanks!
– user10664643
Nov 27 '18 at 1:51
That works. Thanks!
– user10664643
Nov 27 '18 at 1:51
add a comment |
0
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
});
}
});
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%2f53422311%2fdynamic-batch-size-in-tensorflow%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
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.
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%2f53422311%2fdynamic-batch-size-in-tensorflow%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
try with self.image_op = tf.placeholder(tf.float32, shape=[None, 48, 48, 3], name='input_image'). It should take variable batch sizes
– Biswadip Mandal
Nov 22 '18 at 4:29
That works. Thanks!
– user10664643
Nov 27 '18 at 1:51