summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatt Argao <mcargao@email.wm.edu>2012-10-25 16:05:08 -0400
committerMatt Argao <mcargao@email.wm.edu>2012-10-25 16:05:08 -0400
commitf4f7ddf366273449e662fbf5d8cbb08c472f33d3 (patch)
treeb77047830b9b2974f5dae8769927f9876c87863e
parent381b3799d1e7b54e60802dfb7cc83834a72d06a2 (diff)
downloadmode_match-f4f7ddf366273449e662fbf5d8cbb08c472f33d3.tar.gz
mode_match-f4f7ddf366273449e662fbf5d8cbb08c472f33d3.zip
Added pick function and all possible permutations of lenses
-rw-r--r--fitter_check.m51
-rw-r--r--pick.m155
2 files changed, 180 insertions, 26 deletions
diff --git a/fitter_check.m b/fitter_check.m
index 3e0a1df..d28b7f3 100644
--- a/fitter_check.m
+++ b/fitter_check.m
@@ -1,22 +1,27 @@
+lens_set = [.075, .203, .05, .03];
+lens_set = [.075, .203];
+lens_permutations = pick(lens_set,3,'or');
+n_perms = size(lens_permutations,1);
+n_shuffles=10; %number of random placements of lenses
+
% ##########################################
% Sample Solution
-clear;
lambda= 1.064E-6 ;
Ltot= 1.010675025828971 ;
r0= 1.0E+100 ;
w0= 2.563E-5 ;
x0= 0 ;
-focal_length1 = .075;
-focal_length2 = .075;
-focal_length3 = .203;
-
-lns1.abcd=abcd_lens( focal_length1 ) ;
-lns1.x= 0.21358727296049 ;
-lns2.abcd=abcd_lens( focal_length2 ) ;
-lns2.x= 0.40361319425309 ;
-lns3.abcd=abcd_lens( focal_length3 ) ;
-lns3.x= 0.80361319425309 ;
+% focal_length1 = .075;
+% focal_length2 = .075;
+% focal_length3 = .203;
+%
+% lns1.abcd=abcd_lens( focal_length1 ) ;
+% lns1.x= 0.21358727296049 ;
+% lns2.abcd=abcd_lens( focal_length2 ) ;
+% lns2.x= 0.40361319425309 ;
+% lns3.abcd=abcd_lens( focal_length3 ) ;
+% lns3.x= 0.80361319425309 ;
wf= 3.709E-5 ;
rf= 1.0E+100 ;
xf= Ltot;
@@ -25,12 +30,12 @@ q0=wr2q(w0,r0,lambda);
x0=0;
qf=wr2q(wf,rf,lambda);
xf=Ltot;
-
-optics={lns1,lns2,lns3};
-figure(1)
-w_final_handmade = solution_visualization(q0,x0, qf, xf, optics, lambda);
-title('Hand made');
-% ##########################################
+%
+% optics={lns1,lns2,lns3};
+% figure(1)
+% w_final_handmade = solution_visualization(q0,x0, qf, xf, optics, lambda);
+% title('Hand made');
+%% ##########################################
%Initialize sample arrays
@@ -41,13 +46,6 @@ possible_lens_pos = [];
possible_sample_energy = [];
lens_size = .03;
-%Lens permutations
-lens_permutations = perms( [ focal_length1, focal_length2, focal_length3 ]);
-n_shuffles=10;
-
-%Check if permutation has duplicates
-lens_permutations = unique(lens_permutations,'rows');
-n_perms = size(lens_permutations,1);
for i = 1:n_perms
@@ -111,5 +109,6 @@ for n_graph = 1:n_possible_soln
title('Other Solutions');
end
-w_final_handmade;
-x_sol
+possible_soln(index(1:n_graph),:)
+possible_lens_pos(index(1:n_graph),:)
+possible_sample_energy(index(1:n_graph),:) \ No newline at end of file
diff --git a/pick.m b/pick.m
new file mode 100644
index 0000000..7404140
--- /dev/null
+++ b/pick.m
@@ -0,0 +1,155 @@
+% pick Picking elements from a set (combinations, permutations)
+%
+% s = pick(V,k,Type)
+%
+% Gives all possibilities of picking k elements from the
+% set V with or without order and repetition. V can be an
+% array of any size and any type.
+%
+% Type can have the following values: '', 'o', 'r', 'or'.
+% 'o' means pick ordered set of k elements
+% 'r' means replace elements after picking
+%
+% s is an array with all picks, one subset per row.
+%
+% Examples
+% pick(1:2,5,'or')
+% pick('abcd',2,'')
+% pick(-1:1,4,'r')
+% pick('X':'Z',3,'o')
+
+% Stefan Stoll, ETH Zurich, 20 October 2006
+
+function s = pick(V,k,Type)
+
+errThirdMissing = 'Third argument Type ('''', ''o'', ''r'', or ''or'') is missing!';
+errThreeExpected = 'Three arguments (V, k, Type) must be provided.';
+
+switch nargin
+ case 3,
+ case 2, error(errThirdMissing);
+ case 1,
+ if strcmp(V,'test');
+ pick_test;
+ return;
+ else
+ error(errThreeExpected);
+ end
+ case 0, help(mfilename); return;
+ otherwise, error(errThreeExpected);
+end
+
+N = numel(V);
+
+if (N==0)
+ error('First argument V must be an array with at least one element.');
+end
+
+if (numel(k)~=1) || rem(k,1) || (k<1)
+ k
+ error('Second argument k must be a positive integer. You gave the above.');
+end
+
+if ~ischar(Type)
+ Type
+ error('Third argument must be a string.');
+end
+
+if isempty(strfind(Type,'r')) && (k>N)
+ str = sprintf('Picking elements without repetition:\n k must not be larger than the number of elements in V.\n');
+ error([str 'You gave k=%d for %d elements in V.'],k,N);
+end
+
+switch sort(Type)
+ case '', idx = combinations_without_repetition(N,k);
+ case 'o', idx = permutations_without_repetition(N,k);
+ case 'r', idx = combinations_with_repetition(N,k);
+ case 'or', idx = permutations_with_repetition(N,k);
+ otherwise
+ Type
+ error('Third argument Type must be one of '''', ''o'', ''r'', ''or''.');
+end
+
+s = V(idx);
+if (k==1), s = s(:); end
+
+return
+
+%=====================================================================
+function m = combinations_with_repetition(N,k)
+
+if (k==1), m = (1:N).'; return; end
+if (N==1), m = ones(1,k); return; end
+
+m = [];
+for q = 1:N
+ mnext = combinations_with_repetition(N+1-q,k-1);
+ m = [m; q*ones(size(mnext,1),1), mnext+q-1];
+end
+
+
+%===================================================================
+function p = permutations_without_repetition(N,k)
+
+p = permutations_with_repetition(N,k);
+ps = sort(p.').';
+idx = any(ps(:,2:end)==ps(:,1:end-1),2);
+p(idx,:) = [];
+
+
+%===================================================================
+function s = permutations_with_repetition(N,k)
+
+if (k==1), s = (1:N).'; return; end
+if (N==1), s = ones(1,k); return; end
+
+[idx{1:k}] = ndgrid(1:N);
+s = fliplr(reshape(cat(ndims(idx{1}),idx{:}),[],k));
+
+
+%===================================================================
+function c = combinations_without_repetition(N,k)
+
+if (N>1)
+ c = nchoosek(1:N,k);
+else
+ c = 1;
+end
+
+
+%===================================================================
+function pick_test
+
+disp('=========== pick() tests ======================');
+
+Nmax = 6;
+
+Type = {'','o','r','or'};
+Name{1} = 'Combinations without repetition';
+Name{2} = 'Permutations without repetition';
+Name{3} = 'Combinations with repetition';
+Name{4} = 'Permutations with repetition';
+Repetition = [0 0 1 1];
+
+for t = 1:4
+ disp(' ');
+ disp(Name{t});
+ for N = 1:Nmax
+ if Repetition(t), kmax = Nmax; else kmax = N; end
+ for k = 1:kmax
+ s = pick(uint8(1:N),k,Type{t});
+ m1 = size(s,1); k1 = size(s,2);
+ switch t
+ case 1, m = nchoosek(N,k);
+ case 2, m = prod(N-k+1:N);
+ case 3, m = nchoosek(N+k-1,k);
+ case 4, m = N^k;
+ end
+ fprintf(' N=%d, k=%d, expected %dx%d, found %dx%d\n',N,k,m,k,m1,k1);
+ if (m1~=m) | (k1~=k)
+ error('Unexpected size of output array!');
+ end
+ end
+ end
+end
+disp('All tests passed!');