Issues/Questions with 02_production.ipynb

This is my first post, so I hope I haven’t missed something.

I’m trying to work through Website Lesson 2 / Book Chapter 2 using the 02_production.ipynb notebook from fastbook/02_production.ipynb at master · fastai/fastbook · GitHub.

Question:

I thought that when doing any training, fastai/pytorch would use a GPU if available to speed up processing, but when trying to run this code in either Kaggle or Google Collab, it doesn’t seem to use the GPU:

learn = vision_learner(dls, resnet18, metrics=error_rate)
learn.fine_tune(4)

In Kaggle I can see the CPU is pegged, but the GPU shows nothing (Image attached)

In Google Colab, they only show the GPU RAM, but I didn’t see an increase in GPU RAM usage either. Also these runs typically seem to take ~ 30 seconds to run, which isn’t a big deal, but watching the vidoe course, they seem to take significantly less time to run, which also makes me think the GPU isn’t being used. Just curious why.

Issue:

When running this code:

interp.plot_top_losses(5, nrows=1)

both Kaggle and Google Collab have issues displaying the column headers correctly:


Is there a way to fix this?

Hey @bosatsu,

Welcome to the forums and thanks for posting your question :smiley:, you might want to change the topic from “Site Feedback” to “Part 1 2022” since this relates to the course notebooks

You have to manually enable the GPU in both contexts before they can be used, which is my guess as to why you’re not seeing accelerated performance.

In Colab you can enable it from the “Runtime” menu & “Change Runtime Type” selection, where you can then enable a GPU/TPU.

In kaggle you can follow this discussion guide:

  1. Sign in to kaggle
  2. Open any notebook. On the right-hand side click on the drop down beside “Accelerator”
  3. Select “GPU”
  4. Wait for the kernel to start up

To verify if pytorch is using the GPU, you can checkout this stackoverflow

Here’s the example output and code from the accepted answer:

>>> import torch

>>> torch.cuda.is_available()
True

>>> torch.cuda.device_count()
1

>>> torch.cuda.current_device()
0

>>> torch.cuda.device(0)
<torch.cuda.device at 0x7efce0b03be0>

>>> torch.cuda.get_device_name(0)
'GeForce GTX 950M'

Apologies if you’ve already followed those instructions, let me know what output you get from running the above torch.cuda code and we can see what devices are available and being used.

2 Likes

Hey @nglillywhite !

Thanks so much for the response.

I probably should have demonstrated in my post that I had verified that I added a GPU to the runtime environment, but I did do the instructions you provided.

I also tried the code you provided and it does show that there is a GPU available, but it doesn’t really demonstrate whether the GPU is being used by the code. But at this point, this was just a curiosity. Maybe the Kaggle widget for the GPU display isn’t working correctly.

Any thoughts on fixing the display issue I mentioned above when running interp.plot_top_losses(5, nrows=1)?

Hey,

Apologies to guide you through the GPU activation since you’d already done that, the other check you can look at is to see which device your dataloaders is on by running dls.device. I’m not sure if that is the actual deciding factor as to where your model gets trained but it rules out one other possibility that your dataloaders are on your cpu device instead of an accelerated device.

On the display of the losses with plot_top_losses, you could try play with the figsize, nrows parameters, however I’ve noticed those parameters are only shown/explained in the old docs and I can see **kwargs is in the new api, so it might accept these parameters or not, I haven’t tried it out. If I get time this afternoon I’ll come back and make a snippet to play with.

Create a query in Visual Studio Code
By entering the tquery shortcut, you can create the basic layout for a Query object when using the AL Extension in Visual Studio Code. The following code sample shows an example of this process.

al-languageCopy

query Id MyQuery
{
    QueryType = Normal;
    
    elements
    {
        dataitem(DataItemName; SourceTableName)
        {
            column(ColumnName; SourceFieldName)
            {
                
            }
            filter(FilterName; SourceFieldName)
            {
                
            }
        }
    }
    
    var
        myInt: Integer;
    
    trigger OnBeforeOpen()
    begin
        
    end;
}

To select the data, you must define the tables from which you want to retrieve the data and the fields that you want to include from those tables. When you are modeling a query, a data item corresponds to a table, and columns correspond to a field in the table.

To define a new dataitem, you need to specify the source table by entering the name of the table. Each dataitem requires a unique name.

For each field that you want to include in the resulting dataset, you must define a column in the query data model. To define a column, insert a new column section under the dataitem and then provide a name and the source fieldname.

QueryType property

The QueryType property helps you define how the query will be used. This property has two possible values, Normal or API, where Normal is the default value. If you want to use a query in a Power BI report or access it by using an API call, you need to set the QueryType property to API. Then, you can publish this query as a web service. The data from a query can only be viewed.

Along with the QueryType property, you also need to set the APIPublisher, APIGroup, APIVersion, EntityName, and EntitySetName properties with an API query.

In APIs, the name of the data items, columns, and filters should use camel casing. Instead of using CustomerNumber or Customer Number, you should use customerNumber.

al-languageCopy

query 20000 "APIV1 - Customer Sales"
{
    QueryType = API;
    APIPublisher = 'contoso';
    APIGroup = 'app1';
    APIVersion = 'v1.0';
    Caption = 'customerSales', Locked = true;
    EntityName = 'customerSale';
    EntitySetName = 'customerSales';

    elements
    {
        dataitem(customer; Customer)
        {
            column(systemId; SystemId)
            {
                Caption = 'Id', Locked = true;
            }
            column(customerNumber; "No.")
            {
                Caption = 'No', Locked = true;
            }
            column(name; Name)
            {
                Caption = 'Name', Locked = true;
            }
            dataitem(custLedgEntry; "Cust. Ledger Entry")
            {
                DataItemLink = "Customer No." = Customer."No.";
                SqlJoinType = LeftOuterJoin;
                DataItemTableFilter = "Document Type" = filter(Invoice | 
                                                               "Credit Memo");
                column(totalSalesAmount; "Sales (LCY)")
                {
                    Caption = 'TotalSalesAmount', Locked = true;
                    Method = Sum;
                }
                filter(dateFilter; "Posting Date")
                {
                    Caption = 'DateFilter', Locked = true;
                }
            }
        }
    }
}
```[oracle certification malaysia](https://lernix.com.my/oracle-certification-malaysia/)