Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-10-2009, 00:34   #1
nikaldo
Junior Member
 
Iscritto dal: Feb 2009
Messaggi: 3
[C++] Errore di compilazione

In internet ho trovato questo codice sorgente in C++ per la ricerca di numeri primi , ma provandolo sul compilatore C++ 6 della Microsoft
mi segnala un errore di cui non riesco a trovare la soluzione, sperando che qualcuno possa aiutarmi ringrazio in anticipo.

_>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

#include <iostream>
#include <cmath>
using namespace std;

void numeri_primi(int max)
{
int k=(int)(max/trunc(log(max))); /* usa la stima di Gauss sul numero dei numeri primi, valido per max che entra in una variabile */
int i, j , pasI=2;
int *dp=new int[k];
int *m=new int[k];
int massimo=1,prova;

dp[0]=5;
m[0]=25;

if (max >=2){
cout<<2<<endl;
}
if (max >=3){
cout<<3<<endl;
}
if (max >=5){
cout<<5<<endl;
}

for(i=7; i<max ;i+=(pasI=6-pasI)) // evita i multipli di 3
{
/* cerca i divisori tra i primi già trovati fino a sqrt(i) */
for(prova = dp[j=0]; (i%m[j]) && prova*prova < i; prova=dp[++j])
{
if(i>m[j])
m[j]+= 2*prova;
}
if(i!=m[j])
{
cout<<i<<endl;
dp[massimo]=i;
m[massimo++]=i*i;
}
}

delete dp;
delete m;
}

int main(void)
{
int i;

cout<<"Introdurre il numero Max : "<<endl;
cin>>i;
numeri_primi(i);
}


____________________________________________________________________________________________________________________________

Compiling...
Numeriprimi.cpp
c:\n_prime\numeriprimi.cpp(7) : error C2065: 'trunc' : undeclared identifier
c:\n_prime\numeriprimi.cpp(53) : warning C4508: 'main' : function should return a value; 'void' return type assumed
Error executing cl.exe.

N_prime.exe - 1 error(s), 1 warning(s)
nikaldo è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 01:44   #2
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
mai sentito parlare della funzione trunc O_O
Cercando su google ho visto che dovrebbe comportarsi come la funzione floor. Prova a sostituire trunc con floor e la cosa dovrebbe funzionare
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 14-10-2009, 14:16   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
trunc non esiste perché il troncamento si fa semplicemente convertendo da floating point ad intero.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 00:12   #4
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
Quote:
Originariamente inviato da cionci Guarda i messaggi
trunc non esiste perché il troncamento si fa semplicemente convertendo da floating point ad intero.
ah quindi non è equivalente a floor? Allora avevo capito male
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 08:27   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Torav Guarda i messaggi
ah quindi non è equivalente a floor? Allora avevo capito male
E' equivalente solo per i floating point positivi

flloor(-0.1) ritorna -1, (int)-0.1 ritorna 0
flloor(-2.1) ritorna -3, (int)-2.1 ritorna -2
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 09:18   #6
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Una precisazione: su cpu intel il cast da float ad int è critico per le prestazioni in quanto viene svuotata completamente la pipeline della fpu e viene modificata la modalità di funzionamento della stessa (da arrotondamento a troncamento) per eseguire l'operazione e viceversa per poter eseguire tutte le operazioni seguenti.
Il C99 fornisce le funzioni lrint,lrintf ecc che evitano questo problema.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 13:10   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Comunque lrint non fa la stessa cosa della conversione ad intero. Fa l'arrotondamento.
Codice:
int main()
{
   printf("%ld\n", lrint(-0.9));
   printf("%ld\n", lrint(-0.1));      
   printf("%d\n", (int)-0.9);      
}
L'output sarà:
-1
0
0

Questa cosa del cambio di modalità dell'unità floating point sinceramente non la sapevo. Ora provo a tradurre in codice assembly
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 15-10-2009, 13:25   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Per la conversione in asm x64 viene usata questa istruzione: http://www.sesp.cse.clrc.ac.uk/html/...32_hh/vc67.htm
Quindi per i compilatori a 64 bit non ci sono problemi.

In effetti in asm x86 si vede l'istruzione fldcw che svuota la pipeline.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2009, 00:11   #9
nikaldo
Junior Member
 
Iscritto dal: Feb 2009
Messaggi: 3
C++ Errore di esecuzione

Vi ringrazio per l'aiuto , sostituendo a " trunc " l'istruzione "int" il programma funziona perfettamente; mi resta solo la curiosità del perchè sia stata utilizzato questo tipo di istruzione in C++ pechè a quanto ho potuto appurare è invece tipica del linguaggio Visual J++.
nikaldo è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2009, 08:21   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Non ne ho idea...probabilmente è stato utilizzato qualche compilatore che ha nella libreria math questa istruzione non standard.
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Volkswagen ribattezza ID.3 e le dà un mo...
Aruba rende disponibile VMware Hosted Pr...
Questa Olympus da 20 MP con stabilizzazi...
Il nuovo dispositivo di Rabbit si chiama...
'Se avete RAM, siamo pronti ad acquistar...
Veeam corregge diverse vulnerabilit&agra...
MacBook Neo segna una svolta per Apple: ...
Polestar pubblica il report LCA di Poles...
Il rame non basta più: NVIDIA, AM...
Velocissimo e consuma poco: ecco il nuov...
Le migliori Offerte di Primavera sui Rob...
Perplexity 'Personal Computer' è ...
TV QLED da 65 pollici da 449€ con sconti...
Il CEO di Adobe pronto a lasciare dopo q...
Non è bastato il maxi-accordo col...
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:44.


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