Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-11-2007, 16:33   #1
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
[C] Aiutino su formula matematica

Salve a tutti, dovrei scrivere la seguente formula in una funzione scritta in C:




[img=http://img258.imageshack.us/img258/6412/formulatg2.th.gif]


Io ho buttato giu alcune righe di codice ma non mi convincono del tutto...qualcuno potrebbe dirmi se c'è corrispondenza tra la formula e quello che ho scritto io sotto?
Grazie

Codice:
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             sommatoria[l][r][i]+=x[i][k]*z[k]* ((k=l)?1:0)*u[r];


for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
                 derF[l][r]+=y[i]*sommatoria[l][r][i];
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."

Ultima modifica di salvodel : 29-11-2007 alle 10:31.
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2007, 11:24   #2
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
usando la distributività, y[i]*sommatoria_j(alfa[j])=sommatoria_j(alfa[j]*y[i]).

consegue che basta:

Codice:
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             derF[l][r] += y[i]*x[i][k]*z[k]* ((k=l)?1:0)*u[r];

Ultima modifica di mad_hhatter : 28-11-2007 alle 11:31.
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2007, 12:20   #3
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
usando la distributività, y[i]*sommatoria_j(alfa[j])=sommatoria_j(alfa[j]*y[i]).

consegue che basta:

Codice:
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             derF[l][r] += y[i]*x[i][k]*z[k]* ((k=l)?1:0)*u[r];
Grazie mille. Il problema è che avevo molti dubbi su come si comportasse il C. Grazie mille di nuovo.
Ciao
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2007, 13:40   #4
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Grazie mille. Il problema è che avevo molti dubbi su come si comportasse il C. Grazie mille di nuovo.
Ciao
comportamento in che senso? riguardo ai loop o alla precisione numerica?
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2007, 15:15   #5
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
comportamento in che senso? riguardo ai loop o alla precisione numerica?
Avevo dei dubbi sui cicli for, non vorrei che facessero dei prodotti in piu. Appena finisco di scriverlo ti faccio sapere se va.
Ciao
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."

Ultima modifica di salvodel : 28-11-2007 alle 18:34.
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2007, 18:53   #6
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783


Se la formula è invece cosi come mi conviene riscriverla? In un'altra formula simile ho utilizzato le seguenti righe per calcolare i gli ultimi termini tra parentesi:

Codice:
for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        som[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    som[i]+=w[i][10];
In questo caso mi da un po fastidio il termine da sommare x[i][s]. Come posso scriverlo in modo sintetico?Ha senso quanto segue, cioè utilizzare le stesse righe di prima per crearmi un nuovo oggetto SOMMA[i]:

Codice:
for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        som[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    som[i]+=w[i][10];

//A questo punto inserisco le stesse righe di prima ma moltiplicate per SOMMMA[i]
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             derF[l][r] += y[i]*x[i][k]*z[k]* ((k=l)?1:0)*u[r]*SOMMA[i];
Credo che sia sbagliata visto che ho un ciclo for con indice k mentre SOMMA si è gia fatto il suo ciclo.
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."

Ultima modifica di salvodel : 29-11-2007 alle 17:05.
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 29-11-2007, 10:30   #7
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da salvodel Guarda i messaggi


Se la formula è invece cosi come mi conviene riscriverla? In un'altra formula simile ho utilizzato le seguenti righe per calcolare i gli ultimi termini tra parentesi:

Codice:
for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        som[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    x[i]+=w[i][10];
In questo caso mi da un po fastidio il termine da sommare x[i][s]. Come posso scriverlo in modo sintetico?Ha senso quanto segue, cioè utilizzare le stesse righe di prima per crearmi un nuovo oggetto SOMMA[i]:

Codice:
for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        som[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    x[i]+=w[i][10];

//A questo punto inserisco le stesse righe di prima ma moltiplicate per SOMMMA[i]
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             derF[l][r] += y[i]*x[i][k]*z[k]* ((k=l)?1:0)*u[r]*SOMMA[i];
Credo che sia sbagliata visto che ho un ciclo for con indice k mentre SOMMA si è gia fatto il suo ciclo.
Grazie
le parentesi nella formula sono un po' ambigue, puoi specificare meglio i termini?
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 29-11-2007, 11:06   #8
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
le parentesi nella formula sono un po' ambigue, puoi specificare meglio i termini?
Dalla domanda posso dirti che hai capito qual'è il mio problema visto che anche a me crea un di ambiguità. Cmq ora cerco di spiegarmi meglio.



Come ti dicevo prima in un’altra parte del programma mi creavo prima la variabile SOMMA dipendente solo da k e poi la mettevo nella formula che però era leggermente diversa. In questo caso essendo la sua derivata ho il prodotto della derivata della funzione per la derivata del suo argomento…ma questo non penso che ti interessa visto che oltretutto alla formula ho tolto un po di fronzoli per renderla piu snella. Comunque dicevo, non mi conviene anche in questo caso crearmi la variabile SOMMA in questo modo:

Codice:
 for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        SOMMA[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    SOMMA[i]+=x[i][10];
È questa la parentesi che ti creava ambiguità, quella del prodotto tra x[i][k] e z[k]? Penso che sia ridondante. Il senso è di fare tutti i prodotti ed infine aggiungere ad ogni somma un elemento w[i][10].
Se mi trovassi con la seguente formula:




Non farei cosi?

Codice:
/*Creo prima la variabile SOMMA[i]*/
for(i=0;i<M;i++)
   for(k=0;k<N;k++)
      SOMMA[i]+=x[i][k]z[k];
/*A questo punto faccio il prodotto tra i termini x[i][k], z[k] e SOMMA[1]*/
for(i=0;i<M;i++)
   for(k=0;k<N;k++)
      d+=x[i][k]*z[k]SOMMA[i]
Aspetto un tuo consiglio...sperando di non aver detto un sacco di cavolate.
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 29-11-2007, 15:20   #9
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
[edit]
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 29-11-2007, 15:22   #10
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da salvodel Guarda i messaggi


Se la formula è invece cosi come mi conviene riscriverla? In un'altra formula simile ho utilizzato le seguenti righe per calcolare i gli ultimi termini tra parentesi:

Codice:
for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        som[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    x[i]+=w[i][10];
In questo caso mi da un po fastidio il termine da sommare x[i][s]. Come posso scriverlo in modo sintetico?Ha senso quanto segue, cioè utilizzare le stesse righe di prima per crearmi un nuovo oggetto SOMMA[i]:

Codice:
for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        som[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    x[i]+=w[i][10];

//A questo punto inserisco le stesse righe di prima ma moltiplicate per SOMMMA[i]
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             derF[l][r] += y[i]*x[i][k]*z[k]* ((k=l)?1:0)*u[r]*SOMMA[i];
Credo che sia sbagliata visto che ho un ciclo for con indice k mentre SOMMA si è gia fatto il suo ciclo.
Grazie
scusami, avevo guardato solo le parentesi ma non gli indici... quindi la formula non è ambigua.

io farei:

cella[l,r] = 0;
loop(i) {
somma_1 <- prima sommatoria in k (calcolata con un loop)
somma_2 <- seconda sommatoria in k (calcolata con un ulteriore loop indipendente da quello di somma_1)
cella[l,r+] += y[i]*somma_1*somma_2
}

PS: per rendere più leggibile la formula io sposterei la prima parentesi subito prima della corrispondente sommatoria
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 29-11-2007, 17:18   #11
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
scusami, avevo guardato solo le parentesi ma non gli indici... quindi la formula non è ambigua.

io farei:

cella[l,r] = 0;
loop(i) {
somma_1 <- prima sommatoria in k (calcolata con un loop)
somma_2 <- seconda sommatoria in k (calcolata con un ulteriore loop indipendente da quello di somma_1)
cella[l,r+] += y[i]*somma_1*somma_2
}

PS: per rendere più leggibile la formula io sposterei la prima parentesi subito prima della corrispondente sommatoria

Quindi provo a scriverlo come l'ho "fra"inteso

Codice:
for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
             SOMMA1[l][r][i]+=x[i][k]*z[k]* ((k=l)?1:0)*u[r];

for(int i=0;i<s; i++)
    for(int k=0;k<N; k++)
        SOMMA2[i]+=x[i][k]*z[k];
for(int i=0;i<s; i++)
    SOMMA2[i]+=w[i][10];

for(l=0;l<cost;l++)
   for(r=0;r<cost;r++)
      for(i=0;i<M;i++)
         for(k=0;k<S;k++)
                 derF[l][r]+=y[i]*SOMMA1[l][r][i]*SOMMA2[i];
Ti volevo chiedere due cose:
1- che cosa fa loop e perché hai fatto tutto insieme?
2- la prima sommatoria non dovrebbe mantenere espliciti gli indici l ed r ?
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2007, 09:12   #12
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Ti volevo chiedere due cose:
1- che cosa fa loop e perché hai fatto tutto insieme?
2- la prima sommatoria non dovrebbe mantenere espliciti gli indici l ed r ?
1. loop fa la sommatoria in i, ho fatto tutto insieme perché non vale la pena spezzare se puoi fare tutto in una volta (secondo me)

2. la prima sommatoria (loop(i)) è fatta assumendo fissati l,r... in pratica loop(i) va annidato rispetto al loop in l e a quello in r
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2007, 11:47   #13
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
1. loop fa la sommatoria in i, ho fatto tutto insieme perché non vale la pena spezzare se puoi fare tutto in una volta (secondo me)

2. la prima sommatoria (loop(i)) è fatta assumendo fissati l,r... in pratica loop(i) va annidato rispetto al loop in l e a quello in r
Forse ora ho capito. Invece di fare dei cicli for con il loop hai sistemato tutto.
Il tuo è sicuramente piu elegante ma date le mie scarse conoscenze di C credi che quello che abbia scritto io sia corretto oppure è puro vaneggiamento?
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2007, 12:10   #14
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Forse ora ho capito. Invece di fare dei cicli for con il loop hai sistemato tutto.
Il tuo è sicuramente piu elegante ma date le mie scarse conoscenze di C credi che quello che abbia scritto io sia corretto oppure è puro vaneggiamento?
Grazie
il mio loop E' un for

non so se è più elegante, è solo più compatto rispetto a vari loop indipendenti.

il tuo non è puro vaneggiamento: non ho controllato i dettagli, ma mi pare che facessi più o meno le stesse cose, solo con loop indipendenti.
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2007, 14:47   #15
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
il mio loop E' un for

non so se è più elegante, è solo più compatto rispetto a vari loop indipendenti.

il tuo non è puro vaneggiamento: non ho controllato i dettagli, ma mi pare che facessi più o meno le stesse cose, solo con loop indipendenti.
Perfetto, grazie mille(non ti nascondo che per un po ho cercato se esistesse qualche ciclo iterativo di nome loop).
Se hai due minuti giusto per dargli un occhiata per verificare che il tutto sia corretto(intendo la corrispondenza tra la formula e i cicli for) sarebbe perfetto poiché ancora non ho avuto modo di farlo girare per errori vari tra cui questo che non ho ancora capito che vuol dire:

edit
Capito.
Ora l'ho fatto girare ma il sistema si blocca . Ed ora ?
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."

Ultima modifica di salvodel : 30-11-2007 alle 14:57.
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 30-11-2007, 15:56   #16
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Perfetto, grazie mille(non ti nascondo che per un po ho cercato se esistesse qualche ciclo iterativo di nome loop).
Se hai due minuti giusto per dargli un occhiata per verificare che il tutto sia corretto(intendo la corrispondenza tra la formula e i cicli for) sarebbe perfetto poiché ancora non ho avuto modo di farlo girare per errori vari tra cui questo che non ho ancora capito che vuol dire:

edit
Capito.
Ora l'ho fatto girare ma il sistema si blocca . Ed ora ?
posta il codice completo e magari mette delle istruzioni di stampa (tipo "print sono arrivato qui") per cercare di capire in quale loop si pianta
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 02-12-2007, 20:36   #17
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
posta il codice completo e magari mette delle istruzioni di stampa (tipo "print sono arrivato qui") per cercare di capire in quale loop si pianta
Ciao ti posso contattare in privato?
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 02-12-2007, 22:29   #18
gepeppe
Senior Member
 
L'Avatar di gepeppe
 
Iscritto dal: Jun 2005
Città: Napoli
Messaggi: 2599
se lo posti qui ti possiamo dare tutti una mano...compilandolo anche noi magari...
__________________
Hp pavilion dv6-1250el [cpu: P8700 - ati radeon hd 4650 1 gb - 4 gb ram - hd 320 7200 rpm!] Garmin Official Thread
gepeppe è offline   Rispondi citando il messaggio o parte di esso
Old 03-12-2007, 16:00   #19
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da gepeppe Guarda i messaggi
se lo posti qui ti possiamo dare tutti una mano...compilandolo anche noi magari...
A dire il vero mi piacerebbe poter contattare di persona qualche informatico vicino milano per un aiutino.
Se c'è qualcuno che ha voglia di perdere $tempo$.
gepeppe tu sei di napoli? Troppo lontano
Se non trovo nessuno e non ci riesco provo a postarlo qui.
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
È il momento migliore per comprar...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
Il cofondatore di Netflix ha lasciato l'...
ASUS porta in Italia il nuovo Zenbook Du...
Assassin's Creed: Black Flag Resynced, s...
Xbox Game Pass cambierà: tra le n...
I nuovi Surface Pro e Laptop sono vicini...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 16:03.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v