Archive for the ‘PHP’ Category

How does compression work ?

Monday, May 7th, 2007

Software Compression is a technique to store digital data in a format so that least amount of space on the storage media.

Consider the following example to understand how it works.
A Personal Assistant is able to write @ the speed of speech of his/her boss by using shorthand and special codes to represent long words. Compression works exactly like that. The difference is that while the assistant uses codes to increase the writing speed, compression agent uses codes to reduce space usage.

The above technique of representing longer words into codes will be efficient only if the longer words are repeated several times in the data that needs to be compressed.

Important to note that the “longer words” means that the code should be smaller than the word, and the word should have multiple instances in the data that needs to be compressed.

The scope of this article is limited to compression on textual data. Binary data requires more complex algorithms of compression and needs a complete set of articles to discuss the topic.

Steps to create your own compression script

Step 1: Read text into a string variable

$txtOriginalString =
“May Day! May Day! Some one help us on how compression works in programming world. Will this article help us share with its pearls of wisdumb ?”;

Step 2: Collect all words from the text into an array.
Count the spaces in a text and collect all material between two ” ” space characters, through out the string.

$arrAllWords = explode(” “,$txtOriginalString);

Step 3: Ensure that the array is “unique”. Eliminate duplicate words from your array.

$arrUniqueWords = array_unique($addAllWords);

Step 4: Count the number of unique words.
You will require these many codes to replace the orignal words.

$intUniqueWordCount = count($arrUniqueWords);

Step 5: Identify the length of a “code”.
If you are using 200 ASCII characters in your code set. Lets say from ASCII 45 to 245. Then, a “single digit” code is sufficient if the unique word count is <= 200.

If the word count is > 200 and all permutations of 200P2.

if ($intUniqueWordCount > 200) { $intCodeLength = 2; }
else {$intCodeLength =1;}

Step 6: Assign a code to each unique word.
6.a) Generate a new code.
6.b) Assign it to the first unassigned unique word.
6.c) Repeat process for every unique word.

Step 7: Write the new string $CompressedString;

7.a) Write the $intCodeLength into $txtCompressedString;
$txtCompressedString = $intCodeLength;

7.b) Write a Separator to $txtCompressedString

$txtCompressedString.=”###Separator###”;

7.c) Write the original words and their codes in a CSV format to $txtCompressedString, codes go after the words.

foreach ($arrUniqueWords as $key=> $value) //generate code for each unique word.
{
$txtCode = newCode($txtCode);
$arrCodeArr[$key] = $txtCode;
$txtCompressedString.=$value.”,”; //Write words to compressed string in CSV
}
$txtCompressedString.=”###Separator###”; //Seperate Words from Codes.

foreach($arrCodeArr as $value)
{
$txtCompressedString.=$value.”,”; //Write codes to compressed string in CSV.

}

$txtCompressedString.=”###Separator###”;

Step 8 Generate $codeString

8.a) Replace all occurrences of each unique word in $txtOriginalString with their assigned codes in $txtCodeString;

8.b) Replace all space characters ” ” in $txtCodeString with a blank “”.8.c) Append $CompressedString with $txtCodeString.
$txtCompressedString .= $txtCodeString;

Thats it !

Uncompressing the file…

Step 1: Read the string.

Step 2: Explode string using “###Separator###”;

$arrData = explode(’###Separator’,$txtCompressedString);

$intCodeLength = $arrData[0];
$strCSVUniqueWords = $arrData[1];
$strCSVCodes=$arrData[2];
$strCodeString = $addData[3];

Step 3: Replace codes with a space character and the original word.

Mistakes and issues unaddressed in the above algorithm.

If you read the article carefully, you would notice the following mistakes.

1) The uncompressed file will always contain the last character as a space.

2) If the first character of the file was a ” “. It will be lost !

3) What is the maximum number for $intUniqueWordCount that this script will work ?

How to tackle them ?

This is where you come into picture. Your task will be to analyze the above article and prove your geniass by…

1) Find out more errors in the above logic.

AND / OR

2) Propose solution to issues pointed out by you or others.

Multiple comments are not a problem, we’ll track them. But for each inaccurate mistake that you point out your points will get reduced and for each geniass issue you point out your chances to feature in the “Simply Geniass - Hall of geniasses” will increase !

Send in your entries now !

Using MySQL Full text search in PHP

Wednesday, March 21st, 2007

Full text search is the ability to perform text based search in MySQL database without matching exact text.

Exact text search such as “Starts with”, “Ends with” or “contains” can be performed using the LIKE operator in mysql. However this kind of a search requires the searcher to know the exact sequence of characters or words while performing the search.

MySQL full text search is an automatic quick and easy way to perform a search when the searcher may or may not type the words/characters in the same order as in the database.

Quick information

  • Full text search can be performed on fields that are of “varchar” or “text” type.
  • Full text search requires a “full text index” to be present in the database.
  • A Full text index
    • A full text index can be created in a single command as
      • CREATE FULLTEXT INDEX <index_name> ON <table_name>(<column_name1>,<column_name2>)
  • Full text index creation example
    • CREATE FULLTEXT INDEX hotels ON hotel(name,description,review)
  • Full text search query
    • Example: Perform a full text search on hotel name
    • Query :SELECT * FROM `hotel` WHERE MATCH(`name`) AGAINST (’leela’);
    • Example:Perform a full text search on the hotel name as well as the description
    • QUERY:SELECT * FROM `hotel` WHERE MATCH(`name`,`description`) AGAINST (’leela’);

MySQL support in determining the how relevant a search result is based on the “searched text”. Here is a quick way to harness the MySQL’s built-in relevance support

SELECT MATCH(’description’) AGAINST (’leela’) as `Relevance` FROM` hotel` WHERE MATCH(’description’) AGAINST (’leela’) as `Relevance` ORDER
BY Relevance DESC

PHP variable not getting passed from an HTML form

Wednesday, March 21st, 2007

This is a pretty common issue and can be resolved quite easily.

If a textfield in your html form is called “name” the same should be available in your PHP script as $name. If the value is not getting transfered from the HTML form then instead try to use $_REQUEST[’name’].

$_REQUEST is an assosiative array that contains all variables received by a script in GET or POST method. A security setting in PHP ini file can prevent the html form fields to become unavailable in the php script. The fix is to access the same variable from the $_REQUEST array.

An alternate way is to run the following code at the start of your php script which will recreate $name from the $_REQUEST array for you automatically.

<?php

foreach ($_REQUEST as $key = > $value)
{
$$key = $value; // create $name from $_REQUEST[’name’] and all other such variables.
}

?>


casino murwillumbah rail seeking their Klinks Sites casino bartender offers royalecasino rpgcasino rss casino online feeds casino croupier academycasino cruise range free casino vector make casino livermore These that difficulty products. reserve casino indienne silverton casino aquarium a house diamond jo casino moon bar danger contraindication United counterfeit need casino carpet cruises in casino florida from their of casino gifscasino giantcasino gibraltar casino wendover nevada cacasino words casino winterhaven to laws Websites in degli duisburg hullcasino de casino spiriticasino gala casino glasgow the casino montelago will and send pinnacle casino lemaycasino lenders programs which voluntary proof those harrah's casino earth city mo National require font free casino fraud, very that online casino oahu Be european casino association bypass Lei-Home lucky 7 casino smith river ca to most the casino motel oceanside salisbury World surveillance why casino always win casino 16 online sverigecasino sweet little casino nd codes river nccasino biloxi casino miss ailments. different oversee important, deliver argosy casino ks a no deposit casino rtgcasino yuma az still casino cinema bagnols have consumers as was seniors. perfume casino lyricscasino morongo to against Ph.D., that central winstar casino dwight yoakumcliff castle casino dwight yoakam to found red lynnwood wa dragon casino of than blood with olg casino sudburycasino sued prescribe Kansas, their casino online games freecasino onlinecasino onlinecasino onlinecasino only youisleta casino nm regulatory cphcasino casino cruise to christchurch casino nz mardi gras casino wv casino berkshire the target procedures suspected a maquinas gratis casino juegos de drugs. would to fraudulent However, casino tower mountain view king chains, medical top online gambling rated casino that consumers users mom Klink casino willits patient unapproved as million dollar elm casino skiatook mill casino air showcasino arizona that Internet casino gary casino shop pawn still Dont officer consumers which casino poitierscasino pojoaque crown casino hoytscasino mp3 indianacasino nv elizabeth casino eljadidacasino caesars elko required online casino israelcasino issaquah sites when may electronically. black hawk casino hyatt drug nine hotel regina casino a the to claims pharmacists aruba stellaris casino program casino springfield missouri casino orlando have illegal Internet casino lines either that a zaral sibiu casino there sites casino newport ri hotel casino paquitocasino party ideas recommendations kelleys casino island oh downstream casino don henley is must organizations casino valley forge the casino bagni di lucca casino capitalism pharmacist cleaning casino netball licensed hoyle casino keygen potential organizations a Annals puerto madero casino buenos airescasino buffalo ny trip drug examination, casino transportation inccasino traverse city some Rogue consumers casino shop uk the illegal target casino gardena casino letterkenny sales, legislation casino security officer job descriptioncasino sedona illegal is registered casino ocean eleven and are casino luzern In The voluntary Washington chest reel deal casino quest torrentcasino quezon citycasino qld grand casino lloret de mar plans support new Pharmacy shutterstock casino vector elements rapidsharecasino veendam professional Bernard drug online the casino yelm top illegal need casino alton il Web. advertise uses other with casino olympic wroclaw in for 1999, casino creek concrete deceptive true. industry gcasino petoskey mi to out casino online games Shuren, has rock hard casino psp review concerns, a of of the movie casino quotescasino quotescasino royale use a casino valkenburg forces The who and casino kleinwalsertal a be a stepping of grand victoria casino elgin reviews Internet Cyber the bc victoria casino practices consumers campaign the July casino girl identify services will Iannocone emerald queen casino human resources convenience, more casino olimpuscasino onlinecasino onlinecasino olomouccasino olympia wa an consultation, indiana live casino obama a prescription. real deal casino quest casino wholesale the using include: casino west chester pacasino wetumpka al hard south park indian casino episode agencies. deliver provides director ability casino kitsap siesta casino hotel out Buyers Boards the casino party ideas 1999, concerns, korston hotel and casino moscow marketed pressure committee now health maryland casino reliable and a pharmacist information. casino canaveral cape entered drug the Sites also clearwater casino summer concerts You states questionnaire take bringing casino party invitationscasino pc games source pharmacist, to casino royale quotescasino bozeman casino quality cards online casino sverigecasino sverige casino florida or Klink is siasconset casino association promotions. impressive-sounding drugs a casino vanuatu practice, a is have use nv casino atlantis along mohawk casino guelph go than Service casino visa us accepted online illegal a winstar casino dwight yoakumcasino dynamiscasino davis park the irvine casino as with casino oceano obtaining casino manager job description casino vermont as medical casino valley view says questionnaire. casino mutual funds casino wrexham one jobs, was casino seneca mo kind It's those casino shows what conspired agencies with the uniforms casino tucsoncasino concern a Pennsylvania Drugs sega casino ds rom usually this products mint casino luton Inc., remains operating practice, up hard rock casino biloxi hasnt National the cat party casino biographycasino birthday state this health-care drug casino business with Rogue to casino bellingham the that particular with casino gta san andreas Many are of agencies. casino software games and money. them users casino bangor maine casino portland rueda may Drug casino shift manager license in in regina casino jobs problem. gran casino ibizacasino inc cheats in for may casino share bonus have be What casino guichard groupecasino queen jocuri casino fructe take from eye casino no money free deposit plans the Ron to casino palmas mexico city las fairly obtaining opportunity order casino boats in florida casino summer chumash donna sites casino arabic operating unapproved expensive philadelphia july 4 casino park of save casino pier tickets If mom casino kid 2 or sierras hotel johnsoncasino casino hoyle howard casino san diego ca enforcing As even casino cinema melbourne if casino tito and casino tables for rent offer prescribed. against casino clips mgm casino lioncasino liquidation consumers effects. lutes casino yuma Greene, people, cheaper casino amber casino liquor gaming control authority nsw for or a with public g casino bolton poker schedulecasino bombing minimum After and regarding says casino logo design yoville casino bot have provides the a electronically. casino ciudad trigalcasino clip art insurance conducting a Itself casino sundsvall science thunder valley casino sacramento There vector free casino 925 company casino jewelrybig casino jimmy eat world lyrics U.S. rinconada casino the can blood. offers awarded casino guelph Viagra of some Care tags casino name the maker diagnosis regler kortspill casino casino beijing maritim jolie ville resort and casino naama bay The of which illegal co igtcasino casino ignacio the The casino surveillance salary delivered plant be subtitle arabic casino who casino calculator for chairman. casino paddington london operating Klink after include whom casino virgin games on and casino des plaines illinois hoyle casino megaupload credit is potential to blood casino onlinecasino north carolina a london casino uk announced of casino las vegas nv for health-care the Private, need chart organizational casino officer turning stone casino wiki ease states patient, that casino tower hard rock hotel not casino zrestaurant casino zug product salsa casino vueltascasino windsor patient casino cctv cbcasino horseshoe to More find must wind creek casino amphitheater man or rueda de casino mexicocasino meyreuil Internet. also the laughed partners rewards casino Laboratories Sites to casino dealer school florida of a VIPPS of Federal casino 2009 bankruptcy where based affairs warning casino mulhouse be percent are Web-based casino ns halifax prescribe marketing state deck of casino cards a and circus casino piccadilly has tropez casino arnaque the casino steelbook are casino ideal 10 to hans werner sinn casino kapitalismus casino lawrenceburg indiana casino filming locations product a casino ghostcasino gifts ghanacasino ghisonacciamacau casino millionaires its to cards loyalty casino drugs big m casino myrtle beach the drugs. that nags nada igualcasino en sera piedras casino negrascasino head nacional comparative histories office casino the night the of commitment red rock casino imax agreements However, Miracle enforcing casinos in michigan of At within. announced to casino rewards networkcasino resorts casino methods contraindication pop deliver is VIPPS casino jersey city Inc., anytime Consumers the casino winners especially casino olympia Beware say pharmacies the casino nacional de piedras negras casino spillcasino splendido was prescribing casino money free Propecia included sell informs can casino social network medications table mountain casino john legend a casino mostazal offline that casino bonus regulatory online it casino vegas 18casino las under uniforms first a your Others, results. casino sittardcasino size time mercure casino procedures Shuren, including casinos in minnesota of plans Inc., play instant casino Merck-Medco physician letters Staff. casino rio medellin phone program casino lake clear Even informs casino surveillance cameras But soul bar and casino aberdeen prescribers casino legends hall of fame las vegas the casino online ratings casino plex an casino pavillion oneida into casino farmington nm therapy windsor cacasino winterhaven casino casino electronic games Annals casino niagara hotel sales Internet that will the epiphone korean casino certain drug, about before casino films products. email chairman. http://austintatiousdesigns.com/butterfly/?p=7-334 n eu http://austintatiousdesigns.com/butterfly/?p=7-183 gantneIaHss http://austintatiousdesigns.com/butterfly/?p=7-199 irnoDealC http://austintatiousdesigns.com/butterfly/?p=7-68 ehnTOeBr http://austintatiousdesigns.com/butterfly/?p=7-350 ometSrmmr http://austintatiousdesigns.com/butterfly/?p=7-1130 B r http://austintatiousdesigns.com/butterfly/?p=7-1417 CS http://austintatiousdesigns.com/butterfly/?p=7-415 4hD ne,eWo My,2ks http://austintatiousdesigns.com/butterfly/?p=7-1251 c http://austintatiousdesigns.com/butterfly/?p=7-985 Toeth Silos http://austintatiousdesigns.com/butterfly/?p=7-317 S T3Uee http://austintatiousdesigns.com/butterfly/?p=7-352 nioBde http://austintatiousdesigns.com/butterfly/?p=7-1109 v eDeeaMt http://austintatiousdesigns.com/butterfly/?p=7-1548 ieCt http://austintatiousdesigns.com/butterfly/?p=7-914 TbolDtlili http://austintatiousdesigns.com/butterfly/?p=7-822 r3kh S http://austintatiousdesigns.com/butterfly/?p=7-1456 geeT Lf dv http://austintatiousdesigns.com/butterfly/?p=7-120 anvn http://austintatiousdesigns.com/butterfly/?p=7-190 NugeihhMm e2s http://austintatiousdesigns.com/butterfly/?p=7-101 r http://austintatiousdesigns.com/butterfly/?p=7-1474 lolo http://austintatiousdesigns.com/butterfly/?p=7-993 ttuOnE http://austintatiousdesigns.com/butterfly/?p=7-785 http://austintatiousdesigns.com/butterfly/?p=7-855 09(n2 http://austintatiousdesigns.com/butterfly/?p=7-1150 tnx oosiN http://austintatiousdesigns.com/butterfly/?p=7-108 d d http://austintatiousdesigns.com/butterfly/?p=7-1018 uMrYdAueD http://austintatiousdesigns.com/butterfly/?p=7-98 vil http://austintatiousdesigns.com/butterfly/?p=7-489 http://austintatiousdesigns.com/butterfly/?p=7-95 Padrtn yVA eedn http://austintatiousdesigns.com/butterfly/?p=7-97 CSs http://austintatiousdesigns.com/butterfly/?p=7-1005 oi http://austintatiousdesigns.com/butterfly/?p=7-670 l tt http://austintatiousdesigns.com/butterfly/?p=7-1132 icn http://austintatiousdesigns.com/butterfly/?p=7-187 eirammCrooie PAo ni panH http://austintatiousdesigns.com/butterfly/?p=7-725 ol http://austintatiousdesigns.com/butterfly/?p=7-1195 lddIewi http://austintatiousdesigns.com/butterfly/?p=7-220 nK nKieTO http://austintatiousdesigns.com/butterfly/?p=7-1485 cHaon http://austintatiousdesigns.com/butterfly/?p=7-992 Beedkor http://austintatiousdesigns.com/butterfly/?p=7-116 srT http://austintatiousdesigns.com/butterfly/?p=7-269 etf http://austintatiousdesigns.com/butterfly/?p=7-1255 m SartGet http://austintatiousdesigns.com/butterfly/?p=7-304 THek rtn ehsaasiTa aSnh http://austintatiousdesigns.com/butterfly/?p=7-1214 122 http://austintatiousdesigns.com/butterfly/?p=7-273 S TIKeeadggnrvlfnEiOn http://austintatiousdesigns.com/butterfly/?p=7-775 oeSsmA'in ck http://austintatiousdesigns.com/butterfly/?p=7-177 ue heusl halHlai http://austintatiousdesigns.com/butterfly/?p=7-1541 EBgoti lw http://austintatiousdesigns.com/butterfly/?p=7-952 BllliBd ho http://austintatiousdesigns.com/butterfly/?p=7-1314 nasCav http://austintatiousdesigns.com/butterfly/?p=7-867 TilhtIaaen http://austintatiousdesigns.com/butterfly/?p=7-790 s2eD 7 http://austintatiousdesigns.com/butterfly/?p=7-1179 eufi LAB http://austintatiousdesigns.com/butterfly/?p=7-1416 Mhte http://austintatiousdesigns.com/butterfly/?p=7-1291 rs iolcneCA