Posts

Showing posts from October, 2018

The WeakReference class, monitoring memory leak and garbage collection in a Java application

Image
 Below is a Stack implementation that uses an internal resizeable array structure.  public class MyStack< T > implements Stack< T > { private static final int CAPACITY = 100 ; private Object[] array ; private int pos = 0 ; public MyStack () { this . array = new Object[ CAPACITY ] ; } @Override public void push ( T item) { if ( pos >= array . length / 2 ) { Object[] newArray = new Object[ pos * 2 ] ; System. arraycopy ( array , 0 , newArray , 0 , array . length ) ; array = newArray ; } array [ pos ++] = item ; } @Override public T pop () { if (isEmpty()) { throw new RuntimeException( "empty stack" ) ; } @SuppressWarnings ( "unchecked" ) T item = ( T ) array [ pos - 1 ] ; pos -= 1 ; return item ; } @Override @SuppressWarnings ( "unchecked" ) public T peek...

Dynamic Connectivity Problem and the Union-Find Algorithm

Lets say we need to connect some objects and query if some objects are connected or not. Below is an example test: @Test     public void testConnectivity() {         MyConnectionDb connectDb = new MyConnectionDb();         connectDb.connect(4, 3);         connectDb.connect(3, 8);         connectDb.connect(6, 5);         connectDb.connect(9, 4);         connectDb.connect(2, 1);         assertTrue(connectDb.isConnected(8, 9));         assertFalse(connectDb.isConnected(5, 4));         connectDb.connect(5, 0);         connectDb.connect(7, 2);         connectDb.connect(6, 1);         connectDb.connect(7, 3);         assertTrue(connectDb.isConnected(5, 3));     } So whe...

DEVOPS

Image
This table shows imporant aspects of DEVOPS and related software products. The ones that I have used in the past are painted in red. I think this is a very nice table to look at alternative solutions to use for new projects. Of course some of them are essential: Version control. (Subversion,  Git, ..) Build tool. (Maven, Gradle, ..) Testing. Unit Test, Stress Test, UI TEst. (JUnit, JMeter, Selenium) Continuous Integration. (Bamboo, Continuum, ..) The others seem to depend on the size of the organization and the project. Some use AWS, others manage their own servers. 

Do you speak MATLAB?

MATLAB is a programming platform designed specifically for engineers and scientists. I first used it for a masters degree course on image processing. And now, I'm looking at it for the purpose of machine learning. Now lets remember what we can do with it: Matlab has a command line and also you can save your scripts as .m files. You should define your functions and save them as .m files. Note: If you put a semicolon to the end of the expression, the output is not shown in the console. Lets create a 3 x 3 matrix: A = [1, 2, 3; 0, 0, 0; -1, -1, -1] Lets create a vector: V = [2, 3, 6, 7] Lets create a column vector: V = [2; 3; 4; 5] Lets draw a diagram with some values: X = [1,2,3,4,5]; Y= [0,-1,3,4,8]; plot(X,Y) How to define a function? function y = myFunction(x)     y = x^2 + x + 1; end From command line: result = myFunction(6); Lets create a uniformly spaced vector.  V1 = 1:10 V2 = 1:10 plot(V1, V2) We can also specify the int...

Popular posts from this blog

Trie Data Structure and Finding Patterns in a Collection of Words

My Crappy Looking Solution to "Binary Tree Common Ancestor" Problem

A Graph Application in Java: Using WordNet to Find Outcast Words