Suppose we write a C program as two files p1.c and p2.c. 

We can then compile this code on an IA32 machine using a Unix command line:
unix> gcc -O1 -o p p1.c p2.c

Your compiler actually invokes a sequence of programs to turn your source code into your executable.

1. C preprocess expands the source code to include any files specified with the #include command and to expand any macros specific with #define declarations. 

2. The compiler generates assembly- code versions of the two source files having names p1.s and p2.s

3.  The assembler converts the assembly code into binary object-code files p1.o and p2.o. Object code is one form of machine code—it contains binary representations of all of the instructions, but the addresses of global values are not yet filled in. 

4. Finally, the linker merges these two object – code files along with code implementing library functions(e.g., printf) and generates the final executable codefile p.

Happy New year everyone! I know I am late for my greetings. 10 days to be exact. 2014 will be exciting. My final two semesters in school. I have some plans on what I want to do but no plans have been cast in stone yet. I will try to update more often. Have a great year! 

I was going through my image processing notes, and I encounter the topic of Euler’s formula for complex numbers. Despite taking quite a bit of mathematics modules the past few years, I have not studied before Euler’s formula so this appears a little foreign to me. A little search on the internet and I encounter this page. A good read for those that want to know more about Euler’s Formula.