How can I get through very long and very dry, but also very useful technical documents when learning a new...
$begingroup$
Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.
I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.
For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.
There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)
This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).
When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.
I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.
As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?
self-learning
New contributor
$endgroup$
add a comment |
$begingroup$
Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.
I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.
For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.
There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)
This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).
When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.
I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.
As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?
self-learning
New contributor
$endgroup$
add a comment |
$begingroup$
Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.
I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.
For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.
There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)
This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).
When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.
I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.
As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?
self-learning
New contributor
$endgroup$
Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.
I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.
For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.
There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)
This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).
When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.
I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.
As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?
self-learning
self-learning
New contributor
New contributor
edited 11 hours ago
Ben I.♦
18.2k740108
18.2k740108
New contributor
asked 14 hours ago
john01davjohn01dav
1363
1363
New contributor
New contributor
add a comment |
add a comment |
4 Answers
4
active
oldest
votes
$begingroup$
Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.
The key, I find, is not reading the tutorials.
Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.
If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).
You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.
If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).
$endgroup$
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
add a comment |
$begingroup$
I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.
Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.
I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).
Good luck!
$endgroup$
add a comment |
$begingroup$
I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.
Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.
Items on the list would resolve in one of four ways:
- It graduates to the main thread when you stop understanding what is going on.
- You come to understand it over time without doing an explicit research, just from context and osmosis.
- Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.
- It turns out to be unimportant enough that it never comes up again, and can safely be ignored.
The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.
$endgroup$
add a comment |
$begingroup$
Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.
Take breaks.
Study for maybe 20 minutes then take a short break.
Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.Make sure you have plenty of fresh air.
High levels of CO2 and low levels of O2 make us tired.Take notes.
After reading a section write down what you learned.
You might even make these a blog post or do a short talk about it.Do practical things.
This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.Take notes about what to learn.
You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
Use your notes to write down what you'd like to look up then look it up when the time is right.Repeat.
We can't internalize complex knowledge directly.
We need to repeat and practice it.
With software APIs, katas are a proven way to do that.
When you learn something new, make a tiny project putting the knowledge to use.
This should take about 30min.
Repeat this project after a short break.
Then again maybe on the next day.
Repetition with increasing time in between makes sure the knowledge ends up in long term memory.
New contributor
$endgroup$
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
return StackExchange.using("mathjaxEditing", function () {
StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
});
});
}, "mathjax-editing");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "678"
};
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: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
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
});
}
});
john01dav is a new contributor. Be nice, and check out our Code of Conduct.
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%2fcseducators.stackexchange.com%2fquestions%2f5492%2fhow-can-i-get-through-very-long-and-very-dry-but-also-very-useful-technical-doc%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
$begingroup$
Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.
The key, I find, is not reading the tutorials.
Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.
If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).
You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.
If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).
$endgroup$
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
add a comment |
$begingroup$
Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.
The key, I find, is not reading the tutorials.
Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.
If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).
You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.
If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).
$endgroup$
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
add a comment |
$begingroup$
Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.
The key, I find, is not reading the tutorials.
Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.
If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).
You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.
If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).
$endgroup$
Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.
The key, I find, is not reading the tutorials.
Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.
If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).
You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.
If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).
answered 8 hours ago
heatherheather
3,723734
3,723734
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
add a comment |
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
$begingroup$
This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
$endgroup$
– john01dav
8 hours ago
add a comment |
$begingroup$
I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.
Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.
I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).
Good luck!
$endgroup$
add a comment |
$begingroup$
I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.
Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.
I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).
Good luck!
$endgroup$
add a comment |
$begingroup$
I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.
Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.
I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).
Good luck!
$endgroup$
I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.
Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.
I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).
Good luck!
answered 12 hours ago
thesecretmaster♦thesecretmaster
3,19931043
3,19931043
add a comment |
add a comment |
$begingroup$
I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.
Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.
Items on the list would resolve in one of four ways:
- It graduates to the main thread when you stop understanding what is going on.
- You come to understand it over time without doing an explicit research, just from context and osmosis.
- Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.
- It turns out to be unimportant enough that it never comes up again, and can safely be ignored.
The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.
$endgroup$
add a comment |
$begingroup$
I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.
Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.
Items on the list would resolve in one of four ways:
- It graduates to the main thread when you stop understanding what is going on.
- You come to understand it over time without doing an explicit research, just from context and osmosis.
- Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.
- It turns out to be unimportant enough that it never comes up again, and can safely be ignored.
The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.
$endgroup$
add a comment |
$begingroup$
I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.
Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.
Items on the list would resolve in one of four ways:
- It graduates to the main thread when you stop understanding what is going on.
- You come to understand it over time without doing an explicit research, just from context and osmosis.
- Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.
- It turns out to be unimportant enough that it never comes up again, and can safely be ignored.
The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.
$endgroup$
I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.
Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.
Items on the list would resolve in one of four ways:
- It graduates to the main thread when you stop understanding what is going on.
- You come to understand it over time without doing an explicit research, just from context and osmosis.
- Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.
- It turns out to be unimportant enough that it never comes up again, and can safely be ignored.
The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.
answered 14 hours ago
Ben I.♦Ben I.
18.2k740108
18.2k740108
add a comment |
add a comment |
$begingroup$
Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.
Take breaks.
Study for maybe 20 minutes then take a short break.
Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.Make sure you have plenty of fresh air.
High levels of CO2 and low levels of O2 make us tired.Take notes.
After reading a section write down what you learned.
You might even make these a blog post or do a short talk about it.Do practical things.
This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.Take notes about what to learn.
You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
Use your notes to write down what you'd like to look up then look it up when the time is right.Repeat.
We can't internalize complex knowledge directly.
We need to repeat and practice it.
With software APIs, katas are a proven way to do that.
When you learn something new, make a tiny project putting the knowledge to use.
This should take about 30min.
Repeat this project after a short break.
Then again maybe on the next day.
Repetition with increasing time in between makes sure the knowledge ends up in long term memory.
New contributor
$endgroup$
add a comment |
$begingroup$
Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.
Take breaks.
Study for maybe 20 minutes then take a short break.
Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.Make sure you have plenty of fresh air.
High levels of CO2 and low levels of O2 make us tired.Take notes.
After reading a section write down what you learned.
You might even make these a blog post or do a short talk about it.Do practical things.
This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.Take notes about what to learn.
You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
Use your notes to write down what you'd like to look up then look it up when the time is right.Repeat.
We can't internalize complex knowledge directly.
We need to repeat and practice it.
With software APIs, katas are a proven way to do that.
When you learn something new, make a tiny project putting the knowledge to use.
This should take about 30min.
Repeat this project after a short break.
Then again maybe on the next day.
Repetition with increasing time in between makes sure the knowledge ends up in long term memory.
New contributor
$endgroup$
add a comment |
$begingroup$
Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.
Take breaks.
Study for maybe 20 minutes then take a short break.
Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.Make sure you have plenty of fresh air.
High levels of CO2 and low levels of O2 make us tired.Take notes.
After reading a section write down what you learned.
You might even make these a blog post or do a short talk about it.Do practical things.
This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.Take notes about what to learn.
You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
Use your notes to write down what you'd like to look up then look it up when the time is right.Repeat.
We can't internalize complex knowledge directly.
We need to repeat and practice it.
With software APIs, katas are a proven way to do that.
When you learn something new, make a tiny project putting the knowledge to use.
This should take about 30min.
Repeat this project after a short break.
Then again maybe on the next day.
Repetition with increasing time in between makes sure the knowledge ends up in long term memory.
New contributor
$endgroup$
Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.
Take breaks.
Study for maybe 20 minutes then take a short break.
Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.Make sure you have plenty of fresh air.
High levels of CO2 and low levels of O2 make us tired.Take notes.
After reading a section write down what you learned.
You might even make these a blog post or do a short talk about it.Do practical things.
This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.Take notes about what to learn.
You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
Use your notes to write down what you'd like to look up then look it up when the time is right.Repeat.
We can't internalize complex knowledge directly.
We need to repeat and practice it.
With software APIs, katas are a proven way to do that.
When you learn something new, make a tiny project putting the knowledge to use.
This should take about 30min.
Repeat this project after a short break.
Then again maybe on the next day.
Repetition with increasing time in between makes sure the knowledge ends up in long term memory.
New contributor
New contributor
answered 1 hour ago
Jens SchauderJens Schauder
1012
1012
New contributor
New contributor
add a comment |
add a comment |
john01dav is a new contributor. Be nice, and check out our Code of Conduct.
john01dav is a new contributor. Be nice, and check out our Code of Conduct.
john01dav is a new contributor. Be nice, and check out our Code of Conduct.
john01dav is a new contributor. Be nice, and check out our Code of Conduct.
Thanks for contributing an answer to Computer Science Educators Stack Exchange!
- 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.
Use MathJax to format equations. MathJax reference.
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%2fcseducators.stackexchange.com%2fquestions%2f5492%2fhow-can-i-get-through-very-long-and-very-dry-but-also-very-useful-technical-doc%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