On a Ubuntu laptop, with a NVIDIA GPU, when trying to open Mendeley, you get this rather unhelpful error:
The application Mendeley Desktop has closed unexpectedly.
I’m sure there are many causes for this error, but one unexpected reason you might get this error is related to your graphics card.
If you have a NVIDIA GPU on your laptop, try to switch to your Intel graphics card instead of NVIDIA..
To switch to your Intel graphics card, open your terminal and type:
sudo prime-select intel
Then restart Mendeley. Like magic and deep learning, it just seems to work.
(if you need to switch back to your NVIDIA card, just type
sudo prime-select nvidia)
Scenario: You’re trying to get your GPU to work in TensorFlow on a Ubuntu Laptop. You’ve already installed Tensorflow, Cuda, and Nvidia drivers.
You run python and import TensorFlow:
import tensorflow as tf
And you see encouraging messages like:
"successfully opened CUDA library libcublas.so locally"
But in Python, when you run,
You get this cryptic error:
failed call to cuInit: CUDA_ERROR_UNKNOWN
Here’s how to fix this.
Continue reading “TensorFlow – failed call to cuInit: CUDA_ERROR_UNKNOWN”
There are so many ways to normalize vectors… A common preprocessing step in machine learning is to normalize a vector before passing the vector into some machine learning algorithm e.g., before training a support vector machine (SVM).
One way to normalize the vector is to apply some normalization to scale the vector to have a length of 1 i.e., a
unit norm. There are different ways to define “length” such as as l1 or l2-normalization. If you use l2-normalization, “unit norm” essentially means that if we squared each element in the vector, and summed them, it would equal
(note this normalization is also often referred to as,
unit norm or a
vector of length 1 or a
Continue reading “How to normalize vectors to unit norm in Python”
You suddenly get this error when training/saving a model in Caffe or saving a model in pycaffe.
io.cpp:69] Check failed: proto.SerializeToOstream(&output)
*** Check failure stack trace: ***
Here are two possible reasons for this error
- The directory the snapshot is trying to write the .caffemodel into does not exist
- You are out of disk space
Continue reading “caffe – Check failed: proto.SerializeToOstream(&output)”
Title: An Anthropologist on Mars
Author: Oliver Sacks
Narrator: Jonathan Davis
Tags; non-fiction; clinical; neurology;
This book is in the same spirit as Dr. Sack’s earlier enjoyable book, The Man Who Mistook His Wife for a Hat. Of the two, while I preferred his earlier work, this book, An Anthropologist on Mars, is still definitely worth a read/listen. If you read only one, choose The Man Who Mistook His Wife for a Hat. If you liked that book, and you want more of the same, then this is it.
Continue reading “An Anthropologist on Mars – Oliver Sacks – audiobook review”
I’ve written before about my affection for Audible audiobooks. Now I’m putting together a list of books that I have read, along with summaries for each.
Below I started a list of audiobooks that I read, but I decided to move to a new table format, which you can view here. I’ve left the below list for historical purposes, and recommend you check out my updated recommended book list instead.
Continue reading “Recommended Audible audiobooks”
Ah the world wide web… the old www. So many factors to consider when developing web applications, especially if you’re used to developing in a relatively simple research environment.
One thing you will think about is how to get Google to include your page in it’s searchers (i.e., get indexed). To do this, we’ll submit a
sitemap to Google. Basically a sitemap lists the links that you want Google to start indexing (so other people can find it when they search the web).
If you’re using WordPress, this is pretty simple, and you can just download a plugin and skip to the last step below (step 6).
However, if you’re using Google App Engine to run your site, then you need to do a few more steps. So here’s instructions for how to do this.
Continue reading “How to upload sitemap.xml to google app engine”
I’m running Ubuntu on my Lenovo Y50 laptop, with a Nvidia GPU. And every time I do an update (or restart it?), I see the Ubuntu logo, hear the chime to log in, and then see a blank black screen, or a small white dot in the upper corner.
Other times, after a reboot, I get to the login screen, enter my username and password, then everything flickers violently, and it loops back to asks me to enter in my info again.
Today this post is not about how to permanently fix this (although that would be nice), but rather how to get your GUI back (until you update/restart your machine again).
It seems that on some laptops, the Nvidia drivers and Ubuntu do not always nicely play together. Why? I am not sure.
But anyways, here’s how to get fix your laptop when Ubuntu has a black screen on login (assuming your problem is related to the Nvidia drivers).
Continue reading “ubuntu – black screen on ubuntu laptop after installing nvidia drivers”
Our paper entitled: “Multi-resolution-Tract CNN with Hybrid Pretrained and Skin-Lesion Trained Layers” was accepted and presented as an oral talk in the Machine Learning in Medical Imaging (MLMI) Workshop (part of the MICCAI conference).
In this work, we used a convolutional neural network (CNN) to classify 10 different types of skin lesions, including melanoma and non-melanoma types.
The key technical contribution was to use multiple tracts (or paths) within the neural network, to train (and test) the network on an image using multiple image resolutions simultaneously. Additionally, we extended a CNN pretrained on a single image resolution to work for multiple image resolutions.
Here are our slides presented at MLMI (thanks Aïcha!) showing our deep learning approach to classify skin disease:
Continue reading “multi-resolution-tract CNN with hybrid pretrained and skin-lesion trained layers”
There’s this really neat new idea on how to train neural networks that recently came out know as generative adversarial nets (GAN).
The basic idea of a GAN is to train two networks to compete with each other (hence the name “adversarial“). One network (called the generator) creates images that look just like real images. The other network (called the discriminator) distinguishes between real images and those images the generator produced.
Thus the two networks compete with each other, where the generator generates images to fool the discriminator, and the discriminator discriminates between the generator’s images and real images.
Continue reading “(deep convolutional) generative adversarial nets – slides”