X-Git-Url: http://iramuteq.org/git?p=iramuteq;a=blobdiff_plain;f=PrintRScript.py;h=a19680dd4eb695f0f1fdb1194c103e0aa4900e8a;hp=fbcf5cf4f19a33df557c27de79441405494fc117;hb=148fe710bf14981c45e865e8b4ddb68333e62f7c;hpb=7cc2905d5f514220c771dbd6661e3242681db706 diff --git a/PrintRScript.py b/PrintRScript.py index fbcf5cf..a19680d 100644 --- a/PrintRScript.py +++ b/PrintRScript.py @@ -4,7 +4,7 @@ #License: GNU/GPL import tempfile -from chemins import ffr +from chemins import ffr, PathOut import os import locale from datetime import datetime @@ -18,12 +18,13 @@ class PrintRScript : self.pathout = analyse.pathout self.analyse = analyse self.parametres = analyse.parametres + #self.scriptout = self.pathout['lastRscript.R'] self.scriptout = self.pathout['temp'] self.script = u"#Script genere par IRaMuTeQ - %s\n" % datetime.now().ctime() - + def add(self, txt) : self.script = '\n'.join([self.script, txt]) - + def defvar(self, name, value) : self.add(' <- '.join([name, value])) @@ -162,13 +163,17 @@ def RchdTxt(DicoPath, RscriptPath, mincl, classif_mode, nbt = 9, svdmethod = 'sv row.names(data2) <- 1:nrow(data2) """ % ffr(DicoPath['TableUc2']) txt += """ - chd1<-CHD(data1, x = nbt, mode.patate = mode.patate, svd.method = svd.method, libsvdc.path = libsvdc.path) - """ + log1 <- "%s" + chd1<-CHD(data1, x = nbt, mode.patate = mode.patate, svd.method = + svd.method, libsvdc.path = libsvdc.path, log.file = log1) + """ % ffr(DicoPath['log-chd1.txt']) if classif_mode == 0: txt += """ - chd2<-CHD(data2, x = nbt, mode.patate = mode.patate, svd.method = svd.method, libsvdc.path = libsvdc.path) - """ + log2 <- "%s" + chd2<-CHD(data2, x = nbt, mode.patate = mode.patate, svd.method = + svd.method, libsvdc.path = libsvdc.path) log.file = log2) + """ % ffr(DicoPath['log-chd2.txt']) txt += """ #lecture des uce @@ -944,7 +949,7 @@ class PrintSimiScript(PrintRScript) : seuil <- %s if (!is.null(seuil)) { if (method!='cooc') { - seuil <- seuil/100 + seuil <- seuil/1000 } } """ % seuil @@ -1201,6 +1206,41 @@ class ExportAfc(PrintRScript) : txt = """ """ +class MergeGraphes(PrintRScript) : + def __init__(self, parametres): + self.script = u"#Script genere par IRaMuTeQ - %s\n" % datetime.now().ctime() + self.pathout = PathOut() + self.parametres = parametres + self.scriptout = self.pathout['temp'] + + def make_script(self) : + #FIXME + + txt = """ + library(igraph) + library(Matrix) + graphs <- list() + """ + load = """ + load("%s") + g <- graph.simi$graph + V(g)$weight <- (graph.simi$mat.eff/nrow(dm))*100 + graphs[['%s']] <- g + """ + for i, graph in enumerate(self.parametres['lgraphes']) : + path = os.path.dirname(graph) + gname = ''.join(['g', `i`]) + RData = os.path.join(path,'RData.RData') + txt += load % (ffr(RData), gname) + self.add(txt) + self.sources([self.analyse.parent.RscriptsPath['simi']]) + txt = """ + ng <- merge.graph(graphs) + ngraph <- list(graph=ng, layout=layout.fruchterman.reingold(ng, dim=3), labex.cex=V(ng)$weight) + write.graph(ng, "%s", format = 'graphml') + """ % ffr(self.parametres['grapheout']) + self.add(txt) + class TgenSpecScript(PrintRScript): def make_script(self): self.packages(['textometry']) @@ -1229,10 +1269,18 @@ class TgenProfScript(PrintRScript): tgen <- read.csv2("%s", row.names = 1, sep = '\\t') """ % ffr(self.parametres['tgeneff']) txt += """ + tgenlem <- read.csv2("%s", row.names = 1, sep = '\\t') + """ % ffr(self.parametres['tgenlemeff']) + txt += """ res <- build.prof.tgen(tgen) write.table(res$chi2, file = "%s", sep='\\t', col.names = NA) write.table(res$pchi2, file = "%s", sep='\\t', col.names = NA) """ % (ffr(self.pathout['tgenchi2.csv']), ffr(self.pathout['tgenpchi2.csv'])) + txt += """ + reslem <- build.prof.tgen(tgenlem) + write.table(reslem$chi2, file = "%s", sep='\\t', col.names = NA) + write.table(reslem$pchi2, file = "%s", sep='\\t', col.names = NA) + """ % (ffr(self.pathout['tgenlemchi2.csv']), ffr(self.pathout['tgenlempchi2.csv'])) self.add(txt) class FreqMultiScript(PrintRScript): @@ -1259,4 +1307,4 @@ class FreqMultiScript(PrintRScript): dev.off() """ % ffr(self.pathout['barplotrow.png']) self.add(txt) - self.write() \ No newline at end of file + self.write()