In Joomla You can check following files
components/com_users/controller/reset.php
components/com_users/modles/reset.php
In controller file you can find one function name request();
It uses a function the model processResetRequest();
In side this function it will create the activation token with following codes
     // Set the confirmation token.
$token = JUtility::getHash(JUserHelper::genRandomPassword());
$salt = JUserHelper::getSalt('crypt-md5');
$hashedToken = md5($token.$salt).':'.$salt;
$user->activation = $hashedToken;
Also joomla is verifying the token its getting correct then it will allow users to create new password.If you want to do that you can use following code for joomla standard password.
jimport('joomla.user.helper');
 $salt = JUserHelper::genRandomPassword(32);
 $crypt = JUserHelper::getCryptedPassword($password_choose, $salt);
 $password = $crypt.':'.$salt;
the above code is creating the joomla passwords.
If you are planning to use this for mobile device and without editing the core joomla the you can create a file on root and achieve it as like this
Hope this may help you..