Python List Tuples and Dictionary
Lists are what they seem - a list of values. Each one of them is numbered, starting from zero - the first one is numbered zero, the second 1, the third 2, etc. You can remove values from the list, and add new values to the end. Example: Your many cats' names.
Tuples are just like lists, but you can't change their values. The values that you give it first up, are the values that you are stuck with for the rest of the program. Again, each value is numbered starting from zero, for easy reference. Example: the names of the months of the year.
Dictionaries are similar to what their name suggests - a dictionary. In a dictionary, you have an 'index' of words, and for each of them a definition. In python, the word is called a 'key', and the definition a 'value'. The values in a dictionary aren't numbered - they are similar to what their name suggests - a dictionary. In a dictionary, you have an 'index' of words, and for each of them a definition. In python, the word is called a 'key', and the definition a 'value'. The values in a dictionary aren't numbered - they aren't in any specific order, either - the key does the same thing. You can add, remove, and modify the values in dictionaries. Example: telephone book.
Monday, July 13, 2020
Monday, June 29, 2020
Linux File System
A file system is a process that manages how and where data on a storage disk is stored, accessed and managed.
In a UNIX/Linux type OS, "Everything is a file", which means that everything in the computer system from processes, files, directories, sockets, pipes, ... is represented by a file descriptor abstracted over the virtual file-system layer in the kernel. The virtual file system is an interface provided by the kernel. Hence the more accurate phrase is "Everything is a file descriptor", or to make it even more accurate, Linus Torvalds himself corrected it again as :"Everything is a stream of bytes".
Linux main directories list:
/(root file system)
The root file system is the top level directory of the file system. It must contain all of the files required to boot the Linux system before other file systems are mounted. It must include all of the required executables and libraries required to boot the remaining file systems. After the system is booted, all other file system are mounted on standard, well-defined mount points as sub-directories of the root file system.
/bin
Contains User executable files.
/boot
Contains the static boot loader and kernel executable and configuration files required to boot a Linux computer.
/dev
This abstract directory contains the device files for every hardware device attached to the system. These are not device drivers, rather they are files that represent each device on the computer and facilitate access to those devices.
/proc
Another abstracted directory which is created when the system boots. Contains information about the processed on your system.
/etc
Contains the local system configuration files for the host computer.
/home
Home directory storage for user files. Each user has a sub-directory in /home.
/lib
Contains shared library files that are required to boot the system.
/media
A place to mount external removable media devices such as USB thumb drives that may be connected to the host.
/mnt
A temporary mount point for regular file systems (as in not removable media) that can be used while the administrator is repairing or working on a file system.
/opt
Optional files such as vendor supplied application programs should be located here.
/root
This is not the root (/) file system. It is the home directory for the root user.
/sbin
System binary files. These are executables used for system administration.
/tmp
Temporary directory. Used by the operating system and many programs to store temporary files., Users may also store files here temporarily. Not that files stored here may be deleted at any time without prior notice.
/usr
These are shareable, read-only files, including executable binaries and libraries, man files, and other types of documentation.
/var
Variable data files are stored here. This can include things like log files, MySQL, and other database files, web server data files, email inboxes, and much more.
In a UNIX/Linux type OS, "Everything is a file", which means that everything in the computer system from processes, files, directories, sockets, pipes, ... is represented by a file descriptor abstracted over the virtual file-system layer in the kernel. The virtual file system is an interface provided by the kernel. Hence the more accurate phrase is "Everything is a file descriptor", or to make it even more accurate, Linus Torvalds himself corrected it again as :"Everything is a stream of bytes".
Linux main directories list:
/(root file system)
The root file system is the top level directory of the file system. It must contain all of the files required to boot the Linux system before other file systems are mounted. It must include all of the required executables and libraries required to boot the remaining file systems. After the system is booted, all other file system are mounted on standard, well-defined mount points as sub-directories of the root file system.
/bin
Contains User executable files.
/boot
Contains the static boot loader and kernel executable and configuration files required to boot a Linux computer.
/dev
This abstract directory contains the device files for every hardware device attached to the system. These are not device drivers, rather they are files that represent each device on the computer and facilitate access to those devices.
/proc
Another abstracted directory which is created when the system boots. Contains information about the processed on your system.
/etc
Contains the local system configuration files for the host computer.
/home
Home directory storage for user files. Each user has a sub-directory in /home.
/lib
Contains shared library files that are required to boot the system.
/media
A place to mount external removable media devices such as USB thumb drives that may be connected to the host.
/mnt
A temporary mount point for regular file systems (as in not removable media) that can be used while the administrator is repairing or working on a file system.
/opt
Optional files such as vendor supplied application programs should be located here.
/root
This is not the root (/) file system. It is the home directory for the root user.
/sbin
System binary files. These are executables used for system administration.
/tmp
Temporary directory. Used by the operating system and many programs to store temporary files., Users may also store files here temporarily. Not that files stored here may be deleted at any time without prior notice.
/usr
These are shareable, read-only files, including executable binaries and libraries, man files, and other types of documentation.
/var
Variable data files are stored here. This can include things like log files, MySQL, and other database files, web server data files, email inboxes, and much more.
Labels:
TechTopics
Sunday, June 28, 2020
C++ concepts
Vector
Example:
Just like arrays, vectors use contiguous storage locations for their elements, which means that their elements can also be accessed using offsets on regular pointers to its elements, and just as efficiently as in arrays. But unlike arrays, their size can change dynamically, with their storage being handled automatically by the container.
Internally, vectors use a dynamically allocated array to store their elements. This array may need to be reallocated in order to grow in size when new elements are inserted, which implies allocating a new array and moving all elements to it. This is a relatively expensive task in terms of processing time, and thus, vectors do not reallocate each time an element is added to the container.
Instead, vector containers may allocate some extra storage to accommodate for possible growth, and thus the container may have an actual capacity greater than the storage strictly needed to contain its elements (i.e., its size). Libraries can implement different strategies for growth to balance between memory usage and reallocations, but in any case, reallocations should only happen at logarithmically growing intervals of size so that the insertion of individual elements at the end of the vector can be provided with amortized constant time complexity (see push_back).
Therefore, compared to arrays, vectors consume more memory in exchange for the ability to manage storage and grow dynamically in an efficient way.
Compared to the other dynamic sequence containers (deques, lists and forward_lists), vectors are very efficient accessing its elements (just like arrays) and relatively efficient adding or removing elements from its end. For operations that involve inserting or removing elements at positions other than the end, they perform worse than the others, and have less consistent iterators and references than lists and forward_lists.
Labels:
Programming
Sunday, June 21, 2020
Why Real Time Embedded Linux ?
Why Real Time Embedded Linux ?
You might hear of embedded Linux for real time very often. It sounds the entire embedded world depends on this. The question really contains 3 important concepts, we can break this question into 3 sub-questions based on these 3 concepts.
Why Linux ?
This is a generic question, easy for public to understand. Linux is Open source, less legal issues, popular, easier to get support, APIs and expertise. etc.
Why Embedded (vs Desktop Linux) ?
A bit more technical.
1. Embedded Linux system usually requires great reliability. Desktop Linux may have >100M code installed, with a lot of un-necessary features. Embedded Linux typically have 1M foot print, with only required feature installed.
2. Resource constraint. Embedded Linux has no HDD, and its non-volatile storage is life constraint. This coupled with the reliability and power safe requirement, a large portion of embedded linux system is actually read only.
Why Real Time ?
A common mis-understanding about Real Time is that Real Time means Fast, actually Real Time means deterministic. In other words, to complete a task within a specified time, otherwise will lead to an error condition. For example, a dish washer need to stop water filling in Read Time fashion, but screen display update may not be real time.
We classify a task either deterministic or in-deterministic, so the concept of soft Real Time should be obsolete.
Linux is not intrinsically deterministic, there are processed can run to completion. Hence, we need some other modification to make Embedded Linux real-time, mainly two ways, use a RealTime kernal and make regular Linux as a process. or use Preempt_RT, break down Linux locked processes, and put main ISR routine to a task, only left signaling inside ISR, like FreeRTOS. In practical, we can control the worst case latency to be less than 100 micro-seconds, good enough for Real-Time applications.
Labels:
RTOS
ARM in a nutshell.
What is ARM ?
ARM is an Advanced RISC Machine,.
It is a RISC not CISC processor. It is basically a LOAD-STORE architecture, where data processing operations are only between registers and does not involve any memory operations.
It is a 32 bit processor and also has variants of 16 bit and 8 bit architecture, so a word is 32 bits, not 16 bits.
It got auto-increment and auto decremented addressing modes to optimize program loops, which is not very common with RISC processors.
It has a very good speed vs power consumption ratio which makes it suitable for embedded system.
It has 3 stages pipe-line: Fetch, Decode and Execute.
7 sounds a lucky number for ARM:
It has 7 operating modes: Supervisor mode; User Mode, System Mode, Fast Interrupt Mode, Interrupt Mode, Undefined mode and abort Mode.
It has 7 interrupts/exceptions, Reset, Undefined, Pre-fetch abort, data abort, software interrupt, FIQ and IRQ, make ARM enter 5 modes, User Mode and System Mode do not need interrupt to enter,
It has 7 addressing modes: immediate mode, index mode, indirect mode, absolute (Direct) mode register mode, displacement mode and Auto-increment/Auto'decrement mode.
Labels:
Embedded
Subscribe to:
Posts (Atom)