here is the link - http://goo.gl/Lu7Qg
Styles for BibTeX4word - Custom and modified .bst files using windows
I am using Microsoft Windows 7 (and Windows XP at home) and I use Word to create documents. You must first be familiar with Word, Jabref, MikTex, and Bibtex4word before this will make sense. Start by reading the Bibtex4word documentation. These three programs will allow you to automatically create bibliographies in word.
Here is a manual for Miktex
Below is a list of style types that I use regularly:
The first thing to know about this is that it is really anoying. I have been trying to figure this out for weeks and still have had little luck. There are many many websites that give information, but must of the time it is not that helpful.
Finding my .bst files: This is much more difficult that it seems. I though they would be in the "Program Files/miketex2.8" folder. Nope. I finally found them in:
"C:\Users\UserName\AppData\Roaming\MiKTeX\2.8\bibtex" ~ in Windows 7
"C:\Documents and Settings\UserName\Application Data\MiKTeX\2.8\bibtex\bst" ~ in Windows XP
thanks to some hits from this link.
Here is a manual for Miktex
Below is a list of style types that I use regularly:
- ieeetr/cn^s - good for most conferences
- phaip/cn[]^s - actual APL (AIP) file but use et al. for over 5 name which APL does not allow.
- phjcp/cn[]^s - like APL and does not use et al. but has lower caps in names. ~ this can be made to match APL almost perfectly if you highlight all of the references, press ctrl+d, uncheck the small caps option.
- phnflet - like APL without et al. but uses all caps and DOI in wrong place.
- rsc/cn[]^s - RSC reference type such as Lab on a Chip
- achemso/cn[]^s - America chemical society
- http://www.ee.ic.ac.uk/hp/staff/dmb/perl/index.html
- http://web.reed.edu/cis/Help/LaTeX/bibtexstyles.html
The first thing to know about this is that it is really anoying. I have been trying to figure this out for weeks and still have had little luck. There are many many websites that give information, but must of the time it is not that helpful.
Finding my .bst files: This is much more difficult that it seems. I though they would be in the "Program Files/miketex2.8" folder. Nope. I finally found them in:
"C:\Users\UserName\AppData\Roaming\MiKTeX\2.8\bibtex" ~ in Windows 7
"C:\Documents and Settings\UserName\Application Data\MiKTeX\2.8\bibtex\bst" ~ in Windows XP
thanks to some hits from this link.
Posted on Tuesday, November 29, 2011
[Matlab] Loading Large Data Sets
The Old Way to Load DataSets
Lots of my time consists of analyzing huge sets of files recorded by and oscilloscope or some other device. Typically, I would try to use the same name for each file with a number at the end that increase each time. Then I can write a loop to load all of the files, then do analysis and create plots. This causes its own problems for several reasons such as: several loops must be used for different regions of the data (tek0000n for n = 1-9; tek000nn for nn = 10-99; tek00nnn for nnn = 100-999; etc) and broken loops when a single file in the data set is a different length or mission, and many other issues. Such a sustem looks like this where many conditional loops are used to fix the problem:
Read Directory and Load
Recently, google helped me discover a better method where you can actually tell matlab to read and record the files names in a specific folder. The, so long as all the data is the same length, a single loop can be used to import all of the data in a single folder. Here is an example:
The dir command reads the folder \Data, and a structure cell is created with the information for each file. Since I only care about the name, that cell can be extracted and trimmed. Then a single loop can be used to load all of the data into a useful format. To prevent errors if the files are not the same length, each data set is save in its own .mat file. These files can be quickly loaded in Matlab for later use.
Loading several .mat files
Once all of the data is stored in separate .mat files, this data can be easily accessed and plotted. It one were to plot the first 5 data sets that were loaded above, this code would perform the operation:
I realize that there are many non standard matlab functions here, but I encourage people to learn these functions. They have been very useful for me in performing some more advanced actions.
Lots of my time consists of analyzing huge sets of files recorded by and oscilloscope or some other device. Typically, I would try to use the same name for each file with a number at the end that increase each time. Then I can write a loop to load all of the files, then do analysis and create plots. This causes its own problems for several reasons such as: several loops must be used for different regions of the data (tek0000n for n = 1-9; tek000nn for nn = 10-99; tek00nnn for nnn = 100-999; etc) and broken loops when a single file in the data set is a different length or mission, and many other issues. Such a sustem looks like this where many conditional loops are used to fix the problem:
if m <10 & n < 10for i = 1:nTemp = dlmread([File,'/',File,'-0000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endend
if m <10 & n < 100 & n > 10for i = 1:9Temp = dlmread([File,'/',File,'-0000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endfor i = 10:nTemp = dlmread([File,'/',File,'-000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endendif m <10 & n < 1000 & n > 100for i = 1:9Temp = dlmread([File,'/',File,'-0000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endfor i = 10:99Temp = dlmread([File,'/',File,'-000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endfor i = 100:nTemp = dlmread([File,'/',File,'-00',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endendif m > 10 & n < 1000 & n > 100for i = m:99Temp = dlmread([File,'/',File,'-000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endfor i = 100:nTemp = dlmread([File,'/',File,'-00',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endendif m < 10 & n > 1000for i = 1:9Temp = dlmread([File,'/',File,'-0000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endfor i = 10:99Temp = dlmread([File,'/',File,'-000',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);endfor i = 100:999Temp = dlmread([File,'/',File,'-00',num2str(i),'.txt'],'\t',[17 0 3664 1]);Frequency(:,i) = Temp(:,1);Absorption(:,i) = Temp(:,2);end
end
Read Directory and Load
Recently, google helped me discover a better method where you can actually tell matlab to read and record the files names in a specific folder. The, so long as all the data is the same length, a single loop can be used to import all of the data in a single folder. Here is an example:
clear;clc;close all
cd ..
Temp = dir('Data');
Temp2 = {Temp.name};
FileName = Temp2(3:end);
for i = 1:length(FileName)
Temp = dlmread(['Data/',char(FileName(i))],',',[14 0 10013 2]);
time = Temp(:,1);
ch1 = Temp(:,2);
ch2 = Temp(:,3);
save(['[Matlab]/MData/DataSet',num2str(i),'.mat'],'time','ch1','ch2')
end
return
The dir command reads the folder \Data, and a structure cell is created with the information for each file. Since I only care about the name, that cell can be extracted and trimmed. Then a single loop can be used to load all of the data into a useful format. To prevent errors if the files are not the same length, each data set is save in its own .mat file. These files can be quickly loaded in Matlab for later use.
Loading several .mat files
Once all of the data is stored in separate .mat files, this data can be easily accessed and plotted. It one were to plot the first 5 data sets that were loaded above, this code would perform the operation:
for i = [1:5]
Str = ['MData\DataSet',num2str(i),'.mat'];
load(Str)
eval(['time_',num2str(i),' = time;'])
eval(['ch1_',num2str(i),' = ch1;'])
eval(['ch2_',num2str(i),' = ch2;'])end
figurehold on
for i = 1:5
eval(['plot(time_',num2str(i),',ch1_',num2str(i),')'])
end
hold off
I realize that there are many non standard matlab functions here, but I encourage people to learn these functions. They have been very useful for me in performing some more advanced actions.
Posted on Tuesday, November 22, 2011
HTML / Javascript equation solver
I always wanted to do simple calculations in HTML and create simple online equation solvers. I spent some time on it and have created a simple equation solver. I have include the code here with lots of comments to try and help others who might want to learn. The biggest issue I had was with the button. I had to use a form input of type button rather than a button element (<button></button>). the button element would run the code but then reset everything to the defaults immediately. I still do not understand why. If you want to try this code, copy and past it into notepad and save as a .html file. Then open the file in an internet browser. Questions and comments are welcome.
Here is the equation solver:
Here is the source code:
-------------------------------------------------------
----------------------------------------------------------
Here is the equation solver:
Here is the source code:
-------------------------------------------------------
<! comments look like this. They are just here to help the programmer>
<! This program has embedded java scripts to solve an equation with certain inputs>
<form name="F1"> <! gives the form a name so it can be referenced by the java script>
a: <! text in front of input a>
<! adds a space after a:>
<! adds another space>
<input
type = "text"
name = "a"
value = "12"
size = "4"
/> <! creates input a>
<! makes input a a text box>
<! names input a a>
<! sets the initial value of input a>
<! sets the size of input a>
<! ends the seting for input a>
<br /> <! move to next line>
b:
<input
type = "text"
name = "b"
value = "100"
size = "4"
/>
<br />
<br />
<b> Solution to a + b: </b>
<br />
<br />
Output:
<input
type = "text"
name = "out"
value = ""
size = "10"
/>
<br />
<br />
<input
type = "button"
value = "Calculate"
onClick = "clickButton1()"
> <! Creates a button and assigns its properties>
</form> <! end of form-F1>
<script
type ="text/javascript"> // starts the imbedded javascript
// comments look like this in java script
function clickButton1()
{
var a = document.F1.a.value; //sets variable a = the contents of input/textbox a
a = parseFloat(a); // convers a from a string to a floating number
var b = document.F1.b.value;
b = parseFloat(b);
var c = a + b;
document.F1.out.value = c;
}
</script> <! ends the script section of the file>
</html>
<! This program has embedded java scripts to solve an equation with certain inputs>
<form name="F1"> <! gives the form a name so it can be referenced by the java script>
a: <! text in front of input a>
<! adds a space after a:>
<! adds another space>
<input
type = "text"
name = "a"
value = "12"
size = "4"
/> <! creates input a>
<! makes input a a text box>
<! names input a a>
<! sets the initial value of input a>
<! sets the size of input a>
<! ends the seting for input a>
<br /> <! move to next line>
b:
<input
type = "text"
name = "b"
value = "100"
size = "4"
/>
<br />
<br />
<b> Solution to a + b: </b>
<br />
<br />
Output:
<input
type = "text"
name = "out"
value = ""
size = "10"
/>
<br />
<br />
<input
type = "button"
value = "Calculate"
onClick = "clickButton1()"
> <! Creates a button and assigns its properties>
</form> <! end of form-F1>
<script
type ="text/javascript"> // starts the imbedded javascript
// comments look like this in java script
function clickButton1()
{
var a = document.F1.a.value; //sets variable a = the contents of input/textbox a
a = parseFloat(a); // convers a from a string to a floating number
var b = document.F1.b.value;
b = parseFloat(b);
var c = a + b;
document.F1.out.value = c;
}
</script> <! ends the script section of the file>
</html>
----------------------------------------------------------
Posted on Sunday, August 28, 2011
Refractive Index of Water
Due to the effects of optical dispersion, the refractive index of water is dependent on the wavelength of light being used. After a long search, I found a good reference for this information (Daimon and Masumura). here is a plot of their data in the visible range:
Matlab was used to fit a exponential decay function to the 20oC data:
Here are the inputs:
Matlab was used to fit a exponential decay function to the 20oC data:
y = a e-bx + c
where:
a = 0.1140
b = 0.0048
c = 1.3264
Here is a plot of the fit with the data:
****NOTE** This fit is only valid from 400 nm to 800 nm and is not perfect ****
Here is a Calculator to solve this fit:
Here is a Calculator to solve this fit:
Equation Solver
This program solves ae-bx + c using java script imbedded in HTML. This is intended to solve the exponential function to determine the refractive index of water at different wavelengths.Here are the inputs:
Posted on Tuesday, August 23, 2011
Calcium Chloride (CaCl2) Useful Information
Refractive Index
Refractive index is a bulk material property. This property has a real and imaginary part and is dependent on wavelength. The real part describes how light "slows down" or "scatters" in a material and the imaginary part indicates how the material adsorbs light.
Typically, a single real value of refractive index will be attributed to a "transparent" dielectric material. If a material is transparent to your eye then we can assume that the imaginary part of the refractive index is close to zero. Also, in many cases, one may not want to consider the absorption of a material, only its scattering (reflection, refraction, transmission, diffraction, etc). Whenever a single value of refractive index is given with no wavelength specification, a good assumption is that the value was taken at a wavelength of 589.29 nm. This is the sodium D transition, and is typically used as the "standard" for refractive index values.
Now, for CaCl2, the refractive index changes with molar concentration. This is true for most salt solutions. CaCl2 is used in may optofluidic applications for its large refractive index range, and its stability. CaCl2 does not evaporate easily (so no crusty solids under the caps of your containers). So samples will remain good for long periods of time. The refractive index of CaCl2 is available in the CRC handbook of Chemistry and physics. Below is a plot of this data with two fitting functions. Many studies use a linear fit because it is convenient for calibrating devices. However, a second order polynomial has almost a perfect fit. * Remember this data is the refractive index at 589.29 nm. *
Linear Fit:
Polynomial fit:
This is intended to solve the second order polynomial to determine the refractive index of
calcium chloride.
Here are the inputs:
The molarity of CaCl2 needed to match the RI of PDMS is about 3.5M (n ~ 1.41)
Example:
To get 0.25M solution of CaCl2*2H2O (MW = 147.01) in 0.05L
m [g] = 0.25[mol/L] *147.01[g/mol] * 0.05[L] = 1.838 [g]
Where M1 is the initial concentration to be diluted, V1 is the volume of solution one to add to the dilution, M2 is the desired concentration and V2 is the total final volume of the dilute solution (V1 of M1 plus V2-V1 of DI water).
This does not seem to account for the the change in density due to addition of the solute if you use the density of water. I tried to use an average for the density of water and of hydrated CaCl2 but this seem to be even worse. Use just the density of water seems to match well with other references.
Refractive index is a bulk material property. This property has a real and imaginary part and is dependent on wavelength. The real part describes how light "slows down" or "scatters" in a material and the imaginary part indicates how the material adsorbs light.
Typically, a single real value of refractive index will be attributed to a "transparent" dielectric material. If a material is transparent to your eye then we can assume that the imaginary part of the refractive index is close to zero. Also, in many cases, one may not want to consider the absorption of a material, only its scattering (reflection, refraction, transmission, diffraction, etc). Whenever a single value of refractive index is given with no wavelength specification, a good assumption is that the value was taken at a wavelength of 589.29 nm. This is the sodium D transition, and is typically used as the "standard" for refractive index values.
Now, for CaCl2, the refractive index changes with molar concentration. This is true for most salt solutions. CaCl2 is used in may optofluidic applications for its large refractive index range, and its stability. CaCl2 does not evaporate easily (so no crusty solids under the caps of your containers). So samples will remain good for long periods of time. The refractive index of CaCl2 is available in the CRC handbook of Chemistry and physics. Below is a plot of this data with two fitting functions. Many studies use a linear fit because it is convenient for calibrating devices. However, a second order polynomial has almost a perfect fit. * Remember this data is the refractive index at 589.29 nm. *
Linear Fit:
a x + b
where:
a = 0.022
b = 1.3353
Polynomial fit:
a x2 + b x + c
where:
a = -7.871 x 10-4
b = 0.0256
c = 1.3331
Equation Solver
This program solves ax2 + bx + c using java script imbedded in HTML.This is intended to solve the second order polynomial to determine the refractive index of
calcium chloride.
Here are the inputs:
The molarity of CaCl2 needed to match the RI of PDMS is about 3.5M (n ~ 1.41)
Molar Concentration
Mass Needed [g] = desired Molarity [mol/L] * Molecular Weight [g/mol] * desired volume [L]Example:
To get 0.25M solution of CaCl2*2H2O (MW = 147.01) in 0.05L
m [g] = 0.25[mol/L] *147.01[g/mol] * 0.05[L] = 1.838 [g]
Dilution of a solution
M1V1=M2V2Where M1 is the initial concentration to be diluted, V1 is the volume of solution one to add to the dilution, M2 is the desired concentration and V2 is the total final volume of the dilute solution (V1 of M1 plus V2-V1 of DI water).
Converting from %Weight to Molarity
Molarity = (%Weight)/100*(Density)/(MolarMass)This does not seem to account for the the change in density due to addition of the solute if you use the density of water. I tried to use an average for the density of water and of hydrated CaCl2 but this seem to be even worse. Use just the density of water seems to match well with other references.
Posted on Saturday, August 13, 2011
Subscribe to:
Posts (Atom)